Android - select 列表或网格的可能性
Android - possibility to select List or Grid
正如我在标题中所写的那样,我想研究一下您可以选择ListView或GridView的方式。
我用谷歌搜索,但我没有找到足够的东西。
在我的例子中,我有一个 ListView 的自定义适配器,如果我还想实现一个 GridView,你怎么做?
我很感激任何资源,如果你知道教程的话!谢谢:)
要在没有大量重复逻辑的情况下实现这些不同的视图,您应该考虑使用 RecyclerView 并动态更改它的 LayoutManager 到什么你的用户想要。
我对 GridView 和 ListView 使用了相同的自定义适配器。
自定义适配器:
package com.example.nadiaakter.gridviewexample;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
public class CustomAdapter extends BaseAdapter {
ImageView imageView;
Context mContext;
public CustomAdapter(Context mContext){
this.mContext = mContext;
}
@Override
public int getCount() {
return images.length;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null){
imageView = new ImageView(mContext);
imageView.setLayoutParams(new GridView.LayoutParams(85, 85));
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
imageView.setPadding(8,8,8,8);
}else {
imageView = (ImageView) convertView;
}
imageView.setImageResource(images[position]);
return imageView;
}
Integer[] images = {
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7,
R.drawable.sample_0, R.drawable.sample_1,
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7,
R.drawable.sample_0, R.drawable.sample_1,
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7
};
}
activity_main.xml
android:id="@+id/gvImage"
android:columnWidth="90dp"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:numColumns="auto_fit"
android:fadingEdge="horizontal"
android:padding="10dp"
/>
MainActivity.java
package com.example.nadiaakter.gridviewexample;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.widget.GridView;
public class MainActivity extends ActionBarActivity {
GridView gridView;
CustomAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
gridView = (GridView) findViewById(R.id.gvImage);
adapter = new CustomAdapter(this);
gridView.setAdapter(adapter);
}
}
注意:是GridView的例子。 ListView 示例(同 CustomAdapter )如下:
xml
<ListView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/lvImage"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fadingEdge="horizontal"
android:padding="10dp"
/>
再次MainActivity.java
package com.example.nadiaakter.gridviewexample;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.widget.ListView;
public class MainActivity extends ActionBarActivity {
ListView listView;
CustomAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = (ListView) findViewById(R.id.lvImage);
adapter = new CustomAdapter(this);
listView.setAdapter(adapter);
}
}
正如我在标题中所写的那样,我想研究一下您可以选择ListView或GridView的方式。 我用谷歌搜索,但我没有找到足够的东西。
在我的例子中,我有一个 ListView 的自定义适配器,如果我还想实现一个 GridView,你怎么做?
我很感激任何资源,如果你知道教程的话!谢谢:)
要在没有大量重复逻辑的情况下实现这些不同的视图,您应该考虑使用 RecyclerView 并动态更改它的 LayoutManager 到什么你的用户想要。
我对 GridView 和 ListView 使用了相同的自定义适配器。 自定义适配器:
package com.example.nadiaakter.gridviewexample;
import android.content.Context;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.ImageView;
public class CustomAdapter extends BaseAdapter {
ImageView imageView;
Context mContext;
public CustomAdapter(Context mContext){
this.mContext = mContext;
}
@Override
public int getCount() {
return images.length;
}
@Override
public Object getItem(int position) {
return null;
}
@Override
public long getItemId(int position) {
return 0;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
if (convertView == null){
imageView = new ImageView(mContext);
imageView.setLayoutParams(new GridView.LayoutParams(85, 85));
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
imageView.setPadding(8,8,8,8);
}else {
imageView = (ImageView) convertView;
}
imageView.setImageResource(images[position]);
return imageView;
}
Integer[] images = {
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7,
R.drawable.sample_0, R.drawable.sample_1,
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7,
R.drawable.sample_0, R.drawable.sample_1,
R.drawable.sample_2, R.drawable.sample_3,
R.drawable.sample_4, R.drawable.sample_5,
R.drawable.sample_6, R.drawable.sample_7
};
}
activity_main.xml
android:id="@+id/gvImage"
android:columnWidth="90dp"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:numColumns="auto_fit"
android:fadingEdge="horizontal"
android:padding="10dp"
/>
MainActivity.java
package com.example.nadiaakter.gridviewexample;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.widget.GridView;
public class MainActivity extends ActionBarActivity {
GridView gridView;
CustomAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
gridView = (GridView) findViewById(R.id.gvImage);
adapter = new CustomAdapter(this);
gridView.setAdapter(adapter);
}
}
注意:是GridView的例子。 ListView 示例(同 CustomAdapter )如下:
xml
<ListView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/lvImage"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:fadingEdge="horizontal"
android:padding="10dp"
/>
再次MainActivity.java
package com.example.nadiaakter.gridviewexample;
import android.support.v7.app.ActionBarActivity;
import android.os.Bundle;
import android.widget.ListView;
public class MainActivity extends ActionBarActivity {
ListView listView;
CustomAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
listView = (ListView) findViewById(R.id.lvImage);
adapter = new CustomAdapter(this);
listView.setAdapter(adapter);
}
}