我为gridView中的每个项目构建了一个带有onClick侦听器的gridView。我的问题是gridView中每个项目的位置没有正确计算。
例如 - 如果我向gridView添加3个项目 - 所有3个项目的位置值为3.如果我向gridView添加4个项目 - 每个项目的位置值为4.
我已经尝试过对此进行调试,以确切了解导致这种情况的原因 - 但我似乎无法确定问题的确切来源。
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
ImageCell i = (ImageCell) v;
trace("onItemClick in view: " + i.mCellNumber);
Intent intent = null;
switch (position) {
case 1:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser1.class);
break;
case 2:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser2.class);
break;
case 3:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser3.class);
break;
case 4:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser4.class);
break;
case 5:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser5.class);
break;
case 6:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser6.class);
break;
case 7:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser7.class);
break;
}
if (intent != null) {
startActivity(intent);
}
}
/**
* This activity presents a screen with a grid on which images can be added and
* moved around. It also defines areas on the screen where the dragged views can
* be dropped. Feedback is provided to the user as the objects are dragged over
* these drop zones.
*
* <p>
* Like the DragActivity in the previous version of the DragView example
* application, the code here is derived from the Android Launcher code.
*
* <p>
* The original Launcher code required a long click (press) to initiate a
* drag-drop sequence. If you want to see that behavior, set the variable
* mLongClickStartsDrag to true. It is set to false below, which means that any
* touch event starts a drag-drop.
*
* @param <Intent>
*
*/
public class DragActivity extends Activity implements View.OnLongClickListener,
View.OnClickListener, View.OnTouchListener {
/**
*/
// Constants
private static final int HIDE_TRASHCAN_MENU_ID = Menu.FIRST;
private static final int SHOW_TRASHCAN_MENU_ID = Menu.FIRST + 1;
private static final int ADD_OBJECT_MENU_ID = Menu.FIRST + 2;
private static final int CHANGE_TOUCH_MODE_MENU_ID = Menu.FIRST + 3;
private boolean isErase = true;
private EditText et;
private TextView tx;
/**
*/
// Variables
private DragController mDragController; // Object that handles a drag-drop
// sequence. It intersacts with
// DragSource and DropTarget
// objects.
private DragLayer mDragLayer; // The ViewGroup within which an object can be
// dragged.
private DeleteZone mDeleteZone; // A drop target that is used to remove
// objects from the screen.
private int mImageCount = 0; // The number of images that have been added to
// screen.
private ImageCell mLastNewCell = null; // The last ImageCell added to the
// screen when Add Image is clicked.
private boolean mLongClickStartsDrag = true; // If true, it takes a long
// click to start the drag
// operation.
// Otherwise, any touch
// event starts a drag.
public static final boolean Debugging = false; // Use this to see extra
// toast messages.
/**
*/
// Methods
/**
* Add a new image so the user can move it around. It shows up in the
* image_source_frame part of the screen.
*
* @param resourceId
* int - the resource id of the image to be added
*/
public void addNewImageToScreen(int resourceId) {
if (mLastNewCell != null)
mLastNewCell.setVisibility(View.GONE);
FrameLayout imageHolder = (FrameLayout) findViewById(R.id.image_source_frame);
if (imageHolder != null) {
FrameLayout.LayoutParams lp = new FrameLayout.LayoutParams(
LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT,
Gravity.CENTER);
ImageCell newView = new ImageCell(this);
newView.setImageResource(resourceId);
imageHolder.addView(newView, lp);
newView.mEmpty = false;
newView.mCellNumber = -1;
mLastNewCell = newView;
mImageCount++;
// Have this activity listen to touch and click events for the view.
newView.setOnClickListener(this);
newView.setOnLongClickListener(this);
newView.setOnTouchListener(this);
}
}
/**
* Add one of the images to the screen so the user has a new image to move
* around. See addImageToScreen.
*
*/
public void addNewImageToScreen() {
int resourceId = R.drawable.sqwhite;
addNewTextToScreen();
int m = mImageCount % 3;
if (m == 1)
resourceId = R.drawable.sqdrk;
else if (m == 2)
resourceId = R.drawable.sqwhite;
addNewImageToScreen(resourceId);
}
private void addNewTextToScreen() {
// TODO Auto-generated method stub
if (isErase) {
tx.setText(et.getText().toString());
} else {
tx.setText("");
et.setVisibility(View.GONE);
}
isErase = !isErase;
}
/**
* Handle a click on a view.
*
*/
public void onClick(View v) {
if (mLongClickStartsDrag) {
positionListener();
onItemClick(null, v, mImageCount, mImageCount);
}
}
private void positionListener() {
// TODO Auto-generated method stub
}
/**
* Handle a click of the Add Image button
*
*/
public void onClickAddImage(View v) {
addNewImageToScreen();
}
/**
* onCreate - called when the activity is first created.
*
* Creates a drag controller and sets up three views so click and long click
* on the views are sent to this activity. The onLongClick method starts a
* drag sequence.
*
*/
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.demo);
et = (EditText) findViewById(R.id.editText1);
et.setVisibility(View.INVISIBLE);
tx = (TextView) findViewById(R.id.textView1);
GridView gridView = (GridView) findViewById(R.id.image_grid_view);
if (gridView == null)
toast("Unable to find GridView");
else {
gridView.setAdapter(new ImageCellAdapter(this));
// gridView.setOnItemClickListener (this);
}
mDragController = new DragController(this);
mDragLayer = (DragLayer) findViewById(R.id.drag_layer);
mDragLayer.setDragController(mDragController);
mDragLayer.setGridView(gridView);
mDragController.setDragListener(mDragLayer);
// mDragController.addDropTarget (mDragLayer);
mDeleteZone = (DeleteZone) findViewById(R.id.delete_zone_view);
// Give the user a little guidance.
Toast.makeText(getApplicationContext(),
getResources().getString(R.string.instructions),
Toast.LENGTH_LONG).show();
}
/**
* Build a menu for the activity.
*
*/
public boolean onCreateOptionsMenu(Menu menu) {
super.onCreateOptionsMenu(menu);
menu.add(0, HIDE_TRASHCAN_MENU_ID, 0, "Hide Trashcan").setShortcut('1',
'c');
menu.add(0, SHOW_TRASHCAN_MENU_ID, 0, "Show Trashcan").setShortcut('2',
'c');
menu.add(0, ADD_OBJECT_MENU_ID, 0, "Add View").setShortcut('9', 'z');
menu.add(0, CHANGE_TOUCH_MODE_MENU_ID, 0, "Change Touch Mode");
return true;
}
/**
* Handle a click of an item in the grid of cells.
*
*/
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
ImageCell i = (ImageCell) v;
trace("onItemClick in view: " + i.mCellNumber);
Intent intent = null;
switch (position) {
case 1:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser1.class);
break;
case 2:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser2.class);
break;
case 3:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser3.class);
break;
case 4:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser4.class);
break;
case 5:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser5.class);
break;
case 6:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser6.class);
break;
case 7:
Toast.makeText(DragActivity.this, "" + position, Toast.LENGTH_SHORT)
.show();
intent = new Intent(DragActivity.this, FileChooser7.class);
break;
}
if (intent != null) {
startActivity(intent);
}
}
/**
* Handle a long click. If mLongClick only is true, this will be the only
* way to start a drag operation.
*
* @param v
* View
* @return boolean - true indicates that the event was handled
*/
public boolean onLongClick(View v) {
if (mLongClickStartsDrag) {
// Make sure the drag was started by a long press as opposed to a
// long click.
// (Note: I got this from the Workspace object in the Android
// Launcher code.
// I think it is here to ensure that the device is still in touch
// mode as we start the drag operation.)
if (!v.isInTouchMode()) {
toast("isInTouchMode returned false. Try touching the view again.");
return false;
}
return startDrag(v);
}
// If we get here, return false to indicate that we have not taken care
// of the event.
return false;
}
/**
* Perform an action in response to a menu item being clicked.
*
*/
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case HIDE_TRASHCAN_MENU_ID:
if (mDeleteZone != null)
mDeleteZone.setVisibility(View.INVISIBLE);
return true;
case SHOW_TRASHCAN_MENU_ID:
if (mDeleteZone != null)
mDeleteZone.setVisibility(View.VISIBLE);
return true;
case ADD_OBJECT_MENU_ID:
// Add a new object to the screen;
addNewImageToScreen();
return true;
case CHANGE_TOUCH_MODE_MENU_ID:
mLongClickStartsDrag = !mLongClickStartsDrag;
String message = mLongClickStartsDrag ? "Changed touch mode. Drag now starts on long touch (click)."
: "Changed touch mode. Drag now starts on touch (click).";
Toast.makeText(getApplicationContext(), message, Toast.LENGTH_LONG)
.show();
return true;
}
return super.onOptionsItemSelected(item);
}
/**
* This is the starting point for a drag operation if mLongClickStartsDrag
* is false. It looks for the down event that gets generated when a user
* touches the screen. Only that initiates the drag-drop sequence.
*
*/
public boolean onTouch(View v, MotionEvent ev) {
// If we are configured to start only on a long click, we are not going
// to handle any events here.
if (mLongClickStartsDrag)
return false;
boolean handledHere = false;
final int action = ev.getAction();
// In the situation where a long click is not needed to initiate a drag,
// simply start on the down event.
if (action == MotionEvent.ACTION_DOWN) {
handledHere = startDrag(v);
}
return handledHere;
}
/**
* Start dragging a view.
*
*/
public boolean startDrag(View v) {
DragSource dragSource = (DragSource) v;
// We are starting a drag. Let the DragController handle it.
mDragController.startDrag(v, dragSource, dragSource,
DragController.DRAG_ACTION_MOVE);
return true;
}
/**
* Show a string on the screen via Toast.
*
* @param msg
* String
* @return void
*/
public void toast(String msg) {
Toast.makeText(getApplicationContext(), msg, Toast.LENGTH_SHORT).show();
} // end toast
/**
* Send a message to the debug log. Also display it using Toast if Debugging
* is true.
*/
public void trace(String msg) {
Log.d("DragActivity", msg);
if (!Debugging)
return;
toast(msg);
}
}
答案 0 :(得分:0)
尝试确定标记或ID触及的视图:
如果要在xml中定义可点击项,则代码为:
android:tag="my_tag"
如果您以编程方式执行此操作,则在创建视图的位置将其添加到网格中:
view.setTag("my_tag");
在任何一种情况下,重要的是您的标记对于每个视图都是唯一的。适配器代码:
public void onItemClick(AdapterView<?> parent, View v, int position, long id) {
ImageCell i = (ImageCell) v;
trace("onItemClick in view: " + i.mCellNumber);
Intent intent = null;
String tag = View.getTag();
if(tag.equals(Tag1)) {
//do stuff for the view with Tag 1.
} else if (tag.equals(Tag2) {
// do stuff for the view with Tag 2
}
//etc...
Tag1,Tag2可以是与视图中使用的标记相对应的硬编码字符串,也可以是更好的StringResources,它们在您设置标记的xml /编程代码中以及onItemClickCode中使用。