手指移动和放大缩小imageview

转载 2012年03月30日 12:17:52
package com.dengfan;


import android.app.Activity;
import android.app.AlertDialog;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Matrix;
import android.graphics.PointF;
import android.hardware.SensorManager;
import android.os.Bundle;
import android.util.FloatMath;
import android.util.Log;


import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.View.OnTouchListener;
import android.widget.Button;
import android.widget.ImageView;
import android.widget.SimpleAdapter.ViewBinder;
import android.app.Activity;
import android.content.Context;
import android.content.SharedPreferences;
import android.content.SharedPreferences.Editor;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Matrix;
import android.graphics.PointF;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.util.FloatMath;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnTouchListener;
import android.view.ViewGroup.MarginLayoutParams;
import android.widget.ImageView;


public class ImageZoom extends Activity implements OnTouchListener,View.OnClickListener 
{
/** Called when the activity is first created. */


Matrix matrix = new Matrix();
Matrix savedMatrix = new Matrix();


PointF start = new PointF();
PointF mid = new PointF();
float oldDist;


private ImageView myImageView;


static final int NONE = 0;
static final int DRAG = 1;
static final int ZOOM = 2;
int mode = NONE;


@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.zoom);
myImageView = (ImageView) findViewById(R.id.zoom_img);
myImageView.setOnTouchListener(this);
myImageView.setImageBitmap(AppContext.zoomBitmap);
findViewById(R.id.zoom_set_to_wall).setOnClickListener(this);

SharedPreferences sharedPreferences = getSharedPreferences("pref", Context.MODE_PRIVATE);
boolean isFirstTimeUse = sharedPreferences.getBoolean("isfirsttimeuse", true);
Editor editor =  sharedPreferences.edit();
editor.putBoolean("isfirsttimeuse", false);
editor.commit();
if(isFirstTimeUse)
{
AlertDialog alertDialog  =new AlertDialog.Builder(this)
.setMessage("可以使用手指随意拖动和放大图片哦^^")
.setTitle("请用提醒")
.setPositiveButton("知道了", null)
.create();
alertDialog.show();
}
}


@Override
public void onClick(View v) 
{
switch (v.getId()) {
case R.id.zoom_set_to_wall:
try {
//AppContext.zoomBitmap = BitmapCompress.bitmapRoom(AppContext.zoomBitmap, AppContext.screenHeight);
setWallpaper(AppContext.zoomBitmap);
} catch (Exception e) {
e.printStackTrace();
}

break;


default:
break;
}
}

@Override
public boolean onTouch(View v, MotionEvent event) {
System.out.println(event.getPointerCount());
ImageView myImageView = (ImageView) v;
switch (event.getAction() & MotionEvent.ACTION_MASK) {
case MotionEvent.ACTION_DOWN:
matrix.set(myImageView.getImageMatrix());
savedMatrix.set(matrix);
start.set(event.getX(), event.getY());
mode = DRAG;
break;
case MotionEvent.ACTION_UP:
case MotionEvent.ACTION_POINTER_UP:
mode = NONE;
break;


// ���ö�㴥��ģʽ
case MotionEvent.ACTION_POINTER_DOWN:
oldDist = spacing(event);
if (oldDist > 10f) {
savedMatrix.set(matrix);
midPoint(mid, event);
mode = ZOOM;
}
break;
// ��ΪDRAGģʽ�������ƶ�ͼƬ
case MotionEvent.ACTION_MOVE:
if (mode == DRAG) {
matrix.set(savedMatrix);
matrix.postTranslate(event.getX() - start.x, event.getY()
- start.y);
}
// ��ΪZOOMģʽ�����������
else if (mode == ZOOM) {
float newDist = spacing(event);
if (newDist > 10f) {
matrix.set(savedMatrix);
float scale = newDist / oldDist;
// ����˶�ű����ͼƬ���е�λ��
matrix.postScale(scale, scale, mid.x, mid.y);
}
}
break;
}
myImageView.setImageMatrix(matrix);
return true;
}


// �����ƶ�����
private float spacing(MotionEvent event) {
float x = event.getX(0) - event.getX(1);
float y = event.getY(0) - event.getY(1);
return FloatMath.sqrt(x * x + y * y);
}


// �����е�λ��
private void midPoint(PointF point, MotionEvent event) {
float x = event.getX(0) + event.getX(1);
float y = event.getY(0) + event.getY(1);
point.set(x / 2, y / 2);
}

}



zoom.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
 android:orientation="vertical" android:layout_width="fill_parent"
 android:layout_height="fill_parent" android:gravity="center">
 <ImageView android:layout_width="fill_parent"
  android:layout_height="fill_parent" android:scaleType="matrix"
  android:id="@+id/zoom_img" android:layout_centerInParent="true"/>
 <Button android:layout_width="wrap_content" android:layout_height="wrap_content"
     android:id="@+id/zoom_set_to_wall" android:text="设为桌面" android:layout_alignParentLeft="true"
     android:layout_alignParentBottom="true"/>
</RelativeLayout>

相关文章推荐

Android-通过自定义View组件实现跟随手指移动的ImageView组件

在Android应用程序中绘制一个跟随手指的小兔子,当手指在屏幕上拖动时,小兔子将跟随手指拖动的轨迹移动。实现本实例时,首先需要先继承Android.view.View类,然后通过重写其onDraw(...
  • eva1994
  • eva1994
  • 2016年03月15日 11:36
  • 1787

android自定义view实现可自由放大缩小和移动的imageView

本自定义的ZoomImageView实现的功能有: 多指触摸以中心点自由放大缩小,图片整体默认居中于控件中,双击放大缩小并防止出现白边;代码如下...

android 多个ImageView图片缩小、放大、移动,图片不能移出ImageView视图,清空图片内存

picture_kztj.xml

Android 自定义地图控件 可手指拉伸放大缩小拖动,指定坐标加点加线

之前公司 项目有用到 gps定位 ,以及 工厂地图 布置 点 ,但是 无法使用百度地图之类的 第三方地图SDK ,只给一个工厂平面图,就要实现gps定位,一直 地图上布点。 gps 坐标转换到 图片...

Android深入浅出系列之实例应用—简单的手指拖动图片,图片滑来滑去显示应用Gallery和BaseAdapter以及ImageView的使用

前言   我们现在在随便一个手机上用手指在屏幕上滑来滑都可以去拖动图片,其实在Android里这很简单,下面我就给大家具体讲解一下。   思路    我们首先需要Gallery这个对象,俗称画廊...

手指触摸滑动物体带惯性的旋转 以及放大缩小(用插件easytouch 控制物体的旋转和缩放)

using UnityEngine; using UnityEngine.UI; using System.Collections; public class AR_TouchController...
  • wf2537
  • wf2537
  • 2016年05月16日 15:02
  • 2424

android自定义imageview实现放大缩小

  • 2013年11月13日 16:55
  • 1.19MB
  • 下载

两个手指多点触摸 滑动 放大缩小 缩放

using UnityEngine; using System.Collections; public class FingersTwo : MonoBehaviour {   publ...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:手指移动和放大缩小imageview
举报原因:
原因补充:

(最多只允许输入30个字)