Android - Pengalih Gambar

Terkadang Anda tidak ingin gambar muncul secara tiba-tiba di layar, Anda ingin menerapkan beberapa jenis animasi ke gambar saat berpindah dari satu gambar ke gambar lainnya. Ini didukung oleh android dalam bentuk ImageSwitcher.

Pengalih gambar memungkinkan Anda menambahkan beberapa transisi pada gambar melalui tampilannya di layar. Untuk menggunakan Image Switcher, Anda perlu mendefinisikan komponen XML-nya terlebih dahulu. Sintaksnya diberikan di bawah ini -

<ImageSwitcher
   android:id="@+id/imageSwitcher1"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content"
   android:layout_centerHorizontal="true"
   android:layout_centerVertical="true" >
</ImageSwitcher>

Sekarang kita membuat intance dari ImageSwithcer dalam file java dan mendapatkan referensi dari komponen XML ini. Sintaksnya diberikan di bawah ini -

private ImageSwitcher imageSwitcher;
imageSwitcher = (ImageSwitcher)findViewById(R.id.imageSwitcher1);

Hal berikutnya yang perlu kita lakukan adalah mengimplementasikan antarmuka ViewFactory dan mengimplementasikan metode yang tidak diimplementasikan yang mengembalikan imageView. Sintaksnya di bawah -

imageSwitcher.setImageResource(R.drawable.ic_launcher);
imageSwitcher.setFactory(new ViewFactory() {
   public View makeView() {
      ImageView myView = new ImageView(getApplicationContext());
      return myView;
   }
}

Hal terakhir yang perlu Anda lakukan adalah menambahkan Animasi ke ImageSwitcher. Anda perlu mendefinisikan objek kelas Animation melalui kelas AnimationUtilities dengan memanggil metode loadAnimation statis. Sintaksnya diberikan di bawah ini -

Animation in = AnimationUtils.loadAnimation(this,android.R.anim.slide_in_left);
imageSwitcher.setInAnimation(in);
imageSwitcher.setOutAnimation(out);

Metode setInAnimaton menyetel animasi kemunculan objek di layar sedangkan setOutAnimation melakukan yang sebaliknya. Metode loadAnimation () membuat objek animasi.

Selain metode ini, ada metode lain yang ditentukan di kelas ImageSwitcher. Mereka didefinisikan di bawah -

Sr Tidak Metode & deskripsi
1

setImageDrawable(Drawable drawable)

Mengatur gambar dengan pengalih gambar. Gambar tersebut diteruskan dalam bentuk bitmap

2

setImageResource(int resid)

Mengatur gambar dengan pengalih gambar. Gambar dikirimkan dalam bentuk integer id

3

setImageURI(Uri uri)

Mengatur gambar dengan pengalih gambar. Gambar tersebut diteruskan dalam bentuk URI

4

ImageSwitcher(Context context, AttributeSet attrs)

Mengembalikan objek pengalih gambar dengan sudah menyetel beberapa atribut yang diteruskan dalam metode

5

onInitializeAccessibilityEvent (AccessibilityEvent event)

Menginisialisasi AccessibilityEvent dengan informasi tentang View ini yang merupakan sumber peristiwa

6

onInitializeAccessibilityNodeInfo (AccessibilityNodeInfo info)

Menginisialisasi AccessibilityNodeInfo dengan informasi tentang tampilan ini

Contoh

Contoh di bawah ini menunjukkan beberapa efek pengalih gambar pada bitmap. Ini berisi aplikasi dasar yang memungkinkan Anda untuk melihat efek animasi pada gambar.

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

Langkah Deskripsi
1 Anda akan menggunakan IDE studio Android untuk membuat aplikasi Android di bawah paket com.example.sairamkrishna.myapplication.
2 Ubah file src / MainActivity.java untuk menambahkan kode yang diperlukan.
3 Ubah res / layout / activity_main untuk menambahkan komponen XML masing-masing
4 Jalankan aplikasi dan pilih perangkat android yang sedang berjalan dan instal aplikasi di atasnya dan verifikasi hasilnya

Berikut adalah konten file aktivitas utama yang dimodifikasi src/MainActivity.java.

Pada kode di bawah ini tp dan abc menunjukkan logo tutorialspoint.com
package com.example.sairamkrishna.myapplication;

import android.app.Activity;
import android.app.ActionBar.LayoutParams;
import android.os.Bundle;
import android.view.View;

import android.widget.Button;
import android.widget.ImageSwitcher;
import android.widget.ImageView;
import android.widget.Toast;
import android.widget.ViewSwitcher.ViewFactory;

public class MainActivity extends Activity {
   private ImageSwitcher sw;
   private Button b1,b2;

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

      b1 = (Button) findViewById(R.id.button);
      b2 = (Button) findViewById(R.id.button2);

      sw = (ImageSwitcher) findViewById(R.id.imageSwitcher);
      sw.setFactory(new ViewFactory() {
         @Override
         public View makeView() {
            ImageView myView = new ImageView(getApplicationContext());
            myView.setScaleType(ImageView.ScaleType.FIT_CENTER);
            myView.setLayoutParams(new 
               ImageSwitcher.LayoutParams(LayoutParams.WRAP_CONTENT,
                  LayoutParams.WRAP_CONTENT));
            return myView;
         }
      });

      b1.setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
            Toast.makeText(getApplicationContext(), "previous Image",
               Toast.LENGTH_LONG).show();
            sw.setImageResource(R.drawable.abc);
         }
      });

      b2.setOnClickListener(new View.OnClickListener() {
         @Override
         public void onClick(View v) {
            Toast.makeText(getApplicationContext(), "Next Image",
               Toast.LENGTH_LONG).show();
            sw.setImageResource(R.drawable.tp);
         }
      });
   }
}

Berikut ini adalah konten xml yang dimodifikasi res/layout/activity_main.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: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">
      
   <TextView android:text="Gestures  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" />
      
   <ImageSwitcher
      android:layout_width="wrap_content"
      android:layout_height="wrap_content"
      android:id="@+id/imageSwitcher"
      android:layout_below="@+id/textView"
      android:layout_centerHorizontal="true"
      android:layout_marginTop="168dp" />
      
   <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/left"
        android:id="@+id/button"
        android:layout_below="@+id/textView"
        android:layout_centerHorizontal="true" />

   <Button
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:text="@string/right"
        android:id="@+id/button2"
        android:layout_alignParentBottom="true"
        android:layout_alignLeft="@+id/button"
        android:layout_alignStart="@+id/button" />
      
</RelativeLayout>

Berikut ini adalah konten dari Strings.xml mengajukan.

<resources>
    <string name="app_name">My Application</string>
    <string name="left"><![CDATA[<]]></string>
    <string name="right"><![CDATA[>]]></string>
</resources>

Berikut ini adalah konten dari AndroidManifest.xml mengajukan.

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
   package="com.example.sairamkrishna.myapplication"

   <application
      android:allowBackup="true"
      android:icon="@drawable/ic_launcher"
      android:label="@string/app_name"
      android:theme="@style/AppTheme" >
      
      <activity
         android:name="com.example.sairamkrishna.myapplication.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>
      
   </application>
</manifest>

Ayo coba jalankan aplikasi Anda yang baru saja kita modifikasi. 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 semuanya baik-baik saja dengan pengaturan dan aplikasi Anda, itu akan ditampilkan berikut jendela Emulator -

Sekarang jika Anda akan melihat layar perangkat Anda, Anda akan melihat dua tombol.

Sekarang pilih saja tombol panah kanan atas. Sebuah gambar akan muncul dari kanan dan bergerak ke kiri. Itu ditunjukkan di bawah ini -

Sekarang ketuk tombol di bawah, yang akan mengembalikan gambar sebelumnya dengan beberapa transisi. Itu ditunjukkan di bawah ini -