- Zoom ana ekranında yer alan Join butonuna tıklayın.
- Enter meeting ID or personel link name yazan yere, öğretmeninizin veya yöneticinizin size verdiği ID numarası veya linki yazın. Enter your name yazan yere adınızı yazın ve Join butonuna tıklayın.
- Eğer şifreli bir konferans ise şifre girme ekranı açılacaktır. Açılan ekranda şifreyi girin ve Join Meeting butonuna dokunun.
Zoomda Ekran Görüntüsü Paylaşımı Nasıl Yapılır?
Görüntülü derslerde/konferanslarda bilgisayar ekranınızdaki görüntüyü derse/toplantıya katılan kişilerle paylaşabilirsiniz. Oldukça gelişmiş bir konferans programı olan Zoom ile bilgisayar ekranınızı, ekranın sadece belirli bir bölümünü, sadece bilgisayardaki sesi veya beyaz bir tahtaya çizdiğiniz görüntüleri paylaşabilirsiniz. Bunun için ekranın alt kısmında yer alan Share Screen butonuna tıklayın.
Açılan ekranın üst kısmında Basic, Advanced ve Files menüsü yer almaktadır.
Basic sekmesinde yer alan Screen seçeneği ile bilgisayar ekranınızı paylaşabilir, White Board seçeneği ile beyaz bir tahta paylaşarak buraya yazıp çizdiğiniz görüntüleri paylaşabilirsiniz.
Advanced sekmesinde ise Portion of Screen seçeneği ile bilgisayar ekranınızın sadece belirli bir bölümünü paylaşabilirsiniz. Music or Computer Sound seçeneği ile bilgisayarda çaldığınız müziği veya bilgisayarın sesini paylaşabilirsiniz.
Content from 2nd Camera seçeneği ile eğer bilgisayarınızda ikinci bir kamera bağlıysa bu kameranın görüntüsünü paylaşabilirsiniz.
Files seçeneğinde ise Dropbox gibi hesaplarınıza bağlanabilir ve buradaki belgelerinizi görüntüleyebilirsiniz.
Zoom Programını Türkçeleştirme ve Menü Tanıtımları
ZOOM’daki İngilizce kelimelerin Türkçe anlamları
ZOOM, Canlı dersler için artık vazgeçilmez programlardan biri olup kullanımını az yada çok her öğretmenin bilmesi gerekiyor.Ancak programın ingilizce olması,ingilizce bilmeyen öğretmenlerin işini biraz daha zorlaştıyor.
Zoomla ilgili sorun yaşamamak, daha pratik ve sorunsuz kullanmak için yazdırıp masanızın üstünde bulunmasında yarar olduğunu düşünüyoruz.
New Meeting: Yeni bir toplantı, görüşme, online ders oluşturacağınız alan kısımdır. New meeting kısmına tıklayıp Zoom uygulaması üzerinden derslerinizi veya toplantılarınızı yapabilirsiniz.
Join: Mevcut olan bir toplantıya ve derse katılabileceğiniz butondur. Bu kısma tıklayıp görüşmeyi oluşturan kişinin ID’sini ve şifresini girip sınıfa dahil olabilirsiniz. Mevcut olan bir toplantıya ve derse katılabileceğiniz butondur. Bu kısma tıklayıp görüşmeyi oluşturan kişinin ID’sini girip sınıfa dahil olabilirsiniz.
Schedule: İleri Tarihli Sohbet Programla, İleri tarihli bir meeting, online ders, sınıf ortamı oluşturabileceğiniz alandır. Derslerinizi şuan değilde 3 gün sonra planlamak istiyorsanız bu kısmı kullanabilirsiniz.
Share Screen: Ekran paylaşımı yapabileceğiniz alandır.
Meetings: Toplantı Bilgileri
Security: Güvenlik
Participants: Katılımcılar
Chat: (Sohbet) Sohbet penceresini görüntülemesine imkân sağlar.
Share Screen: Yine zoom uygulamamızı kullanmamızın en önemli faktörlerinden birisidir. “Share Screen” kısmından ekran paylaşımı yapıp, öğrencilerinizle derslerinizi beyaz bir tahta üzerinden veya bir doküman üzerinden yapabilirsiniz. Mesela konunuzla ilgili bir soru çözümü yapacağınız zaman, bu kısımdan sorunun pdf veya görüntüsünü öğrencileriniz ile paylaşıp, dokunmatik ekranlar sayesinde bir kalemle sorunuzu kağıda çözer gibi çözebilirsiniz. Buradaki önemli olan nokta telefon, tablet gibi cihazlarda dokunmatik özellik olduğu için dokunmatik kalemler sayesinde soru çözümleriniz oldukça kolaydır. Bilgisayarlar içinde “Grafik Tablet” kullanmanızı tavsiye ederiz. (özellikle işlem yapılan sayısal ağırlıklı dersler için)
Share Screen butonuna tıkladıktan sonra üst kısımdaki gibi bir ekran gelir karşınıza. Öğrencileriniz ile derslerinizi bir beyaz tahta üzerinden yapmak istiyorsanız “Whiteboard” kısmına tıklayıp öğrencileriniz ile beyaz tahta paylaşımı yapabilirsiniz. Uygulamanın orta kısmı beyaz tahta haline gelir, üst kısımda ise öğrencilerinizin ve sizin görüntüleri gelir. Beyaz tahta üzerinden ister uygulamanın size sunmuş olduğu yazı, kalem vb. gibi araçlarla derslerinizi yapabilir isterseniz kendi kaleminize işlem yapabilirsiniz. Burada önemli olan nokta telefon, tablet gibi dokunmatik ekranlarda, dokunmatik bir kalemle tipki deftere yazı yazıyor gibi uygulama üzerine yazabilirsiniz. Bilgisayarlar içinde ek olarak grafik tablet kullanabilirsiniz.
Derslerinizi bir doküman üzerinden işlemek istiyorsanız dokümanı bilgisayarında yada telefonunuzda açtığınızda yukarıdaki ekranın alt kısmında olduğu gibi açık sekmeleri gösterir. Hangi doküman üzerinden ders yapmak istiyorsanız ona tıklayıp öğrencilerinizle sadece o dokümanın ekran paylaşımını yapabilirsiniz.
Record: Kayıt
Breakout Rooms: Bekleme Odası
Reactions: Uygulamanın emojileridir.
Join Audio: Ses – Mikrofon/Hoparlör Ayarları
Start/Stop Video: Video Başlat/Durdur. Toplantı, konferans içi videonuzu durdurmaya yada başlatmanıza olanak sağlar.
Mute: Mikrofonun sesini açar ya da kapatır.
New Share: (Yeni Paylaşım) Yeni bir ekran paylaşımı başlatmanızı sağlar.
Pause Share (Paylaşımı Duraklat): Geçerli paylaşılan ekranınızı duraklatabilirsiniz ve daha sonra tekrar paylaşımı devam
ettirebilirsiniz.
End Meeting (Toplantıyı Sonlandır): Bu kısma tıklayarak canlı dersi ya da toplantıyı bitirebilirsiniz.
Manage Participant -Participants (Katılımcılar – Katılımcıları Yönetme): Katılımcıları görüntüleyip katılımcıları yönetebilirsiniz. Bu kısımdan katılımcılarınızı görebilir, direkt olarak kişinin görüntüsünün üstüne tıklayıp ona odaklanabilirsiniz.
Start – Stop Video ”Videoyu Başlat – Durdur”: Toplantı, konferans içi videonuzu durdurmaya yada başlatmanıza olanak sağlar. Buna tıklayarak online görüşmeyi / toplantıyı başlatabilirsiniz.
Chat (Sohbet): Sohbet penceresini görüntülemesine imkân sağlar. Katılımlarınıza notlarınızı paylaşmak için chat kısmından hangi katılımcıyla konuşmak istiyorsanız üstüne tıklayıp özel olarak konuşabilirsiniz. Veya tüm katılımcıların göreceği şekilde genele yazabilirsiniz. Öğrencileriniz size bir soru sormak istediğiniz eğer sesi kapalıysa chat kısmından sormak istediklerini size sorabilir.
Record (Kayıt): Dersinize, toplantınıza ya da konferansınıza ait video kaydını başlatmanızı sağlar. Sadece masaüstü zoom uygulamasında ve bazı mobil cihazlarda bu özellik vardır. Tüm görüşmelerinizi, meetinginize, derslerinizi kayıt etmenizi ve depolamanızı sağlayan kısım burasıdır. Bu buton sayesinde tüm derslerinizi kayıt edebilirsiniz. Record kısmına tıklayıp kaydı başlattıktan sonra, derslerinizi tamamlayıp görüşmeyi tamamladıktan sonra zoom otomatik olarak kaydınızın size sunacaktır.
Invate (Davet et): En önemli kısım burasıdır. Aslında zoom uygulamasını kullanmamızın nedeni olan birebir veya grup halinde derslerimizi yapacağımız öğrencilerimizi, kişileri oluşturmuş olduğumuz bu sınıfa davet etmemize sağlayan butondur. İster e-posta adresine davet linkinizi gönderebilirsiniz, isterseniz uygulamanız size verdiği linki kopyalayıp görüşme sağlamak istediğiniz kişilere iletebilirsiniz. Veya toplantı ID ve şifresini toplantıya katılacak kişilere yollayabilirsiniz. Bu arada güvenlik amacıyla getirilen son güncellemeyle birlikte artık toplantıya katılan herkesi toplantı sahibinin onaylaması gerekiyor. Bu linke tıklayan kişiler sizin sanal sınıfınıza katılmış olurlar.
Test Speakers and Microphone (Hoparlör ve mikrofonu test et) : Sesi ve mikrofonu test edebilirsiniz.
Audio Settings: Ses ayarları, Sesinizi açıp kapatabileceğiniz butondur. Masaüstü kullanımda ekranın sol altında yer alır.
Zoom Uygulama Ayarları Nasıl Yapılır?
Zoom uygulaması üzerinden görüşmeye başladıktan sonra kullanmak isteyeceğiniz başlıca ayarlara bir bakalım;
- Görüşmeye başladıktan sonra sesinizin karşı tarafa gitmesini istemediğiniz durumlar için mikrofon işaretine yani “Mute” seçeneğine tıklayabilirsiniz. Sesi tekrar açmak istediğinizde de yine aynı yere tıklamanız gerekiyor. Birçok kullanıcı Zoom’da ses gelmiyor yönünde şikayette bulunuyor. Eğer ses ile ilgili sorun yaşıyorsanız mikrofon ikonu yanındaki ok işaretine tıkladığınızda açılacak olan pencereden “audio settings”i seçerek mikrofon ve hoparlör ayarlarınızı kontrol edebilirsiniz.
- Zoom uygulaması kamera kapatma seçeneği de sunuyor. Ses gibi görüntünüzü de “Stop Video” seçeneği ile kapatıp sonrasında yeniden açabilirsiniz. Dilerseniz görüşme boyunca kameranızı kapalı tutabilirsiniz.
- Bir toplantıya katılacaksınız ancak bulunduğunuz ortam dağınık ya da karşı taraftan görünmeye pek uygun değil. Bu durumda Zoom arka plan değişikliği seçeneğini kullanabilirsiniz. Sol alt köşede bulunan video ikonu yanındaki ok işaretine tıkladığınızda açılan pencereden “Choose Virtual Background” seçeneği ile arka plan için bir görsel seçebilirsiniz.
- Zoom ekran paylaşımı yapmanıza da imkan tanıyor. “Share Screen” seçeneği ile toplantı sırasında kendi ekranınızda açacağınız dosyaları katılımcıların görmesini sağlayabilirsiniz.
- Sesli dosyalarda sesin karşı tarafa ulaşması için “Share computer sound” ibaresini işaretlemeyi unutmayın.
- Ekran paylaşımı yaparken beyaz tahta da kullanıp anlatmak istediklerinizi anlık yazılı olarak karşı tarafa iletebilirsiniz. Çeşitli işaretlerle özellikle belirtmek istediğiniz noktalara dikkat çekebilirsiniz. Zoom çoklu ekran deneyimi sayesinde ekranınızdaki bilgileri paylaşırken katılımcıları da karşınızda görmeye devam edersiniz.
Chat seçeneği ile tüm kullanıcılara ya da seçeceğiniz kullanıcıya yazılı mesajlarınızı anlık olarak iletebilirsiniz.
Zoom, Bigisayar, Tablet ve Cep Telefonlarına Nasıl İndirilir ve Kurulur?
Zoom uygulaması ücretsiz indirme, programı yükleme, kayıt ve giriş işlemleri için aşağıdaki adımları takip etmeniz gerekmektedir;
Zoom Meeting bilgisayara nasıl indirilir?
- Zoom uygulamasını kullanmak için Zoom Meetings’in zoom.us internet sitesine tıklıyoruz.
- Karşımıza çıkan sayfada Sing Up Free seçeneğine tıklayıp, çıkan ekrana doğum tarihimizi yazıp continue butonuna tıklıyoruz.
- Karşımıza çıkan sayfada Sing Up Free seçeneğine tıklayıp, çıkan ekrana e-posta adresimizi yazıyoruz.
- Mail adresimize bir Email gelece bu emaili açıyoruz
- Mail adresine gelen doğrulama linkine (Activite Account) tıklıyoruz.
- sonra Zoom’un web sayfasına yönlendiriliyoruz. Çıkan sayfada üye bilgilerini doldurduktan sonra Continue butonu ile üyeliğimizi tamamlıyoruz.
- Hesabınıza eğer @edu.tr uzantılı bir eposta adresiyle kayıt yaptırdıysanız, bir okul adına kullanım açabilirsiniz. Bu noktada Zoom @k12 formatında bir alan adı ya da eposta adresi bekleyebilir. Kişisel hesap açmayı tercih ettiyseniz bu alanı tercihinize göre seçip geçebilirsiniz.
- Açılan “Invite Your Colleagues” sayfasında arkadaşlarınızı davet edebilir veya altta yer alan “Skip This Step” (Bu aşamayı atla) butonuna tıklayarak bu aşamayı atlayabilirsiniz.
- Bu arada mail adresinizi doğrulamanız akabinde “download & run zoom” ifadesiyle karşılaşacaksınız. Bu ifade Zoom’u masaüstü cihazınıza (PC, Laptop vs.) indirmeniz anlamına geliyor. Eğer hali hazırda Zoom üyeliğiniz varsa ama uygulama cihazınızda yüklü değilse buraya tıklayarak Download Center sayfasına direkt ulaşabilirsiniz.
Evet, Zoom’a üye olduğunuza ve Zoom’u masaüstü/mobil cihazınıza indirdiğinize göre artık Zoom kullanmak için hazırsınız!
Zoom Meeting Cep Telefonu veya Tabletlere nasıl indirilir?
Zoom uygulamasını Google Play ve Apple Store’dan indirilebiliyor. Program ücretsiz ancak daha büyük toplantılar başlatmak gibi ek seçeneklere ücret ödemesi gerekebiliyor.
PLAY STORE İNDİRME LİNKİ İÇİN TIKLAYINIZ
APP STORE İNDİRME LİNKİ İÇİN TIKLAYINIZ
Kayıt işlemlerini tamamladıktan soran ekranın sağ üst köşesinde bulunan kişi sembolüne tıklayarak profilinizi görüntüleyip, istediğiniz gibi düzenleyebilirsiniz.
Profil bilginize sınırsız şekilde maksimum 100 kişi katılımlı
ve 40 dakika uzunluğuna sahip toplantılar düzenleyebileceğiniz bilgisini görebilmektesiniz
Ayrıntılı Toast Kullanımı
Toast Mesajı Nedir?
Toast, Android uygulamalarda kullanıcılara uyarı veya bilgilendirme mesajları verilmesini sağlayan, bunun dışında uygulama test aşamasında işlemlerin gerçekleşip gerçekleşmediği hakkında bilgi edinmek amaçlı kullanılan mesaj türüdür.
Ayrıca, hata ayıklama amacıyla da kullanabilirsiniz. Bir tost, küçük bir açılır pencerede bir işlem hakkında basit geri bildirim sağlar.
Toast Message, Javascript’deki alert, Form Application’lardaki msgbox yada messagebox gibi anlayabiliriz. Ekrana veri yazdırmak için kullanılıyor.
Nasıl Kullanılır?
Toast mesajları tasarlanarak kullanılacağı gibi default yani varsayılan şekilde de gösterilebilir. Bunu basit anlamda aşağıdaki kod bloğunu sınıf içine yazarak kullanabiliriz.
makeText methoduna baktığımızda üç parametre aldığını göreceksiniz.
İlki uygulama içeriğini yani contexti , Hangi activity bu işleme erişecek bilgisi gibi bilgileri tutar.
ikincisi kullanıcıya gösterilecek kısa mesajı, parametre olarak String veri bekler.
üçüncüsü de Toast mesajının ekranda gösterilme süresini belirtiyor.
Toast Message süre olarak iki integer değer alabilir;
- Uzun toast message süresi –> Toast.LENGTH_LONG
- Kısa toast message süresi –> Toast.LENGTH_SHORT
show (): Bu yöntem, Tost’u ekranda görüntülemek için kullanılır. Bu yöntem, Toast’un makeText () yöntemini kullanarak oluşturduğumuz metni görüntüler.
Toast toast = Toast.makeText(getApplicationContext(), "Mesajımız..", Toast.LENGTH_LONG);
toast.show();
veya
Toast toast = Toast.makeText(getApplicationContext(), "Mesajımız..", Toast.LENGTH_LONG)show();
şeklinde gösterilir.
Toast nesnesi ise, android.widget paketi içerisinde sınıf olarak bulunur.
Toast.makeText(this, "Mesajımız..", Toast.LENGTH_SHORT).show();
Toast.makeText(getApplicationContext(),"Mesajımız..",Toast.LENGTH_LONG).show();
Yukarıdaki şekilde kullanıldığında mesaj, kısa süreli ekranda görünür. Ama eğer uzun süreli görünmesini istiyorsak Toast.LENGTH_SHORT kısmını Toast.LENGTH_LONG şeklinde değiştirebiliriz.
this yerine bazen getApplicationContext() olarak da görebilirsiniz, her ikiside çalışır.
Yapmış olduğumuz çalışma test amaçlı ve kodların işleyişini değinmek amaçlı, onCreate metodu içinde çalıştırdık.
Toast nesnenizin yerini belirleme
Ekranın alt kısmında, yatay olarak ortalanmış standart bir kısa mesaj bildirimi görünür. Bu konumu setGravity(int, int, int)
yöntemini kullanarak değiştirebilirsiniz. Bu yöntem üç parametreyi kabul eder: Bir Gravity
sabiti, bir x konumu ofseti ve bir y konumu ofseti.
Örneğin, durum mesajının sol üst köşede görünmesi gerektiğine karar verirseniz yerçekimi (gravity) değerini şu şekilde ayarlayabilirsiniz:
toast.setGravity(Gravity.TOP|Gravity.LEFT, 0, 0);
Toast toast = Toast.makeText(getApplicationContext(), "Mesajımız...", Toast.LENGTH_LONG);
toast.setGravity(Gravity.TOP|Gravity.CENTER_HORIZONTAL, 0, 0);
toast.show();
Toast mesajımızın yerini belirlemek için aşağıdaki konum sabitlerini kullanabilirsiniz.
- TOP
- BOTTOM
- LEFT
- RIGHT
- CENTER
- CENTER_HORIZONTAL
- CENTER_VERTICAL
Aşağıdaki kod parçasını incelediğimizde ekran görüntüsünde de gördüğünüz gibi Toast mesajını en altta sola dayalı olarak konumlandırdık.
Toast toast = Toast.makeText(getApplicationContext(), "Mesajımız...", Toast.LENGTH_LONG);
toast.setGravity(Gravity.BOTTOM|Gravity.LEFT, 0, 0);
toast.show();
Toast mesajının kısa süre boyunca gözükmesi için :
Toast.makeText(getApplicationContext(), "Mesajımız…", Toast.LENGTH_SHORT).show();
Toast mesajının uzun süre boyunca gözükmesi için:
Toast.makeText(getApplicationContext(), "Mesajımız…", Toast.LENGTH_LONG).show();
Diyelim ki varsayılan şekilde kullanmak istemiyoruz. Toast mesajlarının daha güzel, kendimize ait bir tasarımla görünmesini istiyoruz.
İlk önce uygulamanın açılış ekranındaki tasarımı yapalım.
toast_1.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/custom_toast_container"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
android:orientation="vertical">
<ImageView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@android:drawable/ic_delete" />
<TextView
android:id="@+id/text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Toast YAZILI MESAJ"
android:textColor="#FFF" />
</LinearLayout>
Java kodumuzda aşağıdadır. Yukarıda oluşturduğumuz görsel bileşeni, Toast mesajına setView yardımı ile verdik. Gördüğünüz gibi istediğimiz şekilde Toast mesajını oluşturmamız mümkün.
LayoutInflater inflater = getLayoutInflater();
View layout = inflater.inflate(R.layout.toast_1,
(ViewGroup) findViewById(R.id.custom_toast_container));
TextView text = layout.findViewById(R.id.text);
text.setText("Bu bir Tost Mesajıdır ");
Toast toast = new Toast(getApplicationContext());
toast.setGravity(Gravity.CENTER_VERTICAL, 0, 0);
toast.setDuration(Toast.LENGTH_LONG);
toast.setView(layout);
toast.show();
Toast olarak sadece resim göstermek istersek
MainActivity.class
package com.ossmatematik.toastresimmesaji;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
Button Btn1,Btn2;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Btn1= findViewById(R.id.button1);
Btn2= findViewById(R.id.button2);
Btn1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
Toast.makeText(getApplicationContext(),"Bu bir Tost MEsajıdır",Toast.LENGTH_LONG).show();
}
});
Btn2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
ImageView resim=new ImageView(getApplicationContext());
resim.setImageResource(R.drawable.reklam);
Toast toast=new Toast(getApplicationContext());
toast.setView(resim);
toast.setDuration(Toast.LENGTH_LONG);
toast.show();
}
});
}
}
Toast Mesajının bizim istediğimiz kadar kalmasını istersek
public void sureliTOAST(String msg, int millisec) {
Handler handler = null;
final Toast[] toast_sureli = new Toast[1];
for(int i = 0; i < millisec; i+=2000) {
toast_sureli[0] = Toast.makeText(this, msg, Toast.LENGTH_SHORT);
toast_sureli[0].show();
if(handler == null) {
handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
toast_sureli[0].cancel();
}
}, millisec);
}
}
}
Bütün kodları toparlarsak;
axtivity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingBottom="@dimen/activity_vertical_margin"
tools:context="com.nuri.toastresimmesaji.MainActivity">
<Button
android:id="@+id/button1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="NORMAL TOAST MESAJI"
android:textSize="30sp" />
<Button
android:id="@+id/button2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="RESİMLİ TOAST"
android:textSize="30sp" />
<Button
android:id="@+id/button3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="RESİM ve YAZILI TOAST"
android:textSize="30sp" />
<Button
android:id="@+id/button4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="ZAMAN AYARLI TOAST(6 SANİYE)"
android:textSize="30sp" />
</LinearLayout>
MainAcivity.java
package com.nuri.toastresimmesaji;
import androidx.appcompat.app.AppCompatActivity;
import android.os.Bundle;
import android.os.Handler;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;
public class MainActivity extends AppCompatActivity {
Button Btn1,Btn2,Btn3,Btn4;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
Btn1= findViewById(R.id.button1);
Btn2= findViewById(R.id.button2);
Btn3= findViewById(R.id.button3);
Btn4= findViewById(R.id.button4);
Btn1.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
Toast.makeText(getApplicationContext(),"Bu bir NORMAL Tost Mesajıdır",Toast.LENGTH_LONG).show();
}
});
Btn2.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
ImageView resim=new ImageView(getApplicationContext());
resim.setImageResource(R.drawable.reklam);
Toast toast=new Toast(getApplicationContext());
toast.setView(resim); //setView yani özel toast kullanımdan kaldırıldı. Bunun yerine SnackBar kullan
toast.setDuration(Toast.LENGTH_LONG);
toast.show();
}
});
Btn3.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
String Baslik = "DENEME";
String mesajim = "Bu bir RESİMLİ Toast MESAJI";
gosterTOAST(mesajim,Baslik);
}
});
Btn4.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v)
{
sureliTOAST("Bu bir Toast MESAJI",6000);
}
});
}
public void gosterTOAST(String Baslik, String msg)
{
LayoutInflater inflater = getLayoutInflater();
View layout = inflater.inflate(R.layout.toast_ekrani,
(ViewGroup) findViewById(R.id.relativeLayout1));
TextView baslikText = layout.findViewById(R.id.toast_baslik);
TextView textMesaj = layout.findViewById(R.id.toast_mesaj);
baslikText.setText(Baslik);
textMesaj.setText(msg);
Toast toast = new Toast(getApplicationContext());
toast.setGravity(Gravity.BOTTOM, 0, 0);
toast.setDuration(Toast.LENGTH_LONG);
toast.setView(layout); //setView yani özel toast kullanımdan kaldırıldı. Bunun yerine SnackBar kullan
toast.show();
}
public void sureliTOAST(String msg, int millisec) {
Handler handler = null;
final Toast[] toast_sureli = new Toast[1];
for(int i = 0; i < millisec; i+=2000) {
toast_sureli[0] = Toast.makeText(this, msg, Toast.LENGTH_SHORT);
toast_sureli[0].show();
if(handler == null) {
handler = new Handler();
handler.postDelayed(new Runnable() {
@Override
public void run() {
toast_sureli[0].cancel();
}
}, millisec);
}
}
}
}
toast_ekrani.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/relativeLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@android:color/white"
android:gravity="center_horizontal">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@android:color/holo_orange_dark"
android:orientation="vertical"
android:padding="5dp">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
tools:ignore="UseCompoundDrawables">
<ImageView
android:id="@+id/imageView1"
android:layout_width="120dp"
android:layout_height="60dp"
android:layout_below="@+id/textView1"
android:layout_margin="5dip"
android:src="@drawable/toast_onemli_uyari"
tools:ignore="ContentDescription,InefficientWeight,ObsoleteLayoutParam" />
<TextView
android:id="@+id/toast_baslik"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center"
android:padding="10dp"
android:text=""
android:textAppearance="?android:attr/textAppearanceLarge"
android:textColor="@android:color/background_dark"
android:textSize="18sp"
tools:ignore="HardcodedText,InefficientWeight" />
</LinearLayout>
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal"
android:padding="10dp">
<TextView
android:id="@+id/toast_mesaj"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_below="@+id/imageView1"
android:layout_weight="1"
android:gravity="center"
android:hint="Mesaj"
android:textColor="@color/colorPrimary"
android:textSize="14sp"
tools:ignore="HardcodedText,InefficientWeight,ObsoleteLayoutParam" />
</LinearLayout>
</LinearLayout>
</RelativeLayout>
Projenin tamamını
https://github.com/netmatematiknet/Toast
adresinden ücretsiz indirebilirsiniz.
Android Uygulama İzinleri için Geniş bir Araştırma
İzin kelimesinin resmi anlamı, birisinin belirli bir şeyi yapmasına izin vermek anlamına gelir – herhangi bir işlem yapılması için verilen izin veya izindir. Android dünyasında, izinler mektup tanımını takip ediyor. Android uygulamaları, bazıları kullanıcılardan izin gerektiren bir dizi işlem gerçekleştirmek üzere oluşturulmuştur.
Bu yazı da Android’in izinlerini nasıl sınıflandırdığını ve kullanıcılardan nasıl izin alacağınızı anlamaya çalışacağız. Bu izinler doğru şekilde kullanılmazsa, uygulamanın çökmesine neden olabilir.
Varsayılan olarak, bir Android uygulaması kendisine verilen sıfır izinlerle başlar. Uygulamanın, cihazın korumalı özelliklerinden herhangi birini kullanması gerektiğinde (ağ istekleri gönderme, kameraya erişme, SMS gönderme vb.), kullanıcının bunu yapması için uygun izin alması gerekir.
Yani Android’in izin sistemi, kurulum sırasında bu izinlerin istenmesi nedeniyle baştan beri en büyük güvenlik sorunlarından biridir. Uygulama bir kez yüklendiğinde, herhangi bir kullanıcının izni ile tam olarak ne yaptığını kabul etmeden, herhangi bir kullanıcının onayı olmadan verilen tüm şeylere erişebiliyordu. Bu güvenlik zayıflığıyla kullanıcının kişisel verilerini toplamaya ve bunları kötü bir şekilde kullanmaya çalışan çok fazla yazılım mevcuttu. Android özgürlüktü ama bu sebepten de çok eleştiriliyordu.
Özgürlüktü ama dezavantajı da oldukça açıktı: geliştiriciler veri toplamak için izin almaya ve kullanıcının gizliliğini ihlal etmeye başladı. Google, uygulamanın söz konusu izinleri gerçekten gerektirip gerektirmediğini kontrol etmediğinden ve kullanıcının belirli izinleri sağlama ve uygulamayı kullanmaya devam etme seçeneği bulunmadığından, geliştiriciler sistem bilgisine veya mikrofona herhangi bir kısıtlama olmadan erişme konusunda çok rahattılar
Android içerisinde 130’dan fazla farklı izin türü vardır. Geliştiricilerin bunlardan her biri için izin alması zordu. Daha da kötüsü, uygulamanızın kullanıcıların kaç tane iznine ihtiyacı olduğunu görmelerinin korkutuculuğundan ziyade neden bu kadar çok izne ihtiyacınız olduğunu kullanıcıya açıklamak çok daha zordur.
Android M (Marshmallow , Android 6.0, API 23)
İOS’un aksine, Android uygulama izinlerine partiye biraz geç geldi. Android Marshmallow (Android M), 5 Ekim 2015 tarihinde piyasaya sürüldü.
Marshmallow’dan önce, izinler kurulum zamanında ele alınmış AndroidManifest.xml ve proje içerisinde belirtilmiştir . İzinlerin tam listesi burada bulunabilir.
Marshmallow’dan önce izinler çok daha basittir (API 23). Tüm izinler kurulum sırasında ele alındı. Bir kullanıcı Google Play Store’dan bir uygulama yüklemeye gittiğinde , kullanıcıya uygulamanın gerekli kıldığı izinlerin bir listesi sunuldu (bazı kişiler buna “izin duvarı” olarak adlandırılıyordu. Kullanıcı tüm izinleri kabul edip devam edebilirdi. Uygulamayı yüklemek veya uygulamayı yüklememeye karar vermekle, kullanıcı izinlerin tamamına izin veriyordu ya da hiç birine izin vermiyordu.Uygulama için yalnızca belirli izinler vermenin bir yolu yoktu ve kullanıcının uygulama yüklendikten sonra belirli izinleri iptal etmesinin bir yolu yoktu.
Android Marshmallow’un halka açık sürümüyle Google, Android için çalışma zamanı izinlerini sundu ve böylece izinler alanını daha iyi hale getirdi. Android Marshmallow, yalnızca izinleri basitleştirmek değil, aynı zamanda gereken izin sayısını azaltmak için uygulama izinlerinde tamamen yeni bir uygulama sunar.
Peki daha önce başlatılmış olan uygulamaya ne oldu?
Eski uygulamalar Android Marshmallow’da çalışacak mı? TargetSdkVersion 22 ya da daha az ise cevap evet .
Bu yeni izin sistemi şu anda size biraz panik getirebilir. “Hey! 3 yıl önce başlattığım uygulamama ne oldu. Android 6.0 aygıtına yüklenmişse, bu davranış da geçerli mi? Uygulamam da çökecek mi?!?”
Endişelenme. Android ekibi çoktan düşünmüş. Uygulamanın targetSdkVersion değeri 23’ten küçükse, uygulamanın henüz yeni izin sistemiyle test edilmediği ve aynı eski davranışa geçeceği varsayılır: kullanıcı yükleme zamanında her bir izni kabul etmek zorundadır ve hepsine izin verilir kurulduktan sonra!
Sonuç olarak, uygulama önceki gibi mükemmel şekilde çalışacaktır. Yine de, kullanıcının bundan sonra hala bir izni iptal edebileceğini unutmayın! Her ne kadar Android 6.0 bunu yapmaya çalıştıklarında kullanıcıyı uyarıyorlar ancak yine de iptal edebiliyorlar.
Şu an kafandaki bir sonraki soru. Peki başvurum çökecek mi?
Android ekibi aracılığıyla Tanrı’dan gönderilen böylesi bir nezaket. TargetSdkVersion uygulamasının 23’ten daha az olduğu uygulamada izinli kullanıcının iptal edilmesini gerektiren bir işlev çağırdığımızda, İstisna atılmaz. Bunun yerine sadece hiçbir şey yapmaz. Değeri döndüren işlev için null döndürür veya 0 duruma göre değişir.
Android 6.0 Marshmallow’da, uygulama kurulum sırasında herhangi bir izin verilmez. Bunun yerine, uygulama çalışma zamanında kullanıcıdan birer birer izin istemelidir.
Sağdaki reismde yani Api 23 den sonra geliştiricinin, kullanıcının henüz izin vermemiş olması gereken izni gerektiren bazı işlevleri çağırmayı denemesi durumunda, işlev aniden uygulamanın çökmesine neden olacak bir İstisna atar.
Ayrıca, kullanıcı telefonun Ayarlar uygulamasını kullanarak verilen izni istediği zaman iptal edebilir.
Şimdi geliştirici artık uygulama kurulumunda tüm izinlere sahip değil. Bunun yerine, geliştiricinin bir resmi tıklatmak veya bir dosyayı kaydetmek için kullanıcının deposuna erişmek için kamerayı kullanmak gibi belirli bir işlemi gerçekleştirme iznini istemesi gerekir. Google ayrıca Android’deki izinler kümesini normal ve tehlikeli izinlere ayırdı .
Normal ve tehlikeli izinlerin tam listesi Android Dokümantasyonunda bulunmaktadır .
Normal İzinler
Kurulum sırasında otomatik olarak verilecek ve iptal edilemeyecek bazı izinler vardır. Buna Normal İzin (PROTECTION_NORMAL) diyoruz.
Normal izinler, kullanıcının gizliliği veya cihazın çalışması için risk teşkil etmeyen izinlerdir. Sistem bu izinleri otomatik olarak verir. Bunlar arasında internete bağlanmak, ağ, Bluetooth, wifi ve NFC bilgilerini almak, alarmları ve duvar kağıtlarını ayarlamak ve bir cihazdaki ses ayarlarını değiştirmek sayılabilir.
Normal izinler, uygulamanızın uygulama sanal alanı dışındaki verilere veya kaynaklara erişmesi gereken alanları kapsar, ancak kullanıcının gizliliği veya diğer uygulamaların çalışması için çok az risk olduğu yerlerdir. Örneğin, saat dilimini ayarlama izni normal bir izindir.
Bir uygulama normal bir izne ihtiyaç duyduğunu beyan ederse, sistem otomatik olarak bu izni yükleme sırasında uygulamayı verir. Sistem, kullanıcıdan normal izinler vermesini istemez ve kullanıcılar bu izinleri iptal edemez.
Android 9’dan itibaren (API seviyesi 28), aşağıdaki izinler şöyle sınıflandırılır PROTECTION_NORMAL
:
İşte bunların tam listesi:
android.permission.ACCESS_LOCATION_EXTRA_COMMANDS android.permission.ACCESS_NETWORK_STATE android.permission.ACCESS_NOTIFICATION_POLICY android.permission.ACCESS_WIFI_STATE android.permission.ACCESS_WIMAX_STATE android.permission.BLUETOOTH android.permission.BLUETOOTH_ADMIN android.permission.BROADCAST_STICKY android.permission.CHANGE_NETWORK_STATE android.permission.CHANGE_WIFI_MULTICAST_STATE android.permission.CHANGE_WIFI_STATE android.permission.CHANGE_WIMAX_STATE android.permission.DISABLE_KEYGUARD android.permission.EXPAND_STATUS_BAR android.permission.FLASHLIGHT android.permission.GET_ACCOUNTS Instagram Hesabındaki Resim ve Videoları android.permission.FLASHLIGHT android.permission.GET_ACCOUNTS android.permission.FLASHLIGHT android.permission.INTERNET android.permission.KILL_BACKGROUND_PROCESSES android.permission.MODIFY_AUDIO_SETTINGS android.permission.NFC android.permission.READ_SYNC_SETTINGS android.permission.READ_SYNC_STATS android.permission.RECEIVE_BOOT_COMPLETED android.permission.REORDER_TASKS android.permission.REQUEST_INSTALL_PACKAGES android.permission.SET_TIME_ZONE android.permission.SET_WALLPAPER android.permission.SET_WALLPAPER_HINTS android.permission.SUBSCRIBED_FEEDS_READ android.permission.TRANSMIT_IR android.permission.USE_FINGERPRINT android.permission.VIBRATE android.permission.WAKE_LOCK android.permission.WRITE_SYNC_SETTINGS com.android.alarm.permission.SET_ALARM com.android.launcher.permission.INSTALL_SHORTCUT com.android.launcher.permission.UNINSTALL_SHORTCUT
Sadece basitçe bu izin isteklerini AndroidManifest.xml
dosyasına yazın, gayet iyi sonuç verecektir. Bu izinler kullanıcı tarafından İptal edilemediğinden yazılım içerisinde bu listelenen izinleri kontrol etmeniz gerekmez.
Normal izinlerin TAM listesi
İmza İzinleri
Sistem bu uygulama izinlerini yükleme sırasında verir, ancak yalnızca izin kullanmaya çalışan uygulama, izni tanımlayan uygulama ile aynı sertifika ile imzalandığında verilir.
Android 8.1’den itibaren (API seviyesi 27), üçüncü taraf uygulamaların kullanabileceği aşağıdaki izinler şöyle sınıflandırılır PROTECTION_SIGNATURE
:
BIND_ACCESSIBILITY_SERVICE
BIND_AUTOFILL_SERVICE
BIND_CARRIER_SERVICES
BIND_CHOOSER_TARGET_SERVICE
BIND_CONDITION_PROVIDER_SERVICE
BIND_DEVICE_ADMIN
BIND_DREAM_SERVICE
BIND_INCALL_SERVICE
BIND_INPUT_METHOD
BIND_MIDI_DEVICE_SERVICE
BIND_NFC_SERVICE
BIND_NOTIFICATION_LISTENER_SERVICE
BIND_PRINT_SERVICE
BIND_SCREENING_SERVICE
BIND_TELECOM_CONNECTION_SERVICE
BIND_TEXT_SERVICE
BIND_TV_INPUT
BIND_VISUAL_VOICEMAIL_SERVICE
BIND_VOICE_INTERACTION
BIND_VPN_SERVICE
BIND_VR_LISTENER_SERVICE
BIND_WALLPAPER
CLEAR_APP_CACHE
MANAGE_DOCUMENTS
READ_VOICEMAIL
REQUEST_INSTALL_PACKAGES
SYSTEM_ALERT_WINDOW
WRITE_SETTINGS
WRITE_VOICEMAIL
Tehlikeli izinler
Tehlikeli izinler, uygulamanın, kullanıcının kişisel bilgilerini içeren veri veya kaynakları istediği veya kullanıcının depolanan verilerini veya diğer uygulamaların çalışmasını etkileyebileceği alanları kapsar. kullanıcının gizliliğini veya cihazın çalışmasını potansiyel olarak etkileyebilecek izinlerdir. Kullanıcı açıkça bu izinleri vermeyi kabul etmelidir. Bunlar, kameraya, rehbere, konuma, mikrofona, sensörlere, SMS’e ve depolamaya erişmeyi içerir.
Örneğin, kullanıcının bağlantılarını okuyabilmek tehlikeli bir izindir. Bir uygulama tehlikeli bir izin gerektirdiğini bildirirse, kullanıcının açıkça uygulamaya izin vermesi gerekir. Kullanıcı izni onaylayana kadar, uygulamanız bu izne bağlı işlevler sağlayamaz.
Tehlikeli izinlerin TAM listesi
Özel İzinler
Normal ve tehlikeli izinler gibi davranmayan birkaç izin vardır. SYSTEM_ALERT_WINDOW
ve WRITE_SETTINGS
özellikle hassastır, bu nedenle çoğu uygulama bunları kullanmamalı. Bir uygulama şu izinlere birini gerekiyorsa, apaçık izne beyan, gerekir ve kullanıcının izni talep eden bir niyet gönderin. Sistem, kullanıcıya ayrıntılı bir yönetim ekranı göstererek amacına cevap verir.
Bu izinlerin nasıl isteneceği ile ilgili detaylar için bakınız SYSTEM_ALERT_WINDOW
ve WRITE_SETTINGS
referans girişleri.
Android sistemi tarafından sağlanan tüm izinler adresinde bulunabilir
Manifest.permission
İzin Grupları
İzinler, bir cihazın yetenekleri veya özellikleriyle ilgili gruplar halinde düzenlenir. Bu sistem altında, izin talepleri grup düzeyinde ele alınmakta ve tek bir izin grubu, uygulama bildiriminde birkaç izin beyanına karşılık gelmektedir. Örneğin, SMS grubu hem bildirimleri hem READ_SMS
de RECEIVE_SMS
bildirimleri içerir. Bu şekilde gruplama izinleri, kullanıcının karmaşık ve teknik izin talepleri tarafından boğulmadan daha anlamlı ve bilinçli seçimler yapmasını sağlar.
Tehlikeli izinler kendi içerisinde gruplara ayrılmıştır. İzinler, dokuz gruba ayrılarak kullanıcıların bir grup halinde bir araya getirilerek tek bir işlemle kapsanan tüm izinleri vermelerini sağlar.
Örneğin, Bu, kullanıcının konumunu bulmak için GPS’i kullanmanız gerekirse, ACCESS_FINE_LOCATION ve ACCESS_COARSE_LOCATION gibi 2 adet izin belirtmeniz anlamına geliyordu ya da bir kullanıcıya Rehber’i görüntüleme, düzenleme ve ekleme izni vermek için 3 adet izin belirtmek gerekiyordu.
Bunun yerine izinleri tek tek almak yerine izin grubuna (Kişiler adı verilen) izin istemek daha etkilidir.
İzin Grupları Konum, Rehber, Telefon, Sensörler, SMS ve Depolama gibi benzer işlemleri gerçekleştiren izinleri basitleştirmeye çalışır. Bir uygulama grubu şu anda tek bir izin grubuna bir ila yedi izin arasında herhangi bir yerde bir araya geliyor. Bu, bir gruptaki tüm izinlerin tek seferde talep edebileceğiniz anlamına gelir!
Tüm tehlikeli Android izinleri izin gruplarına aittir. Herhangi bir izin, koruma seviyesinden bağımsız olarak bir izin grubuna ait olabilir. Bununla birlikte, bir izin grubu yalnızca izin tehlikeli olduğunda kullanıcı deneyimini etkiler.
Cihaz Android 6.0 kullanıyorsa (API seviye 23) ve uygulamanın targetSdkVersion
23 veya daha üstü ise, uygulamanız tehlikeli bir izin istediğinde aşağıdaki sistem davranışı uygulanır:
- Uygulamanın izin grubunda şu anda herhangi bir izni yoksa, sistem, uygulamanın erişmek istediği izin grubunu tanımlayan kullanıcıya izin isteği iletişim kutusunu gösterir. İletişim kutusu, o gruptaki belirli izni açıklamıyor. Örneğin, bir uygulama
READ_CONTACTS
izin isterse, sistem iletişim kutusu sadece uygulamanın cihazın bağlantılarına erişmesi gerektiğini söyler. Kullanıcı onay verirse, sistem uygulamaya sadece istediği izni verir. - Uygulamaya, aynı izin grubunda başka bir tehlikeli izin verilmişse, sistem kullanıcı ile herhangi bir etkileşime girmeden derhal izni verir. Örneğin, bir uygulamanın daha önce talep etmesi ve
READ_CONTACTS
izin verilmiş olması ve daha sonra talepWRITE_CONTACTS
etmesi durumunda, sistem, izinler iletişim kutusunu kullanıcıya göstermeden hemen bu izni verir.
Cihaz Android 5.1 kullanıyorsa (API seviye 22) veya daha düşükse veya uygulama targetSdkVersion
22 veya daha düşükse, sistem kullanıcıdan yükleme sırasında izinleri vermesini ister. Bir kez daha, sistem kullanıcıya bireysel izinleri değil, uygulamanın hangi izin grubunu gerektirdiğini söyler . Örneğin, bir uygulama READ_CONTACTS
kurulum istediğinde , iletişim kutusu Rehber grubunu listeler. Kullanıcı kabul ettiğinde, uygulamaya yalnızca READ_CONTACTS
izin verilir.
Not: Kullanıcı, aynı grupta başka bir izin vermiş olsa bile, uygulamanızın ihtiyacı olan her izni açıkça talep etmesi gerekir. Ek olarak, izinlerin gruplara ayrılması gelecekteki Android sürümlerinde değişebilir. Kodunuz, aynı grupta bulunan belirli bir izin grubuna bağlı bir mantığa sahip olmamalıdır.
Tehlikeli izinler ve izin grupları.
İzin Grubu | İzinler | Açıklama | Açıklama |
---|---|---|---|
CALENDAR(Takvim) | Kullanıcının takvimi ile ilgili çalışma zamanı izinleri için kullanılır.
Manifest.permission.READ_CALENDAR (Takvim Etkinlikleri OKU) Manifest.permission.WRITE_CALENDAR (Takvim Etkinlikleri YAZ) | android.permission-group.CALENDAR | |
CALL_LOG ( Çağrı Geçmişi) | İlişkili telefon özellikleri ile ilgili izinler için kullanılır. | android.permission-group.CALL_LOG | |
CAMERA (Kamera) | Kameraya erişmek veya cihazdan fotoğraf / video çekmekle ilgili izinler için kullanılır.
Manifest.permission.CAMERA (Kameraya Erişim) | android.permission-group.CAMERA | |
CONTACTS(İletişim) | Bu cihazdaki kişiler ve profillerle ilgili çalışma zamanı izinleri için kullanılır.
Manifest.permission.READ_CONTACTS (Telefon Rehberini OKU) Manifest.permission.WRITE_CONTACTS (Telefon Rehberine YAZ) | android.permission-group.CONTACTS | |
LOCATION (Yer) | Cihaz konumuna erişime izin veren izinler için kullanılır.
Manifest.permission.ACCESS_FINE_LOCATION (Kesin Konum) Manifest.permission.ACCESS_COARSE_LOCATION (Genel Konum) | android.permission-group.LOCATION | |
MICROPHONE(Mikrofon) | Aygıttan mikrofon sesine erişimle ilgili izinler için kullanılır. Telefon görüşmelerinin de ses yakaladığını ancak ayrı (daha görünür) bir izin grubunda olduğunu unutmayın.
Manifest.permission.RECORD_AUDIO (Mikrofon ile kayıt) | android.permission-group.MICROPHONE | |
PHONE(Telefon | İlişkili telefon özellikleri ile ilgili izinler için kullanılır.
Manifest.permission.CALL_PHONE (Telefonla Arama) | android.permission-group.PHONE | |
SENSORS(Vücut Sensörleri) | Gövde veya çevresel sensörlere erişim ile ilgili izinler için kullanılır. | android.permission-group.SENSORS | |
SMS(SMS) | Kullanıcının SMS mesajlarıyla ilgili çalışma zamanı izinleri için kullanılır. | android.permission-group.SMS | |
STORAGE(Depolama) | Paylaşılan harici depolama alanıyla ilgili çalışma zamanı izinleri için kullanılır.
Manifest.permission.READ_EXTERNAL_STORAGE (Sd veya Harici Diski OKU) Manifest.permission.WRITE_EXTERNAL_STORAGE (Sd veya Harici Diske YAZ) | android.permission-group.STORAGE |
Tehlikeli izinlerin TAM listesi
Uygulama için İzin Alma
Artık uygulamamızın yeni Çalışma Zamanı İznini mükemmel bir şekilde desteklemesinin zamanı geldi. Önce compileSdkVersion
ve targetSdkVersion
ayarlarını 23 yaparak başlayalım.
android { compileSdkVersion 23 ... defaultConfig { ... targetSdkVersion 23 ... }
Sonraki adım, AndroidManifest.xml
aynı eski yöntemle izin vermek
<uses-permission android:name="android.permission.WRITE_CONTACTS"/>
Dikkat: Manfest izni verilmezse uygulama kilitlenir.
İzinler, aşağıdaki tablo gibi İzin Grubunda gruplandırılmıştır .
Bir uygulamada tehlikeli kategorisindeki bir izne ihtiyaç varsa, bu izin kullanıcı tarafından daha önce onaylanmış bile olsa her seferinde uygulama tarafından kontrol edilmelidir. Çünkü kullanıcı verdiği izinden istediği an cayma hakkına sahiptir. Telefonun “Ayarlar – Uygulamalar – İlgili Uygulama – İzinler” kısmından bu işlemi yapabilir.
Android uygulamamız tehlikeli kategorisindeki bir izne ihtiyaç duyarsa, bu yetki için mutlaka kullanıcıya sorulması gerekir. Bir sonraki adım, izin verilip verilmediğini kontrol etmek için bir işlev oluşturmaktır.
//Öyleyse önce kullanıcıdan izin istemek için bir iletişim kutusu çağıralım. Sonra yeni bir kişi oluşturarak bir sonraki adıma geçebiliriz.
Not: Bir izin grubunda herhangi bir izin verilirse aynı gruptaki başka bir izin de otomatik olarak verilecektir.
Yani, bir kez WRITE_CONTACTS izni verildiyse READ_CONTACTS ve GET_ACCOUNTS izinleri de otomatik olarak verilir.
(READ_CONTACTS , WRITE_CONTACTS ve GET_ACCOUNTS aynı grupta olduğu için.) (ama AndroidManifest.xml dosyasında izin istemek zorundayız)
1. Önce iznin verilip verilmediğini kontrol edelim
checkSelfPermission(Context context, String permission)
Uygulama tarafından izin kontrolü ContextCompat.checkSelfPermission(Context context, String permission) metodu ile yapılır.
Bu metotta kullanıcı
izin verdiğinde PackageManager.PERMISSION_GRANTED döndürülürken,
izin vermediğinde ise PackageManager.PERMISSION_DENIED döndürülür.
private void izin_Kontrolet_Al() { if (ContextCompat.checkSelfPermission(this, Manifest.permission.CALL_PHONE) == PackageManager.PERMISSION_GRANTED) { //Önceden izin VERİLMİŞ öyleyse Serbestçe istediğimizi yapalım. yapilacaklar(); } else { // Önceden izin verilmemiş öyleyse İZİN İSTEYELİM ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CALL_PHONE}, ONAY_KODU); } return; }
2. İzin önceden alınmadıysa izin isteyelim
requestPermissions(String [] izinler, int ONAY_KODU)
İzin alma işlemi için android sistemine ait standart bir dialog mevcuttur. Bu dialog requestPermissions() metodu ile çağrılır ve özelleştirilemez.
Activity izni almak için (Üstteki kodlara ekleme yapalım)
Daha önceden izin verilmişse, çalıştırılacak kodlar çağrılıyor, bu örnekte yapilacaklar() çağrılıyor.
İzin verilmediyse requestPermissions(context, new String [] {izinler}, int ONAY_KODU) ile izin istemek için aşağıdaki gibi bir iletişim kutusunu çağırılıyor.
final private int ONAY_KODU = 1234; private void izin_Kontrolet_Al() { if (ContextCompat.checkSelfPermission(this, Manifest.permission.CALL_PHONE) == PackageManager.PERMISSION_GRANTED) { //Önceden izin VERİLMİŞ öyleyse Serbestçe istediğimizi yapalım. yapilacaklar(); } else { // Önceden izin verilmemiş öyleyse İZİN İSTEYELİM ActivityCompat.requestPermissions(this, new String[]{Manifest.permission.CALL_PHONE}, ONAY_KODU); } return; }
- İzin grubu simgesi
- Uygulama ismi
- “Bir daha asla sorma” onay kutusu (Bir kullanıcı iki kez izin vermezse bu görüntülenir)
- Çoklu diyaloglar için gösterge
- Aksiyon
3. İzin verilip verilmediğini kontrol edelim
İzin istedik ama izin verildi mi acaba? İşlem sonucunda izin verilip verilmediğini kontrol etmek için ise
onRequestPermissionsResult (int permsRequestCode, String [] izinleri, int [] grantResults)
komutları kullanılır.
@Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { //public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); switch (requestCode) { case ONAY_KODU: { // CALL_PHONE izni verilip verilmediğini kontrol edin if (grantResults.length > 0 && grantResults[0] == PackageManager.PERMISSION_GRANTED) { Toast.makeText(Eeeeeee.this, "CALL_PHONE izni VERİLDİ", Toast.LENGTH_SHORT).show(); yapilacaklar(); } else { Toast.makeText(Eeeeeee.this, "CALL_PHONE izni REDDEDİLDİ", Toast.LENGTH_SHORT).show(); } return; } default: super.onRequestPermissionsResult(requestCode, permissions, grantResults); } }
Yukarıdaki kodda, istek kodunun izin talep ederken tarafımızdan gönderilen istek koduyla eşleşip eşleşmediğini kontrol ediyoruz. İstek kodu eşleşirse, kullanıcının izin verdiği veya reddedildiği izinleri kontrol ediyoruz. Kullanıcı izin verirse, CALL_PHONE başlatabiliriz, aksi takdirde kullanıcının izin vermesine izin verecek bir mesaj gösterebiliriz.
4. izin almadan önce neden izin istediğimizi izah edelim
Eğer kullanıcı izin için ilk kez çıkan dialog’a izin vermeyip, yeniden o özelliği kullanmaya çalışırsa, büyük ihtimalle o iznin ne için gerekli olduğunu anlamamıştır. Bu sebeple kullanıcıya standart izin dialog’u gösterilmeden önce, uygulamanın izne neden ihtiyacı olduğunu anlatan bir açıklama gösterilmelidir. Eğer kullanıcı açıklamaya ikna olup izin vermeyi kabul ederse, standart izin penceresine yeniden yönlendirilir.
Android sistemi, kullanıcıya bir açıklama göstermenin gerekli olup olmadığına karar vermemizi kolaylaştıran bir metod sunmuştur:
shouldShowRequestPermissionRationale() metodu
true dönerse, kullanıcıya daha önceden android standart dialog’u gösterilmiş ve kullanıcı izni onaylamamıştır. Bu sebeple true döndüğü durumlarda önce iznin ne için gerekli olduğunu anlatan bir açıklama gösterilmesi ve kullanıcı bu açıklamayı onaylarsa standart izin dialog’una yönlendirilmesi gerekir.
İzin kullanıcıdan ilk defa istenecekse ya da kullanıcı “Never ask again” durumu onaylanmışsa metod false döner.
requestPermissions çağrılmadan önce biz izni neden talep ettiğimizi shouldShowRequestPermissionRationale metodu ile kullanıcıya bir pencerede gerekçe göstermemiz gerekir.
ActivityCompat.shouldShowRequestPermissionRationale(this, Manifest.permission.READ_CALL_LOG)
private void izin_Kontrolet_Al() { int hasWriteContactsPermission = checkSelfPermission(Manifest.permission.CALL_PHONE); if (hasWriteContactsPermission != PackageManager.PERMISSION_GRANTED) { if (!shouldShowRequestPermissionRationale(Manifest.permission.CALL_PHONE)) { showMessageOKCancel("Çağrı için izin vermeniz gerekir", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { requestPermissions(new String[] {Manifest.permission.CALL_PHONE}, ONAY_KODU); } }); return; } requestPermissions(new String[] {Manifest.permission.CALL_PHONE}, ONAY_KODU); return; } yapilacaklar(); } private void showMessageOKCancel(String message, DialogInterface.OnClickListener okListener) { new AlertDialog.Builder(Eeeeeee.this) .setMessage(message) .setPositiveButton("OK", okListener) .setNegativeButton("Cancel", null) .create() .show(); }
Birinci durumda açılan diyalog kutusunda neden izin istediğimizi açıklıyoruz.
İzine hayır derse pencere kapanıyor dolayısıyla “bir daha sorma” kutusunun işaretlenmesine engel olmuş oluyoruz. Uygulama tekrar açıldığında yine baştan alıyoruz. Bu yolla kullanıcının fikir değiştirmesinin önünü açmış oluyoruz. Diğer türlü “bir daha asla sorma” kutusunu işaretlerse kararından geri dönemeyeceği için ona bu yolla fikir değiştirme özgürlüğü vermiş oluyouruz.
İzine evet derse bu sefer 2.diyalog kutusunda izin talebinde bulunuyoruz..
İkinci durumda, herhangi bir izin verme diyalogu olmadan onRequestPermissionsResult
çağrılacaktır PERMISSION_DENIED
.
Buraya kadar olanlar kafa karıştırmaması için tek bir dosyada toplarsak;
package com.mobilprogramlar.ntzinal; import android.Manifest; import android.app.Activity; import android.app.AlertDialog; import android.content.DialogInterface; import android.content.pm.PackageManager; import android.os.Bundle; import android.widget.Toast; import androidx.annotation.NonNull; public class Eeeeeee extends Activity { final private int ONAY_KODU = 1234; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.eeeeee); izin_Kontrolet_Al(); } public void yapilacaklar() { Toast.makeText(getApplicationContext(), "yapilacaklar şunlar", Toast.LENGTH_LONG).show(); } private void izin_Kontrolet_Al() { int hasWriteContactsPermission = checkSelfPermission(Manifest.permission.CALL_PHONE); if (hasWriteContactsPermission != PackageManager.PERMISSION_GRANTED) { if (!shouldShowRequestPermissionRationale(Manifest.permission.CALL_PHONE)) { showMessageOKCancel("Çağrı için izin vermeniz gerekir", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { requestPermissions(new String[] {Manifest.permission.CALL_PHONE}, ONAY_KODU); } }); return; } requestPermissions(new String[] {Manifest.permission.CALL_PHONE}, ONAY_KODU); return; } yapilacaklar(); } private void showMessageOKCancel(String message, DialogInterface.OnClickListener okListener) { new AlertDialog.Builder(Eeeeeee.this) .setMessage(message) .setPositiveButton("OK", okListener) .setNegativeButton("Cancel", null) .create() .show(); } @Override public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, @NonNull int[] grantResults) { //public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { super.onRequestPermissionsResult(requestCode, permissions, grantResults); switch (requestCode) { case ONAY_KODU: { // CALL_PHONE izni verilip verilmediğini kontrol edin if (grantResults[0] == PackageManager.PERMISSION_GRANTED) { Toast.makeText(Eeeeeee.this, "CALL_PHONE izni VERİLDİ", Toast.LENGTH_SHORT).show(); yapilacaklar(); } else { Toast.makeText(Eeeeeee.this, "CALL_PHONE izni REDDEDİLDİ", Toast.LENGTH_SHORT).show(); } break; } default: super.onRequestPermissionsResult(requestCode, permissions, grantResults); } } }
Sonuç; önce isteyeceğimiz izin için bir pencere açarak sebebini anlatıyoruz. Tamam derse asıl izin penceresi çıkıyor ve izin talebinde bulunuyoruz.
Kullandığımız komutları özetlersek;
- ContextCompat.checkSelfPermission () izni olup olmadığını kontrol etmek için verilir.
- ActivityCompat.requestPermissions () izinleri istemek için. Birden fazla izin grubu ile birden fazla izin talep edilebilir.
- ActivityCompat.shouldShowRequestPermissionRationale () , neden izin almak istediğine dair mantıklı bir mesaj göstermeye karar verdi.
- onRequestPermissionsResult () , kullanıcının izin istemine verdiği yanıtı ele almak için.
Buraya kadar anlatılanların çalışır haldeki kodlarını buradan Github hesabından indirebilirsiniz.
Bir seferde birden fazla izin istemek
Kesinlikle birden fazla izin gerektiren bazı özellikler var. Bir kerede yukarıdaki gibi aynı yöntemle birden fazla izin talep edebilirsiniz. Her neyse, her bir izin için de ‘Bir daha asla sorma’ durumunu kontrol etmeyi unutmayın.
Android.Manifest i unutmayalım;
<uses-permission android:name="android.permission.READ_CONTACTS"/> <uses-permission android:name="android.permission.WRITE_CONTACTS"/> <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION"/>
İşte revize edilmiş kod.
final private int REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS = 124; private void insertDummyContactWrapper() { List<String> permissionsNeeded = new ArrayList<String>(); final List<String> permissionsList = new ArrayList<String>(); if (!addPermission(permissionsList, Manifest.permission.ACCESS_FINE_LOCATION)) permissionsNeeded.add("GPS"); if (!addPermission(permissionsList, Manifest.permission.READ_CONTACTS)) permissionsNeeded.add("Kişileri Oku"); if (!addPermission(permissionsList, Manifest.permission.WRITE_CONTACTS)) permissionsNeeded.add("Kişileri Yaz"); if (permissionsList.size() > 0) { if (permissionsNeeded.size() > 0) { // Need Rationale String message = "Erişim izni vermeniz gerekiyor " + permissionsNeeded.get(0); for (int i = 1; i < permissionsNeeded.size(); i++) message = message + ", " + permissionsNeeded.get(i); showMessageOKCancel(message, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { requestPermissions(permissionsList.toArray(new String[permissionsList.size()]), REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS); } }); return; } requestPermissions(permissionsList.toArray(new String[permissionsList.size()]), REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS); return; } insertDummyContact(); } private boolean addPermission(List<String> permissionsList, String permission) { if (checkSelfPermission(permission) != PackageManager.PERMISSION_GRANTED) { permissionsList.add(permission); // Gerekçe Seçeneğini Denetle if (!shouldShowRequestPermissionRationale(permission)) return false; } return true; }
Her bir izin verilen hibe sonucunu aldığında, sonuç aynı geri çağırma yöntemine gönderilir onRequestPermissionsResult
. Kaynak kodun daha temiz ve daha okunaklı görünmesi için HashMap kullanılabilir.
@Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { switch (requestCode) { case REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS: { Map<String, Integer> perms = new HashMap<String, Integer>(); // ilk perms.put(Manifest.permission.ACCESS_FINE_LOCATION, PackageManager.PERMISSION_GRANTED); perms.put(Manifest.permission.READ_CONTACTS, PackageManager.PERMISSION_GRANTED); perms.put(Manifest.permission.WRITE_CONTACTS, PackageManager.PERMISSION_GRANTED); // Sonuçları doldurun for (int i = 0; i < permissions.length; i++) perms.put(permissions[i], grantResults[i]); // ACCESS_FINE_LOCATION için kontrol et if (perms.get(Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED && perms.get(Manifest.permission.READ_CONTACTS) == PackageManager.PERMISSION_GRANTED && perms.get(Manifest.permission.WRITE_CONTACTS) == PackageManager.PERMISSION_GRANTED) { // Tüm İzin Verildi insertDummyContact(); } else { // İzin reddedildi Toast.makeText(MainActivity.this, "Bazı İzin Reddedildi", Toast.LENGTH_SHORT) .show(); } } break; default: super.onRequestPermissionsResult(requestCode, permissions, grantResults); } }
Kodların tamamın birarada;
package com.mobilprogramlar.uygulamazinleri2; import androidx.appcompat.app.AlertDialog; import androidx.appcompat.app.AppCompatActivity; import android.Manifest; import android.content.ContentProviderOperation; import android.content.ContentResolver; import android.content.DialogInterface; import android.content.OperationApplicationException; import android.content.pm.PackageManager; import android.os.Bundle; import android.os.RemoteException; import android.provider.ContactsContract; import android.util.Log; import android.widget.Toast; import java.util.ArrayList; import java.util.HashMap; import java.util.List; import java.util.Map; public class MainActivity extends AppCompatActivity { final private int REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS = 124; private static final String TAG = "İletişim"; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); insertDummyContactWrapper(); } private void insertDummyContact() { // Yeni bir temas kurmak için iki işlem gerekir. ArrayList<ContentProviderOperation> operations = new ArrayList<ContentProviderOperation>(2); // İlk önce, yeni bir raw kişisi kur. ContentProviderOperation.Builder op = ContentProviderOperation.newInsert(ContactsContract.RawContacts.CONTENT_URI) .withValue(ContactsContract.RawContacts.ACCOUNT_TYPE, null) .withValue(ContactsContract.RawContacts.ACCOUNT_NAME, null); operations.add(op.build()); // Ardından, kişinin adını ayarlayın. op = ContentProviderOperation.newInsert(ContactsContract.Data.CONTENT_URI) .withValueBackReference(ContactsContract.Data.RAW_CONTACT_ID, 0) .withValue(ContactsContract.Data.MIMETYPE, ContactsContract.CommonDataKinds.StructuredName.CONTENT_ITEM_TYPE) .withValue(ContactsContract.CommonDataKinds.StructuredName.DISPLAY_NAME, "__DUMMY CONTACT from runtime permissions sample"); operations.add(op.build()); // İşlemleri uygula. ContentResolver resolver = getContentResolver(); try { resolver.applyBatch(ContactsContract.AUTHORITY, operations); } catch (RemoteException e) { Log.d(TAG, "Yeni bir kişi eklenemedi: " + e.getMessage()); } catch (OperationApplicationException e) { Log.d(TAG, "Yeni bir kişi eklenemedi\n: " + e.getMessage()); } } private void insertDummyContactWrapper() { List<String> permissionsNeeded = new ArrayList<String>(); final List<String> permissionsList = new ArrayList<String>(); if (!addPermission(permissionsList, Manifest.permission.ACCESS_FINE_LOCATION)) permissionsNeeded.add("GPS"); if (!addPermission(permissionsList, Manifest.permission.READ_CONTACTS)) permissionsNeeded.add("Kişileri Oku"); if (!addPermission(permissionsList, Manifest.permission.WRITE_CONTACTS)) permissionsNeeded.add("Kişileri Yaz"); if (permissionsList.size() > 0) { if (permissionsNeeded.size() > 0) { // Need Rationale String message = "Erişim izni vermeniz gerekiyor " + permissionsNeeded.get(0); for (int i = 1; i < permissionsNeeded.size(); i++) message = message + ", " + permissionsNeeded.get(i); showMessageOKCancel(message, new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { requestPermissions(permissionsList.toArray(new String[permissionsList.size()]), REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS); } }); return; } requestPermissions(permissionsList.toArray(new String[permissionsList.size()]), REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS); return; } insertDummyContact(); } private boolean addPermission(List<String> permissionsList, String permission) { if (checkSelfPermission(permission) != PackageManager.PERMISSION_GRANTED) { permissionsList.add(permission); // Gerekçe Seçeneğini Denetle if (!shouldShowRequestPermissionRationale(permission)) return false; } return true; } @Override public void onRequestPermissionsResult(int requestCode, String[] permissions, int[] grantResults) { switch (requestCode) { case REQUEST_CODE_ASK_MULTIPLE_PERMISSIONS: { Map<String, Integer> perms = new HashMap<String, Integer>(); // ilk perms.put(Manifest.permission.ACCESS_FINE_LOCATION, PackageManager.PERMISSION_GRANTED); perms.put(Manifest.permission.READ_CONTACTS, PackageManager.PERMISSION_GRANTED); perms.put(Manifest.permission.WRITE_CONTACTS, PackageManager.PERMISSION_GRANTED); // Sonuçları doldurun for (int i = 0; i < permissions.length; i++) perms.put(permissions[i], grantResults[i]); // ACCESS_FINE_LOCATION için kontrol et if (perms.get(Manifest.permission.ACCESS_FINE_LOCATION) == PackageManager.PERMISSION_GRANTED && perms.get(Manifest.permission.READ_CONTACTS) == PackageManager.PERMISSION_GRANTED && perms.get(Manifest.permission.WRITE_CONTACTS) == PackageManager.PERMISSION_GRANTED) { // Tüm İzin Verildi insertDummyContact(); } else { // İzin reddedildi Toast.makeText(MainActivity.this, "Bazı İzinler Reddedildi\n", Toast.LENGTH_SHORT).show(); } } break; default: super.onRequestPermissionsResult(requestCode, permissions, grantResults); } } private void showMessageOKCancel(String message, DialogInterface.OnClickListener okListener) { new AlertDialog.Builder(MainActivity.this) .setMessage(message) .setPositiveButton("Evet", okListener) .setNegativeButton("Hayır", null) .create() .show(); } }
Sonuç;
Bu kısımda anlatılanların çalışır haldeki kodlarını buradan Github hesabından indirebilirsiniz.
Android 6.0 Marshmallow Öncesi
Yukarıdaki kod Android 6.0 Marshmallow’da mükemmel çalışıyor olmasına rağmen. Maalesef Android’in Marshmallow öncesi Android’inde çökmesine neden olacak, çünkü bu işlevler API Seviye 23’e eklenmiş.
Düz yol, Sürüm Sürümü’nü aşağıdaki kodla kontrol edebilmenizdir.
if (Build.VERSION.SDK_INT >= 23) { // Marshmallow+ } else { // Pre-Marshmallow }
Ancak kod daha da karmaşık olacak. Bu yüzden , bu şey için hazırlanmış olan Support Library v4’ten biraz yardım almanızı öneririm . Bu işlevleri şununla değiştirin:
if (ContextCompat.checkSelfPermission(thisActivity, Manifest.permission.CALL_PHONE) == PackageManager.PERMISSION_GRANTED){ //CALL_PHONE özelliği için kullanıcı zaten daha önceden yetki vermiştir. Bu yetki ile yapılmak istenen burada yapılır. } else { // İzin için kullanıcıya açıkça sorulmalıdır. }
İzinleri kontrol et
İzniniz olup olmadığını kontrol etmek için ContextCompat.checkSelfPermission()
yöntemi kullanın.
Örneğin, bu pasaj, etkinliğin takvime yazma izni olup olmadığını kontrol etmeyi gösterir:
if (ContextCompat.checkSelfPermission(thisActivity, Manifest.permission.WRITE_CALENDAR)!= PackageManager.PERMISSION_GRANTED) { // İzin verilmemiştir }else { // İzin verilmiştir }
Uygulama M üzerinde çalıştırılır veya çalıştırılmaz.
Bu metod kullanıcı izin verdiğinde PackageManager.PERMISSION_GRANTED dönerken,
izin vermediğinde ise PackageManager.PERMISSION_DENIED döner.
ActivityCompat.requestPermissions ()
ActivityCompat.requestPermissions ()
Bu fonksiyon M öncesi çağrılırsa, OnRequestPermissionsResultCallback, aniden doğru PERMISSION_GRANTED
veya PERMISSION_DENIED
sonuç ile çağrılır .
ActivityCompat.shouldShowRequestPermissionRationale ()
ActivityCompat.shouldShowRequestPermissionRationale ()
Bu fonksiyon Android MarshMallow öncesi çağrılırsa, her zaman false geri döner.
shouldShowRequestPermissionRationale()
Kullanıcıya daha önceden android standart dialog’u gösterilmiş ve kullanıcı izni onaylamamışsa true döner
HER ZAMAN Support Library v4 deki checkSelfPermission, requestPermissions ve shouldShowRequestPermissionRationale fonksiyonlarını kullanmaya çalışın.
Bu şekilde uygulamanız aynı kod mantığına sahip herhangi bir Android sürümünde mükemmel bir şekilde çalışacaktır. Lütfen bu fonksiyonların bazı ek parametreler gerektirdiğini unutmayın: Context ya da Activity gibi.. Yapacak özel bir şey yok, sadece istediğini doğru bir şekilde iletin. İşte kaynak kod:
private void insertDummyContactWrapper() { int hasWriteContactsPermission = ContextCompat.checkSelfPermission(MainActivity.this, Manifest.permission.WRITE_CONTACTS); if (hasWriteContactsPermission != PackageManager.PERMISSION_GRANTED) { if (!ActivityCompat.shouldShowRequestPermissionRationale(MainActivity.this, Manifest.permission.WRITE_CONTACTS)) { showMessageOKCancel("Rehber’e erişime izin vermeniz gerekir", new DialogInterface.OnClickListener() { @Override public void onClick(DialogInterface dialog, int which) { ActivityCompat.requestPermissions(MainActivity.this, new String[] {Manifest.permission.WRITE_CONTACTS}, REQUEST_CODE_ASK_PERMISSIONS); } }); return; } ActivityCompat.requestPermissions(MainActivity.this, new String[] {Manifest.permission.WRITE_CONTACTS}, REQUEST_CODE_ASK_PERMISSIONS); return; } insertDummyContact(); }
Şu anda bu yeni izin sisteminin büyük resmini net bir şekilde gördüğünüze inanıyorum. Ve bunun ne kadar büyük bir sorun olduğunu da anladığınıza inanıyorum.
Ancak başka seçeneğiniz yok. Çalışma Zamanı İzni zaten Android Marshmallow’da kullanılıyor. Geri dönüşü olmayan noktadayız. Şu anda yapabileceğimiz tek şey, uygulamamızı bu yeni izin sistemini tam olarak desteklemektir.
İyi haber şu ki, Çalışma Zamanı İzni akışı gerektiren yalnızca birkaç izin var. Sık kullanılan izinlerin çoğu, örneğin, İNTERNET, Normal İzin’dedir , otomatik olarak verilir ve onlarla hiçbir şey yapmanıza gerek kalmaz. Sonuç olarak, değiştirmeniz gereken kodun sadece bir kısmı vardır.
Yorum yazabilmek için oturum açmalısınız.