ViewPager图片预览之图片的放大缩小,移动,切换(第一课)连载

1,自由的放大和缩小

2.双击放大与缩小

3.放大以后可以进行自由的移动

4.处理与ViewPager之间的的事件冲突

需要用到的知识点

1.Matrix (图片放大,缩小需要用到矩阵)

2.ScaleGestureDetector(检测用户多指触控时缩放的手势)

3.GestureDetector:检测用户双击时需要做的一些处理

4.事件分发机制(当我们图片放大时,我们的图片是可以左右移动的,在ViewPager左右切换图片,两者会有冲突)。

----------------------------------------------------代码设计

第一课

第一步 :自定义ImageView 实现图片自适应控件大小:(效果是:图片小于控件大小时,放大到控件大小,图片大于控件大小时,自动缩小到控件大小)

package com.example.viewpagerimage;

import android.content.Context;
import android.graphics.Matrix;
import android.graphics.drawable.Drawable;
import android.util.AttributeSet;
import android.view.ViewTreeObserver.OnGlobalLayoutListener;
import android.widget.ImageView;

//实现监听器OnGlobalLayoutListener,监听图片是否加载完成
public class MyImageView extends ImageView implements OnGlobalLayoutListener{

	private boolean mOnce;//判断是否初始化
	private float mInitScale;//初始化时缩放的值
	private float mMidScale;//双击放大到达的值
	private float mMaxScale;//放大的最大值

	private Matrix mScaleMatrix;
	public MyImageView(Context context, AttributeSet attrs, int defStyleAttr) {
		super(context, attrs, defStyleAttr);
		//init
		mScaleMatrix = new Matrix();
		setScaleType(ScaleType.MATRIX);
		//当图片加载时,图片可能很大,也可能很小,需要让图片自适应屏幕大小,当图片太大时自动缩小到屏幕大小,当图片太小时放大到屏幕大小。

	}

	public MyImageView(Context context, AttributeSet attrs) {
		this(context, attrs,0);
		// TODO Auto-generated constructor stub
	}

	public MyImageView(Context context) {
		this(context,null);
		// TODO Auto-generated constructor stub
	}
	@Override
	protected void onAttachedToWindow() {
		// TODO Auto-generated method stub
		super.onAttachedToWindow();//当View 显示在屏幕上时调用
		getViewTreeObserver().addOnGlobalLayoutListener(this);//注册接口
	}
	@SuppressWarnings("deprecation")
	@Override
	protected void onDetachedFromWindow() {
		// TODO Auto-generated method stub
		super.onDetachedFromWindow();//当View从屏幕上移除时调用
		getViewTreeObserver().removeGlobalOnLayoutListener(this);//移除接口
	}
	/**
	 * 获取ImageView加载完成的图片
	 */
	@Override
	public void onGlobalLayout() {
		// 全局的布局完成后调用
		if(!mOnce){
			//得到控件的宽和高
			int width = getWidth();
			int height = getHeight();
			//得到我们的图片以及宽和高
			Drawable d = getDrawable();
			if(d == null)
				return;

			int dw = d.getIntrinsicWidth();
			int dh = d.getIntrinsicHeight();
			float scale = 1.0f;//缩放值
			//如果图片的宽度大于控件高度,但是宽度小于控件的宽度,将其缩小
			if(dw > width && dh < height){
				scale = width*1.0f/dw;
			}
			else if(dh > height && dw < width){
				scale = height*1.0f /dh;
			}

			else if(dw > width && dh > height){
				scale = Math.min(width*1.0f/dw, height*1.0f/dh);
			}
			else if(dw < width && dh < height){
				scale = Math.min(width *1.0f/dw, height*1.0f/dh);
			}
			/*
			 * 得到初始化时缩放的比例
			 * */

			mInitScale = scale;
			mMaxScale = mInitScale * 4;
			mMidScale = mInitScale * 2;

			//将图片移动到当前控件的中心
			int dx = getWidth()/2 - dw /2;
			int dy = getHeight()/2 - dh/2;

			mScaleMatrix.postTranslate(dx, dy);//平移
			mScaleMatrix.postScale(mInitScale, mInitScale,width/2,height/2);//缩放,后面两个参数是缩放的中心点
			setImageMatrix(mScaleMatrix);

			mOnce = true;

		}
	}
}

布局文件使用:

<LinearLayout 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="com.example.viewpagerimage.MainActivity" >

    <com.example.viewpagerimage.MyImageView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:scaleType="matrix"
        android:src="@drawable/viewpatherimage" />

</LinearLayout>

小图片放大自适应:

大图片缩小自适应:

时间: 2024-10-12 19:39:20

ViewPager图片预览之图片的放大缩小,移动,切换(第一课)连载的相关文章

ViewPager图片预览之图片的放大缩小,移动,切换(第四课)结束了

终极版 package com.zhy.view; import android.annotation.SuppressLint; import android.content.Context; import android.graphics.Matrix; import android.graphics.RectF; import android.graphics.drawable.Drawable; import android.util.AttributeSet; import andro

ViewPager图片预览之图片的放大缩小,移动,切换(第三课)连载

第三课(第三步):支持以手指触控的任意点为中心开始缩放 关键部分是在缩放的时候不断进行边界检测,防止放大后缩小后出现白边: /** * 在缩放的时候进行边界控制范围位置控制 */ private void checkBorderAndCenterWhenScale() { // TODO Auto-generated method stub RectF rect = getMatrixRectF(); float deltaX = 0; float deltaY = 0; float width

jquery图片预览使图片在屏幕正中间。

<ul> <li><img src='image/u1.jpg'></li> <li><img src='image/u2.jpg'></li> <li><img src='image/u3.jpg'></li></ul><div class="bg"> <img class="bgImg" src="&qu

ViewPager图片预览之图片的放大缩小,移动,切换(第二课)连载

第二步:给自定义控件添加支持手指触控缩放的功能:(支持手指触控放大) 因为涉及到手势触摸事件所以要实现OnScaleGestureListener,OnTouchListener这两个接口. 声明成员变量: private ScaleGestureDetector mScaleGestureDetector;//捕获用户多指触控缩放的比例 在构造函数中初始化: mScaleGestureDetector = new ScaleGestureDetector(context, this); set

js实现移动端图片预览:手势缩放, 手势拖动,双击放大...

.katex { display: block; text-align: center; white-space: nowrap; } .katex-display > .katex > .katex-html { display: block; } .katex-display > .katex > .katex-html > .tag { position: absolute; right: 0px; } .katex { font-style: normal; font

本地与在线图片转Base64及图片预览

查看效果:http://sandbox.runjs.cn/show/tgvbo9nq 本地图片转Base64(从而可以预览图片): function localImgLoad() { var src = this.files[0]; var self = $(this); var read = new FileReader(); read.onload = function(e) { var html = "<img src=" + e.target.result + "

微信企业号办公系统-图片预览放大功能-previewImage

在微信里看过文章的应该知道,文章里的图片点击后可以放大.分享和保存. 然而自己在微信里开发的网页,里面的图片点击后没办法实现这个效果,然后就去看了下微信JS文档,里面有个previewImage可以调用. previewImage是微信客户端给内置浏览器增加的一个Javascript Interface,通过调用这个API,可以调起微信客户端提供的大图片查看组件. 官方说明和例子: wx.previewImage({ current: '', // 当前显示图片的http链接 urls: []

一款基于jQuery可放大预览的图片滑块插件

今天给大家分享一款基于jQuery可放大预览的图片滑块插件.这款jQuery焦点图插件的特点是可以横向左右滑动图片,并且点击图片可以进行放大预览,唯一的缺陷是这款焦点图并不能循环切换,如果你有较好的JavaScript功底,可以自己修改代码来实现这一功能.效果图如下: 在线预览   源码下载 实现的代码. html代码: <div id="slider"> <div class="spic"> <img src="images

简单的移动端图片预览 包含放大缩小以及对各种手势的判定

<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta name="viewport" content="maximum-scale=1.0,minimum-scale=1.0,user-scalable=0,width=device-width,initial-scale=1.0"/> <title>title&