前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android画图之抗锯齿 博客分类: Android小技巧 Android

Android画图之抗锯齿 博客分类: Android小技巧 Android

作者头像
chroya
发布2018-10-31 17:37:01
2.8K0
发布2018-10-31 17:37:01
举报
文章被收录于专栏:封碎

    在画图的时候,图片如果旋转或缩放之后,总是会出现那些华丽的锯齿。其实Android自带了解决方式。     方法一:给Paint加上抗锯齿标志。然后将Paint对象作为参数传给canvas的绘制方法。

代码语言:javascript
复制
paint.setAntiAlias(true);

    方法二:给Canvas加上抗锯齿标志。 有些地方不能用paint的,就直接给canvas加抗锯齿,更方便。

代码语言:javascript
复制
canvas.setDrawFilter(new PaintFlagsDrawFilter(0, Paint.ANTI_ALIAS_FLAG|Paint.FILTER_BITMAP_FLAG));

      测试代码如下:

代码语言:javascript
复制
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Matrix;
import android.graphics.Paint;
import android.graphics.PaintFlagsDrawFilter;
import android.view.View;

public class MyView extends View {
	private PaintFlagsDrawFilter pfd;
	private Paint mPaint = new Paint();
	private Matrix matrix = new Matrix();;
	private Bitmap bmp;

	public MyView(Context context) {
		super(context);
		initialize();
	}

	private void initialize() {
		pfd = new PaintFlagsDrawFilter(0, Paint.ANTI_ALIAS_FLAG|Paint.FILTER_BITMAP_FLAG);		
		mPaint.setAntiAlias(true);
		matrix.setRotate(30);
		matrix.postScale(0.5f, 0.5f);
		bmp = BitmapFactory.decodeResource(getResources(), R.drawable.show);
	}
	
	@Override
	public void dispatchDraw(Canvas canvas) {
		canvas.translate(100, 0);
		canvas.drawBitmap(bmp, matrix, null);
		canvas.translate(0, 250);
		canvas.drawBitmap(bmp, matrix, mPaint);
		canvas.setDrawFilter(pfd);
		canvas.translate(0, 250);
		canvas.drawBitmap(bmp, matrix, null);
	}
}

下图是效果:

      可以看出,两种方式都挺有效的。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2010-10-26 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档