问题:
需求中需要页面返回时有动画,开发时使用了ActivityOptions sharedelements ,但是由于页面中有surfaceview(相机sdk使用了surfaceview,暂时无法改为textureview),而surfaceview无法跟随动画(高版本机型有些可以),所以需要先把surfaceview隐藏,用黑色背景替换,然后再执行动画,但是碰到了surfaceview gone掉时,瞬间透明,漏出了底下的activity,比较明显的bug。
解决:
思路:先改变surfaceview的大小,设为1
//动画启动前,隐藏 surfaceview
view_surface.post {
hepai_view_surface.updateLayoutParams<ViewGroup.LayoutParams> {
width = 1
height = 1
}
view_surface.holder.setFixedSize(1,1)
}
//在大小变化后,再将surfaceview设置为gone
override fun surfaceChanged(holder: SurfaceHolder, format: Int, width: Int, height: Int) {
restartPreview()
if (width ==1 && isHide) {
currentHolder = null
stopCamera()
surfaceView?.visibility = View.GONE
}
}
网友评论