1 package com.example.qjm3662.android_touch_test;
  2 
  3 import android.os.Bundle;
  4 import android.support.design.widget.FloatingActionButton;
  5 import android.support.design.widget.Snackbar;
  6 import android.support.v7.app.AppCompatActivity;
  7 import android.support.v7.widget.Toolbar;
  8 import android.util.Log;
  9 import android.view.MotionEvent;
 10 import android.view.View;
 11 import android.view.Menu;
 12 import android.view.MenuItem;
 13 import android.widget.ImageView;
 14 import android.widget.LinearLayout;
 15 
 16 public class MainActivity extends AppCompatActivity {
 17 
 18     private String TAG = "MainActivity";
 19     private LinearLayout root;
 20     private ImageView iv;
 21     @Override
 22     protected void onCreate(Bundle savedInstanceState) {
 23         super.onCreate(savedInstanceState);
 24         setContentView(R.layout.activity_main);
 25 
 26         root = (LinearLayout) findViewById(R.id.container);
 27         iv = (ImageView) findViewById(R.id.iv);
 28 
 29         root.setOnTouchListener(new View.OnTouchListener() {
 30 
 31             float offsetX;
 32             float offsetY;
 33             float curruntDistance;      //当前距离
 34             float lastDistance = -1;    //前一次的距离
 35             @Override
 36             public boolean onTouch(View v, MotionEvent event) {
 37                 switch(event.getAction()){
 38                     case MotionEvent.ACTION_DOWN:
 39                         Log.e(TAG,"down");
 40                         break;
 41                     case MotionEvent.ACTION_UP:
 42                         Log.e(TAG,"up");
 43                         break;
 44                     case MotionEvent.ACTION_MOVE:
 45                         if(event.getPointerCount() > 1){
 46                             
 47                             //两个触摸点之间的距离
 48                             offsetX = event.getX(0) - event.getX(1);
 49                             offsetY = event.getY(0) - event.getY(1);
 50 
 51                             //当前距离
 52                             curruntDistance = (float) Math.sqrt(offsetX * offsetX + offsetY * offsetY);
 53 
 54                             //第一次给lastDistance赋值
 55                             if(lastDistance < 0){
 56                                 lastDistance = curruntDistance;
 57                             }else{
 58                                 //获取ImageView的layoutParms
 59                                 LinearLayout.LayoutParams layoutParams = (LinearLayout.LayoutParams) iv.getLayoutParams();
 60                                 
 61                                 //与上一次相比距离增大(5px是为了考虑操作误差)
 62                                 if(curruntDistance - lastDistance > 5){
 63                                     
 64                                     //放大图片操作
 65                                     layoutParams.width = (int) (1.1f*iv.getWidth());
 66                                     layoutParams.height = (int) (1.1f*iv.getHeight());
 67 
 68                                     //操作完务必给lastDistance重新赋值
 69                                     lastDistance = curruntDistance;
 70                                     iv.setLayoutParams(layoutParams);
 71                                     Log.e(TAG,"放大");
 72                                 }
 73                                 //与上一次相比距离减小(5px是为了考虑操作误差)
 74                                 else if(lastDistance - curruntDistance > 5){
 75                                     layoutParams.width = (int) (0.9f*iv.getWidth());
 76                                     layoutParams.height = (int) (0.9f*iv.getHeight());
 77                                     lastDistance = curruntDistance;
 78                                     iv.setLayoutParams(layoutParams);
 79                                     Log.e(TAG,"缩小");
 80                                 }
 81                             }
 82                         }
 83 
 84 //                        Log.e(TAG, "move");
 85 //                        //多点触控
 86 //                        Log.e(TAG,"Point count : " + event.getPointerCount());
 87 //                        if(event.getPointerCount() > 1){
 88 //                            Log.e(TAG,String.format("x1:%f,y1:%f\nx2:%f,y2:%f",event.getX(0),event.getY(0),event.getX(1),event.getY(1)));
 89 //                        }
 90                         
 91                         
 92 //                        //获取单个触摸点
 93 //                        LinearLayout.LayoutParams lp;
 94 //                        lp = (LinearLayout.LayoutParams) iv.getLayoutParams();
 95 //                        Log.e(TAG,String.format("x:%f,y:%f",event.getX(),event.getY()));
 96 //                        lp.leftMargin = (int) event.getX();
 97 //                        lp.topMargin = (int) event.getY();
 98 //                        iv.setLayoutParams(lp);
 99                         break;
                 }
                 return true;
             }
         });
     }
 
 }  

Android_Touch_Test的更多相关文章

随机推荐

  1. 洛谷 P1331 海战

    传送门 题解:由于船是方形的,所以比较简单.但是考试的时候跪了,orz.忘了考虑类似一圈井号中间有一摊水.          可以只考虑这个点上方和左边点的情况,这样分为四种情况.一种是左边是一滩水, ...

  2. facebook分块加载,页面优化,BigPipe,简单实例

    <!DOCTYPE html><html><head><meta charset=”utf-8″><title>BigPipe Demo 3 ...

  3. 转:7个鲜为人知却超实用的PHP函数

    PHP have lots of built-in functions, and most developers know many of them. But a few functions are ...

  4. 多线程+fork 引发的bug查找

    1. 问题描述 某个server SA是一个多线程服务器,主线程会调用fork,再exec生成工作进程SB. 实际上,SA的主线程fork出了一个子线程,但没有执行exec. # ps ajxf | ...

  5. More lumber is required

    hdu4396:http://acm.hdu.edu.cn/showproblem.php?pid=4396 题意:一个无向带权图,然后给出起点s,终点e,让你求s到e的最短路径,但是这里的路径有要求 ...

  6. HDU 3446 daizhenyang's chess

    http://acm.hdu.edu.cn/showproblem.php?pid=3446 题意:一个棋盘,有个KING,有一些能走的点,每次只能走到没走过的地方,没路可走的输,求先手是否必胜. 思 ...

  7. java签名证书

    import java.io.FileInputStream; import java.security.KeyStore; import java.security.PrivateKey; impo ...

  8. 【索引】XBox360玩机心得

    基础知识 查看XBox360的系统版本信息:http://www.cnblogs.com/duxiuxing/p/4292140.html XBox360光盘游戏的安装: 自制系统 XBox360自制 ...

  9. 哈希表的C语言实现

    首先介绍一下什么是哈希表.同线性表.树一样,哈希表也是一种数据结构,理想情况下可以不需要任何比较,一次存取便能得到所查记录.所以它的优点就是查找特定记录的速度快.因为哈希表是基于数组的,所以创建后就难 ...

  10. struts2校验器规范错误解决

    今天struts2的校验器的配置文件文件头出现了错误,配置如下: <!DOCTYPE validators PUBLIC        "-//OpenSymphony Group// ...