IOS 作业项目(4)步步完成 画图 程序(中续)
一,程序布局整理
前言://1,程序启动//2,程序流程框架//3,程序界面一致//4,程序界面功能,
//这里只做页面的固定功能, //在首次创建界面时,我们会指定好固定事件触发前的固定方法 //至于另外程序启动后,运行过程中会添加和减少的事件触发的方法,我们会在另外一个"刷新"方法内实现
在上面7大视图中添加按钮事件,这些事件写在所有外观布局代码的最下边,例如在editScene视图中,我们把所有的事件都写在如下内容处,其余视图中的事件按此方式来写
//------------------------------------------------------------------------------------------
//返回按钮功能
[leftButton addTarget:self action:@selector(editSceneBackMainScene:) forControlEvents:UIControlEventTouchUpInside];
//保存按钮功能
[rightButton addTarget:self action:@selector(editSceneBackMainScene:) forControlEvents:UIControlEventTouchUpInside];
//背景颜色按钮的功能
[backgroundButton addTarget:self action:@selector(editSceneToBgColorScene:) forControlEvents:UIControlEventTouchUpInside];
//画笔颜色按钮的功能
[midButton addTarget:self action:@selector(editSceneToLineColorScene:) forControlEvents:UIControlEventTouchUpInside];
//画笔大小按钮的功能
[lineWidthButton addTarget:self action:@selector(editSceneToLineWidthScene:) forControlEvents:UIControlEventTouchUpInside];
//-----------------------------------------------------------------------------------------------------------------------
二,画图
布局和跳转写好之后,就要完成主要功能,最主要功能是画图,界面三
建立一个画图类,.h文件如下:
@interface TuyaPad : UIView
@property (nonatomic,strong)UIColor * lineColor;
@property (nonatomic,assign)CGFloat lineWidth;
-(UIImage *)getImageFromCurrentContext;
@end
实现内容如下:
#import "TuyaPad.h"
@interface TuyaPath:NSObject
@property (nonatomic,assign)CGMutablePathRef path;
@property (nonatomic,assign)CGColorRef color;
@property (nonatomic,assign)CGFloat width;
@end
@implementation TuyaPath
@end
@interfaceTuyaPad()
//存储路径信息
@property (nonatomic,strong)NSMutableArray* pathlist;
@end
@implementation TuyaPad
{
//触摸路径
CGMutablePathRef touchPath;
//中间变量路径
CGMutablePathRef tempPath;
//三个触摸点
CGPoint startPoint,controlPoint,endPoint;
}
- (id)initWithFrame:(CGRect)frame
{
self = [super initWithFrame:frame];
if (self) {
self.lineColor=[UIColor blackColor];
self.lineWidth=10.f;
self.pathlist=[[NSMutableArray alloc]init];
}
returnself;
}
// Only override drawRect: if you perform custom drawing.
// An empty implementation adversely affects performance during animation.
- (void)drawRect:(CGRect)rect
{
[super drawRect:rect];
//1,获取当前画布
CGContextRef context=UIGraphicsGetCurrentContext();
//2,划线
for (TuyaPath *path in self.pathlist) {
//设置描绘颜色
CGContextSetStrokeColorWithColor(context, path.color);
//设置线条宽度
CGContextSetLineWidth(context, path.width);
//将路径添加到画布上
CGContextAddPath(context, path.path);
//设置线条形状
CGContextSetLineCap(context, kCGLineCapRound);
//开始描绘
CGContextStrokePath(context);
}
}
//触摸开始
-(void)touchesBegan:(NSSet *)touches withEvent:(UIEvent *)event
{
//实例化tuyaPath对象
TuyaPath *itemPath=[[TuyaPath alloc]init];
itemPath.color=self.lineColor.CGColor;
itemPath.width=self.lineWidth;
//实例化触摸路径对象
touchPath=CGPathCreateMutable();
itemPath.path=touchPath;
//将TuyaPath对象添加到路径数组内
[self.pathlist addObject:itemPath];
//获取触摸对象
UITouch *touch=[touches anyObject];
startPoint =[touch previousLocationInView:self];
controlPoint=[touch previousLocationInView:self];
endPoint=[touch locationInView:self];
[self touchesMoved:touches withEvent:event];
}
//触摸移动
-(void)touchesMoved:(NSSet *)touches withEvent:(UIEvent *)event
{
//获取触摸对象
UITouch *touch=[touches anyObject];
startPoint=controlPoint;
controlPoint=[touch previousLocationInView:self];
endPoint=[touch locationInView:self];
CGFloat mid1x=(startPoint.x+controlPoint.x)/2.0;
CGFloat mid1y=(startPoint.y+controlPoint.y)/2.0;
CGFloat mid2x=(controlPoint.x+endPoint.x)/2.0;
CGFloat mid2y=(controlPoint.y+endPoint.y)/2.0;
tempPath=CGPathCreateMutable();
CGPathMoveToPoint(tempPath, NULL, mid1x, mid1y);
CGPathAddQuadCurveToPoint(tempPath, NULL, controlPoint.x, controlPoint.y, mid2x, mid2y);
//将中间变量路径添加到触摸路径内
CGPathAddPath(touchPath, NULL, tempPath);
//获取路径数组内的最后一个元素
TuyaPath *laseItem=[self.pathlist lastObject];
laseItem.path=touchPath;
//根据中间变量路径,计算最小范围
CGRect boundingBox=CGPathGetBoundingBox(tempPath);
boundingBox.origin.x-=self.lineWidth;
boundingBox.origin.y-=self.lineWidth;
boundingBox.size.width+=2*self.lineWidth;
boundingBox.size.height+=2*self.lineWidth;
//[self setNeedsDisplay];
[selfsetNeedsDisplayInRect:boundingBox];//在原画板上画bounding区域的内容
}
//触摸结束
-(void)touchesEnded:(NSSet *)touches withEvent:(UIEvent *)event
{
//获取触摸路径对象
TuyaPath *lastPath=[self.pathlist lastObject];
//指定触摸路径对象结束时,触摸路径是touchPath
lastPath.path=touchPath;
}
-(UIImage *)getImageFromCurrentContext
{
UIGraphicsBeginImageContext(self.bounds.size);//创建画布用UIGraphicsGetCurrentContext()可以获得
[self.layerrenderInContext:UIGraphicsGetCurrentContext()];//self.layer当前画布上的内容 渲染到图片画布
UIImage *result= UIGraphicsGetImageFromCurrentImageContext();
UIGraphicsEndImageContext();
[self.pathlistremoveAllObjects];
[selfsetNeedsDisplay];
return result;
}
@end
主要内容如上,剩下的是细节和部分功能,在下节上主要代码.
IOS 作业项目(4)步步完成 画图 程序(中续)的更多相关文章
- IOS 作业项目(4)步步完成 画图 程序(中)
一,承接上文,继续本文 [UIButton buttonWithType:UIButtonTypeRoundedRect]; 如此声明的按钮才会有点击闪动的效果!如果直接frame方式声明就不会有. ...
- IOS 作业项目(4)步步完成 画图 程序(问题处理)终结
一,解决换色程序崩溃问题 程序崩溃是因为颜色的内存被释放,添加如下类的内容即可 @implementation TuyaPath - (id)init { self = [super init]; i ...
- IOS 作业项目(4)步步完成 画图 程序(剧终)
// // CHViewController.m // SuperDrawingSample // // Created by JaikenLI on 13-11-21. // Copyrig ...
- IOS 作业项目(4)步步完成 画图 程序(上)
先上流程图
- IOS 作业项目(2) 画图(保存,撤销,笔粗细设定功能)
先上效果图
- IOS 作业项目 TableView两个section中cell置顶功能实现
点击cell会置顶,其他的下移
- IOS 作业项目(3) 霓虹灯效果
先上效果图 #import "CHViewController.h"@interface CHViewController (){ int i; int j;}@pro ...
- IOS 作业项目(1) 关灯游戏 (百行代码搞定)
1,准备工作,既然要开关灯,就需要确定灯的灯的颜色状态 首先想到的是扩展UIColor
- iOS:项目中疑难Crash问题集锦
项目中疑难Crash问题集锦 iOS App运行中遇到Crash的情况相信大家都遇到过,开发和者测试中遇到了可能很方便的办法就是直接拿着设备连接一下,然后使用Xcode自带的工具就可以解析出Crash ...
随机推荐
- hdu-----(2807)The Shortest Path(矩阵+Floyd)
The Shortest Path Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others ...
- hdu----(2848)Repository(trie树变形)
Repository Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total ...
- poj1122 FDNY to the Rescue!(dij+反向建图+输出路径)
题目链接:poj1122 FDNY to the Rescue! 题意:给出矩阵,矩阵中每个元素tij表示从第i个交叉路口到第j个交叉路口所需时间,若tij为-1则表示两交叉路口之间没有直接路径,再给 ...
- K2工作流的使用
K2的工作流作为工作流中的战斗机,被各大企业争相抢购着,当然我们公司也买了,用起来确实方便也的确很强大. 主要分两的模块: 一.K2.net 2003 Service Manager 以上是对配置用户 ...
- shell脚本初析
简单理解:运用很多工具,将复杂的步骤简单化,体现在shell脚本中框架:必须有备注,写的别人能够看得懂开头:#! /bin/bash 代表的意思是改文件使用的是bash语法要想使用该种方法运行shel ...
- mysql的部分命令图解
1.查询有哪些库: show databases; 图中除了Carlton库之外,其它都是系统自带的. 要养成在命令后加入:的习惯 2.查看某个库的表 show tables; 3. 查看表的字段 ...
- 关于HTML5应用开发功耗调优化小结
HTML5的优化一直是困扰我的难题,特别是在移动端开发游戏和应用,所以对此进行了一些总结: 功耗优化点介绍 在移动设备中主要的功耗点在: 1. 网络的传输, 不管是3G网络还是WiFi传输都是移动设备 ...
- POJ 1436 区间染色
Horizontally Visible Segments Time Limit: 5000MS Memory Limit: 65536K Total Submissions: 4507 Ac ...
- UVa 11426 - GCD - Extreme (II)
http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem&p ...
- 线程系列3---ThreadLocal类研究
2013-12-23 17:44:44 Java为线程安全提供了一些工具类,如ThreadLocal类,它代表一个线程局部变量,通过把数据放在ThreadLocal中就可以让每个线程创建一个该变量的副 ...