public class ShaderView extends View {private final Bitmap bitmap;private final ShapeDrawable drawable;// 放大镜的半径private static final int RADIUS = 80;// 放大倍数private static final int FACTOR = 3;private final Matrix matrix = new Matrix();public ShaderView(Context context) {super(context);Bitmap bmp = BitmapFactory.decodeResource(getResources(),R.drawable.demo);bitmap = bmp;BitmapShader shader = new BitmapShader(Bitmap.createScaledBitmap(bmp,bmp.getWidth() * FACTOR, bmp.getHeight() * FACTOR, true),TileMode.CLAMP, TileMode.CLAMP);// 圆形的drawabledrawable = new ShapeDrawable(new OvalShape());drawable.getPaint().setShader(shader);drawable.setBounds(0, 0, RADIUS * 2, RADIUS * 2);}@Overridepublic boolean onTouchEvent(MotionEvent event) {final int x = (int) event.getX();final int y = (int) event.getY();// 这个位置表示的是,画shader的起始位置matrix.setTranslate(RADIUS - x * FACTOR, RADIUS - y * FACTOR);drawable.getPaint().getShader().setLocalMatrix(matrix);// bounds,就是那个圆的外切矩形drawable.setBounds(x - RADIUS, y - RADIUS, x + RADIUS, y + RADIUS);invalidate();return true;}@Overridepublic void onDraw(Canvas canvas) {super.onDraw(canvas);canvas.drawBitmap(bitmap, 0, 0, null);drawable.draw(canvas);}}


基本原理就是使用ShapeDrawable构造一个圆形的drawable,然后它的paint的shader设置为将要放大的图片,然后就是简单的位置移动问题了。放大镜的半径和放大倍数都可以在代码里面修改,代码都有注释,应该很好理解了。

不过,一个问题如果只有一种解决方法的话,那未免有点令人沮丧,想玩点另类的都不行。
玩程序就得玩出个性,玩出激情。哈哈,废话太多,切回正题。


再来看看放大镜的另外一种实现吧

public class PathView extends View {private final Path mPath = new Path();private final Matrix matrix = new Matrix();private final Bitmap bitmap;// 放大镜的半径private static final int RADIUS = 80;// 放大倍数private static final int FACTOR = 2;private int mCurrentX, mCurrentY;public PathView(Context context) {super(context);mPath.addCircle(RADIUS, RADIUS, RADIUS, Direction.CW);matrix.setScale(FACTOR, FACTOR);bitmap = BitmapFactory.decodeResource(getResources(), R.drawable.demo);}@Overridepublic boolean onTouchEvent(MotionEvent event) {mCurrentX = (int) event.getX();mCurrentY = (int) event.getY();invalidate();return true;}@Overridepublic void onDraw(Canvas canvas) {super.onDraw(canvas);// 底图canvas.drawBitmap(bitmap, 0, 0, null);// 剪切canvas.translate(mCurrentX - RADIUS, mCurrentY - RADIUS);canvas.clipPath(mPath);// 画放大后的图canvas.translate(RADIUS - mCurrentX * FACTOR, RADIUS - mCurrentY* FACTOR);canvas.drawBitmap(bitmap, matrix, null);}}


这里使用的是Path类,将canvas剪切出一块圆形区域,在其上绘制放大的部分。
下面我们用这个工具来查看一套PC配置,让你看得更清楚,工程下载地址http://download.csdn.net/detail/hustpzb/4523274



更多相关文章

  1. Android中图片的放大和缩小源码
  2. android缩放大图片加载
  3. Android(安卓)之多点触摸 手势拉伸放大缩小图片 并在ImageView上
  4. Android(安卓)WebView加载HTML表单并通过javascript提交
  5. Android手势放大缩小组件
  6. Android(安卓)P 中的新文本特性
  7. android中图片的拖拉和缩放
  8. android从手机内存获得图片并全屏显示
  9. Android中图片的放大和缩小源码

随机推荐

  1. 【Android(安卓)基础】Progressbar 实现L
  2. Dagger2使用介绍(下篇)
  3. 日期对话框DatePickerDialog
  4. android录制音频的时,报错setAudioSource
  5. Android(安卓)编译出错版本匹配问题解决
  6. Android(安卓)Parcelable对象生成:Parcela
  7. android开发笔记之Button的圆角和按下效
  8. android studio不能运行
  9. android 通话记录插入 短信插入 联系人插
  10. LeakCanary笔记