Android - Navigasi

Dalam bab ini, kita akan melihat bagaimana Anda dapat menyediakan navigasi maju dan mundur antar aplikasi. Pertama-tama kita akan melihat bagaimana menyediakan navigasi dalam aplikasi.

Menyediakan Navigasi Atas

Navigasi atas akan memungkinkan aplikasi kita berpindah ke aktivitas sebelumnya dari aktivitas berikutnya. Itu bisa dilakukan seperti ini.

Untuk mengimplementasikan navigasi Naik, langkah pertama adalah mendeklarasikan aktivitas mana yang merupakan induk yang sesuai untuk setiap aktivitas. Anda dapat melakukannya dengan menentukanparentActivityNameatribut dalam suatu aktivitas. Sintaksnya diberikan di bawah ini -

android:parentActivityName = "com.example.test.MainActivity"

Setelah itu Anda perlu menelepon setDisplayHomeAsUpEnabled metode dari getActionBar()dalam metode aktivitas onCreate. Ini akan mengaktifkan tombol kembali di bilah tindakan atas.

getActionBar().setDisplayHomeAsUpEnabled(true);

Hal terakhir yang perlu Anda lakukan adalah mengganti onOptionsItemSelectedmetode. saat pengguna menekannya, aktivitas Anda menerima panggilan ke onOptionsItemSelected (). ID untuk tindakan tersebut adalahandroid.R.id.homeSintaksnya diberikan di bawah ini -

public boolean onOptionsItemSelected(MenuItem item) {
   
   switch (item.getItemId()) {
      case android.R.id.home:
      NavUtils.navigateUpFromSameTask(this);
      return true;
   }	
}

Menangani tombol kembali perangkat

Karena Anda telah mengaktifkan tombol kembali untuk menavigasi dalam aplikasi Anda, Anda mungkin ingin meletakkan fungsi tutup aplikasi di tombol kembali perangkat.

Itu bisa dilakukan dengan mengganti onBackPressed dan kemudian menelepon moveTaskToBack dan finishmetode. Sintaksnya diberikan di bawah ini -

@Override
public void onBackPressed() {
   moveTaskToBack(true); 
   MainActivity2.this.finish();
}

Terlepas dari metode setDisplayHomeAsUpEnabled ini, ada metode lain yang tersedia di kelas API ActionBar. Mereka tercantum di bawah ini -

Sr Tidak Metode & deskripsi
1

addTab(ActionBar.Tab tab, boolean setSelected)

Metode ini menambahkan tab untuk digunakan dalam mode navigasi tab

2

getSelectedTab()

Metode ini mengembalikan tab yang saat ini dipilih jika dalam mode navigasi tab dan setidaknya ada satu tab

3

hide()

Metode ini menyembunyikan ActionBar jika sedang ditampilkan

4

removeAllTabs()

Metode ini menghapus semua tab dari bilah tindakan dan batal memilih tab saat ini

5

selectTab(ActionBar.Tab tab)

Metode ini pilih tab yang ditentukan

Contoh

Contoh di bawah ini menunjukkan penggunaan Navigasi. Ini berisi aplikasi dasar yang memungkinkan Anda untuk menavigasi dalam aplikasi Anda.

Untuk bereksperimen dengan contoh ini, Anda perlu menjalankannya di perangkat sebenarnya atau di emulator.

Langkah Deskripsi
1 Anda akan menggunakan studio Android untuk membuat aplikasi Android di bawah paket com.example.sairamkrishna.myapplication.
2 Ubah file src / MainActivity.java untuk menambahkan kode Aktivitas.
3 Buat aktivitas baru dengan nama second_main.java dan edit untuk menambahkan kode aktivitas.
4 Ubah layout file XML res / layout / activity_main.xml tambahkan komponen GUI apa pun jika diperlukan.
5 Ubah layout file XML res / layout / second.xml tambahkan komponen GUI jika diperlukan.
6 Ubah AndroidManifest.xml untuk menambahkan kode yang diperlukan.
7 Jalankan aplikasi dan pilih perangkat android yang sedang berjalan dan instal aplikasi di atasnya dan verifikasi hasilnya.

Berikut adalah konten dari src/MainActivity.java.

package com.example.sairamkrishna.myapplication;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;

public class MainActivity extends Activity  {
   Button b1;

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main);

      b1 = (Button) findViewById(R.id.button);
      b1.setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
            Intent in=new Intent(MainActivity.this,second_main.class);
            startActivity(in);
         }
      });
   }
}

Berikut adalah konten dari src/second_main.java.

package com.example.sairamkrishna.myapplication;

import android.app.Activity;
import android.os.Bundle;
import android.webkit.WebView;
import android.webkit.WebViewClient;

/**
   * Created by Sairamkrishna on 4/6/2015.
*/

public class second_main extends Activity {
   WebView wv;

   @Override
   protected void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      setContentView(R.layout.activity_main_activity2);

      wv = (WebView) findViewById(R.id.webView);
      wv.setWebViewClient(new MyBrowser());
      wv.getSettings().setLoadsImagesAutomatically(true);
      wv.getSettings().setJavaScriptEnabled(true);
      wv.loadUrl("http://www.tutorialspoint.com");
   }

   private class MyBrowser extends WebViewClient {
      @Override
      public boolean shouldOverrideUrlLoading(WebView view, String url) {
         view.loadUrl(url);
         return true;
      }
   }
}

Berikut adalah konten dari activity_main.xml.

Pada kode di bawah ini abcmenunjukkan logo tutorialspoint.com
<?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:layout_width="match_parent"
   android:layout_height="match_parent" android:paddingLeft="@dimen/activity_horizontal_margin"
   android:paddingRight="@dimen/activity_horizontal_margin"
   android:paddingTop="@dimen/activity_vertical_margin"
   android:paddingBottom="@dimen/activity_vertical_margin"
   tools:context=".MainActivity"
   android:transitionGroup="true">
   
   <TextView android:text="Navigation example" android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/textview"
      android:textSize="35dp"
      android:layout_alignParentTop="true"
      android:layout_centerHorizontal="true" />
      
   <TextView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="Tutorials point"
      android:id="@+id/textView"
      android:layout_below="@+id/textview"
      android:layout_centerHorizontal="true"
      android:textColor="#ff7aff24"
      android:textSize="35dp" />
      
   <ImageView
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/imageView"
      android:src="@drawable/abc"
      android:layout_below="@+id/textView"
      android:layout_centerHorizontal="true"
      android:theme="@style/Base.TextAppearance.AppCompat" />
      
   <Button
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:text="first page"
      android:id="@+id/button"
      android:layout_below="@+id/imageView"
      android:layout_alignRight="@+id/textView"
      android:layout_alignEnd="@+id/textView"
      android:layout_marginTop="61dp"
      android:layout_alignLeft="@+id/imageView"
      android:layout_alignStart="@+id/imageView" />

</RelativeLayout>

Berikut adalah konten dari activity_main_activity2.xml.

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
   android:orientation="vertical" android:layout_width="match_parent"
   android:layout_height="match_parent"
   android:weightSum="1">
   
   <WebView
      android:layout_width="match_parent"
      android:layout_height="wrap_content"
      android:id="@+id/webView"
      android:layout_gravity="center_horizontal"
      android:layout_weight="1.03" />

</LinearLayout>

Berikut adalah konten dari Strings.xml.

<resources>
   <string name="app_name">My Application</string>
</resources>

Berikut adalah konten dari AndroidManifest.xml.

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.sairamkrishna.myapplication" >
   <uses-permission android:name="android.permission.INTERNET"></uses-permission>
   
   <application
      android:allowBackup="true"
      android:icon="@mipmap/ic_launcher"
      android:label="@string/app_name"
      android:theme="@style/AppTheme" >
      
      <activity
         android:name=".MainActivity"
         android:label="@string/app_name" >
         
         <intent-filter>
            <action android:name="android.intent.action.MAIN" />
            <category android:name="android.intent.category.LAUNCHER" />
         </intent-filter>
         
      </activity>
		
      <activity android:name=".second_main"></activity>
      
   </application>
</manifest>

Mari coba jalankan aplikasi Anda. Saya berasumsi bahwa Anda telah membuat fileAVDsaat melakukan pengaturan lingkungan. Untuk menjalankan aplikasi dari Android studio, buka salah satu file aktivitas proyek Anda dan klik

ikon Run dari toolbar. Android studio menginstal aplikasi pada AVD Anda dan memulainya dan jika semua baik-baik saja dengan pengaturan dan aplikasi Anda, itu akan ditampilkan mengikuti jendela Emulator−

Sekarang cukup tekan tombol dan layar berikut akan ditampilkan kepada Anda.

Aktivitas kedua berisi tampilan web, dialihkan ke tutorialspoint.com seperti yang ditunjukkan di bawah ini