声明全局变量

#define kMainBoundsHeight   ([UIScreen mainScreen].bounds).size.height //屏幕的高度
#define kMainBoundsWidth ([UIScreen mainScreen].bounds).size.width //屏幕的宽度
const CGFloat animalDuration = 0.25; //添加动画延时效果

ViewController.m

//
// ViewController.m
// iPhone
//
// Created by zlw on 2018/4/10.
// Copyright © 2018年 xujinzhong. All rights reserved.
// #import "ViewController.h"
#import "Masonry.h"
#import "ReactiveObjC.h"
#import "showV.h" @interface ViewController () @end @implementation ViewController
{
UIButton *_doneBtn;
} - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib.
self.view.backgroundColor = [UIColor whiteColor]; _doneBtn = [[UIButton alloc] init];
_doneBtn.backgroundColor = [UIColor grayColor];
_doneBtn.layer.cornerRadius = ;
_doneBtn.layer.masksToBounds = YES;
[_doneBtn setTitle:@"show" forState:UIControlStateNormal];
[self.view addSubview:_doneBtn]; [_doneBtn mas_makeConstraints:^(MASConstraintMaker *make) {
make.top.offset();
make.centerX.equalTo(self.view);
make.width.offset();
make.height.offset();
}]; __block showV *_showView;
[[_doneBtn rac_signalForControlEvents:UIControlEventTouchDown]subscribeNext:^(__kindof UIControl * _Nullable x) {
_showView = [[showV alloc] init];
[self.view addSubview:_showView];
_showView.frame = CGRectMake(, , kMainBoundsWidth, kMainBoundsHeight);
[_showView showViewData];
}];
} @end

showV.h

//
// showV.h
// iPhone
//
// Created by zlw on 2018/4/10.
// Copyright © 2018年 xujinzhong. All rights reserved.
// #import <UIKit/UIKit.h> @interface showV : UIView -(void)showViewData; @end

showV.m

//
// showV.m
// iPhone
//
// Created by zlw on 2018/4/10.
// Copyright © 2018年 xujinzhong. All rights reserved.
// #import "showV.h"
#import "Masonry.h"
#import "ReactiveObjC.h" @interface showV () @property(nonatomic, strong) UIView *bkView;
@property(nonatomic, strong) UIVisualEffectView *alphView;
@property(nonatomic, strong) NSString *content; @end @implementation showV -(instancetype)init{
self = [super init]; if (self) {
self.backgroundColor = [UIColor whiteColor];
} return self;
} -(NSString *)content{
if (!_content) {
_content = @"您将要激活闪电下单模式。通过点击下面的“我接受这些合同条款”,您会承认您已经阅读并理解以下合同条款,您同意特此遵守。您当前的程序端版本使您在下面的订单提交模式间选择。您同意遵守本规定的条款和条件,有关这样的模式。\n\n1. 订单提交的默认模式是两步处理法。使用默认模式,您需先选择买卖方向,然后您需要选择一个合适的订单类型,它的参数并且根据您选定的具体订单类型和您的交易意愿,通过点击买入,卖出,下单,确认您订单的提交。使用默认模式,您的订单将直到您完成前面提到的两个步骤才会提交。\n\n2. 订单提交的闪电下单模式是一步处理法。使用闪电下单模式,您的订单将会被直接提交,而无需再次确认。不会有后续确认提示您点击。一旦您点击,您将无法撤销或更改您的订单。在正常市场条件和系统性能下,市价订单提交后,单子会立即成交。\n\n您可以在【开启闪电下单按钮】停用闪电下单模式。\n\n通过选择闪电下单模式,您了解到您的订单将根据您点击卖或买价进行提交,没有后续订单确认。您同意并接受您选择的订单提交模式相关的全部风险,包括,但不限于,过失风险,提交订单时发生的失误。\n\n您同意完全赔偿和使ZLW TRADING 在由您,您的交易经理或任何代表您进行交易的人,造成的任何错误遗漏或失误而导致的结果引起的各种损失,成本和费用上免受损失。\n";
}
return _content;
} -(void)showViewData{
UIColor *bkColor = [UIColor blackColor];
UIColor *whileColor = [UIColor whiteColor];
UIColor *grayColor = [UIColor grayColor]; UIBlurEffect *beffect = [UIBlurEffect effectWithStyle:UIBlurEffectStyleDark];
_alphView = [[UIVisualEffectView alloc] initWithEffect:beffect];
[self addSubview:_alphView];
_alphView.alpha = ; [_alphView mas_makeConstraints:^(MASConstraintMaker *make) {
make.edges.equalTo(self);
}]; self.bkView = [[UIView alloc] init];
[self addSubview:self.bkView];
self.bkView.backgroundColor = bkColor;
self.bkView.frame = CGRectMake(, kMainBoundsHeight-, kMainBoundsWidth, ); UILabel *labTitle = [UILabel new];
labTitle.text = @"免责声明";
labTitle.textAlignment = NSTextAlignmentCenter;
labTitle.backgroundColor = bkColor;
labTitle.textColor = whileColor;
[self.bkView addSubview:labTitle]; [labTitle mas_makeConstraints:^(MASConstraintMaker *make) {
make.left.top.equalTo(self.bkView);
make.width.equalTo(self.bkView);
make.height.offset();
}]; UITextView *textV = [UITextView new];
textV.backgroundColor = bkColor;
textV.textColor = grayColor;
textV.font = [UIFont systemFontOfSize:];
textV.text = self.content;
textV.editable = NO;
[self.bkView addSubview:textV]; [textV mas_makeConstraints:^(MASConstraintMaker *make) {
make.top.equalTo(labTitle.mas_bottom);
make.centerX.equalTo(self.bkView);
make.width.equalTo(self.bkView).offset(-);
make.bottom.equalTo(self.bkView).offset(-);
}]; UIButton *closeBtn = [UIButton new];
[closeBtn setTitle:@"关闭" forState:UIControlStateNormal];
closeBtn.backgroundColor = [UIColor blueColor];
[self.bkView addSubview:closeBtn];
[closeBtn mas_makeConstraints:^(MASConstraintMaker *make) {
make.top.equalTo(textV.mas_bottom);
make.centerX.equalTo(textV);
make.width.equalTo(self.bkView);
make.bottom.equalTo(self.bkView);
}]; [[closeBtn rac_signalForControlEvents:UIControlEventTouchDown] subscribeNext:^(__kindof UIControl * _Nullable x) {
[UIView animateWithDuration:animalDuration animations:^{
self.alphView.alpha = 0.0;
self.bkView.frame = CGRectMake(, kMainBoundsHeight, kMainBoundsWidth, );
} completion:^(BOOL finished) {
[self removeFromSuperview];
}];
}]; [UIView animateWithDuration:animalDuration animations:^{
self.alphView.alpha = 1.0;
self.bkView.frame = CGRectMake(, kMainBoundsHeight-, kMainBoundsWidth, );
}];
} - (void)touchesBegan:(NSSet<UITouch *> *)touches withEvent:(UIEvent *)event{
[UIView animateWithDuration:animalDuration animations:^{
self.alphView.alpha = 0.0;
self.bkView.frame = CGRectMake(, kMainBoundsHeight, kMainBoundsWidth, );
} completion:^(BOOL finished) {
[self removeFromSuperview];
}]; } @end

iOS - 毛玻璃动画效果的更多相关文章

  1. iOS各种动画效果

    ios各种动画效果 最普通动画: //开始动画 [UIView beginAnimations:nil context:nil];  //设定动画持续时间 [UIView setAnimationDu ...

  2. iOS的动画效果类型及实现方法

    实现iOS漂亮的动画效果主要有两种方法, 一种是UIView层面的, 一种是使用CATransition进行更低层次的控制, 第一种是UIView,UIView方式可能在低层也是使用CATransit ...

  3. iOS 转盘动画效果实现

    代码地址如下:http://www.demodashi.com/demo/11598.html 近期公司项目告一段落,闲来无事,看到山东中国移动客户端有个转盘动画挺酷的.于是试着实现一下,看似简单,可 ...

  4. iOS开动画效果之──实现 pushViewController 默认动画效果

    在开发中,视图切换会常常遇到,有时我们不是基于导航控制器的切换,但实际开发中,有时需要做成push效果,下面将如何实现push和pop 默认动画效果代码实例: 一.push默认动画效果 CATrans ...

  5. ios animation 动画效果实现

    1.过渡动画 CATransition CATransition *animation = [CATransition animation]; [animation setDuration:1.0]; ...

  6. iOS毛玻璃擦除效果

    思路:首先我的思路放两个imageView在Controller里把高清的图片放在下面,带有毛玻璃效果的图片放在上面. //在Controller的view上加一个手势代码如下(温馨提示,开启imae ...

  7. iOS简单动画效果:闪烁、移动、旋转、路径、组合

    #define kDegreesToRadian(x) (M_PI * (x) / 180.0) #define kRadianToDegrees(radian) (radian*180.0)/(M_ ...

  8. iOS火焰动画效果、图文混排框架、StackView效果、偏好设置、底部手势等源码

    iOS精选源码 高性能图文混排框架,构架顺滑的iOS应用. 使用OpenGLE覆盖阿尔法通道视频动画播放器视图. 可选最大日期截至当日日期的日期轮选器ChooseDatePicker 简单轻量的图片浏 ...

  9. iOS UIView动画效果 学习笔记

    //启动页动画 UIImageView *launchScreen = [[UIImageView alloc]initWithFrame:[UIScreen mainScreen].bounds]; ...

随机推荐

  1. R: 缺失值 & 查看变量类型

    ################################################### 问题:缺失值   18.5.2 有关处理缺失值的各种方法有什么?各自的适用场景. 解决方案: n ...

  2. Coding CTO 孙宇聪:《人,技术与流程》

    我先做一下自我介绍,我是 07 年加入的 Google,在 Moutain View 总部任Google SRE,今年年初回国加入 Coding . 在 Google 我参与了两个 Project, ...

  3. 15. Bypass 360主机卫士SQL注入防御(多姿势)

    在服务器客户端领域,曾经出现过一款 360 主机卫士,目前已停止更新和维护,官网都打不开了,但服务器中依然经常可以看到它的身影. 从半年前的测试虚拟机里面,翻出了 360 主机卫士 Apache 版的 ...

  4. 功防技术与实践第1.2章,kali初步了解

    20169314 2016-2017-2 <网络攻防实践>/<网络攻击与防范>第2周学习总结 一.教材学习内容总结 1.hacker和cracker的区别 网络攻防分三部分:系 ...

  5. C# 关于跨线程访问控件问题

    跨线程访问控件问题的原因是:控件都是在主线程中创建的,而系统默认控件的修改权归其创建线程所有.在子线程中如果需要直接修改控件的内容,需要使用委托机制将控件的修改操作交给主线程处理.因此,当没有使用委托 ...

  6. iTop4412 裸机开发 LED

    平台:iTop4412 SCP 2G 开发板有两个可控制的LED灯:分别接到引脚:KP_COL0和VDD50_EN KP_COL0就是GPL2_0 VDD50_EN就是GPK1_1 配置GPX_CON ...

  7. MySQL中ORDER BY与LIMIT一起使用(有坑)

    1.  现象与问题 ORDER BY排序后,用LIMIT取前几条,发现返回的结果集的顺序与预期的不一样 下面是我遇到的问题: 可以看到,带LIMIT与不带LIMIT的结果与我预期的不一样,而且“很不可 ...

  8. Docker 企业级镜像仓库 Harbor 的搭建与维护

    目录 一.什么是 Harbor 二.Harbor 安装 2.1.Harbor 安装环境 2.2.Harbor安装 2.3 配置HTTPS 三.Harbor 的使用 3.1.登录Harbor并使用 3. ...

  9. LOJ6053 简单的函数(min_25筛)

    题目链接:LOJ 题目大意:从前有个积性函数 $f$ 满足 $f(1)=1,f(p^k)=p\oplus k$.(异或)求其前 $n$ 项的和对 $10^9+7$ 取模的值. $1\le n\le 1 ...

  10. Educational Codeforces Round 53C(二分,思维|构造)

    #include<bits/stdc++.h>using namespace std;const int N=1e6+6;int x[N],y[N];int sx,sy,n;char s[ ...