自定义提醒视图Alert-动态绘制
1.
.h文件
#import <UIKit/UIKit.h>
#define Wi [[UIScreen mainScreen]bounds].size.width
#define He [[UIScreen mainScreen]bounds].size.height
@interface Alert : UIView
typedef enum{
AlertStyleYes=0,
AlertStyleNo,
AlertStyleWarning,
}AlertStyle;
@property(nonatomic,strong) UIView *alertView;
@property(nonatomic,strong) UIView *drawView;
@property(nonatomic) AlertStyle alertStyle;
@property(nonatomic,strong) UILabel *alertLabel;
@property(nonatomic,strong) UILabel *messageLabel;
@property(nonatomic,strong) UIButton *cancelButton;
@property(nonatomic,strong) UIButton *confirmButton;
-(instancetype)initAlertWithStyle:(AlertStyle)alertStyle;
@end
.m文件
#import "Alert.h"
@implementation Alert
-(instancetype)initAlertWithStyle:(AlertStyle)alertStyle{
CGRect frame= CGRectMake(0, 0, Wi, He);
self=[super initWithFrame:frame];
if (self) {
self.backgroundColor=[UIColor colorWithRed:0.1 green:0.2 blue:0.3 alpha:0.3];
//
// self.center=CGPointMake(Wi/2, He/2);
//
[self initViews];
//
if (alertStyle==AlertStyleNo) {
[self drawNo];
}
if (alertStyle==AlertStyleYes) {
[self drawYes];
}
if (alertStyle==AlertStyleWarning) {
[self drawWarning];
}
}
return self;
}
/*
初始化视图
*/
-(void)initViews{
//
self.alertView=[[UIView alloc]initWithFrame:CGRectMake(0, 0, 160, 190)];
self.alertView.backgroundColor=[UIColor colorWithRed:0.8 green:0.8 blue:1.5 alpha:0.9];
self.alertView.layer.masksToBounds=YES;
self.alertView.layer.cornerRadius=5;
self.alertView.center=self.center;
[self addSubview:self.alertView];
//
self.drawView=[[UIView alloc]initWithFrame:CGRectMake(0, 0, 160, 110)];
// self.drawView.backgroundColor=[UIColor blackColor];
[self.alertView addSubview:self.drawView];
//
self.alertLabel=[[UILabel alloc]initWithFrame:CGRectMake(0, 95, self.drawView.frame.size.width, 30)];
self.alertLabel.textAlignment=1;
_alertLabel.text=@"alertLabel";
[self.alertView bringSubviewToFront:_alertLabel];
[self.alertView addSubview:_alertLabel];
//
self.messageLabel=[[UILabel alloc]initWithFrame:CGRectMake(0, 120, self.drawView.frame.size.width, 30)];
self.messageLabel.textAlignment=1;
_messageLabel.text=@"messageLabel";
[self.alertView bringSubviewToFront:_messageLabel];
[self.alertView addSubview:_messageLabel];
//
_cancelButton=[UIButton buttonWithType:UIButtonTypeCustom];
[_cancelButton setFrame:CGRectMake(10, 150, 60, 30)];
[_cancelButton setTitle:@"取消" forState:UIControlStateNormal];
[_cancelButton addTarget:self action:@selector(back) forControlEvents:UIControlEventTouchUpInside];
[_cancelButton setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
_cancelButton.backgroundColor=[UIColor colorWithRed:0.1 green:0.2 blue:0.5 alpha:0.8];
_cancelButton.layer.masksToBounds=YES;
_cancelButton.layer.cornerRadius=5;
[self.alertView addSubview:_cancelButton];
//
_confirmButton=[UIButton buttonWithType:UIButtonTypeCustom];
[_confirmButton setFrame:CGRectMake(90, 150, 60, 30)];
[_confirmButton setTitle:@"确定" forState:UIControlStateNormal];
[_confirmButton addTarget:self action:@selector(back) forControlEvents:UIControlEventTouchUpInside];
[_confirmButton setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];
_confirmButton.backgroundColor=[UIColor colorWithRed:0.6 green:0.3 blue:0.2 alpha:0.8];
_confirmButton.layer.masksToBounds=YES;
_confirmButton.layer.cornerRadius=5;
[self.alertView addSubview:_confirmButton];
}
-(void)back{
[self removeFromSuperview];
}
/*
设置alertStyle
*/
-(void)setAlertStyle:(AlertStyle)alertStyle{
_alertStyle=alertStyle ;
[self addSubview:self.alertView];
if (alertStyle==AlertStyleNo) {
[self drawNo];
}
if (alertStyle==AlertStyleYes) {
[self drawYes];
}
if (alertStyle==AlertStyleWarning) {
[self drawWarning];
}
}
/**************************三个绘制*****************************/
/*
绘制yes
*/
-(void)drawYes{
//先移除再绘制
[self.drawView.layer.sublayers makeObjectsPerformSelector:@selector(removeFromSuperlayer) ];
_alertLabel.text=@"Yes";
_alertLabel.textColor=[UIColor blueColor];
//
_messageLabel.text=@"登陆成功";
_messageLabel.textColor=[UIColor grayColor];
//
UIBezierPath *path = [UIBezierPath bezierPath];
[path moveToPoint:CGPointMake(120, 50)];
[path addArcWithCenter:CGPointMake(80, 50) radius:40 startAngle:2*M_PI endAngle: 0 clockwise:0];
[path moveToPoint:CGPointMake(60,50)];
[path addLineToPoint:CGPointMake(80, 70)];
[path addLineToPoint:CGPointMake(110, 30)];
// NSLog(@"%f",M_PI);
//
CAShapeLayer *pathLayer = [CAShapeLayer layer];
pathLayer.frame = self.bounds;
pathLayer.path = path.CGPath;
pathLayer.strokeColor = [[UIColor blueColor] CGColor];
pathLayer.fillColor = nil;
pathLayer.lineWidth = 4.0f;
pathLayer.lineJoin = kCALineJoinBevel;
[self.drawView.layer addSublayer:pathLayer];
//
CABasicAnimation *pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
//pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnimation.duration =0.5;
pathAnimation.fromValue = [NSNumber numberWithFloat:0.0f];
pathAnimation.toValue = [NSNumber numberWithFloat:1.0f];
[pathLayer addAnimation:pathAnimation forKey:@"strokeEnd"];
}
/*
绘制No
*/
-(void)drawNo{
//先移除再绘制
[self.drawView.layer.sublayers makeObjectsPerformSelector:@selector(removeFromSuperlayer) ];
//
_alertLabel.text=@"登陆失败";
_alertLabel.textColor=[UIColor redColor];
//
_messageLabel.text=@"密码输入错误";
_messageLabel.textColor=[UIColor grayColor];
//
UIBezierPath *path=[UIBezierPath bezierPath];
[path moveToPoint:CGPointMake(40, 10)];
[path addLineToPoint:CGPointMake(40, 90)];
[path addLineToPoint:CGPointMake(120, 90)];
[path addLineToPoint:CGPointMake(120, 10)];
[path addLineToPoint:CGPointMake(40, 10)];
[path moveToPoint:CGPointMake(60, 30)];
[path addLineToPoint:CGPointMake(100, 70)];
[path moveToPoint:CGPointMake(100, 30)];
[path addLineToPoint:CGPointMake(60, 70)];
//
CAShapeLayer *pathLayer = [CAShapeLayer layer];
pathLayer.frame = self.bounds;
pathLayer.path = path.CGPath;
pathLayer.strokeColor = [[UIColor redColor] CGColor];
pathLayer.fillColor = nil;
pathLayer.lineWidth = 4.0f;
pathLayer.lineJoin = kCALineJoinBevel;
[self.drawView.layer addSublayer:pathLayer];
//
CABasicAnimation *pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnimation.duration = 0.5;
pathAnimation.fromValue = [NSNumber numberWithFloat:0.0f];
pathAnimation.toValue = [NSNumber numberWithFloat:1.0f];
[pathLayer addAnimation:pathAnimation forKey:@"strokeEnd"];
}
/*
绘制Warning
*/
-(void)drawWarning{
//先移除再绘制
[self.drawView.layer.sublayers makeObjectsPerformSelector:@selector(removeFromSuperlayer) ];
//
_alertLabel.text=@"警告";
_alertLabel.textColor=[UIColor colorWithRed:1.4 green:1.0 blue:0 alpha:1.0];
//
_messageLabel.text=@"内存不足";
_messageLabel.textColor=[UIColor grayColor];
//
UIBezierPath *path=[UIBezierPath bezierPath];
[path moveToPoint:CGPointMake(80, 10)];
[path addLineToPoint:CGPointMake(30, 95)];
[path addLineToPoint:CGPointMake(130, 95)];
[path addLineToPoint:CGPointMake(80, 10)];
[path moveToPoint:CGPointMake(80, 30)];
[path addLineToPoint:CGPointMake(80, 75)];
[path moveToPoint:CGPointMake(80, 80)];
[path addLineToPoint:CGPointMake(80, 85)];
//
CAShapeLayer *pathLayer = [CAShapeLayer layer];
pathLayer.frame = self.bounds;
pathLayer.path = path.CGPath;
pathLayer.strokeColor = [[UIColor yellowColor] CGColor];
pathLayer.fillColor = nil;
pathLayer.lineWidth = 4.0f;
pathLayer.lineJoin = kCALineJoinBevel;
[self.drawView.layer addSublayer:pathLayer];
//
CABasicAnimation *pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnimation.duration = 0.5;
pathAnimation.fromValue = [NSNumber numberWithFloat:0.0f];
pathAnimation.toValue = [NSNumber numberWithFloat:1.0f];
[pathLayer addAnimation:pathAnimation forKey:@"strokeEnd"];
}
/*
//
UIBezierPath *path = [UIBezierPath bezierPath];
[path moveToPoint:CGPointMake(0.0,20.0)];
[path addLineToPoint:CGPointMake(120.0, 500.0)];
[path addLineToPoint:CGPointMake(220, 0)];
[path addLineToPoint:CGPointMake(310, 40)];
[path addLineToPoint:CGPointMake(SCREEN_WIDTH, 110)];
//
CAShapeLayer *pathLayer = [CAShapeLayer layer];
pathLayer.frame = self.view.bounds;
pathLayer.path = path.CGPath;
pathLayer.strokeColor = [[UIColor redColor] CGColor];
pathLayer.fillColor = nil;
pathLayer.lineWidth = 2.0f;
pathLayer.lineJoin = kCALineJoinBevel;
[self.view.layer addSublayer:pathLayer];
//
CABasicAnimation *pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];
pathAnimation.duration = 2.0;
pathAnimation.fromValue = [NSNumber numberWithFloat:0.0f];
pathAnimation.toValue = [NSNumber numberWithFloat:1.0f];
[pathLayer addAnimation:pathAnimation forKey:@"strokeEnd"];
*/
@end
2.效果:
自定义提醒视图Alert-动态绘制的更多相关文章
- iOS可视化动态绘制连通图
上篇博客<iOS可视化动态绘制八种排序过程>可视化了一下一些排序的过程,本篇博客就来聊聊图的东西.在之前的博客中详细的讲过图的相关内容,比如<图的物理存储结构与深搜.广搜>.当 ...
- C# 动态绘制任务栏图标的实现
通常我们在做一个应用时会遇到这样的需求:将收到的消息条数显示到任务栏,比如如下的效果 怎么实现呢? 答案是采用WindowsAPICodePack实现,具体参见:Windows 7 任务栏开发 之 覆 ...
- 自定义View视图
自定义View视图文件查找逻辑 之前MVC5和之前的版本中,我们要想对View文件的路径进行控制的话,则必须要对IViewEngine接口的FindPartialView或FindView方法进行重写 ...
- iOS可视化动态绘制连通图(Swift版)
上篇博客<iOS可视化动态绘制八种排序过程>可视化了一下一些排序的过程,本篇博客就来聊聊图的东西.在之前的博客中详细的讲过图的相关内容,比如<图的物理存储结构与深搜.广搜>.当 ...
- 自定义view:view的绘制流程
1.view的绘制流程 当 Activity 接收到焦点的时候,它会被请求绘制布局,该请求由 Android framework 处理.绘制是从根节点开始,对布局树进行 measure 和 draw. ...
- (排班表二)后台动态绘制Grid表格
后台动态绘制值班表(Grid表格 列名不固定) 要求:表头除了值班人姓名,还要显示日期,及每天的星期值,用斜杠‘/’分隔.即:几号/星期几 最终实现的效果:根据查询的年月显示每个值班人查询月份每天的值 ...
- 1.Android 视图及View绘制分析笔记之setContentView
自从1983年第一台图形用户界面的个人电脑问世以来,几乎所有的PC操作系统都支持可视化操作,Android也不例外.对于所有Android Developer来说,我们接触最多的控件就是View.通常 ...
- UICollectionView(集合视图)以及自定义集合视图
一.UICollectionView集合视图 其继承自UIScrollView. UICollectionView类是iOS6新引进的API,用于展示集合视图,布局 ...
- Android 自定义View修炼-自定义HorizontalScrollView视图实现仿ViewPager效果
开发过程中,需要达到 HorizontalScrollView和ViewPager的效果,于是直接重写了HorizontalScrollView来达到实现ViewPager的效果. 实际效果图如下: ...
随机推荐
- LeetCode题解-147 对链表进行插入排序
对链表进行插入排序. 插入排序的动画演示如上.从第一个元素开始,该链表可以被认为已经部分排序(用黑色表示). 每次迭代时,从输入数据中移除一个元素(用红色表示),并原地将其插入到已排好序的链表中. 插 ...
- Java内存模型Cookbook
前言 指令重排 内存屏障 多处理器 指南 前言 这是一篇用于说明在JSR-133中制定的新Java内存模型(JMM)的非官方指南. 这篇指南提供了在最简单的背景下各种规则存在的原因,而不是这些规则在指 ...
- js获取url地址的参数的方法
js获取url参数值 今天说一下如何获取url参数值. 思路 通过location的search就可以获取到url中问号后面的值. 字符串过滤到问号 通过split方法分割参数集合 循环赋值 匹配对应 ...
- Linux实用指令
Linux实用指令 Rpm&Yum 一种用于互联网下载包的打包和安装工具,它包含某些Linux分发版中,它生产具有 .rpm 扩展名的文件.RPM 是 RedHat Package Man ...
- (转)MySQL 插入数据时,中文乱码问题的解决
MySQL 插入数据时,中文乱码问题的解决 原文:http://www.cnblogs.com/sunzn/archive/2013/03/14/2960248.html 当向 MySQL 数据库插 ...
- (转)Mysql备份还原数据库之mysqldump实例及参数详细说明
http://www.xuejiehome.com/blfl-2.html http://www.cnblogs.com/xuejie/archive/2013/01/11/2856911.html ...
- Java之IO(三)ByteArrayInputStream和ByteArrayOutputStream
转载请注明源出处:http://www.cnblogs.com/lighten/p/6972297.html 1.前言 这组输入输出流比较特殊,一般的流指定都是磁盘IO和网络IO,从文件中读取数据或者 ...
- oauth2.0实现sso单点登录的方式和相关代码
SSO介绍 什么是SSO 百科:SSO英文全称Single Sign On,单点登录.SSO是在多个应用系统中,用户只需要登录一次就可以访问所有相互信任的应用系统.它包括可以将这次主要的登录映射到其他 ...
- [转]Elasticsearch Java API总汇
http://blog.csdn.net/changong28/article/details/38445805#comments 3.1 集群的连接 3.1.1 作为Elasticsearch节点 ...
- 【字符串】Simplify Path(栈)
题目: Given an absolute path for a file (Unix-style), simplify it. For example,path = "/home/&quo ...