Android:scrollBy實現view隨意移動并顯示坐標
本文通過FrameLayout和LinearLayout來布局,并通過捕捉onTouchEvent事件來實現畫面的隨意移動,并同時顯示移動后畫面坐標。原文http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2013/0111/800.html
控制view移動的函數主要是scrollTo和scrollBy,兩者的差別如下:
scrollTo讓我們的layout視圖相對于屏幕的左上角進行偏移;
scrollBy是相當于我們當前的坐標進行偏移,我們上面的例子如果改成scrollBy的話,這個TextView文字會不斷地向右下角移動,多 次后我 們就不看不到這個TextView的內容了,因為它已經進行了非Layout視圖區,而如果我們用scrollTo的話,不管點多少次按鈕,它永 遠就就 上面顯示的那個位置。
這里我們用scrollBy更合理一些。
1、先上布局文件:main.xml
<?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent"> <LinearLayout android:id="@+id/container" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="horizontal"> <ImageView android:src="@drawable/icon1" android:layout_width="wrap_content" android:layout_height="wrap_content"/> </LinearLayout> <LinearLayout android:id="@+id/showXY" android:layout_width="fill_parent" android:layout_height="wrap_content" android:layout_gravity="bottom" android:orientation="horizontal"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="5px" android:text="當前坐標:"/> <TextView android:id="@+id/xyValue" android:layout_width="wrap_content" android:layout_height="wrap_content" android:padding="5px" android:text="0,0"/> </LinearLayout> </FrameLayout>
2、Activity代碼,MainActivity.java:
package org.shuxiang.test; import android.app.Activity; import android.os.Bundle; import android.view.MotionEvent; import android.view.Window; import android.widget.LinearLayout; import android.widget.TextView; public class MainActivity extends Activity { private LinearLayout container; private int currentX; private int currentY; private TextView xyValue; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(R.layout.main); container = (LinearLayout) findViewById(R.id.container); xyValue = (TextView) findViewById(R.id.xyValue); } @Override public boolean onTouchEvent(MotionEvent event) { switch (event.getAction()) { case MotionEvent.ACTION_DOWN: { currentX = (int) event.getRawX(); currentY = (int) event.getRawY(); break; } case MotionEvent.ACTION_MOVE: { int x2 = (int) event.getRawX(); int y2 = (int) event.getRawY(); container.scrollBy(currentX - x2 , currentY - y2); currentX = x2; currentY = y2; xyValue.setText(x2 + "," + y2); break; } case MotionEvent.ACTION_UP: { break; } } return true; } }
本文由用戶 jianghejie 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!