设为首页 加入收藏

TOP

Android 双缓冲技术
2014-11-24 03:22:23 来源: 作者: 【 】 浏览:1
Tags:Android 缓冲 技术

先概述一下,双缓冲的核心技术就是先通过setBitmap方法将要绘制的所有的图形会知道一个Bitmap上,然后再来调用drawBitmap方法绘制出这个Bitmap,显示在屏幕上。具体的实现代码如下:


先贴出View类代码:


package com.lbz.pack.test;

import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.graphics.Bitmap.Config;
import android.graphics.drawable.BitmapDrawable;
import android.view.KeyEvent;
import android.view.MotionEvent;
import android.view.View;

public class GameView extends View implements Runnable
{
/* 声明Bitmap对象 */
Bitmap mBitQQ = null;

Paint mPaint = null;

/* 创建一个缓冲区 */
Bitmap mSCBitmap = null;

/* 创建Canvas对象 */
Canvas mCanvas = null;

public GameView(Context context)
{
super(context);

/* 装载资源 */
mBitQQ = ((BitmapDrawable) getResources().getDrawable(R.drawable.qq)).getBitmap();

/* 创建屏幕大小的缓冲区 */
mSCBitmap=Bitmap.createBitmap(320, 480, Config.ARGB_8888);

/* 创建Canvas */
mCanvas = new Canvas();

/* 设置将内容绘制在mSCBitmap上 */
mCanvas.setBitmap(mSCBitmap);

mPaint = new Paint();

/* 将mBitQQ绘制到mSCBitmap上 */
mCanvas.drawBitmap(mBitQQ, 0, 0, mPaint);

/* 开启线程 */
new Thread(this).start();
}

public void onDraw(Canvas canvas)
{
super.onDraw(canvas);

/* 将mSCBitmap显示到屏幕上 */
canvas.drawBitmap(mSCBitmap, 0, 0, mPaint);
}

// 触笔事件
public boolean onTouchEvent(MotionEvent event)
{
return true;
}


// 按键按下事件
public boolean onKeyDown(int keyCode, KeyEvent event)
{
return true;
}


// 按键弹起事件
public boolean onKeyUp(int keyCode, KeyEvent event)
{
return false;
}


public boolean onKeyMultiple(int keyCode, int repeatCount, KeyEvent event)
{
return true;
}


/**
* 线程处理
*/
public void run()
{
while (!Thread.currentThread().isInterrupted())
{
try
{
Thread.sleep(100);
}
catch (InterruptedException e)
{
Thread.currentThread().interrupt();
}
//使用postInvalidate可以直接在线程中更新界面
postInvalidate();
}
}
}


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇Android 读书笔记 下一篇Android 之简单Tween动画设计

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·常用meta整理 | 菜鸟 (2025-12-25 01:21:52)
·SQL HAVING 子句:深 (2025-12-25 01:21:47)
·SQL CREATE INDEX 语 (2025-12-25 01:21:45)
·Shell 传递参数 (2025-12-25 00:50:45)
·Linux echo 命令 - (2025-12-25 00:50:43)