Android通過手勢實現的縮放處理執行個體代碼_Android

來源:互聯網
上載者:User

網路上傳言HTC的HERO-ROM支援多點觸摸的論證大多源於瀏覽網頁和圖片時,能像IPhone一樣通過手勢來控制頁面的大小。下面的例子是利用現有的API實現HERO瀏覽圖片和網頁的縮放功能。

主要原理是onTouchEvent事件中的參數MotionEvent,它有一個getSize()方法。在一個點的時候,該方法永遠返回0,而在兩個觸電的時候,該方法則根據兩點相對位置變化而返回不同的值。我們只需計算出兩點之間的距離變化,距離的大小表明我們希望目標變化的趨勢。而getX()和getY()方法則永遠座落在兩觸點之間,這樣趨勢和目標我們都有了。剩下的就是對目標根據趨勢進行放大或縮小即可。

複製代碼 代碼如下:

 /**
 * ...
 *
 * @author vlinux
 *
 */
public class MultiTouchTestActivity extends Activity {
 /** Called when the activity is first created. */
 @Override
 public void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  // setContentView(R.layout.main);
  View view = new MultiTouchView(this);
  setContentView(view);
 }

 class MultiTouchView extends View {

  private float x1;
  private float y1;
  private float x2;
  private float y2;

  public MultiTouchView(Context context) {
   super(context);
   // TODO Auto-generated constructor stub
  }

  @Override
  public boolean onTouchEvent(MotionEvent event) {
   // TODO Auto-generated method stub

   float size = event.getSize();

   int szi = (int) size;
   int dxi = szi >> 12;
   int dyit = ((1 << 12) - 1);
   int dyi = szi & dyit;

   DisplayMetrics metrics = getResources().getDisplayMetrics();
   float dx = metrics.widthPixels * dxi / (float) dyit;
   float dy = metrics.heightPixels * dyi / (float) dyit;

   x1 = event.getX();
   y1 = event.getY();

   x2 = x1 + dx;
   y2 = y1 + dy;

   invalidate();

   return true;
  }

  @Override
  protected void onDraw(Canvas canvas) {
   // TODO Auto-generated method stub
   super.onDraw(canvas);

   float r = (float) Math.sqrt((x1 - x2) * (x1 - x2) + (y1 - y2)
     * (y1 - y2)) / 2;
   r = 50 >= r ? 50 : r;

   Paint paint = new Paint();
   paint.setColor(Color.BLUE);
   canvas.drawCircle(x1, y1, r, paint);

  }

 }

}


聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.