我有兩個ImageButton
s,我想爲它們設置相同的OnTouchListener
,但問題是 - 當我觸摸一個Image時,另一個相鄰的Image也在移動。 我也覺得,當我觸摸圖片2時,它正在移出屏幕並隱形。我希望它保持在屏幕上,並希望Touch事件應該爲他們單獨工作。On Touch Listener無法正常工作
這是我到現在爲止所做的。
//this is the snippet from main activity where the onTouch is implemented and layout is created
RelativeLayout.LayoutParams params = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT, RelativeLayout.LayoutParams.WRAP_CONTENT);
params.addRule(RelativeLayout.ALIGN_PARENT_LEFT, RelativeLayout.TRUE);
imgMaster.setLayoutParams(params);
params = new RelativeLayout.LayoutParams(RelativeLayout.LayoutParams.WRAP_CONTENT, RelativeLayout.LayoutParams.WRAP_CONTENT);
params.addRule(RelativeLayout.RIGHT_OF, imgMaster.getId());
imgMaster.setOnTouchListener(new ChoiceTouchListener());
imgMood.setOnTouchListener(new ChoiceTouchListener());
imgMood.setLayoutParams(params);
imgMaster.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(getApplicationContext(), "Clicked Master", Toast.LENGTH_SHORT).show();
}
});
imgMood.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Toast.makeText(getApplicationContext(), "Clicked Mood", Toast.LENGTH_SHORT).show();
}
});
}
private final class ChoiceTouchListener implements OnTouchListener {
public boolean onTouch(View view, MotionEvent event) {
//ImageButton views = (ImageButton) view;
final int X = (int) event.getRawX();
final int Y = (int) event.getRawY();
switch (view.getId()) {
case R.id.master:
switch (event.getAction() & MotionEvent.ACTION_MASK) {
case MotionEvent.ACTION_DOWN:
RelativeLayout.LayoutParams lparams = (RelativeLayout.LayoutParams) view.getLayoutParams();
_xDelta = X - lparams.leftMargin;
_yDelta = Y - lparams.topMargin;
break;
case MotionEvent.ACTION_UP:
break;
case MotionEvent.ACTION_POINTER_DOWN:
break;
case MotionEvent.ACTION_POINTER_UP:
break;
case MotionEvent.ACTION_MOVE:
RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) view.getLayoutParams();
layoutParams.leftMargin = X - _xDelta;
layoutParams.topMargin = Y - _yDelta;
layoutParams.rightMargin = -250;
layoutParams.bottomMargin = -250;
view.setLayoutParams(layoutParams);
break;
}
case R.id.mood:
switch (event.getAction() & MotionEvent.ACTION_MASK) {
case MotionEvent.ACTION_DOWN:
RelativeLayout.LayoutParams lparams = (RelativeLayout.LayoutParams) view.getLayoutParams();
_xDelta = X - lparams.leftMargin;
_yDelta = Y - lparams.topMargin;
break;
case MotionEvent.ACTION_UP:
break;
case MotionEvent.ACTION_POINTER_DOWN:
break;
case MotionEvent.ACTION_POINTER_UP:
break;
case MotionEvent.ACTION_MOVE:
RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) view.getLayoutParams();
layoutParams.leftMargin = X - _xDelta;
layoutParams.topMargin = Y - _yDelta;
layoutParams.rightMargin = -250;
layoutParams.bottomMargin = -250;
view.setLayoutParams(layoutParams);
break;
}
break;
}
return false;
}
}
//這是我提前佈局
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="match_parent"
android:id="@+id/view_root"
android:background="@drawable/transparent_background"
xmlns:android="http://schemas.android.com/apk/res/android">
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/mood"
android:src="@drawable/mood"
android:background="@null"/>
<ImageButton
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/master"
android:src="@drawable/master"
android:background="@null" /></RelativeLayout>
感謝。
這些圖像是否重疊在一起?我問這是因爲你使用了相對佈局,並沒有提到每個圖像相對於彼此的相對位置 – Dibzmania
@Dibzmania但添加規則已經定義在代碼中的位置 –
@Dibzmania可能是它的重疊...但如果我設置類似於在佈局android:layout_alignParentBottom =「true」 android:layout_alignParentRight =「true」 android:layout_alignParentEnd =「true」圖像它沒有做任何改變.... –