Android中一种常见的自定义画UI接口类:SurfaceView.可以在异步线程中,完成相关数据更新。

首先介绍几个基本的定义,在其他知识中也会设计如下名词:

1.Paint

  画笔,所有的图像、图形都是由画笔完成的。

  定义非常简单:

  Paint paint = new Paint();

  paint.setColor(Color.Black);//设置画笔的颜色

2.Canvas

  画布,图像和图形都是通过Paint画在画布上面。画布对象通常是通过SurfaceHolder.lockCanvax()获得。

  Canvas canvas = holder.lockCanvas();

  canvas.drawRect(0,0,widht,height,paint);//画矩形

3.Surface

  在应用的时候,没有使用到具体的实现类和抽象类。

  API里面的描述是:Surface是原始图像缓存区的一个句柄(原始图像缓存区是有屏幕图像合成器管理的)。因此,可以知道Canvas所需要展示的数据,会被加载到Surface中,然后显示在屏幕上的。  

4.SurfaceView

  一个屏幕显示的View,控制Surface的显示大小,位置等。说白了就类似TextView一样。

  需要子类实现具体的制订化功能,继承SurfaceView的同时,还需要实现SurfaceHolder.Callback接口(后面有讲解)。

5.SurfaceHolder

  怎么能说清楚呢,SurfaceHolder是Surface的控制器,提供几个方法:

  addCallback(SurfaceHolder.Callback callback); //添加SurfaceHolder.Callback的监听实现

  lockCanvas();

  lockCanvas(Rect dirty);

  unlockCanvas(Canvas canvas);

6.SurfaceHolder.Callback

  是一个接口,实现类可以监听SurfaceView的状态变化。接口方法如下:

  surfaceCreated();

  surfaceChanged();

  surfaceDestory();

  

具体使用Demo,完成的功能就是将一张图片,上下不停的滑动:

1、RBSurfaceView 是Surface的实现类。

public class RBSurfaceView extends SurfaceView implements SurfaceHolder.Callback{
    private Paint paint;
    private WindowManager windowManager;
    private Context context;
    private float screenWidth,screenHeight;
    private float bitmapX,bitmapY;
    private int alphaNum;
    private boolean alphaFlag ;
    
    private OnRunThread onRunThread;
    private OnDrawThread onDrawThread;
    
    @SuppressWarnings("deprecation")
    public RBSurfaceView(Context context) {
        super(context);
        // TODO Auto-generated constructor stub
        this.context = context;
        getHolder().addCallback(this);
        windowManager = (WindowManager) getContext().getSystemService(Context.WINDOW_SERVICE);
        screenWidth = (float) windowManager.getDefaultDisplay().getWidth();
        screenHeight =(float)  windowManager.getDefaultDisplay().getHeight();
        paint = new Paint();
        onRunThread = new OnRunThread(this);
        onDrawThread = new OnDrawThread(this);
        onRunThread.start();
    }
    @Override
    protected void onDraw(Canvas canvas) {
        // TODO Auto-generated method stub
        super.onDraw(canvas);
        paint.setColor(Color.WHITE);
        canvas.drawRect(0, 0, screenWidth, screenHeight, paint);
        Bitmap bitmapA = BitmapFactory.decodeResource(context.getResources(), R.drawable.ic_launcher);
        canvas.drawBitmap(bitmapA, bitmapX, bitmapY, paint);
        if (alphaFlag) {
            Bitmap bitmapB = BitmapFactory.decodeResource(context.getResources(), R.drawable.icon_gcoding);
            paint.setAlpha(alphaNum);
            canvas.drawBitmap(bitmapB, 0, 0, paint);
        }
    }
    @Override
    public void surfaceCreated(SurfaceHolder holder) {
        // TODO Auto-generated method stub
        onDrawThread.start();
    }

@Override
    public void surfaceChanged(SurfaceHolder holder, int format, int width,
            int height) {
        // TODO Auto-generated method stub
        
    }

@Override
    public void surfaceDestroyed(SurfaceHolder holder) {
        // TODO Auto-generated method stub
        
    }
    public float getBitmapX() {
        return bitmapX;
    }
    public void setBitmapX(float bitmapX) {
        this.bitmapX = bitmapX;
    }
    public float getBitmapY() {
        return bitmapY;
    }
    public void setBitmapY(float bitmapY) {
        this.bitmapY = bitmapY;
    }
    public int getAlphaNum() {
        return alphaNum;
    }
    public void setAlphaNum(int alphaNum) {
        this.alphaNum = alphaNum;
    }
    public float getScreenWidth() {
        return screenWidth;
    }
    public void setScreenWidth(float screenWidth) {
        this.screenWidth = screenWidth;
    }
    public float getScreenHeight() {
        return screenHeight;
    }
    public void setScreenHeight(float screenHeight) {
        this.screenHeight = screenHeight;
    }
    public boolean isAlphaFlag() {
        return alphaFlag;
    }
    public void setAlphaFlag(boolean alphaFlag) {
        this.alphaFlag = alphaFlag;
    }
}
  

2、OnDrawThread 是不停的让RBSurfaceView的onDraw方法画图片

public class OnDrawThread extends Thread{
    private RBSurfaceView surfaceView;
    private SurfaceHolder holder;
    public OnDrawThread(RBSurfaceView surfaceView){
        super();
        this.surfaceView = surfaceView;
        holder = surfaceView.getHolder();
    }
    @Override
    public void run() {
        // TODO Auto-generated method stub
        super.run();
        Canvas canvas = null;
        while (true) {
            canvas = holder.lockCanvas(null);
            synchronized (surfaceView) {
                if (canvas != null) {
                    surfaceView.onDraw(canvas);
                }    
            }
            holder.unlockCanvasAndPost(canvas);
            try {
                Thread.sleep(30);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            
        }
    }
}

3、OnRunThread 主要负责不停的变化图片的坐标,然后设置给RBSurfaceView。

public class OnRunThread extends Thread{
    private RBSurfaceView surfaceView;
    private SurfaceHolder holder;
    public OnRunThread(RBSurfaceView surfaceView){
        super();
        this.surfaceView = surfaceView;
        holder = surfaceView.getHolder();
        bitmapX = 0;
        bitmapY = 0;
    }
    boolean runFlag;
    int alphaNum;
    float bitmapX;
    float bitmapY;
    @Override
    public void run() {
        // TODO Auto-generated method stub
        super.run();
        while (true) {
            while (bitmapX < surfaceView.getScreenWidth()) {
                surfaceView.setBitmapX(bitmapX);
                surfaceView.setBitmapY(bitmapY);
                if (runFlag) {
                    bitmapY = bitmapY - 20;
                }else {
                    bitmapY = bitmapY + 20;
                }
                if (bitmapY <=0) {
                    runFlag = false;
                }else if (bitmapY >= surfaceView.getScreenHeight()+60) {
                    runFlag = true;
                }
                try {
                    Thread.sleep(30);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
            
            surfaceView.setAlphaFlag(true);
            for (alphaNum = 0; alphaNum <= 255; alphaNum++) {
                if (alphaNum == 255) {
                    surfaceView.setAlphaFlag(false);
                    bitmapX = 0;
                    bitmapY = surfaceView.getScreenHeight() +60;
                }
                surfaceView.setAlphaNum(alphaNum);
                try {
                    Thread.sleep(20);
                } catch (InterruptedException e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }                
            }
        }
    }
}

  

  

    

Android 开发 SurfaceView 总结的更多相关文章

  1. Android开发学习清单

    目录: 第1章 Android应用与开发环境1.1 Android的发展和历史1.1.1 Android的发展和简介1.1.2 Android平台架构及特性1.2 搭建Android开发环境1.2.1 ...

  2. Android使用SurfaceView实现墨迹天气的风车效果

    SurfaceView也是继承自View,它和我们以前接触到的View(Button.TextView等)最大的不同是,SurfaceView可以有一个单独的线程进行绘制,这个线程区别于UI线程(主线 ...

  3. Android开发中的问题及相应解决(持续更新)

    最近博客写的少了,以后还得经常更新才行. ------------------------------------------------------------ 1.特定业务需求下try cath ...

  4. Android之SurfaceView学习(一)

    对应的中文翻译SurfaceView是视图(View)的继承类,这个视图里内嵌了一个专门用于绘制的Surface.你可以控制这个Surface的格式和尺寸.Surfaceview控制这个Surface ...

  5. 【随笔】android开发的学习路线

    第一阶段:Java面向对象编程 1.Java基本数据类型与表达式,分支循环. 2.String和StringBuffer的使用.正则表达式. 3.面向对象的抽象,封装,继承,多态,类与对象,对象初始化 ...

  6. Android开发中,那些让您觉得相见恨晚的方法、类或接口

    Android开发中,那些让你觉得相见恨晚的方法.类或接口本篇文章内容提取自知乎Android开发中,有哪些让你觉得相见恨晚的方法.类或接口?,其实有一部是JAVA的,但是在android开发中也算常 ...

  7. Android开发面试经——4.常见Android进阶笔试题(更新中...)

      Android开发(29)  版权声明:本文为寻梦-finddreams原创文章,请关注:http://blog.csdn.net/finddreams 关注finddreams博客:http:/ ...

  8. [转]【eoeAndroid索引】史上最牛最全android开发知识汇总

    一.开发环境搭建 (已完成) 负责人:kris 状态:已完成 所整理标签为:搭建 SDK JDK NDK Eclipse ADT 模拟器 AVD 调试器(DEBUG) DDMS 测试 日志 Logca ...

  9. android开发的学习路线(转)

    第一阶段:Java面向对象编程 1.Java基本数据类型与表达式,分支循环. 2.String和StringBuffer的使用.正则表达式. 3.面向对象的抽象,封装,继承,多态,类与对象,对象初始化 ...

随机推荐

  1. Spark学习之路 (十七)Spark分区[转]

    分区的概念 分区是RDD内部并行计算的一个计算单元,RDD的数据集在逻辑上被划分为多个分片,每一个分片称为分区,分区的格式决定了并行计算的粒度,而每个分区的数值计算都是在一个任务中进行的,因此任务的个 ...

  2. 纪中10日T1 2313. 动态仙人掌

    纪中10日 2313. 动态仙人掌 (File IO): input:dinosaur.in output:dinosaur.out 时间限制: 1500 ms  空间限制: 524288 KB  具 ...

  3. 纪中10日T3 2296. 神殿 bfs

    2296. 神殿 (File IO): input:temple.in output:temple.out 时间限制: 1500 ms  空间限制: 524288 KB  具体限制 Goto Prob ...

  4. IIS7启用ASP程序的步骤。

    IIS7配置asp程序 https://www.cnblogs.com/rollup/p/4969502.html

  5. [Python]PyCharm中%matplotlib inline报错

    %matplotlib作用 是在使用jupyter notebook 或者 jupyter qtconsole的时候,才会经常用到%matplotlib,也就是说那一份代码可能就是别人使用jupyte ...

  6. html里面用Jquery移除tr元素后,滚动条会回到顶部问题处理

    问题如下图,删除一行后,滚动条会自动回到顶部,即使先把滚动条禁止也还是会回到顶部 参考这个 https://bbs.csdn.net/topics/392233437 发现确实自己的按钮事件写在了a标 ...

  7. jQuery笔记(二)jQuery中DOM操作

    前言 本篇主要介绍DOM操作,在说DOM操作之前,首先我们应该熟悉DOM树,以一个例子为例来说明DOM树.首先看这段HTML代码.(本文后面的代码如果没有特别指出,都是针对下述HTML代码进行操作) ...

  8. Java设计模式(一)UML总结

    定义 统一建模语言(英语: Unified Modeling Language ,缩写UML)是非专利的第三代建模和规约语言. UML特点 UML是一种开放的方法 用于说明.可视化.构建和编写一个正在 ...

  9. simmon effect(psychology experiment) : this time, we add file_function who can creat a file in the window which contains our result

    #the real experiment for simon effect #load the library which is our need import pygame import sys i ...

  10. react-父子子孙组件嵌套-context

    方案一 import React from 'react' import ReactTypes from 'prop-types' /* // 最外层的父组件 export default class ...