#import <UIKit/UIKit.h>

typedef void(^compeletionHandler) (NSInteger selectButtonIndex);

@class ZSDCustom;

@protocol ZSDCustomDelegate <NSObject>

-(void)showCustomView:(ZSDCustom *)customView andButtonClick:(NSInteger)selectIndex;

@end

@interface ZSDCustom : UIView

@property(nonatomic,copy)compeletionHandler myHandler;

@property(nonatomic,weak)id<ZSDCustomDelegate>delegate;

-(void)showCustomView:(ZSDCustom *)customView andDelegate:(id)delegate andCompeleteHandler:(compeletionHandler)handler;

@end

#import "ZSDCustom.h"

#define kDialogWidth 280.0f

#define kButtonSize CGSizeMake(115.0f,45.0f)

@implementation ZSDCustom

{

UIView *dialogView;

}

-(id)initWithFrame:(CGRect)frame

{

if (self=[super initWithFrame:frame])

{

[self setUp];

}

return self;

}

-(void)setUp

{

self.frame = [UIScreen mainScreen].bounds;

self.backgroundColor = [UIColor colorWithRed:0 green:0 blue:0 alpha:0.5f];

CGRect frect = CGRectZero;

frect.size.width = kDialogWidth;

dialogView = [[UIView alloc]initWithFrame:frect];

dialogView.backgroundColor = [UIColor whiteColor];

dialogView.layer.cornerRadius = 4.0f;

dialogView.layer.masksToBounds = YES;

[self addSubview:dialogView];

//按钮

frect.origin.x = 15.0f;

frect.origin.y = 56.0f + 20.0f;

frect.size = kButtonSize;

UIButton *cancelBtn = [UIButton buttonWithType:UIButtonTypeCustom];

cancelBtn.frame = frect;

[cancelBtn.titleLabel setFont:[UIFont boldSystemFontOfSize:15.0f]];

[cancelBtn setTitleColor:[UIColor blackColor] forState:UIControlStateNormal];

[cancelBtn setTitle:@"取消" forState:UIControlStateNormal];

[cancelBtn setBackgroundColor:[UIColor colorWithRed:243.0 / 255.0f green:243.0 / 255.0f blue:243.0 / 255.0f alpha:1.0]];

[cancelBtn addTarget:self action:@selector(buttonClick:) forControlEvents:UIControlEventTouchUpInside];

[cancelBtn.layer setBorderWidth:1.0];

[cancelBtn.layer setBorderColor:[UIColor grayColor].CGColor];

[cancelBtn.layer setCornerRadius:4.0f];

[cancelBtn setTag:1];

[dialogView addSubview:cancelBtn];

frect.origin.x = kDialogWidth - 15.0f - kButtonSize.width;

UIButton *okBtn = [UIButton buttonWithType:UIButtonTypeCustom];

okBtn.frame = frect;

[okBtn setTitleColor:[UIColor whiteColor] forState:UIControlStateNormal];

[okBtn.titleLabel setFont:[UIFont boldSystemFontOfSize:15.0f]];

[okBtn setTitle:@"确认" forState:UIControlStateNormal];

[okBtn setBackgroundColor:[UIColor colorWithRed:207.0 / 255.0f green:44.0 / 255.0f blue:65.0 / 255.0f alpha:1.0]];

[okBtn addTarget:self action:@selector(buttonClick:) forControlEvents:UIControlEventTouchUpInside];

[okBtn.layer setCornerRadius:4.0f];

[okBtn setTag:2];

[dialogView addSubview:okBtn];

float totalHeight = CGRectGetMaxY(okBtn.frame) + 20.0f;

frect = dialogView.frame;

frect.origin.x = (self.bounds.size.width - kDialogWidth) / 2.0f;

frect.origin.y = (self.bounds.size.height - totalHeight) / 2.0f;

frect.size.height = totalHeight;

dialogView.frame = frect;

}

-(void)buttonClick:(UIButton *)sender

{

if (_myHandler) {

_myHandler(sender.tag);

}

if (sender.tag==2) {

if (_delegate&&[_delegate respondsToSelector:@selector(showCustomView:andButtonClick:)]) {

[_delegate showCustomView:self andButtonClick:sender.tag];

}

}

else

{

[self hide];

}

}

-(void)show

{

UIWindow *keyWindow = [UIApplication sharedApplication].keyWindow;

[keyWindow addSubview:self];

dialogView.alpha = 0;

dialogView.transform = CGAffineTransformMakeScale(0.01f, 0.01f);

[UIView animateWithDuration:0.3f animations:^{

dialogView.alpha = 1.0;

dialogView.transform = CGAffineTransformMakeScale(1.0, 1.0);

}];

}

-(void)hide

{

[UIView animateWithDuration:0.3f animations:^{

dialogView.alpha = 0;

dialogView.transform = CGAffineTransformMakeScale(0.01f, 0.01f);

} completion:^(BOOL finished) {

[self removeFromSuperview];

}];

}

-(void)showCustomView:(ZSDCustom *)customView andDelegate:(id)delegate andCompeleteHandler:(compeletionHandler)handler

{

[customView show];

_delegate=delegate;

_myHandler=handler;

}

@end

#import "ViewController.h"

#import "ZSDCustom.h"

@interface ViewController ()<ZSDCustomDelegate>

@end

@implementation ViewController

- (void)viewDidLoad {

[super viewDidLoad];

// Do any additional setup after loading the view, typically from a nib.

}

- (void)didReceiveMemoryWarning {

[super didReceiveMemoryWarning];

// Dispose of any resources that can be recreated.

}

- (IBAction)showViewBtnClick:(UIButton *)sender

{

ZSDCustom *custom=[[ZSDCustom alloc]initWithFrame:CGRectZero];

[custom showCustomView:custom andDelegate:self andCompeleteHandler:^(NSInteger selectButtonIndex) {

NSLog(@"selectButtonIndex=%ld",selectButtonIndex);

}];

}

-(void)showCustomView:(ZSDCustom *)customView andButtonClick:(NSInteger)selectIndex

{

NSLog(@"selectIndex=%ld",selectIndex);

}

@end

iOS- 自定义UIView (测试block和代理)的更多相关文章

  1. IOS自定义UIView

    IOS中一般会用到几种方式自定义UIView 1.继承之UIView的存代码的自定义View 2.使用xib和代码一起使用的自定义View 3.存xib的自定义View(不需要业务处理的那种) 本文主 ...

  2. OpenGL ES: iOS 自定义 UIView 响应屏幕旋转

    iOS下使用OpenGL 如果使用GLKit View 那么不用担心屏幕旋转的问题,说明如下: If you change the size, scale factor, or drawable pr ...

  3. iOS:UIView的block函数实现转场动画---双视图

    使用UIView动画函数实现转场动画——双视图 + (void)transitionFromView:(UIView *)fromView toView:(UIView *)toView durati ...

  4. iOS:UIView的block函数实现转场动画---单视图

    使用UIView动画函数实现转场动画——单视图 + (void)transitionWithView:(UIView *)view duration:(NSTimeInterval)duration ...

  5. iOs 自定义UIView 日历的实现 Swift2.1

    学习Swift有一个月了,动手写一个UIView吧. 所有源代码在最后,直接用就可以了,第一次写Swift,和C#,Java还是有区别的 (博客园可以考虑在代码插入中添加Swift的着色了) 1  函 ...

  6. iOS开发——OC篇&消息传递机制(KVO/NOtification/Block/代理/Target-Action)

     iOS开发中消息传递机制(KVO/NOtification/Block/代理/Target-Action)   今晚看到了一篇好的文章,所以就搬过来了,方便自己以后学习 虽然这一期的主题是关于Fou ...

  7. iOS block和代理的区别

      block和代理是iOS开发中实现回调的两种方式,大多数情况下是用哪个都可以,主要看个人喜好.本文主要是对两者做一下对比. 1.block简介   在 iOS中, block一共分三种.   (1 ...

  8. IOS xib和代码自定义UIView

    https://www.jianshu.com/p/1bcc29653085 总结的比较好 iOS开发中,我们常常将一块View封装起来,以便于统一管理内部的子控件. 下面就来说说自定义View的封装 ...

  9. 荼菜的iOS笔记--UIView的几个Block动画

    前言:我的第一篇文章荼菜的iOS笔记–Core Animation 核心动画算是比较详细讲了核心动画的用法,但是如你上篇看到的,有时我们只是想实现一些很小的动画,这时再用coreAnimation就会 ...

随机推荐

  1. python svn

    svn 0.3.36 Downloads ↓ Intuitive Subversion wrapper. Introduction svn is a simple Subversion library ...

  2. POJ1469COURSES(二分图匹配)

    裸的二分图匹配 题目poj.org/problem?id=1469 不解释:

  3. LeetCode 刷题记录

    写在前面:因为要准备面试,开始了在[LeetCode]上刷题的历程.LeetCode上一共有大约150道题目,本文记录我在<http://oj.leetcode.com>上AC的所有题目, ...

  4. CodeForces 710A King Moves (水题)

    题意:给定一个坐标,问你皇后有几个方向可以走. 析:直接格举那八个方向即可. 代码如下: #pragma comment(linker, "/STACK:1024000000,1024000 ...

  5. WEB数据挖掘(十三)——关联规则与序列模式(1)

    一.Apriori算法简介:  Apriori算法是一种挖掘关联规则的频繁项集算法,其核心思想是通过候选集生成和情节的向下封闭检测两个阶段来挖掘频繁项集. Apriori(先验的,推测的)算法应用广泛 ...

  6. Spring+jpa+access

    ========访问数据库的属于文件============ driver=com.hxtt.sql.access.AccessDriverurl=jdbc:access:/D:/eclipse/pr ...

  7. web APi角色认证

    http://www.cnblogs.com/youring2/archive/2013/03/09/2950992.html http://kb.cnblogs.com/page/107117/

  8. 关于刘冬大侠Spring.NET系列学习笔记3的一点勘正

    诚如他第22楼“只因渴求等待”提出的疑问一样,他的下面那一段代码是存在一点点问题的, XElement root = XElement.Load(fileName); var objects = fr ...

  9. 如何在KVM中管理存储池

    来自:http://blog.csdn.net/my2005lb/article/details/8635661 KVM平台以存储池的形式对存储进行统一管理,所谓存储池可以理解为本地目录.通过远端磁盘 ...

  10. HDU 4637 Rain on your Fat brother 线段与半圆和线段交 简单题

    题意: 应该不难读懂. 做法: 我们可以把雨滴看做静止不动,然后maze(这题的那个人)就是往左上方运动就可以了,计算出maze能跑到的最远的点,然后就是求起点和终点所构成的线段与每个雨滴交的时间,注 ...