Если вы просто хотите переместить вид по экрану, нет необходимости использовать перетаскивание; Вы можете просто обновить местоположение вида x & y на экране, используя MotionEvent.ACTION_DOWN
& MotionEvent.ACTION_MOVE
события View.OnTouchListener
.
. Чтобы избежать смещения вида с экрана, мы рассчитаем ширину & высота вида root с использованием getViewTreeObserver()
Итак, ваш макет будет иметь вид root, содержащий TextView
, который вы хотите перемещать по экрану.
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/root_layout"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity">
<TextView
android:id="@+id/textview"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="Hello World" />
</RelativeLayout>
И ваше поведение будет:
public class MainActivity extends AppCompatActivity {
private int mXDelta = 0;
private int mYDelta = 0;
private int mRootWidth;
private int mRootHeight;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
final RelativeLayout rootLayout = findViewById(R.id.root_layout);
rootLayout.getViewTreeObserver().addOnGlobalLayoutListener(new ViewTreeObserver.OnGlobalLayoutListener() {
@Override
public void onGlobalLayout() {
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.JELLY_BEAN) {
rootLayout.getViewTreeObserver()
.removeOnGlobalLayoutListener(this);
}
mRootWidth = rootLayout.getWidth();
mRootHeight = rootLayout.getHeight();
}
});
TextView textView = findViewById(R.id.textview);
textView.setOnTouchListener(mOnTouchListener);
}
View.OnTouchListener mOnTouchListener = new View.OnTouchListener() {
@Override
public boolean onTouch(View view, MotionEvent event) {
int xScreenTouch = (int) event.getRawX(); // x location relative to the screen
int yScreenTouch = (int) event.getRawY(); // y location relative to the screen
switch (event.getAction() & MotionEvent.ACTION_MASK) {
case MotionEvent.ACTION_DOWN:
RelativeLayout.LayoutParams lParams = (RelativeLayout.LayoutParams) view.getLayoutParams();
mXDelta = xScreenTouch - lParams.leftMargin;
mYDelta = yScreenTouch - lParams.topMargin;
break;
case MotionEvent.ACTION_MOVE:
RelativeLayout.LayoutParams layoutParams = (RelativeLayout.LayoutParams) view
.getLayoutParams();
layoutParams.leftMargin = Math.max(0, Math.min(mRootWidth - view.getWidth(), xScreenTouch - mXDelta));
layoutParams.topMargin = Math.max(0, Math.min(mRootHeight - view.getHeight(), yScreenTouch - mYDelta));
view.setLayoutParams(layoutParams);
break;
}
return true;
}
};
}
Результат
