android单点触控移动,多点触控放大缩小

activity_main.xml:

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <ImageView
        android:id="@+id/imgage"
        android:src="@drawable/liying"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerHorizontal="true"
        android:layout_centerVertical="true"
       />

</RelativeLayout>

MainActivity.class:

package com.example.day4_one;

import android.os.Bundle;
import android.app.Activity;
import android.view.Menu;

import android.app.Activity;
import android.content.res.Resources;
import android.util.DisplayMetrics;
import android.util.Log;
import android.view.Menu;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.widget.ImageView;
import android.widget.RelativeLayout;
import android.widget.Toast;

public class MainActivity extends Activity {
    private ImageView image;
    float lastDistance = -1;
    float x0 = 0;
    float y0 = 0;
     private int screenWidth;
       private int screenHeight; 

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        image = (ImageView) findViewById(R.id.imgage);
        //获得屏幕宽高 不让出界
         DisplayMetrics dm = getResources().getDisplayMetrics();
            screenWidth = dm.widthPixels;
            screenHeight = dm.heightPixels-100; 

        image.setOnTouchListener(new OnTouchListener() {

            private float x;
            private float y;

            @Override
            public boolean onTouch(View v,final MotionEvent event) {
                // TODO Auto-generated method stub
                int action = event.getAction();
                Log.i("TAG","触摸开始......");
                switch (action) {
                case MotionEvent.ACTION_DOWN:
                    //getX()是表示Widget相对于自身左上角的x坐标,而getRawX()是表示相对于屏幕左上角的x坐标值(注意:这个屏幕左上角是手机屏幕左上角,不管activity是否有titleBar或是否全屏幕)
                    x = event.getRawX();
                    y = event.getRawX();
                    break;

                case MotionEvent.ACTION_MOVE:
                    //得到触摸点的个数
                    int count = event.getPointerCount();
                    Log.i("TAG","触摸点的个数:"+count);

                    if(count > 1){
                        Log.i("TAG", event.getX(0)+","+event.getY(0)+"|"+event.getX(1)+","+event.getY(1));
                        //获得两点的坐标差
                        float distanceX = event.getX(0) - event.getX(1);
                        float distanceY = event.getY(0) - event.getY(1);
                        //获得两点之间的距离
                        float betweenDistance = (float) Math.sqrt(distanceX*distanceX + distanceY*distanceY);
                        Log.i("TAG","当前两点之间的新距离:"+betweenDistance);

                        if(betweenDistance < 1){
                            lastDistance = betweenDistance;

                        }else if((betweenDistance - lastDistance) > 5){
                            //放大
                            lastDistance = betweenDistance;
                            //获得布局参数
                            RelativeLayout.LayoutParams params = (android.widget.RelativeLayout.LayoutParams) image.getLayoutParams();
                            params.width = (int) (image.getWidth()*1.1f);
                            params.height = (int) (image.getHeight()*1.1f);
                            image.setLayoutParams(params);
                        }else if((lastDistance - betweenDistance) > 5){
                            lastDistance = betweenDistance;
                            //获得布局参数
                            RelativeLayout.LayoutParams params = (android.widget.RelativeLayout.LayoutParams) image.getLayoutParams();
                            params.width = (int) (image.getWidth()*0.9f);
                            params.height = (int) (image.getHeight()*0.9f);
                            image.setLayoutParams(params);
                        }

                    }else if(count == 1){

                        //移动距离
                        float rawX = event.getRawX()-x;
                        float rawy = event.getRawY()-y;
                        //定义新的
                        int left = (int) (image.getLeft()+rawX);
                        int top = (int) (image.getTop()+rawy);
                        int right = (int) (image.getRight()+rawX);
                        int bottom = (int) (image.getBottom()+rawy);
                         // 设置不能出界
                          if (left < 0) {
                              left = 0;
                              right = left + v.getWidth();
                          } 

                          if (right > screenWidth) {
                              right = screenWidth;
                              left = right - v.getWidth();
                          } 

                          if (top < 0) {
                              top = 0;
                              bottom = top + v.getHeight();
                          } 

                          if (bottom > screenHeight) {
                              bottom = screenHeight;
                              top = bottom - v.getHeight();
                          } 

                        //赋值
                        image.layout(left, top, right, bottom);
                        //改成新的按下作标
                        x=event.getRawX();
                        y=event.getRawY();
                        /*return false;*/
                    }
                    break;

                }

                return true;
            }
        });
    }
    //全局移动
   @Override
public boolean onTouchEvent(MotionEvent event) {
    // TODO Auto-generated method stub
      /*image.setX(event.getX());
        image.setY(event.getY()); */
    return true;
}

}
时间: 2024-10-11 00:11:11

android单点触控移动,多点触控放大缩小的相关文章

android 百度最新地图sdk包怎么去除 放大缩小按钮

// 隐藏缩放控件 int childCount = mMapView.getChildCount(); View zoom = null; for (int i = 0; i < childCount; i++) { View child = mMapView.getChildAt(i); if (child instanceof ZoomControls) { zoom = child; break; } } zoom.setVisibility(View.GONE); // 隐藏比例尺控件

Android多点触控技术

1 简介 Android多点触控在本质上需要LCD驱动和程序本身设计上支持,目前市面上HTC.Motorola和Samsung等知名厂商只要使用电容屏触控原理的手机均可以支持多点触控Multitouch技术,对于网页缩放.手势操作上有更好的用户体验. 在Android平台上事件均使用了MotionEvent对象方式处理,比如开始触控时会触发ACTION_DOWN,而移动操作时为 ACTION_MOVE,最终放开手指时触发ACTION_UP事件.当然还有用户无规则的操作可能触发ACTION_CAN

【朝花夕拾】Android自定义View篇之(八)多点触控(上)基础知识

前言 转载请声明,转自[https://www.cnblogs.com/andy-songwei/p/11155259.html],谢谢! 在前面的文章中,介绍了不少触摸相关的知识,但都是基于单点触控的,即一次只用一根手指.但是在实际使用App中,常常是多根手指同时操作,这就需要用到多点触控相关的知识了.多点触控是在Android2.0开始引入的,在现在使用的Android手机上都是支持多点触控的.本系列文章将对常见的多点触控相关的重点知识进行总结,并使用多点触控来实现一些常见的效果,从而达到将

android 多点触控

多点触控 1.多点触控从字面意思讲就是你用大于等于2根的手指触摸子啊手机屏幕上. Android中监听触摸事件是onTouchEvent方法,它的参数为MotionEvent,下面列举MotionEvent的一些常用的方法: getPointerCount() 获得触屏的点数. getPointerId(int pointerIndex) 返回一个触摸点的标示,pointIndex是你第几个触控点的索引 getX() 获得触屏的X坐标值 getY() 获得触屏的Y坐标值 getAction()

9. Cocos2d-x 游戏编程 之 多点触碰

上一篇内容讲了 单点触碰,然后这篇接着讲 多点触碰.多点触碰就是说,多个手指同时在屏幕上操作,然后触发监听器,回调方法实现功能而已. 1.先了解这个代码如何在手机上调试.因为这个是关乎到多个手指触碰才能触发的监听器,所以说,在模拟器上实现不了手指的触碰.必须在真机上跑才行. 其实很简单,只要在项目中的 ios 这个文件夹中的 AppController.mm 文件里边的 - (BOOL)application:(UIApplication *)application didFinishLaunc

WPF布局之让你的控件随着窗口等比放大缩小,适应多分辨率满屏填充应用

一直以来,我们设计windows应用程序,都是将控件的尺寸定好,无论窗体大小怎么变,都不会改变,这样的设计对于一般的应用程序来说是没有问题的,但是对于一些比较特殊的应用,比如有背景图片的,需要铺面整个屏幕,由于存在多种不同的分辨率,所以会出现布局混乱的情况.今天我们来看看WPF中如何让我们的控件也随着分辨率放大缩小.下面来写一个例子看看效果吧~  一.普通布局中的问题 这里我们写一个简单的页面,新建WPF项目,在MainWindow里面添加按钮,如下图: 这个页面很简单,只有三个按钮,我们想的是

[Android]可缩放性ImageView(可以放大缩小)

由于项目需求的原因,最近一直在研究可缩放性ImageView,用本文来记录一下最近所学: 该ImageView的实现功能有: 1)初步打开时,图片按比例满屏(填充ImageView)显示. 2)在放大缩小过程中,可以控制最大放大比例和最小缩小比例. 3)在缩放过程中,若图片的宽或高小于ImageView,则在图片在宽或高居中显示. 4)在放大后,可以移动图片,并且限制好移动的边界,不会超出图片. 5)实现双击放大或缩小的功能.(若当前图片显示为最大的比例则缩小为最小比例,若不是最小比例则放大了最

Android 本地/网路下载图片实现放大缩小

 Android 本地加载/网路下载图片实现放大缩小拖拉效果,自定义控件. package com.example.ImageViewCustom; import android.app.Activity; import android.os.Bundle; import com.example.ImageViewCustom.CustomControl.MImageView; public class MyActivity extends Activity { MImageView mImag

Android笔记:触摸事件的分析与总结----多点触控

一.多点触控 当多点同时触摸屏幕时,系统将会产生如下的触摸事件: 1.ACTION_DOWN:触摸屏幕的第一个点.此时手势开始.该点的数据通常在MotionEvent事件队列索引位置0处. 2.ACTION_POINTER_DOWN:除了第一个点的其他触摸点数据.该点的数据的索引位置由getActionIndex()方法返回. 3.ACTION_MOVE:在手势过程中发生的一次变化. 4.ACTION_POINTER_UP:当不是第一个点的其他点UP后触发. 5.ACTION_UP:当手势中的最

Android多点触控技术实战,自由地对图片进行缩放和移动

转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/11100327 在上一篇文章中我带着大家一起实现了Android瀑布流照片墙的效果,虽然这种效果很炫很酷,但其实还只能算是一个半成品,因为照片墙中所有的图片都是只能看不能点的.因此本篇文章中,我们就来对这一功能进行完善,加入点击图片就能浏览大图的功能,并且在浏览大图的时候还可以通过多点触控的方式对图片进行缩放. 如果你还没有看过 Android瀑布流照片墙实现,体验不规则排列的美感