参考:http://www.iteye.com/topic/710262
前面一篇博文介绍了简单的把Bitmap画到屏幕上,以及缩放Bitmap以铺满屏幕。对Bitmap的操作还有很多。比如截取Bitmap的部分区域,可以使用
mBitmap = Bitmap.createBitmap(bmp, 100, 100, 120, 120);
缩放一个Bitmap,前面一篇已经涉及到了,可以用Bitmap.createScaledBitmap()方法根据给定的Bitmap创建一个新的,缩放后的Bitmap。
Bitmap mBitmap = Bitmap.createScaledBitmap(bmp, mScreenWidth, mScreenHeight, true);
其中mScreenWidth和mScreenHeight是屏幕的宽度和高度,这里就将bmp拉伸到整个屏幕。
每次createBitmap,都会分配新的内存,带来资源的消耗,所以用Bitmap的createBitmap虽然简单方便,但是不是最优方法。介绍一个比较好点的方法,不用创建新的Bitmap,用Canvas在画的时候直接缩放或者剪切
canvas.drawBitmap(mBitmap, null, new Rect(0, 0, 200, 200), null);这里的 Rect 对象表示一个矩形区域,从 (0,0) 到 (200,200) 之间的矩形区域。这段代码将把 mBitmap 缩放并绘制到屏幕上的 (0,0) 到 (200,200) 之间的区域。
效果图:
这个方法还有第二个参数我给的是null,其实这个参数也是个Rect对象,表示源Rect。把图片的某个区域拿出来画到屏幕的指定区域。
canvas.drawBitmap(mBitmap, new Rect(100, 100, 300, 300), new Rect(100, 100, 200, 200), null);这里将 mBitmap 的 (100,100) 到 (300,300) 区域拿出来,自动缩放并画到屏幕的 (100,100) 到 (200,200) 区域。
对于Bitmap的处理,上面介绍的 是最简单的两种,平移和缩放。而要是需要更复杂的处理,比如旋转和倾斜,就得使用Matrix了。下面几篇将介绍Matrix在画图中的使用。
public class ViewActivity extends Activity { /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(new MyView(this)); } public class MyView extends View { private Bitmap mBitmap; private int mScreenWidth; private int mScreenHeight; public MyView(Context context) { super(context); initialize(); } private void initialize() { DisplayMetrics dm = getResources().getDisplayMetrics(); mScreenWidth = dm.widthPixels; mScreenHeight = dm.heightPixels; // Bitmap bmp mBitmap = ((BitmapDrawable)getResources().getDrawable(R.drawable.show)).getBitmap(); // mBitmap = Bitmap.createScaledBitmap(bmp, mScreenWidth, mScreenHeight, true); } @Override protected void onDraw(Canvas canvas) { // super.onDraw(canvas); //当然,如果界面上还有其他元素需要绘制,只需要将这句话写上就行了。 // canvas.drawBitmap(mBitmap, 0, 0, null); // canvas.drawBitmap(mBitmap, null, new Rect(0,0,200,200), null); canvas.drawBitmap(mBitmap, new Rect(100, 100, 300, 300), new Rect(100, 100, 200, 200), null); } } }