在BitmapDecode这个例子中,从里面可以学到有流转化为字节数组,同时有两种读取留图片的方法,还有两种现在图片的方法,但是我觉得在这里最好用的还是能显示出gif效果,通常gif图片是只显示第一的。
首先是将图片转化为流java.io.InputStream is;
is = context.getResources().openRawResource(R.drawable.beach);
后面就有两种实现:bm = BitmapFactory.decodeStream(is, null, opts);
BitmapFactory.decodeStream(is);
第二种很简单了 关键是第一种的第三个参数:
BitmapFactory.Options opts = new BitmapFactory.Options();
Bitmap bm;
opts.inJustDecodeBounds = false; // this will request the bm 默认是false 如果设置为true 那么返回的图像是为null 这点注意。
// scaled down by 4 默认为1 只要《=1 就是显示原图片的大小,其他的你设置为4就是原图片的1/4倍大小。
opts.inSampleSize = 4;
bm = BitmapFactory.decodeStream(is, null, opts);
后面呢 就是从一个图像复制另一个图像了,这里用到了复制色素的数组:
int w = mBitmap2.getWidth();
int h = mBitmap2.getHeight();
int[] pixels = new int[w*h];
mBitmap2.getPixels(pixels, 0, w, 0, 0, w, h);
mBitmap3 = Bitmap.createBitmap(pixels, 0, w, w, h,
Bitmap.Config.ARGB_4444);
在后面的代码 就是实现gif图像的了:
is = context.getResources().openRawResource(R.drawable.a3);
mMovie = Movie.decodeStream(is);
或者呢
byte[] array = streamToBytes(is);
mMovie = Movie.decodeByteArray(array, 0, array.length);
如果这么做还不能完全实现动态效果,必须是时时更新画面,才可以达到播放gif效果:
long now = android.os.SystemClock.uptimeMillis();
if (mMovieStart == 0) { // first time
mMovieStart = now;
}
if (mMovie != null) {
int dur = mMovie.duration();
Log.i("dur","AA"+dur);
if (dur == 0) {
dur = 300;
}
int relTime = (int)((now - mMovieStart) % dur);
mMovie.setTime(relTime);
// mMovie.draw(canvas, getWidth() - mMovie.width(), getHeight() - mMovie.height());
mMovie.draw(canvas, 150,250);
invalidate();
}
上面的代码中最重要的就是 mMovie.setTime(relTime); 里面的参数必须是变化的 不然也只有第一帧动画
invalidate();也是必须的
其他的细节就是画图了:
两种方法,也说不上两种方法了 只要注意就好:
canvas.drawBitmap(mBitmap4, 210, 170, null);
mDrawable.draw(canvas);
第二种只是当你设置setBounds属性的时候,画图显示只能采用这种方法而不能采用上面的方法。
mDrawable = context.getResources().getDrawable(R.drawable.button);
mDrawable.setBounds(150, 20, 300, 100);