今天来介绍我们项目中经常用到的弹出窗口效果,比如等待加载动画,提示信息等等。我们要实现的效果是,弹出一个视图,覆盖到原有视图上,并且弹出视图背后有阴影效果将整个视图遮盖,先上图(临时桥的,很不美观,但是可表达效果)
其实要实现这样的效果很简单:
可能很多同学试过,创建一个透明并且背景为黑色的backgroundView,然后覆盖到self.view上,然后再创建一个提示视图promptView,放到backgroundView上,但是你会发现因为backgroundView设置了alpha值,所以promptView也有他父视图的alpha值,实现的效果就不是我们这样的。其实正确的思路是:
1. 创建一个backgroundView,设置alpha为0.1,背景色为黑色,然后添加到self.view(你需要放置的位置);
2. 创建一个promptView,里面你有想要做的任何操作,比如有文子,有加载动画等等你想要的视图,然后添加到self.view上,注意,这里的promptView和backgroundView是兄弟关系,不是父子关系;
这样就完成了一个类似于弹出窗口。
我们可以把这个功能性的视图封装成一个view叫PromptView,
步骤1:在他的initWithFrame方法中,写
- (instanc