博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
简笔画项目总结: ios绘图机制 & 实现记录笔迹功能
阅读量:5260 次
发布时间:2019-06-14

本文共 2192 字,大约阅读时间需要 7 分钟。

    简笔画的项目是从暑期8月份开始的,差不多9月多的时候已经有出版,修修改改拖到现在才算能结项目. 现在来总结有点晚了,一些体会早忘记了,但我还是尽力回忆一些自己认为有用的东西记录一下。 

1、故事板。我在上个项目 中谈到了故事板,就是项目的设计图。因为这次的项目系统较为复杂,逻辑连贯性不强,这就考验设计故事板的人的写故事板的能力。其实故事板就是你要完全理解整个应用依赖的东西,所以故事板写得清晰合理的话,项目也会进行得较为顺利。这次的故事板有很多细节没有交代清楚,好多东西都需要后来的讨论才最终确定下来,这虽说是无可避免的但是能减少就减少吧。

2、ios绘图机制:因为简笔画项目主要就是一个绘图软件,所以总结一些ios的绘图是必须的。   

可参考上面的官方文档。

ios提供了2种绘图方案:

1,采用iOS的核心图形库:Quartz, Core Animation, and UIKit

2,采用OpenGL ES。

这次项目是用第一种,OpenGL更多的是应用于游戏场景中。

Quartz类库是画画的主要类库,提供了基于路径画图、反锯齿渲染、渐变填充、图像、色彩、坐标空间转换和PDF文档的一些操作。

UIKit提供划线、Quartz images和颜色操作的objective-C 封装。

Core Animation:提供了UIKit的的底层支持,也可以用来实现自定义动画。

 

The UIKit Graphics System

1、画图主要在中进行,但你不能主动去调用它,它只能被系统本身调用,我们只能通过 or  通知系统更新绘图,系统之后会自行去调用drawRect。

2、Graphics Contexts:Conceptually, a graphics context is an object that describes where and how drawing should occur, including basic drawing attributes such as the colors to use when drawing, the clipping area, line width and style information, font information, compositing options, and so on。从定义可以看出,Graphics Contexts可以理解成一个画板,画板上可以定义一些基本的画图元素。每个UIVIew都会创建。

3、坐标。

上图是用户坐标、视图坐标、硬件坐标的关系。但我们更关心的是ios接口给我们的坐标系统:2种坐标系统

upper-left-origin coordinate system (ULO)  and  lower-left-origin coordinate system (LLO)

关于坐标变换的可以参考 。

4、画图。

说了这么多,究竟在ios上如何实现画图呢?

 

-(void)drawRect:(CGRect)rect{         CGContextRef ref=UIGraphicsGetCurrentContext();//拿到当前被准备好的画板。在这个画板上画就是在当前视图上画         CGContextBeginPath(ref);//这里提到一个很重要的概念叫路径(path),其实就是告诉画板环境,我们要开始画了,你记下。         CGContextMoveToPoint(ref, 0, 0);//画线需要我解释吗?不用了吧?就是两点确定一条直线了。         CGContextAddLineToPoint(ref, 300,300);         CGFloat redColor[4]={
1.0,0,0,1.0}; CGContextSetStrokeColor(ref, redColor);//设置了一下当前那个画笔的颜色。 CGContextStrokePath(ref);//告诉画板,对我移动的路径用画笔画一下。}

 

什么简单的画了一条线,其实画画的过程都差不多,有几个步骤:

1,拿到当前面板  UIGraphicsGetCurrentContext

2,开始画声明

3,画

4,提交画

主要在对Graphics Contexts做的那些修改上面:

 

具体内容自行查文档,这里不赘述。

5、View截图

-(UIImage *)getImage{    UIGraphicsBeginImageContext(self.bounds.size);    [self.layer renderInContext:UIGraphicsGetCurrentContext()];    UIImage *Img = UIGraphicsGetImageFromCurrentImageContext();    UIGraphicsEndImageContext();    return Img;}

 

 记录笔迹:

具体看我的另一篇blog:

 

 

 

more :

 

转载于:https://www.cnblogs.com/mybkn/archive/2012/11/15/2772120.html

你可能感兴趣的文章
LeetCode#48 Rotate Image
查看>>
Pizza Pie Charts – 基于 Snap SVG 框架的响应式饼图
查看>>
【Vue课堂】Vue.js 父子组件之间通信的十种方式
查看>>
【转】win8.1下安装ubuntu
查看>>
程序员进阶中--说说这一年的“酸甜苦辣”
查看>>
zoj3662Math Magic
查看>>
匈牙利算法
查看>>
我的iOS学习历程 - UITouch(触摸反应)
查看>>
转-Hive/Phoenix + Druid + JdbcTemplate 在 Spring Boot 下的整合
查看>>
Linux下给mysql创建用户分配权限
查看>>
千万级用户的大型网站,应该如何设计其高并发架构?
查看>>
easyui-datebox 只能获取当前日期以前的日期
查看>>
Linux简单学习
查看>>
LDAP学习小结【仅原理和基础篇】
查看>>
MySQL练习题1
查看>>
Linux OpenGL 实践篇-16 文本绘制
查看>>
项目:Android平台txt阅读软件
查看>>
解决Spring MVC报No converter found for return value of type:class java.util.ArrayList问题
查看>>
关系代数和sql语句对应关系
查看>>
jQuery-ui treegird 使用
查看>>