缘由:
Android 画板项目因为性能问题要代码从View迁移到SurfaceView上,重构后的绘画逻辑代码是用的公版的框架,代码逻辑一看再看,硬是一个“canvas绘画轨迹不生效”,先排查了因为SurfaceView双缓冲的线程的同步问题,就猜是不是Android的api的设置问题,看了SurfaceView的源码也是无济于事心都灰了,头发一撮一撮的掉。然后询问上司,让排查是不是显示的层级问题,绘画层被其他内容盖住了,果然姜还是老的辣。
终于给我逮住了小王八蛋子啊啊啊啊
原因分析:
出现BUG的原因在于在原本View的代码逻辑里在代码里调用了一句
setBackgroundColor(Color.WHITE);
在层级关系里面,View层是SurfaceView层的上层,在View层设置Background就把SurfaceView层的内容全盖住了,头头把小弟按住了,太难了。
所以啊,父类代码往子类迁移一定要注意层级关系,重写方法也是有个前后的继承调用关系的,一步小心就中招了。希望不会再犯,太难受了。