上下文画图-总结

第一:通过路径来画图 - 步骤 -- 这个是比较复杂的方式

//0. 找到图形上下文-Context (所有的路径都要画到图形上下文中)
    CGContextRefcontext = UIGraphicsGetCurrentContext();
     //1.创建一个可变的路径
   CGMutablePathRef mutablePath =CGPathCreateMutable();
     //2. 在该可变路径中添加了一个矩形路径
   CGPathAddRect(mutablePath, nil, CGRectMake(100, 100,100, 100));
    //3.将该可变路径添加到上下文
   CGContextAddPath(context, mutablePath);
    //
4.-------- 将路径绘制出来draw (上下文负责) --------
    CGContextDrawPath(context, kCGPathStroke);
    //5.关闭路径
   CGPathRelease(mutablePath);

第二种画矩形的方式

//这种方式不需要关闭路径
 CGContextRefcontext = UIGraphicsGetCurrentContext();
    CGContextAddRect(context, CGRectMake(100, 100, 150, 150));
    CGContextDrawPath(context, kCGPathStroke);
/**
 1. 当我们需要自定义绘制的内容时, 重写drawRect: 方法(不能直接调用drawRect:)
 2. 当我们需要刷新界面的内容(重新绘制时), 调用setNeedsDisplay方法
 */
- (void)setTitle:(NSString *)title{
   _title = title;
    //重新调用drawRect
    [self setNeedsDisplay];
}
- (void)drawRect:(CGRect)rect{
   // [@"zhoushujian" drawInRect:CGRectMake(100, 100, 100, 23)
withAttributes:nil];
  //  [self drawImage:rect];
}

绘图片

- (void)drawImage:(CGRect)rect{
    //图片的绘制
    //确定图片的size,在该size当中进行绘制
  UIImage*image = [UIImage imageNamed:@"帅哥.jpg"];
    //对图片进行绘制,drawInRect:会对图片进行拉伸,
    [imagedrawInRect:CGRectMake(100, 100,image.size.width,image.size.height)];
  NSString*context = @"云霞宝宝,我想你";
    NSMutableParagraphStyle*paragraph = [NSMutableParagraphStyle new];
    //居中对齐
    paragraph.alignment= NSTextAlignmentCenter;
   NSDictionary *dict = @{
                     NSFontAttributeName:[UIFont
systemFontOfSize:20],
                     NSForegroundColorAttributeName:[UIColor redColor];
                     NSParagraphStyleAttributeName:paragraph
                     };
    [context drawInRect:CGRectMake(0, 280, rect.size.width,
rect.size.height)
withAttributes:dict];
}

字符串绘制

- (void)drawString:(CGRect)rect{
    //字符串的绘制
  NSString*context = @"好好学习,天天上炕";
   NSShadow *shadow = [NSShadow
new];
    //阴影偏移量,阴影颜色
    shadow.shadowOffset = CGSizeMake(50, 50);
    shadow.shadowColor = [UIColor
grayColor];
    //高斯模糊
    shadow.shadowBlurRadius= 5;
    //创建一个段落
    NSMutableParagraphStyle*paragraph = [NSMutableParagraphStyle new];
    //文本居中对齐
    paragraph.alignment= NSTextAlignmentCenter;
    //最常用的几个属性: 前景色, 字体类型, 段落样式(文本居中对齐):用字典
  NSDictionary *dict = @{                  
  //设置文本字体类型
                     NSFontAttributeName:[UIFont systemFontOfSize:35],   
  //设置字体颜色
                     NSForegroundColorAttributeName:[UIColor redColor];                
  //段落样式
                   NSParagraphStyleAttributeName:paragraph,                 
  //设置背影
                    NSShadowAttributeName:shadow,         
  //配置背影描边颜色
                     NSStrokeColorAttributeName:[UIColor grayColor]
                     };
    [context  drawInRect:CGRectMake(0, 200, rect.size.width,400) withAttributes:dict];
}

画一个测试效果

- (void)drawTest{
    CGContextRefcontext = UIGraphicsGetCurrentContext();
    //设置颜色
    [[UIColor redColor] set];
  //宽度
    CGContextSetLineWidth(context, 50);
    //设置线段顶点样式
    CGContextSetLineCap(context, kCGLineCapRound);
    //设置连接点的样式
    CGContextSetLineJoin(context, kCGLineJoinRound);
    //设置阴影状态  最后一个参数是模糊值,
    CGContextSetShadow(context, CGSizeMake(50, 50), 10);
    //画起点
    CGContextMoveToPoint(context, 100, 100); 
  //画线
    CGContextAddLineToPoint(context, 200, 200);
  //渲染
    CGContextDrawPath(context, kCGPathStroke);
    //设置另一根线的颜色
    [[UIColor blueColor] set];
//设置另一根线
    CGContextMoveToPoint(context, 200, 200);
    CGContextAddLineToPoint(context,200, 100);
    //封闭路径
    //CGContextClosePath(context);
  //渲染
    CGContextDrawPath(context, kCGPathStroke);
}

虚线

- (void)drawXuXian{
    // [self  drawJuXing];
    CGContextRefcontext = UIGraphicsGetCurrentContext();
    //设置线条宽度
    CGContextSetLineWidth(context, 50);
    //设置起点
    CGContextMoveToPoint(context, 100, 100);
  //连线
    CGContextAddLineToPoint(context, 300, 100);
    //创建一个数组
   CGFloat length[] = {4,6,5,6,8,9};
   /**
     * 虚线开始绘制的地方, 距离起始位置20
     * 虚线获取的间隙, 数组
     * 数组的个数
  */
   CGContextSetLineDash(context,0, length, 6);
  //渲染
    CGContextDrawPath(context, kCGPathStroke);
}

画矩形

- (void)drawJuXing{
    //0.找到图形上下文-Context (所有的路径都要画到图形上下文中)
    CGContextRefcontext = UIGraphicsGetCurrentContext();
    //描边颜色
    [[UIColor redColor] setFill];
    //1.创建一个可变的路径
   CGMutablePathRef mutablePath =CGPathCreateMutable();
    //2.在该可变路径中添加了一个矩形路径
   CGPathAddRect(mutablePath, nil, CGRectMake(100, 100,100, 100));
    //3.将该可变路径添加到上下文
   CGContextAddPath(context, mutablePath);
    //
4.-------- 将路径绘制出来draw (上下文负责) --------
    CGContextDrawPath(context, kCGPathFill);
    //5.关闭路径
   CGPathRelease(mutablePath);
   /*第二种方式画矩形
  CGContextRef context = UIGraphicsGetCurrentContext();
  CGContextAddRect(context, CGRectMake(100, 100, 150, 150));
  CGContextDrawPath(context, kCGPathStroke);
  */
   /*
     //画两个矩形,描述奇偶填充
  CGContextRef context = UIGraphicsGetCurrentContext();
  CGContextAddRect(context, CGRectMake(50, 50, 200, 300));
  CGContextAddRect(context, CGRectMake(100, 100, 200, 300));
  CGContextDrawPath(context, kCGPathEOFillStroke);
  */
}

画圆弧

- (void)drawYuanHu{
    //画圆弧
    //0 ,找到图形上下文-context
    //-------- 绘制弧线(椭圆, 再确定角度, 就可以裁剪出弧线)--------
    //* Quartz 2D 最初是为macOS而设计, 后继再引用到iOS
    //* Quartz 2D 的坐标系是以左下解为原点, 而UIKit是以左上角为原点
    //* 沿X轴是翻译过来的
   /**
     *  绘制弧线
     * x 与y 确定圆心
     * raduis 确定半径
     * startAngle 与endAngle 确定了弧度度数
     * clockwise 顺逆时针, 1顺时针, 0是逆时针
  */
    CGContextRefcontext = UIGraphicsGetCurrentContext();
   CGContextAddArc(context, 200,
200, 100,
M_PI*2,M_PI_2, 0);
    CGContextDrawPath(context, kCGPathStroke);
}

画圆

- (void)drawYuan{
    //0.找到图形上下文-Context (所有的路径都要画到图形上下文中)
    CGContextRefcontext = UIGraphicsGetCurrentContext();
    //1.路径
    CGContextAddEllipseInRect(context, CGRectMake(100, 100, 100, 150));
    //2.将路径绘制出来
    CGContextDrawPath(context, kCGPathStroke);
   /*
  typedef CF_ENUM (int32_t, CGPathDrawingMode) {
     kCGPathFill,  填充
     kCGPathEOFill, 奇偶填充
     kCGPathStroke, 描边
     kCGPathFillStroke, 既描边又填充
     kCGPathEOFillStroke  ,奇偶填充
  };
  */
}

画线

- (void)drawLine{
    CGContextRefcontext = UIGraphicsGetCurrentContext();
    //1. 确定起点(移动到某个点)
    CGContextMoveToPoint(context, 100, 100);
    //2. 连接当前点到起点
    CGContextAddLineToPoint(context, 200, 200);
    //3. 再画一条线
    CGContextAddLineToPoint(context, 100, 300);
    CGContextAddLineToPoint(context, 0, 200);
    //关闭路径就是形成一个回路-如果不关闭的话,就是一个开路
    CGContextClosePath(context);
  //渲染
    CGContextDrawPath(context, kCGPathStroke);
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容