Activity:
package com.bocom;
import android.app.Activity;
import android.content.pm.ActivityInfo;
import android.graphics.BitmapFactory;
import android.graphics.Matrix;
import android.graphics.PointF;
import android.os.Bundle;
import android.util.FloatMath;
import android.util.Log;
import android.view.Menu;
import android.view.MotionEvent;
import android.view.View;
import android.view.Window;
import android.view.View.OnTouchListener;
import android.widget.ImageView;
import android.widget.ImageView.ScaleType;
public class MainActivityImage extends Activity implements OnTouchListener {
private ImageView imgview;
private ImageView img;
private Matrix matrix = new Matrix();
private Matrix savedMatrix = new Matrix();
static final int NONE = 0;
static final int DRAG = 1;
static final int ZOOM = 2;
int mode = NONE;
// Remember some things for zooming
PointF start = new PointF();
PointF mid = new PointF();
float oldDist = 1f;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
requestWindowFeature(Window.FEATURE_NO_TITLE);
setContentView(R.layout.activity_main_activity_image);
setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT);
imgview = (ImageView) this.findViewById(R.id.imag1);
// imgview.setAnimation(AnimationUtils.loadAnimation(this,
// R.anim.newanim));
// img = (ImageView) this.findViewById(R.id.imag);
// Matrix mt = img.getImageMatrix();
// // mt.postRotate(30);
// mt.postScale(0.5f, 0.5f);
// mt.postScale(1.5f, 1.5f);
// mt.postRotate(30, 130, 100);
// mt.postTranslate(100, 10);
//
// img.setImageMatrix(mt);
// imgview.setLongClickable(true);
String v=getIntent().getStringExtra("iv");
if("1".equals(v))
imgview.setImageBitmap(BitmapFactory.decodeResource(
this.getResources(), R.drawable.i1_1));
if("2".equals(v))
imgview.setImageBitmap(BitmapFactory.decodeResource(
this.getResources(), R.drawable.i1_2));
imgview.setOnTouchListener(this);
imgview.setLongClickable(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);
}
@Override
public boolean onTouch(View v, MotionEvent event) {
// TODO Auto-generated method stub
/*
* Log.d("Infor", "类别:"+event.getAction()); Log.d("Infor",
* "mask:"+event.getActionMasked()); Log.d("Infor",
* "index:"+event.getActionIndex()); Log.d("Infor",
* "points:"+event.getPointerCount());
*/
ScaleType type=ScaleType.MATRIX;
imgview.setScaleType(type);
Log.d("Infor", "size:" + event.getSize());
if (event.getActionMasked() == MotionEvent.ACTION_POINTER_UP)
Log.d("Infor", "多点操作");
switch (event.getActionMasked()) {
case MotionEvent.ACTION_DOWN:
matrix.set(imgview.getImageMatrix());
savedMatrix.set(matrix);
start.set(event.getX(), event.getY());
Log.d("Infor", "触摸了...");
mode = DRAG;
break;
case MotionEvent.ACTION_POINTER_DOWN: // 多点触控
oldDist = this.spacing(event);
if (oldDist > 10f) {
Log.d("Infor", "oldDist" + oldDist);
savedMatrix.set(matrix);
midPoint(mid, event);
mode = ZOOM;
}
break;
case MotionEvent.ACTION_POINTER_UP:
mode = NONE;
break;
case MotionEvent.ACTION_MOVE:
if (mode == DRAG) { // 此实现图片的拖动功能...
matrix.set(savedMatrix);
matrix.postTranslate(event.getX() - start.x, event.getY()
- start.y);
} else if (mode == ZOOM) {// 此实现图片的缩放功能...
float newDist = spacing(event);
if (newDist > 10) {
matrix.set(savedMatrix);
float scale = newDist / oldDist;
matrix.postScale(scale, scale, mid.x, mid.y);
}
}
break;
}
imgview.setImageMatrix(matrix);
return false;
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main_activity_image, menu);
return true;
}
}
xml:
<?xml version="1.0" encoding="UTF-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_height="fill_parent"
android:layout_width="fill_parent"
android:id="@+id/linearLayout1"
>
<ImageView
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:id="@+id/imag1"
android:scaleType="center"
></ImageView>
</RelativeLayout>
Manifast,colors.xml,styles.xml:
<activity
android:name=".MainActivityImage"
android:theme="@style/Transparent"
android:label="@string/title_activity_main_activity_image" >
</activity>
<?xml version="1.0" encoding="utf-8"?>
<resources>
<color name="transparent">#9000</color>
</resources>
<style name="Transparent">
<item name="android:windowBackground">@color/transparent</item>
<item name ="android:windowIsTranslucent">true</item>
<item name="android:windowAnimationStyle">@+android:style/Animation.Translucent</item>
</style>
分享到:
相关推荐
android多点触控放大缩小图片demo
Android的多点触控放大缩小图片,如果你感觉好,可以给我评论,不好也可留言。我好改进。
surfaceview 多点触控移动放大缩小.rar
很有用的东西,两个android ui经常要用到的组件,一个是左右划屏,一个是多点触控放大缩小图片
Android高仿qq发送图片中编辑图片功能,支持图片涂鸦、擦除、改变画笔颜色和...多点触控放大缩小、移动;代码注释清除,扩展性强.rar,太多无法一一验证是否可用,程序如果跑不起来需要自调,部分代码功能进行参考学习。
图片轮播,并支持多点触控放大或缩小图片,以多点的中心点为中心缩放
Android手势识别-多点触控。 包含在画布中的多点触控和利用多点触控实现图片的放大和缩小
flash,多点触控开发 经过自己优化,基于BorderContainer,只要往里面的image里面放入图片即可实现多点触控的旋转放大缩小灯操作。
Android中使用拖拉与多点触控功能实现图片的拖拉与缩放功能案例(内附APK)!
多点控制实现放大缩小demo 单点控制移动,半透明Activity
主要介绍了Android多点触控实现对图片放大缩小平移,惯性滑动等功能的相关资料,需要的朋友可以参考下
Android 多点触控实例。 多点触控图像,根据手势随意放大/缩小图像。
在Android上查看图片或者浏览网页时,我们往往有把图片或者网页放大或者缩小的的需求,这样就能够获得更多的细节信息 或者获得更多的全貌信息,多点触摸与绽放功能正是满足这种应用场景的技术。
本文通过一个自定义控件ZoomImageView,实现多点触控(移动,多点缩放),双击放大缩小,并在放大缩小过程自解决边界白边的情况,同时结合ViewPager的使用,并解决存在的事件冲突情况。
Android图片浏览,图片放大缩小平移,使用多点触控和双击。 滚动,以平滑滚动甩。
根据github上demo修改的,支持手势滑动,多点触控放大缩小,支持viewpager中放大所有,支持网络下载图片...完整并且完美的例子,很好用的...
两个手指滑动缩放画面用于Android手机端,没有进行ios的测试
SDL是Simple DirectMedia Layer 的缩写,是一套开放源代码的跨平台多媒体开发库,使用C语言写成。SDL提供了数种控制图像、声音、输出入的函数,让开发者只要...本代码示例了在Android上SDL多点触控实现放大缩小的功能。
在Android上查看图片或者浏览网页时,我们往往有把图片或者网页放大或者缩小的的需求,这样就能够获得更多的细节信息 或者获得更多的全貌信息,多点触摸与绽放功能正是满足这种应用场景的技术。