A.关于Quiartz2D的一些细节
1.UIKit的工具已经封装了上下文引用,所以不用手动获取和渲染
 - (void)drawRect:(CGRect)rect {
[[UIColor redColor] set];
UIRectFill(CGRectMake(, , , ));
}
 
 
2.多个path
 - (void)drawRect:(CGRect)rect {
CGContextRef ctx = UIGraphicsGetCurrentContext(); // 1.1创建第一个path
CGMutablePathRef linePath = CGPathCreateMutable(); // 1.2.描绘path
CGPathMoveToPoint(linePath, NULL, , );
CGPathAddLineToPoint(linePath, NULL, , ); // 1.3.添加linePath到上下文
CGContextAddPath(ctx, linePath); // 2添加一个圆的path
CGMutablePathRef circlePath = CGPathCreateMutable();
CGPathAddEllipseInRect(circlePath, NULL, CGRectMake(, , , ));
CGContextAddPath(ctx, circlePath); // 渲染上下文
CGContextStrokePath(ctx); // 释放path
CGPathRelease(linePath);
CGPathRelease(circlePath);
}
 
 
B.自定义一个类似UIImageView的控件
 //
// MyImageView.h
// MyImageView
//
// Created by hellovoidworld on 14/12/31.
// Copyright (c) 2014年 hellovoidworld. All rights reserved.
// #import <UIKit/UIKit.h> @interface MyImageView : UIView @property(nonatomic, weak) UIImage *image; @end
 //
// MyImageView.m
// MyImageView
//
// Created by hellovoidworld on 14/12/31.
// Copyright (c) 2014年 hellovoidworld. All rights reserved.
// #import "MyImageView.h" @implementation MyImageView - (void)setImage:(UIImage *)image {
_image = image; // 重新设置了图片的时候,重绘
[self setNeedsDisplay];
} - (void)drawRect:(CGRect)rect {
[self.image drawInRect:rect];
} @end controller:
- (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib. MyImageView *imageView = [[MyImageView alloc] init];
imageView.frame = CGRectMake(, , , );
[self.view addSubview:imageView];
imageView.image = [UIImage imageNamed:@"M4"];
}
 
 
C.带有placeholder的TextView
 
 //
// MyTextView.h
// MyTextField
//
// Created by hellovoidworld on 14/12/31.
// Copyright (c) 2014年 hellovoidworld. All rights reserved.
// #import <UIKit/UIKit.h> @interface MyTextView : UITextView @property(nonatomic, copy) NSString *placeHolderText; @end
 
 //
// MyTextView.m
// MyTextField
//
// Created by hellovoidworld on 14/12/31.
// Copyright (c) 2014年 hellovoidworld. All rights reserved.
// #import "MyTextView.h" @interface MyTextView() <UITextViewDelegate> /** 原来的文本颜色 */
@property(nonatomic, weak) UIColor *originalTextColor; @end @implementation MyTextView // 重写初始化方法,设置代理
- (instancetype)init {
if (self = [super init]) {
self.returnKeyType = UIReturnKeyDone;
self.delegate = self;
} return self;
} // 重新设置了placeHolderText的时候要重绘一下控件
- (void)setPlaceHolderText:(NSString *)placeHolderText {
_placeHolderText = placeHolderText;
[self setNeedsDisplay];
} // 开始编辑,消除placeHolder
- (BOOL)textViewShouldBeginEditing:(UITextView *)textView {
if ([self.text isEqualToString:self.placeHolderText]) {
self.text = nil;
self.textColor = self.originalTextColor;
} return YES;
} // 结束编辑,如果文本为空,设置placeHolder
- (void)textViewDidEndEditing:(UITextView *)textView {
[self setNeedsDisplay];
} - (void)drawRect:(CGRect)rect {
if (self.text.length == ) {
self.text = self.placeHolderText;
self.textColor = [UIColor grayColor];
}
} @end
 
 
D. 图片水印
1.步骤
(1)在storyboard拖入一个UIImageView, 在控制器代码创建图片上下文
创建一个基于位图的上下文 --> 系统创建一个位图对象
相当于创建了一个新的UIImage对象
(2)画背景
(3)画水印
(4)从上下文取得制作完毕的UIImage对象
(5)结束图片上下文
 //
// UIImage+HW.m
// Watermark
//
// Created by hellovoidworld on 14/12/31.
// Copyright (c) 2014年 hellovoidworld. All rights reserved.
// #import "UIImage+HW.h" @implementation UIImage(HW) + (instancetype) image:(NSString *) image withWatermark:(NSString *) watermark {
// 取得背景图片
UIImage *bgImage = [UIImage imageNamed:image]; // 1.开启一个位图上下文
UIGraphicsBeginImageContextWithOptions(bgImage.size, NO, 0.0); // 2.添加背景图片到位图上下文
[bgImage drawInRect:CGRectMake(, , bgImage.size.width, bgImage.size.height)]; // 3.添加水印图片
UIImage *watermarkImage = [UIImage imageNamed:watermark];
CGFloat scale = 0.5;
CGFloat margin = ;
CGFloat watermarkWidth = watermarkImage.size.width * scale;
CGFloat watermarkHeight = watermarkImage.size.width *scale;
CGFloat watermarkX = bgImage.size.width - watermarkWidth - margin;
CGFloat watermarkY = bgImage.size.height - watermarkHeight - margin;
[watermarkImage drawInRect:CGRectMake(watermarkX, watermarkY, watermarkWidth, watermarkHeight)]; // 4.取得合成后的图片
UIImage *resultImage = UIGraphicsGetImageFromCurrentImageContext(); // 5.关闭图文上下文
UIGraphicsEndImageContext(); return resultImage;
} @end
 
(6)显示到UIImageView
 - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib. UIImage *watermarkedImage = [UIImage image:@"M4" withWatermark:@"a9ec8a13632762d0092abc3ca2ec08fa513dc619"]; UIImageView *imageView = [[UIImageView alloc] initWithImage:watermarkedImage];
imageView.frame = CGRectMake(, , , );
[self.view addSubview:imageView];
}
 
(7)保存图片
a.将image压缩
b.写入文件
     // 压缩图片为PNG格式的二进制数据
NSData *data = UIImagePNGRepresentation(watermarkedImage); // 写入文件
NSString *path =[[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"watermarkedImage.png"];
NSLog(@"%@", path);
[data writeToFile:path atomically:YES];
 
 
 
E.头像图片裁剪
裁剪的图片形成新的图片,这里是讲矩形图片裁剪成圆形并带白色边框
1.步骤
(1)背景大圆
(2)小圆裁剪
(3)加入图片
 
 /**  创建带有指定宽度和颜色边框的圆形头像图片 */
+ (instancetype) imageOfCircleHeadIcon:(NSString *) image withBorderWidth:(CGFloat) borderWidth borderColor:(UIColor *) borderColor {
// 取得图片
UIImage *headIconImage = [UIImage imageNamed:image]; // 开启图片上下文
CGFloat backImageWidth = headIconImage.size.width + * borderWidth;
CGFloat backImageHeight = headIconImage.size.height + * borderWidth;
CGSize backImageSize = CGSizeMake(backImageWidth, backImageHeight);
UIGraphicsBeginImageContextWithOptions(backImageSize, NO, 0.0); // 描绘背景大圆
[borderColor set]; // 设置圆环颜色
CGContextRef ctx = UIGraphicsGetCurrentContext();
CGFloat backCircleRadius = backImageWidth * 0.5; // 大圆半径
CGFloat backCircleX = backCircleRadius; // 大圆圆心X
CGFloat backCircleY = backCircleRadius; // 大圆圆心Y
CGContextAddArc(ctx, backCircleX, backCircleY, backCircleRadius, , M_PI * , );
CGContextFillPath(ctx); // 描绘用来显示图片的小圆
CGFloat frontCircleRadius = backCircleRadius - borderWidth; // 图片小圆半径
CGFloat frontCircleX = backCircleX;
CGFloat frontCircleY = backCircleY;
CGContextAddArc(ctx, frontCircleX, frontCircleY, frontCircleRadius, , M_PI * , ); // 裁剪(后面描绘的将会受到裁剪)
CGContextClip(ctx); // 添加图片到上下文
[headIconImage drawInRect:CGRectMake(borderWidth, borderWidth, headIconImage.size.width, headIconImage.size.height)]; // 取得合成后的图片
UIImage *headIconResultImage = UIGraphicsGetImageFromCurrentImageContext(); // 关闭图片上下文
UIGraphicsEndImageContext(); return headIconResultImage;
}
 
 
 
F.屏幕截图
1.步骤
(1)使用位图上下文
(2)将控制器view的layer渲染到上下文
[self.view.layer renderInContext:UIGraphicsGetCurrentContext()];
(3)取出图片,保存图片
(4)结束位图上下文
 
 
 /** 点击“屏幕截图” */
- (IBAction)screenShotcut {
// 延迟截图, 防止截到的时按钮被按下的状态
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(0.1 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{ UIView *view = self.view; // 1.开启位图上下文
UIGraphicsBeginImageContextWithOptions(view.frame.size, NO, 0.0); // 2.渲染控制器view的layer到上下文
[view.layer renderInContext:UIGraphicsGetCurrentContext()]; // 3.从上下文取得图片
UIImage *screenImage = UIGraphicsGetImageFromCurrentImageContext(); // 4.结束上下文
UIGraphicsEndImageContext(); // 存储图片
NSData *data = UIImagePNGRepresentation(screenImage);
NSString *path = [[NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES) lastObject] stringByAppendingPathComponent:@"screenShot.png"];
NSLog(@"%@", path);
[data writeToFile:path atomically:YES]; }); }
 
 
 
 
G.drawRect原理
为什么要实现drawRect才能绘图到view上
因为在drawRect方法中才能取得图文相关的上下文
 
 
H.背景平铺
1.条纹背景
 - (void)viewDidLoad {
[super viewDidLoad];
// Do any additional setup after loading the view, typically from a nib. // 开启图片上下文
CGFloat rowW = self.view.frame.size.width;
CGFloat rowH = ;
UIGraphicsBeginImageContextWithOptions(CGSizeMake(rowW, rowH), NO, 0.0); CGContextRef ctx = UIGraphicsGetCurrentContext();
// 画色块背景
[[UIColor redColor] set];
CGContextAddRect(ctx, CGRectMake(, , rowW, rowH));
CGContextFillPath(ctx); // 画线
[[UIColor greenColor] set];
CGFloat lineWidth = ;
CGContextSetLineWidth(ctx, lineWidth);
CGFloat lineX = ;
CGFloat lineY = rowH - lineWidth;
CGContextMoveToPoint(ctx, lineX, lineY);
CGContextAddLineToPoint(ctx, rowW - lineX, lineY);
CGContextStrokePath(ctx); UIImage *image = UIGraphicsGetImageFromCurrentImageContext(); // 使用平铺方式铺满屏幕
[self.view setBackgroundColor:[UIColor colorWithPatternImage:image]]; UIGraphicsEndImageContext();
}
 
 
 
 
 

[iOS UI进阶 - 1] 自定义控件的更多相关文章

  1. [iOS UI进阶 - 0] Quiartz2D

    A.简介 1. 需要掌握的 drawRect:方法的使用 常见图形的绘制:线条.多边形.圆 绘图状态的设置:文字颜色.线宽等 图形上下文状态的保存与恢复 图形上下文栈 1.基本图形绘制* 线段(线宽. ...

  2. iOS UI进阶-1.0 Quartz2D

    概述 Quartz 2D是一个二维绘图引擎,同时支持iOS和Mac系统.Quartz 2D能完成的工作: 绘制图形 : 线条\三角形\矩形\圆\弧等 绘制文字 绘制\生成图片(图像) 读取\生成PDF ...

  3. [iOS UI进阶 - 6.1] 核心动画CoreAnimation

    A.基本知识 1.概念 Core Animation是一组非常强大的动画处理API,使用它能做出非常炫丽的动画效果,而且往往是事半功倍,使用它需要先添加QuartzCore.framework和引入对 ...

  4. [iOS UI进阶 - 6.0] CALayer

    A.基本知识 1.需要掌握的 CALayer的基本属性 CALayer和UIView的关系 position和anchorPoint的作用   2.概念 在iOS中,你能看得见摸得着的东西基本上都是U ...

  5. [iOS UI进阶 - 3.1] 触摸事件的传递

    A.事件的产生和传递 发生触摸事件后,系统会将该事件加入到一个由UIApplication管理的事件队列中UIApplication会从事件队列中取出最前面的事件,并将事件分发下去以便处理,通常,先发 ...

  6. [iOS UI进阶 - 5.0] 手势解锁Demo

    A.需求 1.九宫格手势解锁 2.使用了绘图和手势事件   code source: https://github.com/hellovoidworld/GestureUnlockDemo     B ...

  7. [iOS UI进阶 - 3.0] 触摸事件的基本处理

    A.需要掌握和练习的 1.介绍事件类型2.通过按钮的事件处理引出view的事件处理3.响应者对象 --> UIResponder --> UIView4.view的拖拽* 实现触摸方法,打 ...

  8. [iOS UI进阶 - 2.3] 彩票Demo v1.3

    A.需求 真机调试 "关于”模块 存储开关状态 打电话.发短信 应用评分 打开其他应用 cell 在iOS6 和 iOS7的适配 block的循环引用 屏幕适配 code source:   ...

  9. [iOS UI进阶 - 2.0] 彩票Demo v1.0

    A.需求 1.模仿“网易彩票”做出有5个导航页面和相应功能的Demo 2.v1.0 版本搭建基本框架   code source:https://github.com/hellovoidworld/H ...

随机推荐

  1. C++ STL之迭代器注意事项

    1.两个迭代器组成的区间是前闭后开的 2.如果迭代器的有效性,如果迭代器所指向的元素已经被删除,那么迭代器会失效 http://blog.csdn.net/hsujouchen/article/det ...

  2. grunt + compass

    compass和sass文章列表:http://182.92.240.72/tag/compass/ compass实战grunt: http://wrox.cn/article/2000491/ h ...

  3. CSS效果

    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs& ...

  4. 关于ie6对齐

    先来没有任何对齐时的样子: 1.一种是在父级没有高度的情况下居中. 给每个独立的元素都加上vertical-align:middle; 针对文字可以不加,加与不加都可以居中对齐.但是无法做到绝对的居中 ...

  5. Facebook存储技术方案:找出“暖性BLOB”数据

    Facebook公司已经在其近线存储体系当中彻底弃用RAID与复制机制,转而采用分布式擦除编码以隔离其所谓的“暖性BLOB”. 暖性?BLOB?这都是些什么东西?大家别急,马上为您讲解: BLOB—— ...

  6. PHP适合做大型网站吗?

    1. 对递归的不良支持 递归是一种函数调用自身的机制.这是一种强大的特性可以把某些复杂的东西变得很简单.有一个使用递归的例子是快速排序(quicksort).不幸的是,PHP并不擅长递归.Zeev,一 ...

  7. HelloX操作系统网络功能简介及使用和开发指南

    HelloX网络功能简介及使用和开发指南 HelloX网络功能简介 作为物联网操作系统,网络功能是必备的核心功能之一.按照规划,HelloX实现了两个不同类型的TCP/IP协议栈,一个面向资源受限的嵌 ...

  8. POJ 1664 放苹果

    放苹果 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 24985   Accepted: 15908 Description ...

  9. 【原创】回溯线搜索 Backtracking line search

    机器学习中很多数值优化算法都会用到线搜索(line search).线搜索的目的是在搜索方向上找到是目标函数\(f(x)\)最小的点.然而,精确找到最小点比较耗时,由于搜索方向本来就是近似,所以用较小 ...

  10. HTML5和CSS3的学习视频

    用Windows8和IE10开发HTML5网页视频教程专辑(Build New World) http://dreamdesign.csrjgzs.com/Article/ShowArticle.as ...