android学习12——重载SurfaceView一些方法的执行顺序

先看代码

public class SurfaceViewActivity extends Activity {
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        requestWindowFeature(Window.FEATURE_NO_TITLE);
        getWindow().setFlags(
                WindowManager.LayoutParams.FLAG_FULLSCREEN,
                WindowManager.LayoutParams.FLAG_FULLSCREEN);
        setContentView(new MySurfaceView(this));
    }
}
public class MySurfaceView extends SurfaceView implements SurfaceHolder.Callback {
    private SurfaceHolder surfaceHolder;
    private Paint paint;
    public MySurfaceView(Context context) {
        super(context);
        surfaceHolder = getHolder();
        surfaceHolder.addCallback(this);
        paint = new Paint();
        paint.setColor(Color.RED);
    }

    @Override
    public void surfaceCreated(SurfaceHolder holder) {
        Log.i("Logzy", Thread.currentThread().getName() + ":surfaceCreated");
        myDraw();
    }

    @Override
    public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) {
        Log.i("Logzy", Thread.currentThread().getName() + ":surfaceChanged");
    }

    @Override
    public void surfaceDestroyed(SurfaceHolder holder) {
        Log.i("Logzy", Thread.currentThread().getName() + ":surfaceDestroyed");
    }

    private void myDraw() {
        Canvas canvas = surfaceHolder.lockCanvas();
        canvas.drawRect(0, 0, 100, 100, paint);
        surfaceHolder.unlockCanvasAndPost(canvas);
    }

    @Override
    public void onWindowFocusChanged(boolean hasWindowFocus) {
        super.onWindowFocusChanged(hasWindowFocus);
        Log.i("Logzy", Thread.currentThread().getName() + ":onWindowFocusChanged");
    }
}

重写了surfaceCreated,surfaceChanged,surfaceDestroyed,onWindowFocusChanged这几个方法.运行程序,结果是:

04-13 08:56:03.111  13682-13682/edu.cgxy.surfaceview I/Logzymain:surfaceCreated
04-13 08:56:03.111  13682-13682/edu.cgxy.surfaceview I/Logzymain:surfaceChanged
04-13 08:56:03.141  13682-13682/edu.cgxy.surfaceview I/Logzymain:onWindowFocusChanged

再把程序切换到后台,结果是

04-13 08:59:49.661  13682-13682/edu.cgxy.surfaceview I/Logzymain:onWindowFocusChanged
04-13 08:59:49.791  13682-13682/edu.cgxy.surfaceview I/Logzymain:surfaceDestroyed

posted on   荷楠仁  阅读(1107)  评论(0编辑  收藏  举报

编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义

导航

统计

点击右上角即可分享
微信分享提示