CoreGraphics--画线/圆/矩形
- (void)drawRect:(CGRect)rect {
// Drawing code
NSLog(@"drawRect自动调用");
//画图步骤
//获取上下文(/画笔/绘图环境)
CGContextRef context = UIGraphicsGetCurrentContext();
//设置画笔颜色
CGContextSetStrokeColorWithColor(context, [UIColor redColor].CGColor);
//线条的宽度
CGContextSetLineWidth(context, 4);
//开始画
//1.画一条直线
// [self drawOneLineWith:context];
//2-1.画多条线
// [self drawManyLines:context];
//2-2
// [self drawManyLines2:context];
//3画虚线
// [self drawDashLine:context];
//4 画矩形
// [self drawRectShape:context];
//5.填充的矩形
// [self drawFillRect:context];
//6 画椭圆
// [self drawCircle:context];
//7.填充的椭圆
// [self drawFillCircle:context];
//8 显示文字
// [self drawText];
//9.显示图片
[self drawImage];
// 10绘制曲线
//11圆弧
}
#pragmark mark 11 圆弧
- (void)drawArc{
//画布
CGContextRef ctx = UIGraphicsGetCurrentContext();
CGContextBeginPath(ctx);
//圆弧
* @param c 当前图形
* @param x 圆弧的中心点坐标x
* @param y 曲线控制点的y坐标
* @param radius 指定点的x坐标值
* @param startAngle 弧的起点与正X轴的夹角,
* @param endAngle 弧的终点与正X轴的夹角
* @param clockwise 指定1创建一个顺时针的圆弧,或是指定0创建一个逆时针圆弧
*
*/
CGContextAddArc(ctx, 100, 100, 50, 0,M_PI/2, 0);
CGContextSetLineWidth(ctx, 3); //线宽
// CGContextStrokePath(ctx);//描线
CGContextFillPath(ctx); //填充
}
#pragma mark 10 二次曲线
- (void)drawCurve {
// 获取当前图形,视图推入堆栈的图形,相当于你所要绘制图形的图纸
CGContextRef ctx = UIGraphicsGetCurrentContext();
// 创建一个新的空图形路径。
CGContextBeginPath(ctx);
//开始点
CGContextMoveToPoint(ctx, 160, 100);
/** * @brief 在指定点追加二次贝塞尔曲线,通过控制点和结束点指定曲线。
@param c 当前图形 * @param cpx 曲线控制点的x坐标 *
@param cpy 曲线控制点的y坐标 *
@param x 指定点的x坐标值 *
@param y 指定点的y坐标值 * */
CGContextAddQuadCurveToPoint(ctx, 160, 50, 190, 50);
CGContextSetLineWidth(ctx, 20);
CGContextSetStrokeColorWithColor(ctx, [UIColor brownColor].CGColor);
CGContextStrokePath(ctx);
}
#pragma makr -- 9 显示图片
- (void)drawImage{
[[UIImage imageNamed:@"收藏-128"] drawInRect:CGRectMake(0, 0, 100, 100)];
}
#pragma mark -- 8 显示文字
- (void)drawText{
//起点(attribute 中设这参数)
[@"aaabbbcccddd" drawAtPoint:CGPointMake(100, 100) withAttributes:NULL];
//
[@"asdfasdfaf" drawInRect:CGRectMake(100, 150, 200, 200) withAttributes:NULL];
}
#pragma mark -- 7 画填充的 椭圆
- (void)drawFillCircle:(CGContextRef)context{
//填充的颜色
[[UIColor redColor] setFill];
CGContextFillEllipseInRect(context, CGRectMake(40, 40, 200, 300));
}
#pragma mark -- 6 画椭圆
- (void)drawCircle:(CGContextRef)context{
CGContextStrokeEllipseInRect(context, CGRectMake(40, 40, 300, 200));
}
#pragma mark -- 5填充的矩形
- (void)drawFillRect:(CGContextRef)context{
//设置填充颜色
[[UIColor yellowColor] setFill];
CGContextFillRect(context, CGRectMake(40, 40, 250, 300));
}
#pragma mark --4画矩形
- (void)drawRectShape:(CGContextRef)context{
CGContextStrokeRect(context, CGRectMake(40, 40, 200, 300));
//同理(stroke 画图方法; 也有add..方法 )
// CGContextAddRect(context, CGRectMake(40, 40, 200, 300));
// CGContextStrokePath(context);
}
#pragma mark -- 3 画虚线
- (void)drawDashLine:(CGContextRef)context{
//设置虚线类型
// CGFloat lengths[] = {5,15,5}; //长5 空隙15 长5 ...
CGFloat lengths[] = {5,5};
CGContextSetLineDash(context, 0, lengths, sizeof(lengths)/sizeof(lengths[0]));
// CGContextSetLineDash(<#CGContextRef c#>, <#CGFloat phase#>, <#const CGFloat *lengths#>, <#size_t count#>)
//phase 开始点 跳过多少个点数(0代表从头画)
//lengths 虚线的样式
//count 长度
//起点
CGContextMoveToPoint(context, 50, 50);
//画线
CGContextAddLineToPoint(context, 200, 200);
CGContextStrokePath(context);
//第二段设置成 直线 NULL
CGContextSetLineDash(context, 0, NULL, 0);
//需要重新设置起点
CGContextMoveToPoint(context, 200, 200);
CGContextAddLineToPoint(context, 250,400);
CGContextStrokePath(context);
}
#pragma mark --画多条线 (方式二)
- (void)drawManyLines2:(CGContextRef)context{
CGPoint point[] = {CGPointMake(50, 50),CGPointMake(100, 100),CGPointMake(100, 200)};
//计算数组中元素个数
// int count = sizeof(数组名)/size(sizeof(a[0]));
//个数
CGContextAddLines(context, point, sizeof(point)/sizeof(point[0]));
//闭合
CGContextClosePath(context);
//开始画
CGContextStrokePath(context);
}
#pragma mark --画多条线 (方式一)
- (void)drawManyLines:(CGContextRef)context{
//例如:三角形
CGContextMoveToPoint(context, 200, 100);
CGContextAddLineToPoint(context, 100, 200);
CGContextAddLineToPoint(context, 300, 200);
//回到起点
// CGContextAddLineToPoint(context, 200, 100);
//按方法2 : 闭合(起点和终点连线)
CGContextClosePath(context);
CGContextStrokePath(context);
}
#pragma mark -- 1 画一条线
- (void)drawOneLineWith:(CGContextRef)context{
//起点
CGContextMoveToPoint(context, 50, 50);
//终点:画线
CGContextAddLineToPoint(context, 200, 200);
//开始画
CGContextStrokePath(context); //画线
//CGContextFillPath(context); //填充路径
}
CoreGraphics--画线/圆/矩形的更多相关文章
- 使用gimp画线、矩形、圆等
使用gimp画线.矩形.圆等 https://blog.csdn.net/tody_guo/article/details/7628508 2012年06月03日 19:08:47 Tody Guo ...
- PHP合成图片、生成文字、居中对齐、画线、矩形、三角形、多边形、图片抗锯齿、不失真 高性能源码示例
function generateImg($source, $text1, $text2, $text3, $font = './msyhbd.ttf') { $date = '' . date ( ...
- H5中画图标签Canvas---画矩形,画线,画圆,渐变色,图形载入
一: 1.鼠标监视坐标值 <!DOCTYPE html> <head> <meta charset=UTF-8> <title>canvas的演示< ...
- IOS Quartz 各种绘制图形用法---实现画图片、写文字、画线、椭圆、矩形、棱形等
// Only override drawRect: if you perform custom drawing. // An empty implementation adversely affec ...
- OpenCV各种绘制调用:线,矩形,圆,椭圆,文字
OpenCV提供了各种绘制接口,可以往图片里画各种东西,这种功能可以为以后在图像上标记一些信息方便调试 // drawcall.cpp: 定义控制台应用程序的入口点. // #include &quo ...
- 【液晶模块系列基础视频】4.1.X-GUI图形界面库-画线画圆等函数简介
[液晶模块系列基础视频]4.1.X-GUI图形界面库-画线画圆等函数简介 ============================== 技术论坛:http://www.eeschool.org 博客地 ...
- 纯JS画点、画线、画圆的方法
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- IOS 绘制基本图形( 画圆、画线、画圆弧、绘制三角形、绘制四边形)
// 当自定义view第一次显示出来的时候就会调用drawRect方法- (void)drawRect:(CGRect)rect { // 1.获取上下文 CGContextRef ctx = UIG ...
- LCD编程_画点线圆
上篇博客中进行了lcd的简单测试,这篇博客将进行更加复杂的测试——画点.画线.画圆.画线和画圆是在画点的基础上实现的,因此本篇博客重点实现画点操作. 先抛出这样的一个问题,已知: (x,y)的坐标: ...
随机推荐
- Web应用中监听者的通知顺序按照DD中的定义顺序
Web应用中监听者的通知顺序按照DD中的定义顺序: XML: <?xml version="1.0" encoding="UTF-8"?> < ...
- bootstrap 表单控件 控件状态 控件大小 help-block
bootstrap 表单控件 控件状态 控件大小 help-block <!DOCTYPE html> <html lang="en"> <head& ...
- Servlet 获取IllegelStateException
Servlet 获取IllegelStateException: response提交之后,进行requestDispatcher.forwar(),会产生这样的问题: 但是必须是outputStre ...
- saiku的源码包Bulid常见问题和jar包
最近在做kylin+mondrian+saiku的二次开发的时候,Bulid saiku的源码出现了很多问题,基本上一大部分问题jar找不到问题,很多jar国内网站都找不到.这时候只有手动下载然后注册 ...
- 怎么应用vertical-align,才能生效?
vertical-align 的使用 以前总是想要一些元素垂直居中对齐,经常用line-height,可是对于图片来说,line-height的表现并不理想(非常不理想)可看我的文章:line-he ...
- (四)Hololens Unity 开发之 凝视系统
学习源于官方文档 Gaze in Unity 笔记一部分是直接翻译官方文档,部分各人理解不一致的和一些比较浅显的保留英文原文 HoloLens 有三大输入系统,凝视点.手势和声音 ~ 本文主要记录凝视 ...
- yii2 中布局文件的 设置方法
网页主题应用的属性: [yii\base\Application::layout|layout 该属性指定渲染 视图 默认使用的布局名字,默认值为 'main' 对应布局路径下的 main.php 文 ...
- 微信小程序----关于变量对象data 和 前端wxml取后台js变量值
(一)页面变量对象data 对象data 有两个方面用途 第一,前端wxml的数据渲染是通过设置此对象中定义的变量进行关联展现的 第二,定义JS页面中的页面局部变量,使其整个页面中可使用或调用 对象d ...
- Xcode版本太低引发的bug,xcode各种版本下载方式详解
问题描述: mac系统10.9.5 .之前用的xcode 是5.1.接sdk时,一直报错,编译不过去.最后发现原因是xcode版本太低导致的. 于是去网上找xcode历史版本下载.因为系统版本原因,我 ...
- Python学习--15 日期和时间
获取当前时间 # coding: utf-8 from datetime import datetime now = datetime.now() print(now) print(now.strft ...