Xamarin-Andriod보기
ListViews
Listview는 스크롤 가능한 항목 목록을 표시하는 사용자 인터페이스 요소입니다.
목록보기에 데이터 바인딩
이 예제에서는 요일을 표시하는 listView를 만들 것입니다. 먼저 새 XML 파일을 만들고 이름을 지정하겠습니다.listViewTemplate.xml.
에 listViewTemplate.xml, 우리는 아래와 같이 새로운 textview를 추가합니다.
<?xml version = "1.0" encoding = "utf-8" ?>
<TextView xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@+id/textItem"
android:textSize ="20sp"
android:layout_width = "fill_parent"
android:layout_height = "wrap_content"/>
다음으로 이동 Main.axml 선형 레이아웃 내부에 새 목록보기를 만듭니다.
<ListView
android:minWidth="25px"
android:minHeight="25px"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/listView1" />
열다 MainActivity.cs다음 코드를 입력하여 데이터를 우리가 만든 목록보기에 바인딩합니다. 코드는OnCreate() 방법.
SetContentView(Resource.Layout.Main);
var listView = FindViewById<ListView>(Resource.Id.listView1);
var data = new string[] {
"Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday"
};
listView.Adapter = new ArrayAdapter(this, Resource.Layout.ListViewTemplate, data);
Var data = new string[] 단순히 항목을 배열로 보유합니다.
Array Adapter는 컬렉션의 항목을 뷰로 반환합니다. 기본적으로 어레이 어댑터는 기본 textView를 사용하여 각 항목을 표시합니다. 위의 코드에서 우리는ListViewTemplate.xml 아래에 표시된 생성자를 사용하여 참조했습니다.
ArrayAdapter(this, Resource.Layout.ListViewTemplate, data);
마지막으로 애플리케이션을 빌드하고 실행하여 출력을 확인합니다.
GridView
gridView는 애플리케이션이 스크롤 가능한 그리드의 2 차원 방식으로 콘텐츠를 레이아웃 할 수 있도록하는보기 그룹입니다.
GridView를 추가하려면 새 프로젝트를 만들고 호출합니다. gridViewApp. 이동Main.axml 아래와 같이 그리드를 추가합니다.
<?xml version = "1.0" encoding="utf-8"?>
<GridView xmlns:android = "http://schemas.android.com/apk/res/android"
android:id = "@+id/gridview"
android:layout_width = "fill_parent"
android:layout_height = "fill_parent"
android:columnWidth = "90dp"
android:numColumns = "auto_fit"
android:verticalSpacing = "10dp"
android:horizontalSpacing = "10dp"
android:stretchMode = "columnWidth"
android:gravity = "center" />
다음으로 새 클래스를 만들고 이름을 지정합니다. ImageAdpter.cs. 이 클래스는 그리드에 표시 될 모든 항목에 대한 어댑터 클래스를 포함합니다.
내부 ImageAdapter, 다음 코드를 추가하십시오-
public class ImageAdapter : BaseAdapter {
Context context;
public ImageAdapter(Context ch) {
context = ch;
}
public override int Count {
get {
return cars.Length;
}
}
public override long GetItemId(int position) {
return 0;
}
public override Java.Lang.Object GetItem(int position) {
return null;
}
public override View GetView(int position,
View convertView, ViewGroup parent) {
ImageView imageView;
if (convertView == null) {
imageView = new ImageView(context);
imageView.LayoutParameters = new GridView.LayoutParams(100, 100);
imageView.SetScaleType(ImageView.ScaleType.CenterCrop);
imageView.SetPadding(8, 8, 8, 8);
} else {
imageView = (ImageView)convertView;
}
imageView.SetImageResource(cars[position]);
return imageView;
}
int[] cars = {
Resource.Drawable.img1, Resource.Drawable.img2,
Resource.Drawable.img3, Resource.Drawable.img4,
Resource.Drawable.img5, Resource.Drawable.img6,
};
}
위의 코드에서 우리는 단순히 자동차 이미지를 이미지 어댑터에 바인딩했습니다. 다음으로MainActivity.cs 다음에 다음 코드를 추가하십시오. setContentView().
var gridview = FindViewById<GridView>(Resource.Id.gridview);
gridview.Adapter = new ImageAdapter(this);
gridview.ItemClick += delegate(object sender,
AdapterView.ItemClickEventArgs args) {
Toast.MakeText(this,
args.Position.ToString(), ToastLength.Short).Show();
};
위의 코드는 다음에서 gridView를 찾습니다. main.axml 그리고 그것을 imageAdapter 수업. Gridview.ItemClick 생성 onClick 사용자가 이미지를 클릭하면 선택한 이미지의 위치를 반환하는 이벤트입니다.
이제 애플리케이션을 빌드하고 실행하여 출력을 확인합니다.