Swift基础之设计折线坐标图
最近添加了折线视图的样式,所以在这里用Swift语言重新再使用设计一下
首先设置纵坐标的数值是:体重
//体重
let weightLabel = UILabel.init(frame: CGRectMake(0, 10, 60, 30));
weightLabel.text = "体重(kg)";
weightLabel.textColor = UIColor.lightGrayColor();
weightLabel.font = UIFont.systemFontOfSize(12);
weightLabel.textAlignment = NSTextAlignment.Center;
weightLabel.adjustsFontSizeToFitWidth = true;
weightV.addSubview(weightLabel);
然后设计纵向坐标设计(一定要注意设计的顺序结构,否则坐标位置容易出问题)
//纵向
let vierArray:NSArray = ["90","80","70","60","50","0"];
for i:Int in 0 ..< vierArray.count {
//纵坐标值
let vLabel = UILabel.init(frame: CGRectMake(0, 40+CGFloat(i)*30, 30, 30));
vLabel.text = vierArray[i] as? String;
vLabel.font = UIFont.systemFontOfSize(11);
vLabel.textAlignment = NSTextAlignment.Center;
vLabel.adjustsFontSizeToFitWidth = true;
vLabel.textColor = UIColor.lightGrayColor();
weightV.addSubview(vLabel);
//横坐标线
let vLineV = UIView.init(frame: CGRectMake(30, 55+30*CGFloat(i), 260, 1));
if i==vierArray.count-1 {
vLineV.backgroundColor = UIColor.blackColor();
}
else
{
vLineV.backgroundColor = UIColor.lightGrayColor();
}
weightV.addSubview(vLineV);
}
设置横向
//横向
let hierArray:NSArray = ["0","1","2","3","4","5","6","7","8"];
for i:Int in 0 ..< hierArray.count {
//横坐标值
let hLabel = UILabel.init(frame: CGRectMake(30*CGFloat(i), 40+30*CGFloat(vierArray.count)-15, 30, 30));
hLabel.text = hierArray[i] as? String;
hLabel.font = UIFont.systemFontOfSize(11);
hLabel.textAlignment = NSTextAlignment.Right;
hLabel.adjustsFontSizeToFitWidth = true;
hLabel.textColor = UIColor.lightGrayColor();
weightV.addSubview(hLabel);
//纵坐标线
let hLineV = UIView.init(frame: CGRectMake(30+30*CGFloat(i), 40, 1, 30*CGFloat(vierArray.count)-15));
if i==0 {
hLineV.backgroundColor = UIColor.blackColor();
}
else
{
hLineV.backgroundColor = UIColor.lightGrayColor();
}
weightV.addSubview(hLineV);
}
横坐标:年龄
//年龄
let ageLabel = UILabel.init(frame: CGRectMake(260, 40+30*CGFloat(vierArray.count)-15, 60, 30));
ageLabel.text = "年龄(岁)";
ageLabel.textColor = UIColor.lightGrayColor();
ageLabel.font = UIFont.systemFontOfSize(12);
ageLabel.textAlignment = NSTextAlignment.Right;
ageLabel.adjustsFontSizeToFitWidth = true;
weightV.addSubview(ageLabel);
接下来就是折线的显示了
//创建layer设置属性
let layerR = CAShapeLayer.init();
//设置包围的颜色,默认为黑色
layerR.fillColor = UIColor.clearColor().CGColor;
//折线宽度
layerR.lineWidth = 1.0;
//设置折线颜色
layerR.strokeColor = UIColor.blueColor().CGColor;
weightV.layer.addSublayer(layerR);
//创建贝塞尔路径
let pathH = UIBezierPath.init();
//设置起点
pathH.moveToPoint(CGPointMake(30, 100));
//添加坐标点
let xArray:NSArray = [50,70,90,110,130,150,170,190,210,230,250,270];
let yArray:NSArray = [160,180,200,200,150,120,80,100,130,130,180,110];
for i:Int in 0 ..< xArray.count {
pathH.addLineToPoint(CGPointMake((xArray[i] as! CGFloat), (yArray[i] as! CGFloat)));
}
layerR.path = pathH.CGPath;
//创建基础动画,连接个点
let animationN = CABasicAnimation.init(keyPath: "strokeEnd");
//设置时间
animationN.duration = 5;
//添加动画
layerR.addAnimation(animationN, forKey: nil);
效果图如下:
源码下载:http://download.csdn.net/detail/hbblzjy/9651941
Swift基础之设计折线坐标图的更多相关文章
- iOS绘制坐标图,折线图-Swift
坐标图,经常会在各种各样的App中使用,最常用的一种坐标图就是折线图,根据给定的点绘制出对应的坐标图是最基本的需求.由于本人的项目需要使用折线图,第一反应就是搜索已经存在的解决方案,因为这种需求应该很 ...
- iOS Swift 模块练习/swift基础学习
SWIFT项目练习 SWIFT项目练习2 iOS Swift基础知识代码 推荐:Swift学习使用知识代码软件 0.swift中的宏定义(使用方法代替宏) 一.视图 +控件 1.UIImag ...
- 【转】Swift 语言的设计错误
Swift 语言的设计错误 在『编程的智慧』一文中,我分析和肯定了 Swift 语言的 optional type 设计,但这并不等于 Swift 语言的整体设计是完美没有问题的.其实 Swift 1 ...
- swift基础:第六部分:类与对象
http://reactnative.cn/docs/0.24/getting-started.html#content(react Native 开发文档) 互联网这个时代,你松懈一天,就会有很多很 ...
- swift基础:第二部分:函数和闭包
今天本来想利用上午的时间本来打算将swift基础部分学习完的,不巧的是,后台来和我讨论用户评价的接口,讨论过后,商讨出一种可行的方案,十几分钟时间过去了,我拿到将接口介入到已经完成的页面中,完美,终于 ...
- Swift基础语法学习总结(转)
Swift基础语法学习总结 1.基础 1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift使用print和println打印,它的传参是一个泛型 ...
- Swift基础语法学习总结
Swift基础语法学习总结Swift高级语法学习总结Swift语法总结补充(一) 1.基础 1.1) swift还是使用// 和/* */ 来注释,并且/* */允许多行注释. 1.2) swift ...
- swift -- 基础
swift -- 基础 1.常量和变量 常量: let 变量: var 2.声明常量和变量 常量的声明: let let a = 1 //末尾可以不加分号,等号两边的空格必须对应(同 ...
- Swift基础学习
Swift基础学习 http://c.biancheng.net/cpp/html/2242.html 这个网站最近看了一下,对于基本语法解释概括的相对全面,如同重新练习一遍OC似的,挺全面的,谢谢 ...
随机推荐
- [Awson原创]网络(network)
Description Awson是某国际学校信竞组的一只菜鸡.学校为了使教育信息化,打算在学校内新建机房,并且为机房联网.但吝啬的学校又不想花费过多的开销,于是将规划 网络路线的任务交给了信竞组的A ...
- [SDOI2016]生成魔咒
题目描述 魔咒串由许多魔咒字符组成,魔咒字符可以用数字表示.例如可以将魔咒字符 1.2 拼凑起来形成一个魔咒串 [1,2]. 一个魔咒串 S 的非空字串被称为魔咒串 S 的生成魔咒. 例如 S=[1, ...
- [ZJOI2009]染色游戏
Description 一共n × m 个硬币,摆成n × m 的长方形.dongdong 和xixi 玩一个游戏, 每次可以选择一个连通块,并把其中的硬币全部翻转,但是需要满足存在一个 硬币属于这个 ...
- 2015 多校联赛 ——HDU5344(水)
Problem Description MZL loves xor very much.Now he gets an array A.The length of A is n.He wants to ...
- bzoj 4974: 字符串大师
Description 一个串T是S的循环节,当且仅当存在正整数k,使得S是T^k(即T重复k次)的前缀,比如abcd是abcdabcdab的循环节 .给定一个长度为n的仅由小写字符构成的字符串S,请 ...
- SpringCache学习之操作redis
一.redis快速入门 1.redis简介 在java领域,常见的四大缓存分别是ehcache,memcached,redis,guava-cache,其中redis与其他类型缓存相比,有着得天独厚的 ...
- SpringBoot多环境部署,在启动时动态设置相应的配置文件
项目中,往往在测试环境和正式环境拥有不同的配置,例如数据库连接,第三方库的appkey等.这时候,我们就要在不同的环境启用不同的配置 下面新建三个文件,分别表示开发环境,生产环境和测试环境的配置文件 ...
- Linux的管理类命令及其使用方法
文件操作相关有一些命令可以帮助我们"修剪"之前看到的文件树. $touch a.txt 如果a.txt不存在,生成一个新的空文档a.txt.如果a.txt存在,那么只更改该文档的时 ...
- 3-学习GPRS_Air202(需要知道的关于Lua的一些基本的知识)
http://www.cnblogs.com/yangfengwu/p/8948935.html 学东西一定是打破沙锅学到底,有问题就解决问题,不要试图去回避或者放弃解决当前的问题,如果总是回避或 ...
- NOIP2017D2T3 列队—Treap
NOIP2017列队 Description Sylvia 是一个热爱学习的女孩子. 前段时间,Sylvia 参加了学校的军训.众所周知,军训的时候需要站方阵. Sylvia所在的方阵中有n × m ...