5、画图

(1)画线

//绘图代码写在drawRect里,view加载完成,需要显示的时候调用

//1、获取图形上下文 2、创建路径 3、把图形放入上下文 4、渲染上下文

//drawRect的rect是绘制View的bounds

//重绘

[self setNeedsDisplay];

set =  setStroke(描边) + setFill(填充)

//方法一:最原始的方法

//1、获取图形上下文,CG,CoreGraphics,有关图形的框架,开发mac也可以用

CGContextRef ctx = UIGraphicsGetCurrentContext();

//2、创建路径

CGMutablePathRef path = CGPathCreateMutable();

//设置起始点

CGPathMoveToPoint(path, NULL, 50, 50);

//画线到某一点

CGPathAddLineToPoint(path, NULL, 200, 200);

//3、把图形放入上下文

CGContextAddPath(ctx, path);

//4、渲染上下文

CGContextStrokePath(ctx);

//绘图的第二种方法

- (void)drawLine2 {

CGContextRef ctx = UIGraphicsGetCurrentContext();

//设置起始点

CGContextMoveToPoint(ctx, 50, 50);

//画线并设置终点

CGContextAddLineToPoint(ctx, 200, 200);

//渲染上下文

CGContextStrokePath(ctx);

}

//第三种方法

- (void)drawLine3 {

//贝塞尔线,UIKit

//创建路径

UIBezierPath * path = [UIBezierPath bezierPath];

//设置起点

[path moveToPoint:CGPointMake(50, 50)];

//画线并设置终点

[path addLineToPoint:CGPointMake(200, 200)];

//绘制路径

[path stroke];

}

//属性

- (void)drawCtxState {

CGContextRef ctx = UIGraphicsGetCurrentContext();

CGContextMoveToPoint(ctx, 50, 50);

CGContextAddLineToPoint(ctx, 100, 50);

//    CGContextMoveToPoint(ctx, 80, 60);

//默认下一根线的起点就是上一根线的终点

CGContextAddLineToPoint(ctx, 100, 200);

//设置线宽度

CGContextSetLineWidth(ctx, 5);

//设置连接样式

CGContextSetLineJoin(ctx, kCGLineJoinRound);

//设置顶角样式

CGContextSetLineCap(ctx, kCGLineCapRound);

//设置线的颜色

[[UIColor redColor] setStroke];

CGContextStrokePath(ctx);

}

//画曲线

- (void)drawRect:(CGRect)rect {

// Drawing code

CGContextRef ctx = UIGraphicsGetCurrentContext();

CGContextMoveToPoint(ctx, 50, 50);

//画曲线 arg1 上下文  arg2,3 控制点x,y   arg4,5 终点x,y

CGContextAddQuadCurveToPoint(ctx, 100, 100, 250, 50);

CGContextStrokePath(ctx);

}

 

(2)画图形

//画矩形

UIBezierPath * path = [UIBezierPath bezierPathWithRect:CGRectMake(20, 20, 200, 200)];

//画圆角矩形

UIBezierPath * path = [UIBezierPath bezierPathWithRoundedRect:CGRectMake(20, 20, 200, 200) cornerRadius:100];

//画圆弧

//Center 圆弧中心

//radius 圆弧半径

//startAngle 起始角度

//endAngle 结束角度

//clockwise YES 顺时针  NO 逆时针

CGPoint center = CGPointMake(125, 125);

UIBezierPath * path = [UIBezierPath bezierPathWithArcCenter:center radius:100 startAngle:0 endAngle:M_PI_2 clockwise:NO];

[path addLineToPoint:center];

//封闭路径

[path closePath];

[path stroke];

//要使用setFill,路径一定是封闭的

[[UIColor greenColor] setFill];

[path fill];

//画椭圆

UIBezierPath * path = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(20, 50, 200, 100)];

[path stroke];

}

6、绘制图片和文字

(1)绘制图片

- (void)drawPicture {

//图片裁剪,超出部分全部剪掉

UIRectClip(CGRectMake(0, 0, 50, 50));

UIImage * image = [UIImage imageNamed:@"01"];

//根据rect拉伸图片

[image drawInRect:CGRectMake(0, 0, 100, 100)];

[image drawInRect:rect];

//显示原图片尺寸

[image drawAtPoint:CGPointZero];

//平铺绘图

[image drawAsPatternInRect:rect];

}

(2)绘制文字

- (void)drawRect:(CGRect)rect {

// Drawing code

NSString * string = @"hgfdagskjhdcadkhdkjlashkdklhahgfdagskjhdcad";

NSShadow * shadow = [[NSShadow alloc] init];

shadow.shadowColor = [UIColor yellowColor];

shadow.shadowOffset = CGSizeMake(5, 5);

//模糊度

shadow.shadowBlurRadius = 3;

NSDictionary * dict = @{NSFontAttributeName:[UIFont systemFontOfSize:30],

NSForegroundColorAttributeName:[UIColor redColor],

NSStrokeColorAttributeName:[UIColor blueColor],

NSStrokeWidthAttributeName:@(2),

NSShadowAttributeName: shadow};

//不会换行

[string drawAtPoint:CGPointZero withAttributes:nil];

[string drawInRect:rect withAttributes:dict];

}

5、画图

(1)画线

//绘图代码写在drawRect里,view加载完成,需要显示的时候调用

//1、获取图形上下文 2、创建路径 3、把图形放入上下文 4、渲染上下文

//drawRect的rect是绘制View的bounds

//重绘

[self setNeedsDisplay];

set =  setStroke(描边) + setFill(填充)

//方法一:最原始的方法

//1、获取图形上下文,CG,CoreGraphics,有关图形的框架,开发mac也可以用

CGContextRef ctx = UIGraphicsGetCurrentContext();

//2、创建路径

CGMutablePathRef path = CGPathCreateMutable();

//设置起始点

CGPathMoveToPoint(path, NULL, 50, 50);

//画线到某一点

CGPathAddLineToPoint(path, NULL, 200, 200);

//3、把图形放入上下文

CGContextAddPath(ctx, path);

//4、渲染上下文

CGContextStrokePath(ctx);

//绘图的第二种方法

- (void)drawLine2 {

CGContextRef ctx = UIGraphicsGetCurrentContext();

//设置起始点

CGContextMoveToPoint(ctx, 50, 50);

//画线并设置终点

CGContextAddLineToPoint(ctx, 200, 200);

//渲染上下文

CGContextStrokePath(ctx);

}

//第三种方法

- (void)drawLine3 {

//贝塞尔线,UIKit

//创建路径

UIBezierPath * path = [UIBezierPath bezierPath];

//设置起点

[path moveToPoint:CGPointMake(50, 50)];

//画线并设置终点

[path addLineToPoint:CGPointMake(200, 200)];

//绘制路径

[path stroke];

}

//属性

- (void)drawCtxState {

CGContextRef ctx = UIGraphicsGetCurrentContext();

CGContextMoveToPoint(ctx, 50, 50);

CGContextAddLineToPoint(ctx, 100, 50);

//    CGContextMoveToPoint(ctx, 80, 60);

//默认下一根线的起点就是上一根线的终点

CGContextAddLineToPoint(ctx, 100, 200);

//设置线宽度

CGContextSetLineWidth(ctx, 5);

//设置连接样式

CGContextSetLineJoin(ctx, kCGLineJoinRound);

//设置顶角样式

CGContextSetLineCap(ctx, kCGLineCapRound);

//设置线的颜色

[[UIColor redColor] setStroke];

CGContextStrokePath(ctx);

}

//画曲线

- (void)drawRect:(CGRect)rect {

// Drawing code

CGContextRef ctx = UIGraphicsGetCurrentContext();

CGContextMoveToPoint(ctx, 50, 50);

//画曲线 arg1 上下文  arg2,3 控制点x,y   arg4,5 终点x,y

CGContextAddQuadCurveToPoint(ctx, 100, 100, 250, 50);

CGContextStrokePath(ctx);

}

 

(2)画图形

//画矩形

UIBezierPath * path = [UIBezierPath bezierPathWithRect:CGRectMake(20, 20, 200, 200)];

//画圆角矩形

UIBezierPath * path = [UIBezierPath bezierPathWithRoundedRect:CGRectMake(20, 20, 200, 200) cornerRadius:100];

//画圆弧

//Center 圆弧中心

//radius 圆弧半径

//startAngle 起始角度

//endAngle 结束角度

//clockwise YES 顺时针  NO 逆时针

CGPoint center = CGPointMake(125, 125);

UIBezierPath * path = [UIBezierPath bezierPathWithArcCenter:center radius:100 startAngle:0 endAngle:M_PI_2 clockwise:NO];

[path addLineToPoint:center];

//封闭路径

[path closePath];

[path stroke];

//要使用setFill,路径一定是封闭的

[[UIColor greenColor] setFill];

[path fill];

//画椭圆

UIBezierPath * path = [UIBezierPath bezierPathWithOvalInRect:CGRectMake(20, 50, 200, 100)];

[path stroke];

}

6、绘制图片和文字

(1)绘制图片

- (void)drawPicture {

//图片裁剪,超出部分全部剪掉

UIRectClip(CGRectMake(0, 0, 50, 50));

UIImage * image = [UIImage imageNamed:@"01"];

//根据rect拉伸图片

[image drawInRect:CGRectMake(0, 0, 100, 100)];

[image drawInRect:rect];

//显示原图片尺寸

[image drawAtPoint:CGPointZero];

//平铺绘图

[image drawAsPatternInRect:rect];

}

(2)绘制文字

- (void)drawRect:(CGRect)rect {

// Drawing code

NSString * string = @"hgfdagskjhdcadkhdkjlashkdklhahgfdagskjhdcad";

NSShadow * shadow = [[NSShadow alloc] init];

shadow.shadowColor = [UIColor yellowColor];

shadow.shadowOffset = CGSizeMake(5, 5);

//模糊度

shadow.shadowBlurRadius = 3;

NSDictionary * dict = @{NSFontAttributeName:[UIFont systemFontOfSize:30],

NSForegroundColorAttributeName:[UIColor redColor],

NSStrokeColorAttributeName:[UIColor blueColor],

NSStrokeWidthAttributeName:@(2),

NSShadowAttributeName: shadow};

//不会换行

[string drawAtPoint:CGPointZero withAttributes:nil];

[string drawInRect:rect withAttributes:dict];

}

iOS 画图讲解的更多相关文章

  1. iOS 画图讲解2

    1.图片水印 //layer上下文只能显示在drawRect里 //当开启上下文时,绘制图形即可在viewDidLoad中实现 //位图的上下文 //UIGraphicsBeginImageConte ...

  2. IOS NSUserDefaults 讲解 用法

    IOS NSUserDefaults 讲解 用法    NSUserDefaults适合存储轻量级的本地数据,比如要保存一个登陆界面的数据,用户名.密码之类的,个人觉得使用NSUserDefaults ...

  3. iOS开发讲解SDWebImage,你真的会用吗?

    SDWebImage作为目前最受欢迎的图片下载第三方框架,使用率很高.但是你真的会用吗?本文接下来将通过例子分析如何合理使用SDWebImage. 使用场景:自定义的UITableViewCell上有 ...

  4. 利用IOS画图功能画出五角星,并且可以调整五角星的填充范围

    我们要花的为一个黄色的五角星并且其中的填充黄色能够任意调整,比如只填满半个五角星,或者只填满一个角等等. 首先要重写DrawRect 方法,然后在这里实现我们的画图代码. - (void)drawRe ...

  5. iOS 画图基础

    基础要点: 1,画图不可以在 ViewController 里,而是应该在一个 UIView 的子类中,比如新建一个 DrawView 继承自 UIView. 2,覆盖 UIView 的 drawRe ...

  6. ios 画图总结

    0 CGContextRef context = UIGraphicsGetCurrentContext(); 设置上下文1 CGContextMoveToPoint 开始画线2 CGContextA ...

  7. ios 深入讲解iOS键盘一:控制键盘隐藏显示

    在iOS的开发中,我们一般使用UITextField.UITextView处理文字输入等操作,大部分情况下我们只需要一两行代码去手动管理键盘的显示隐藏:让UITextField或UITextView成 ...

  8. ios开发讲解之anchorPoint和position详解

    引言 相信初接触到CALayer的人都会遇到以下几个问题:  为什么修改anchorPoint会移动layer的位置? CALayer的position点是哪一点呢? anchorPoint与posi ...

  9. iOS 谓词讲解

    1.NSPredicate (1)比较运算符 1.比较运算符 > .< .== . >= .<= . != 运算符还可以跟逻辑运算符一起使用,&&  ,  || ...

随机推荐

  1. 技术文集:万能WINDOWS XP封装

    这里将系统封装分为3步:做系统.封装.部署 一.做系统 平台不限,但不建议在虚拟机上制作.CPU及主板芯片没有限制,关于intelide和intelppm的不兼容问题,深度白金3in1并没有删除这些注 ...

  2. Cocos2d-x 关于在iOS平台真机测试的一些注意

    下面简单记录一下在最近cocos2d-x项目在iOS平台真机测试和模拟器测试中遇到的一些要注意的地方(使用ipod): 1.图片大小 游戏中基本上都是会用到图片,那么在使用图片的时候要特别注意图片的s ...

  3. Left join 中On和Where的作用范围

    SQL语句如下: SELECT * FROM 表1 LEFT JOIN 表2 ON 表1.id = 表2.id AND 表2.Name != 'ff'WHERE 表1.NAME != 'aa' Lef ...

  4. 配置IIS服务器,.apk文件下载

    iis中支持下载apk文件, 发布的网站上右键->属性->HTTP头->下方有个按钮叫[MIME类型]->添加:两个栏, 扩展名填写: .apk MIME类型填写: 扩展名为 ...

  5. VS2010 远程调试

    1.在客户端电脑建一个账户,账户名和密码和调试端的账户密码一样 2.在客户端电脑进入 管理工具-本地安全策略-本地策略-安全选项 网络访问:本地账户的共享和安全模式”,改为“经典-本地用户以自己的身份 ...

  6. 负载均衡SESSION同步总结

    1.redis/分布式文件存储系统/数据库 存储session,解决负载均衡集群中session不一致问题 http://www.cnblogs.com/painsOnline/p/5194851.h ...

  7. HTML要点(四)<meta>标签

    浏览器支持 所有浏览器都支持 <meta> 标签. 定义和用法 <meta> 元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和 ...

  8. Java中String对象的不可变性

    首先看一个程序 package reverse; public class Reverse { public static void main(String[] args) { String c1=n ...

  9. MariaDB5.5.32 绿色版下载安装一条龙

    1.下载地址: http://ftp.yz.yamagata-u.ac.jp/pub/dbms/mariadb/mariadb-5.5.32/win32-packages/mariadb-5.5.32 ...

  10. 战舰少女 黑暗炼钢 按键精灵 代码及apk下载

    注: 该代码仅仅适用于1920*1080分辨率的android手机,因为我只有这个分辨率的手机TnT 代码其实蛮简单的,都是比较简单的模拟就好了…… 要改也比较轻松吧 APK下载地址:链接: http ...