我试图在GridView
内获取单个项目,以便在手指移动时更改图像。我有两张图片no_touch
和touch
。我想要的是,当活动开始时,GridView中的所有项目都被设置为no_touch,当手指触摸任何一个或多个项目时,这些项目将更改为touch
图像。
到目前为止我所能得到的是当其中一个项目点击时,它会改变整个 GridView的背景(并出现一个小的吐司)。我希望能够"滑行"沿着每个项目,只有那些改变图像。
到目前为止我的代码:
MainActivity.java :
public class MainActivty extends Activity {
drawingView dview;
GridView grid;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_activity1);
final GridView gridview = (GridView) findViewById(R.id.gridview);
gridview.setAdapter(new ImageAdapter(this));
gridview.setVisibility(GridView.VISIBLE);
gridview.setOnItemClickListener(new OnItemClickListener() {
public void onItemClick(AdapterView<?> parent, View v,
int position, long id) {
gridview.setBackgroundColor(Color.RED);
Toast.makeText(Activity1.this, "Position " + position,
Toast.LENGTH_SHORT).show();
}
});
}
}
ImageAdapter.java 的
public class ImageAdapter extends BaseAdapter {
private Context mContext;
public ImageAdapter(Context c) {
mContext = c;
}
public int getCount() {
return mThumbIds.length;
}
public Object getItem(int position) {
return null;
}
public long getItemId(int position) {
return 0;
}
public View getView(int position, View convertView, ViewGroup parent) {
ImageView imageView;
if (convertView == null) {
imageView = new ImageView(mContext);
imageView.setScaleType(ImageView.ScaleType.CENTER_CROP);
} else {
imageView = (ImageView) convertView;
}
imageView.setImageResource(mThumbIds[position]);
return imageView;
}
public Integer[] mThumbIds = {R.drawable.images ....};
}
如果有人知道如何,即使只是为了获得单个项目更改图像onClick,它将是辉煌的。
提前致谢,
答案 0 :(得分:0)
您已在网格上设置了点击侦听器。要执行您期望的操作(单击itens),您应该在此GridView上的每个ImageView上设置侦听器。
示例:
imageView.setOnClickListener(new OnClickListener() {...});
如果你知道你拥有的大小和图像,更好的方法是通过XML布局和drawables使用itens状态为“press”和默认值。
<selector
xmlns:android="http://schemas.android.com/apk/res/android">
<item android:state_pressed="true" android:drawable="@drawable/thedrawable_whenpressed">
</item>
<item android:drawable="@drawable/the_default_drawable">
</item>
</selector>