Xamarin-ギャラリー
ギャラリーは、水平方向のスクロール可能なリストにアイテムを表示するために使用されるビューの一種です。選択したアイテムが中央に表示されます。この例では、水平方向にスクロール可能な画像を含むギャラリーを作成します。画像をクリックすると、選択した画像の番号が表示されます。
まず、新しいプロジェクトを作成し、Gallery AppTutorialなどの名前を付けます。コーディングを開始する前に、7つの画像をに貼り付けますresource /drawable folder。案内するmain.axml 下 resources folder 線形レイアウトタグの間にギャラリーがあります。
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#d3d3d3">
<Gallery
android:id="@+id/gallery"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:padding="10dp" />
</LinearLayout>
と呼ばれる新しいクラスを作成します ImageAdapter。このクラスは、上記で作成したギャラリーに画像をバインドするために使用されます。
最初のステップは、コンテキストを含むクラスを追加することです cont フィールドを格納するために使用します。
public class ImageAdapter : BaseAdapter {
Context cont;
public ImageAdapter(Context ct) {
cont = ct;
}
}
次に、画像を含む配列リストをカウントし、そのサイズを返します。
public override int Count {
get {
return imageArraylist.Length;
}
}
次のステップでは、アイテムの位置を取得します。次のコードは、その方法を示しています。
public override Java.Lang.Object GetItem(int position) {
return null;
}
public override long GetItemId(int position) {
return 0;
}
次のステップでは、 imageview アダプターによって参照されるアイテムの場合。
public override View GetView(int position,View convertView, ViewGroup parent) {
ImageView img = new ImageView(cont);
img.SetImageResource(imageArraylist[position]);
img.SetScaleType(ImageView.ScaleType.FitXy);
img.LayoutParameters = new Gallery.LayoutParams(200, 100);
return img;
}
最後のステップでは、で追加した画像への参照を作成します resources.drawableフォルダ。これを行うには、画像のコレクションを保持する配列を作成します。次のコードはそれを行う方法を説明しています。
int[] imageArraylist = {
Resource.Drawable.img1,
Resource.Drawable.img2,
Resource.Drawable.img3,
Resource.Drawable.img4,
Resource.Drawable.img5,
Resource.Drawable.img6,
};
}
次に、 mainActivity.cs OnCreate()メソッドの下に次のコードを挿入します。
Gallery myGallery = (Gallery)FindViewById<Gallery>(Resource.Id.gallery);
myGallery.Adapter = new ImageAdapter(this);
myGallery.ItemClick += delegate(object sender, AdapterView.ItemClickEventArgs args) {
Toast.MakeText(this,
args.Position.ToString(), ToastLength.Short).Show();
}
最後に、アプリケーションをビルドして実行し、出力を表示します。