29 Eylül 2016 Perşembe

Android Dersleri -5-

Farklı Cihazlarda Destek

Android cihazlar bütün dünyada çok fazla şekil ve boyutları içermektedir.Başarılı Android uygulamaları geliştirmek için farklı cihaz ayarlarına adapte edilmesi gerekmektedir.Farklı diller, ekran boyutları ve versiyonları dikkate almanız gerekmektedir.

 

Farklı Diller Desteği

En iyi yöntem farklı diller için farklı dosyalarda tutumak
MyProject/
    res/
       values/
           strings.xml
       values-es/
           strings.xml
       values-fr/
           strings.xml
English (default locale), /values/strings.xml:
<?xml version="1.0" encoding="utf-8"?>

<resources>

    <string name="title">My Application</string>

    <string name="hello_world">Hello World!</string>

</resources>
Spanish, /values-es/strings.xml:
<?xml version="1.0" encoding="utf-8"?>

<resources>

    <string name="title">Mi Aplicación</string>

    <string name="hello_world">Hola Mundo!</string>

</resources>
French, /values-fr/strings.xml:
<?xml version="1.0" encoding="utf-8"?>

<resources>

    <string name="title">Mon Application</string>

    <string name="hello_world">Bonjour le monde !</string>

</resources>

Farklı Ekranlarda Destek

Android, aygıt ekranları  iki genel özelliklerini kullanarak sınıflandırır: büyüklüğü ve yoğunluğu
·         Dört genelleştirilmiş boyutları vardır : small, normal, large, xlarge
·         Ve dört genelleştirilmiş yoğunlukları: low (ldpi), medium (mdpi), high (hdpi), extra high (xhdpi)
Farklı layout ve farklı bitmap tanımlamak için ayrı dizinlerde bu alternatif kaynakların yerleştirmeniz gerekir.

Farklı Layouts Ekleme
Farklı ekran boyutları üzerinde kullanıcı deneyimini optimize etmek için, desteklemek istediğiniz her ekran boyutu için benzersiz bir düzen XML dosyası oluşturmanız gerekir.
MyProject/
    res/
        layout/
            main.xml
        layout-large/
            main.xml
Dosya adları aynı olmalıdır, ancak içerikleri ilgili ekran boyutu için optimize edilmiş bir kullanıcı arayüzü sağlamak için farklıdır.
@Override

 protected void onCreate(Bundle savedInstanceState) {

     super.onCreate(savedInstanceState);

     setContentView(R.layout.main);

}
Eğer büyük ekranlarda özel bir düzen sağlamak istiyorsanız, o zaman hem large ve hem de land qualifier kullanmanız gerekir.
MyProject/
    res/
        layout/              # default (portrait)
            main.xml
        layout-land/         # landscape
            main.xml
        layout-large/        # large (portrait)
            main.xml
        layout-large-land/   # large landscape
            main.xml
Farklı Bitmaps

her zaman düzgün genelleştirilmiş yoğunluk kovalar her ölçeklendirilir bitmap kaynakları sağlamalıdır: low, medium, high and extra-high density. 
Bu tüm ekran yoğunlukları iyi grafik kalitesi ve performansı elde etmesine yardımcı olur.
MyProject/
    res/
        drawable-xhdpi/
            awesomeimage.png
        drawable-hdpi/
            awesomeimage.png
        drawable-mdpi/
            awesomeimage.png
        drawable-ldpi/
            awesomeimage.png

Farklı Platform Versiyon Desteği      

Her zaman düzgün genelleştirilmiş yoğunluk kovalar her ölçeklendirilir bitmap kaynakları sağlamalıdır: low, medium, high and extra-high density. 
Android'in son sürümleri genellikle app için büyük API'leri sağlarken, daha fazla cihaz güncellenecektir kadar Android'in eski sürümlerini desteklemeye devam etmelidir. Bu ders aynı zamanda eski sürümlerini desteklemeye devam ederken son API'leri için nasıl yararlanacağını gösterir.

 

En düşük ve hedef API Seviyeleri belirtin

 AndroidManifest.xml dosyası uygulama ilgili ayrıntıları açıklar ve desteklediği Android hangi sürümleri tanımlar

<manifest xmlns:android="http://schemas.android.com/apk/res/android" ... >

    <uses-sdk android:minSdkVersion="4" android:targetSdkVersion="15" />

    ...

</manifest>

Runtime Sistem Versiyonu Kontrol Etmek

Android Derlemesi sabitleri sınıfta her platform sürümü için benzersiz bir kod sağlar. Bu API'ler sistemde mevcuttur sadece çalıştırılan yüksek API seviyelerine bağlıdır kod sağlamak koşulları oluşturmak için uygulaması içinde bu kodları kullanın.

private void setUpActionBar() {

    // Make sure we're running on Honeycomb or higher to use ActionBar APIs

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {

        ActionBar actionBar = getActionBar();

        actionBar.setDisplayHomeAsUpEnabled(true);

    }

}
Styles ve Temalar

dialog box:
<activity android:theme="@android:style/Theme.Dialog">
transparent background:
<activity android:theme="@android:style/Theme.Translucent">
Kendi tanımladığınız temalar için /res/values/styles.xml:
<activity android:theme="@style/CustomTheme">
Bütün programa uygulamak için
<application android:theme="@style/CustomTheme">


 

Android Dersleri -4-


Basit Kullanıcı Arayüzü Yapmak

Bu dersimizde XML dosyamıza bir tane text field ve buton ekleyeceğiz.

Android'te arayüzü View ve ViewGroup'ların hiyerarşileri ile inşa ederiz.View objeleri sıklıkla kullandığımız text fields ve butonlardır.ViewGroup'ları ise görünmeyen bileşenlerdir ki ona bağlı olan nesnleşeri nasıl bağlacağını ortaya koyar, grid ya da vertical list gibi.

Biz bu dersimizde Linear Layout üzerinde çalışacağız.

Bir Linear Layout oluşturmak

1.Project penceresinden app > res > layout > activity_main.xml.
Bu XML aktivitelerin düzenlerini tanımlar ve içinde "Hello World" yazan text view içerir.
2.Yazılı herşeyi silelim ve aşağıdaki kodu ekleyelim.
<?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:orientation="horizontal">
</LinearLayout>
LinearLayout bir view gruptur (Aynı zamanda View Group'un alt sınıfıdır) yatay ve dikey olarak ayarlanabilir.
Bileşenleri tanıyalım:
android:layout_width : Genişliği ayarlar android:layout_height : Yüksekliği ayarlar
match_parent kullanıldığında bağlı bulunduğu view'e göre kendisini otomatik olarak ayarlar
"match_parent" kullanıldığında bağlı bulunduğu view'e göre kendisini otomatik olarak ayarlar

Text Field Eklemek


<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:orientation="horizontal">
    <EditText android:id="@+id/edit_message"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:hint="@string/edit_message" />
</LinearLayout>


Bileşenleri Tanıyalım:

android:id : View için tekil bir Id sağlar.Kod tarafında bu Id kullanarak bileşende okuma ya da düzenleme yapabiliriz.@ işareti ise herhangi bir objeyi XML dosyasından okumak istediğimizde kullanırız.edit_message olduğu gibi. (+) işareti ise ID ilk defa tanımladığımızda gerekmektedir.Proje compile olduğunda ID R.java dosyasına oluşturulur ve EditText elementini temsil eder.

android:layout_width :
 android:layout_height:
"wrap_content" değer görünümün içeriğini uydurmaya ihtiyaç duyduğu gibi görünüm yalnızca kadar büyük olması gerektiğini belirtir."match_parent" bunu yukarıda açıklamıştık.

android:hint: Bu metin alanı boş olduğunda görüntülemek için varsayılan bir dizedir."@string/edit_message"  değer ayrı bir dosyada tanımlanan bir dize kaynağı anlamına gelir

String Resources Ekleme

  1. Project penceresinden, res > values > strings.xml. açalım.
  2. Aşağıdaki gibi Ekleyelim

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="app_name">My First App</string>
    <string name="edit_message">Enter a message</string>
    <string name="button_send">Send</string>
</resources>

 Button Ekleme

<LinearLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:orientation="horizontal"
    android:layout_width="match_parent"
    android:layout_height="match_parent">
        <EditText android:id="@+id/edit_message"
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:hint="@string/edit_message" />
        <Button
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:text="@string/button_send" />
</LinearLayout>

Çalıştıralım.
EditText'i Ekran'a sığdırmak için  activity_main.xml dosyasındaki alanı


<EditText android:id="@+id/edit_message"
    android:layout_weight="1"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:hint="@string/edit_message" />
şeklinde değiştiriyoruz.Çalıştıralım sonrasında;

Send Button'a Bir Event Ekleyelim

<Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="@string/button_send"
      android:onClick="sendMessage" />
nde Buton'a tıklandığında sendMessage() metodu çalışacak.
 java > com.example.myfirstapp > MainActivity.java
açalım ve aşağıdaki gibi ekleyelim.

package com.example.mypc.myfirstapp;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

public class MainActivity extends AppCompatActivity {
    public final static String EXTRA_MESSAGE = "com.example.myfirstapp.MESSAGE";
    @Override    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    /** Called when the user clicks the Send button */    public void sendMessage(View view) {
        Intent intent = new Intent(this, DisplayMessageActivity.class);
        EditText editText = (EditText) findViewById(R.id.edit_message);
        String message = editText.getText().toString();
        intent.putExtra(EXTRA_MESSAGE, message);
        startActivity(intent);
    }
}

Intent objesi çalışan iki ayrı bileşeni ayrı bileşenler arasındaki bağlanmayı sağlayan bir nesnedir

İkinci Activity Oluşturma

  1.  Project penceresinden ,  app seçip  New > Activity > Empty Activity.
  2.  Configure Activity penceresinden "DisplayMessageActivity" Activity Name girip Finish tıklayın

 DisplayMessageActivity.java aşağıdaki şekilde olması gerekmektedir.

package com.example.mypc.myfirstapp;

import android.content.Intent;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.EditText;

public class MainActivity extends AppCompatActivity {
    public final static String EXTRA_MESSAGE = "com.example.myfirstapp.MESSAGE";
    @Override    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
    }

    /** Called when the user clicks the Send button */    public void sendMessage(View view) {
        Intent intent = new Intent(this, DisplayMessageActivity.class);
        EditText editText = (EditText) findViewById(R.id.edit_message);
        String message = editText.getText().toString();
        intent.putExtra(EXTRA_MESSAGE, message);
        startActivity(intent);
    }
}

Nesneleri açıklayalım:
 putExtra() metodu EditText' değerini diğer intent'e taşır.EXTRA_MESSAGE public bir değişen olduğundan farklı intentlerde anahtar olarak kullanılır.
startActivity() metodu DisplayMessageActivity  sınıfını bir örneğini başlatır.
getIntent() metodu faaliyete başlamış Intent yakalar. Her Activity bir Intent taradından çağırır. 
getStringExtra() ilk faaliyetten gelen verileri alır.
Şimdi Çalıştıralım.
Evet istediğimiz şekilde çalıştı.Bir diğer derste görüşmek dileğiyle...