su易做图ceview详解
周末看《精通Android游戏开发》(Pro Android Games),里面讲到游戏的框架,其中一个重要的概念su易做图ceview,觉得不是很理解,于是花了一点时间研究了下,写下自己的心得。
su易做图ce,这个单词的意思是浮在表面的,那么su易做图ceview就是浮在表面的view了。如果真的这样解释,估计有人要拍砖了。然而,话虽不能这么说,取这个名儿,多少还是有点关系的。su易做图ce是一个可见区域。
我们在屏幕上看到的这些view,在屏幕上看到的就是画面,在内存中就是一块内存区。绘图的时候,就是显示的硬件如显卡将内存区的这块图形数据绘制到屏幕上。所以,从内存的角度去看这些东西,会比较好理解。
su易做图ce是su易做图ceview中的一个可见部分。我们知道,我们看到的屏幕上的图形,是二维的,我们看到的就是长和宽,其实,在内部实际上是三维的,另一个维度,就是层layer。我们用visio绘图,都会看到这种情况,一个图形会将另个图形遮住,是因为这个图形在上层。如果有同AutoCAD的经验,对这个更容易理解。我们看到的图形实际上是很多图形一层层的叠加在一起的,这些图形元素完全不可见,或者部分可见部分不可见,或者完全可见。
这样看来,su易做图ce就可以这样理解:它是内存中一块区域,它是su易做图ceview可见不那个部分,绘图操作作用于它,然后它就会被显卡之类的显示控制器绘制到屏幕上。
su易做图ce是个啥,大概已经有了些概念了。因为它对应了一个内存区,大家都知道,内存区的对象是有生命周期的,可以动态的申请创建和销毁,当然也可能会更新。于是,就有了作用于这个内存区的操作,这些操作就是su易做图ceCreated/Changed/Destroyed。三个操作放在一起,就是callback,
所以在很多例子里看到,会有callback。
callback,是回调,意思是自己能干一些活,不过自己不去主动做,而是到别人那里去登记一下,别人需要的时候,就会叫我去做。就这个例子而言,可以打这个比方,某建筑工人队伍A,能盖房子,能装修,也能拆房子。可是他自己不去主动的做这些事情,而是去向开发商B去登记这三种能力,当然了,他把这三种能力打了包,叫做A的能力。啥时候,B有活干了,就叫A去做,或者是盖房子,或者是装修,或者是拆建筑。在这个例子中,能力包就是callback.
说了这个例子,其实就解释了 su易做图ce相关的一些东西,callback已经说过了,下面来说说其他的。假设su易做图ce就是一栋房子,那么su易做图ce拥有su易做图ceHolder,谁呢?在这个例子中好比建筑队A。盖房子对应的就是su易做图ceCreated, 拆房子就对应了su易做图ceDestroyed,装修就对应了su易做图ceChanged.
su易做图ce有生存期,好比房子有生存期,在建造以后就存在,在拆了之后就没有了。装修必须发生在这之间。同样的,su易做图ce的change必须发生在created和destroyed之间。
su易做图ceview知道su易做图ce的holder是谁,在su易做图ceview生成的时候,会调用getHolder得到holder,然后holder会调用addCallback将三个callback函数注册。
holder拥有对于su易做图ce的控制权。在很多程序中,会在su易做图ceCreated的函数实现中创建另一个线程。所以在这里有两个线程,一个是UI线程,另一个负责画图的线程。画图线程由UI线程调用su易做图ceCreated的时候创建,在su易做图ceDestroyed调用的时候放回到线程池。在这中间,画图线程负责图形的绘制。
在这种模型下,UI线程和画图线程各司其职,前者主要负责和用户的交互,而后者,在负责绘制图形。这样,绘制图形的时候如果时间较长,不会阻塞用户的输入。
我们知道,线程共享内存数据,所以, su易做图ce对于两个线程是共享的。所以,为了避免在画图的时候,UI线程也对su易做图ce进行操作,在画图前,需要对su易做图ce加锁。这个工作是有holder干的,holder会先锁住su易做图ce中的一块holder.lockCanvas,我们叫canvas,然后,在上面绘画,画完之后,会解锁unlockCanvasAndPost。
在 应用中,画图可以是一次性的,也可以是由定时器触发的定时的画。实现的都是runnable类中的run方法。关于runnable类,这个Java中定义的,并不是android独有的,可以参考Java的referrence.
这个模型最大的好处就是,画图不依赖于UI线程,不会阻塞UI线程。
而单纯的view是依赖于UI线程画图的。对于完全依赖于用户的输入进行图像显示的更新的,用view是可以的,但是如果能够自动的进行绘图,而不需等待用户的输入,su易做图ceview无疑是更好的选择。
有图有易做图,请看图
摘自 爱心觉罗氏
补充:移动开发 , Android ,