公司的项目有大量的图标,曲线图,饼图,离散图,柱状图等等。。。选用Charts,毕竟有GitHub上有一万多颗星。Charts是swift写的,而我的项目是OC+swift混编的,如何混编->请移步(稍后更新链接)
先移步GitHub欣赏下大神的代码https://github.com/danielgindi/Charts
顺带看看示例图
data:image/s3,"s3://crabby-images/c8738/c873887c98ec8854e9c7ce1d83a088d9a74483df" alt=""
data:image/s3,"s3://crabby-images/5d6bd/5d6bd181d0bf4e2adcb85b7f8ad782669cb1218a" alt=""
下面开始框架的集成,我选用的是直接野蛮拖入法(公司网速不给力,pod半天没反应。。。)
1.下载demo源码
Charts
2.新建一个OC工程项目,工程目录如下:
data:image/s3,"s3://crabby-images/34b54/34b549edc1f76bf60d8bdbd73da4d41d90dca258" alt=""
3.将下载下来的demo中的Charts-master文件夹拖进工程中。!!!注意是在Finder中拖进去,如图:
data:image/s3,"s3://crabby-images/7d683/7d68391a10dc336bad96e6b6a6323973697cbb3a" alt=""
4.拖进去后,如图:
data:image/s3,"s3://crabby-images/5ca88/5ca8887da202e83db2fcb1c389893108b7bb0968" alt=""
5.回到项目中,将刚刚拖进来的Charts-master文件夹中的Charts.xcodeproj 拖进xcode中如下:
data:image/s3,"s3://crabby-images/dd832/dd832bcf081b7fc450a09fdb57c866ecc21e21cf" alt=""
data:image/s3,"s3://crabby-images/e3b13/e3b13d0aa956ddec0f7d44ce152c7bfcdb4a343d" alt=""
6.接下来需要配置一些东西
data:image/s3,"s3://crabby-images/4626e/4626ef8d76c3689879d9d2164210880c5fff73d7" alt=""
data:image/s3,"s3://crabby-images/2b4f1/2b4f1b4c103c2784b85d4e5c04193760a4964f10" alt=""
data:image/s3,"s3://crabby-images/a42f4/a42f4e10cc0222f6ce35960a3764bf0c3ebe3a4f" alt=""
data:image/s3,"s3://crabby-images/104c5/104c567a352f41826c8a78b34dfe2af186a3b22c" alt=""
很重要的一点,亲自爬过的坑,少导入一个地方,然后结果是模拟器能跑,真机起来就挂!!!
7.新建一个swift文件,名字随意,这里取名为 ChartsConnect.swift
data:image/s3,"s3://crabby-images/1d49e/1d49e5efe8106bb9fc150959b28defe4bff19670" alt=""
data:image/s3,"s3://crabby-images/fd56c/fd56ce077f19c9ea2d4d9b0374c75ccebf41f115" alt=""
8,在桥接文件中引入Charts
data:image/s3,"s3://crabby-images/d72c1/d72c1c7adb9893054ce9181f313f6587934c9cf8" alt=""
9,在controller中引入 两个文件,可能没有提示,需要自己手写。我引入时是有提示的
ChartsDemo-Bridging-Header.h 用于桥接OC和swift的
ChartsDemo-Swift.h是系统生成的,为了让OC可以用swift,生成的类似于OC中的.h文件
data:image/s3,"s3://crabby-images/880ca/880ca67f912699447f746cae03c8083dcf8c146d" alt=""
10,开撸.先clean一下,编译,没有错误,没有警告。
然后创建控制器代码
LineChartView *charView = [[LineChartView alloc] initWithFrame:self.view.bounds];
[self.view addSubview:charView];
运行如图:
data:image/s3,"s3://crabby-images/36dec/36dec56f8d0b32dcc24521d8e08b35dc6946dda9" alt=""
11.至此,手动导入Charts框架完成。后续还有。。。之所以不用pod,实在是公司网太慢。。。
传送门
网友评论