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 사용자가 이미지를 클릭하면 선택한 이미지의 위치를 ​​반환하는 이벤트입니다.

이제 애플리케이션을 빌드하고 실행하여 출력을 확인합니다.