canvas教程

Android学习笔记之Bitmap位图的旋转

字号+ 作者:H5之家 来源:H5之家 2015-11-12 11:15 我要评论( )

这里演示了加密文本,利用特定字符来定位位置sockdata=PHIDOHBBNIEFMNDIBJLENNEBBODILAEAPMIHHKMKBOKILJOJHGPDDBEOPMCEMLAPJNFDLOJCPHEAMEDNPINODFMBMLFPFHLLGBN

位图的旋转也可以借助Matrix或者Canvas来实现。

通过postRotate方法设置旋转角度,然后用createBitmap方法创建一个经过旋转处理的Bitmap对象,最后用drawBitmap方法绘制到屏幕上,于是就实现了旋转操作。

下面例子中把原位图和经旋转处理的位图都绘制到屏幕上,目的是做一个对比。

package xiaosi.bitmap; import android.app.Activity; import android.os.Bundle; public class mianActivity extends Activity { private BitmapView bitmapView = null; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); bitmapView = new BitmapView(this); setContentView(bitmapView); } }


BitmapView.java

package xiaosi.bitmap; import android.content.Context; import android.content.res.Resources; import android.graphics.Bitmap; import android.graphics.BitmapFactory; import android.graphics.Canvas; import android.graphics.Color; import android.graphics.Matrix; import android.view.View; public class BitmapView extends View { public BitmapView(Context context) { super(context); } //重写onDraw方法 public void onDraw(Canvas canvas) { // 获取资源文件的引用res Resources res = getResources(); // 获取图形资源文件 Bitmap bmp = BitmapFactory.decodeResource(res, R.drawable.h); // 设置canvas画布背景为白色 canvas.drawColor(Color.BLACK); // 在画布上绘制缩放之前的位图,以做对比 //屏幕上的位置坐标是0,0 canvas.drawBitmap(bmp, 0, 0, null); // 定义矩阵对象 Matrix matrix = new Matrix(); // 缩放原图 matrix.postScale(1f, 1f); // 向左旋转45度,参数为正则向右旋转 matrix.postRotate(-45); //bmp.getWidth(), 500分别表示重绘后的位图宽高 Bitmap dstbmp = Bitmap.createBitmap(bmp, 0, 0, bmp.getWidth(), 500, matrix, true); // 在画布上绘制旋转后的位图 //放在坐标为0,200的位置 canvas.drawBitmap(dstbmp, 0, 200, null); } }


 

源代码下载:点击打开链接

 

 

 

版权声明:本文为博主原创文章,未经博主允许不得转载。

 

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

相关文章
  • HTML5新特性详解(三)

    HTML5新特性详解(三)

    2017-04-30 16:03

  • 学习慕课网canvas倒计时实例笔记

    学习慕课网canvas倒计时实例笔记

    2017-04-30 14:01

  • 从一个画板demo学习canvas

    从一个画板demo学习canvas

    2017-04-30 13:00

  • canvas的神奇用法 javascript技巧笔记 CFEI.NET

    canvas的神奇用法 javascript技巧笔记 CFEI.NET

    2017-04-30 12:00

网友点评