大家好,今天小编关注到一个比较有意思的话题,就是关于手机放大镜做法图纸的问题,于是小编就整理了1个相关介绍手机放大镜做法图纸的解答,让我们一起看看吧。
可以通过以下步骤实现安卓图片局部放大镜效果:
1. 创建一个自定义的ImageView,继承自ImageView类。
2. 在onDraw()方法中,首先调用父类的onDraw()方法,绘制原始图片。
3. 然后根据触摸事件获取当前触摸点的坐标,以及放大镜的半径和中心点。
4. 把触摸点作为中心,根据半径画一个圆,然后裁剪出这个圆。
5. 接着,把原图按照当前放大倍数绘制到画布上,由于裁剪过,只有局部图像显示出来。
6. 最后,再画一个圆框,把局部图像圆形显示出来。
代码示例:
public class MagnifierImageView extends ImageView implements View.OnTouchListener {
nbsp; nbsp; private int radius;//放大镜半径
nbsp; nbsp; private int centerX;//放大镜中心x坐标
nbsp; nbsp; private int centerY;//放大镜中心y坐标
nbsp; nbsp; private int scale = 2;//放大倍数
nbsp; nbsp; private Paint circlePaint;//画圆的画笔
nbsp; nbsp; private Paint bitmapPaint;//绘制bitmap的画笔
nbsp; nbsp; private Bitmap bitmap;//原始图片
nbsp; nbsp; public MagnifierImageView(Context context) {
nbsp; nbsp; nbsp; nbsp; super(context);
nbsp; nbsp; nbsp; nbsp; init();
nbsp; nbsp; }
nbsp; nbsp; public MagnifierImageView(Context context, AttributeSet attrs) {
nbsp; nbsp; nbsp; nbsp; super(context, attrs);
nbsp; nbsp; nbsp; nbsp; init();
nbsp; nbsp; }
nbsp; nbsp; public MagnifierImageView(Context context, AttributeSet attrs, int defStyleAttr) {
nbsp; nbsp; nbsp; nbsp; super(context, attrs, defStyleAttr);
nbsp; nbsp; nbsp; nbsp; init();
nbsp; nbsp; }
nbsp; nbsp; //初始化操作
nbsp; nbsp; private void init() {
nbsp; nbsp; nbsp; nbsp; circlePaint = new Paint();
nbsp; nbsp; nbsp; nbsp; circlePaint.setColor(Color.WHITE);
nbsp; nbsp; nbsp; nbsp; circlePaint.setStyle(Paint.Style.STROKE);
nbsp; nbsp; nbsp; nbsp; circlePaint.setStrokeWidth(2);
nbsp; nbsp; nbsp; nbsp; setOnTouchListener(this);
nbsp; nbsp; }
nbsp; nbsp; @Override
nbsp; nbsp; protected void onDraw(Canvas canvas) {
nbsp; nbsp; nbsp; nbsp; super.onDraw(canvas);
nbsp; nbsp; nbsp; nbsp; if (bitmap == null) {
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //获取原始图片
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; Drawable drawable = getDrawable();
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; if (drawable != null) {
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; bitmap = ((BitmapDrawable) drawable).getBitmap();
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; }
nbsp; nbsp; nbsp; nbsp; }
nbsp; nbsp; nbsp; nbsp; if (bitmap != null) {
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //绘制圆形
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; canvas.drawCircle(centerX, centerY, radius, circlePaint);
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //根据放大倍数获取局部图像
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; int x = centerX - radius;
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; int y = centerY - radius;
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; int width = radius * 2;
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; Bitmap tempBitmap = Bitmap.createBitmap(bitmap, x, y, width, width);
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //缩小局部图像
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; Bitmap scaledBitmap = Bitmap.createScaledBitmap(tempBitmap, width / scale, width / scale, false);
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //绘制局部图像
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; canvas.drawBitmap(scaledBitmap, x radius / (scale * 2), y radius / (scale * 2), bitmapPaint);
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //绘制局部图像的圆框
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; canvas.drawCircle(centerX, centerY, radius / scale, circlePaint);
nbsp; nbsp; nbsp; nbsp; }
nbsp; nbsp; }
nbsp; nbsp; @Override
nbsp; nbsp; public boolean onTouch(View view, MotionEvent motionEvent) {
nbsp; nbsp; nbsp; nbsp; switch (motionEvent.getAction()) {
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; case MotionEvent.ACTION_DOWN:
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; case MotionEvent.ACTION_MOVE:
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //获取触摸点坐标
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; centerX = (int) motionEvent.getX();
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; centerY = (int) motionEvent.getY();
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //设置放大镜半径
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; radius = getWidth() / 6;
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //重绘界面
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; invalidate();
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; break;
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; case MotionEvent.ACTION_UP:
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; //取消放大镜
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; radius = ;
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; invalidate();
nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; nbsp; break;
nbsp; nbsp; nbsp; nbsp; }
nbsp; nbsp; nbsp; nbsp; return true;
nbsp; nbsp; }
}
在布局文件中引用该自定义ImageView即可:
lt;com.example.MagnifierImageView
nbsp; nbsp; nbsp;android:id=#34;@ id/imageView#34;
nbsp; nbsp; nbsp;android:layout_width=#34;wrap_content#34;
nbsp; nbsp; nbsp;android:layout_height=#34;wrap_content#34;
nbsp; nbsp; nbsp;android:src=#34;@drawable/test_image#34;/gt;请问您需要我继续做什么?
安卓图片局部放大镜效果做的方法如下:
1首先准备好需要编辑的图片
2接下来把在图片上鼠标右键,然后打开方式选择FSCapture打开
3打开图片后,点击菜单栏上的绘制按钮
4然后点击左侧菜单栏上的 圆圈加号( )号这个按钮
关于手机放大镜做法图纸和手机放大镜做法图纸怎么画的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。 手机放大镜做法图纸的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于手机放大镜做法图纸怎么画、手机放大镜做法图纸的信息别忘了在本站进行查找喔。
[免责声明]本文来源于网络,不代表本站立场,如转载内容涉及版权等问题,请联系邮箱:3801085100@qq.com,我们会予以删除相关文章,保证您的权利。
转载请注明出处:http://www.woglobalmarket.com/yundongyangsheng/ws/12983.html
相关热词:
时间:2024-07-10
时间:2024-08-07
时间:2024-04-24
时间:2024-08-05
时间:2024-11-30
时间:2024-04-07
时间:2024-05-11
时间:2024-08-06
时间:2024-09-09
时间:2024-09-17
时间:2024-08-19
时间:2024-08-17
时间:2024-07-27
时间:2024-09-01
时间:2024-06-12
时间:2024-11-17