iOS - 毛玻璃动画效果
声明全局变量
#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 - 毛玻璃动画效果的更多相关文章
- iOS各种动画效果
ios各种动画效果 最普通动画: //开始动画 [UIView beginAnimations:nil context:nil]; //设定动画持续时间 [UIView setAnimationDu ...
- iOS的动画效果类型及实现方法
实现iOS漂亮的动画效果主要有两种方法, 一种是UIView层面的, 一种是使用CATransition进行更低层次的控制, 第一种是UIView,UIView方式可能在低层也是使用CATransit ...
- iOS 转盘动画效果实现
代码地址如下:http://www.demodashi.com/demo/11598.html 近期公司项目告一段落,闲来无事,看到山东中国移动客户端有个转盘动画挺酷的.于是试着实现一下,看似简单,可 ...
- iOS开动画效果之──实现 pushViewController 默认动画效果
在开发中,视图切换会常常遇到,有时我们不是基于导航控制器的切换,但实际开发中,有时需要做成push效果,下面将如何实现push和pop 默认动画效果代码实例: 一.push默认动画效果 CATrans ...
- ios animation 动画效果实现
1.过渡动画 CATransition CATransition *animation = [CATransition animation]; [animation setDuration:1.0]; ...
- iOS毛玻璃擦除效果
思路:首先我的思路放两个imageView在Controller里把高清的图片放在下面,带有毛玻璃效果的图片放在上面. //在Controller的view上加一个手势代码如下(温馨提示,开启imae ...
- iOS简单动画效果:闪烁、移动、旋转、路径、组合
#define kDegreesToRadian(x) (M_PI * (x) / 180.0) #define kRadianToDegrees(radian) (radian*180.0)/(M_ ...
- iOS火焰动画效果、图文混排框架、StackView效果、偏好设置、底部手势等源码
iOS精选源码 高性能图文混排框架,构架顺滑的iOS应用. 使用OpenGLE覆盖阿尔法通道视频动画播放器视图. 可选最大日期截至当日日期的日期轮选器ChooseDatePicker 简单轻量的图片浏 ...
- iOS UIView动画效果 学习笔记
//启动页动画 UIImageView *launchScreen = [[UIImageView alloc]initWithFrame:[UIScreen mainScreen].bounds]; ...
随机推荐
- hdu1076
#include<iostream> using namespace std; int main() { int cases; int k; cin>>cases; while ...
- hdu1065
#include <stdio.h> int main() { int t; double x, y; scanf("%d", &t); for; i < ...
- <base target="_self"/>标签的用法
语法 <base target="value"> 属性值 值 描述 _blank 在新窗口中打开被链接文档. _self 默认.在相同的框架中打开被链接文档. _par ...
- 【leetcode 114. 二叉树展开为链表】解题报告
思路:递归,将左子树变成单链表形式,再将右子树变成单链表形式,最后将左子树单链表的末端连接到右子树单链表表头,将根节点的左孩子置空 void flatten(TreeNode* root) { if ...
- ElasticSearch 学习一: 基本命令
1. 启动时指定集群和节点的名字./elasticsearch -Ecluster.name=my_cluster_name -Enode.name=my_node_namee.g. ./elasti ...
- C#之数据类型转换
前言 在C#中学习中,像在VB学习的时候一样,我们会接触到很多种数据类型,但是VB中在用数据类型的时候,我们会考虑这个数据要求多大的内存,或者说有时候为了满足很少的大内存事件,而狠心分配给它较大 ...
- 清北刷题冲刺 10-30 p.m
少女 #include<iostream> #include<cstdio> #include<queue> #include<cstdlib> #de ...
- VC添加全局热键的方法
VC添加全局热键的方法 这个方法靠谱 http://blog.csdn.net/lujianfeiccie2009/article/details/7498704 VC添加全局热键的方法 标签: bu ...
- php配置redis
redis扩展程序下载链接(版本3.0.504) 链接: https://pan.baidu.com/s/1QfrjtnifOl8SPf7XCEly2g 密码: u6x6 wampserver下载地址 ...
- UVALive 7500 Boxes and Balls 2015EC final 签到题 二分
分析题目后,得到要求的是最接近n的一个数,并且这个数字能写成1+2+3+....+x = ans这种形式. 要求的是最大的值. 这题就直接二分去做吧.二分出一个f(mid)<=n的最大值. 最后 ...