剪切图动画 ClipBitmapMovie

public class ClipBitmapMovie extends Activity{ @Override protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub super.onCreate(savedInstanceState); this.getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, WindowManager.LayoutParams.FLAG_FULLSCREEN); requestWindowFeature(Window.FEATURE_NO_TITLE); setContentView(new ClipBitmapMovieView(this)); } } class ClipBitmapMovieView extends SurfaceView implements Callback,Runnable{ private SurfaceHolder mSurfaceHolder; private Thread mThread; private Canvas mCanvas; private Paint mPaint; private Bitmap mBitmap; private int mCurrentFrame; private boolean mFlag; public ClipBitmapMovieView(Context context) { super(context); mSurfaceHolder=this.getHolder(); mSurfaceHolder.addCallback(this); mPaint=new Paint(); mPaint.setColor(Color.WHITE); mPaint.setAntiAlias(true); } @Override public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) { // TODO Auto-generated method stub } @Override public void surfaceCreated(SurfaceHolder holder) { mFlag=true; mBitmap=BitmapFactory.decodeResource(getResources(), R.drawable.fish); mThread=new Thread(this,"My Thread"); mThread.start(); } @Override public void surfaceDestroyed(SurfaceHolder holder) { mFlag=false; } @Override public void run() { while (mFlag) { long start=System.currentTimeMillis(); myDraw(); logic(); long end=System.currentTimeMillis(); if(((end-start)<50)){ try { Thread.sleep(50-(end-start)); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } } private void logic() { mCurrentFrame++; if(mCurrentFrame>=10){ mCurrentFrame=0; } } private void myDraw() { try { mCanvas=mSurfaceHolder.lockCanvas(); if (mCanvas != null) { mCanvas.drawColor(Color.WHITE); mCanvas.clipRect(0, 0, mBitmap.getWidth()/10, mBitmap.getHeight()); mCanvas.drawBitmap(mBitmap, -mCurrentFrame*mBitmap.getWidth()/10, 0, mPaint); } } catch (Exception e) { // TODO Auto-generated catch block e.printStackTrace(); }finally{ if (mCanvas != null) { mSurfaceHolder.unlockCanvasAndPost(mCanvas); } } } }

问题一:

mCanvas.drawBitmap(mBitmap, -mCurrentFrame*mBitmap.getWidth()/10, 0, mPaint);

刚开始对这个如何画出图片的参数不理解,通过跟踪调试发现当mCurrentFrame=1时,x和y位置参数是-1200/10,0,也就是说画图的坐标原点在x轴的负半轴上,而且mCurrentFrame越大离原点越远,画的时候是画的整幅图片但是因为clipPath()只截取了一帧的大小所以我们看到的只是一个。

所欲可以理解为从坐标原点开始不断将图片网x轴负半轴拉直到图片完全在x轴负半轴,然后重复这个操作。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值