利用CocoasPod在Swift项目中使用CorePlot

简介:

最近在研究可用的第三方的图标控件,然后网上搜了之后,感觉功能比较强大的就是CorePlot了,于是就开始研究如何部署到程序中。网上关于这方面的教程比较少,大部分都是objective-c的,而且历史也比较久远,后来找到一篇老外写的blog,讲述在swift中如何使用CorePlothttp://blog.alwold.com/2014/08/07/using-coreplot-with-swift-in-ios/),研究了好久,总算成功安装了。下面就一步一步介绍。

1. 建立工程

首先建立一个简单的swift工程,工程名字为CorePlot,记住选择language为swift。这里就不再截图详细说明了,不清楚的同学可以看我的上一篇blog

2. 安装CocoaPods

这里我重点说一下如何安装CocoaPods把,因为安装过程耗费了我好久,而且中间有不少点也鲜有提起。

这里有两篇中文的blog比较不错,都由可取之处,供大家了解CocoaPods是什么。

CocoaPods详解之--使用篇 http://blog.csdn.net/wzzvictory/article/details/18737437

CocoaPods安装和使用教程 http://code4app.com/article/cocoapods-install-usage

关于CocoaPods是什么和它的强大我就不多说了,两篇blog都有介绍,我重点说一下我的安装过程。

1>

打开终端,依次输入下面的命令

gem sources --remove https://rubygems.org/
gem sources -a http://ruby.taobao.org/

这样是为了访问taobao的ruby镜像,因为GFW,在国内没法直接访问cocoapods,所以需要把我们的source设置成taobao的一个镜像网站。注意区分https和http

为了验证ruby镜像  可以输入

gem sources -l
注意是字母 hijk L mn 的L,不是数字1
接下来会显示

*** CURRENT SOURCES ***
http://ruby.taobao.org/

注意,这里面一定只能有一条,如果你的里面仍然有rubygems.org说明没有remove成功,重新试一下上面的命令。

2> 

输入下面的命令就开始安装cocoapods

sudo gem install cocoapods

注意,这里输入完成之后,可能需要等一段时间才能开始下载和安装,我当时是等了大概有3分钟才安装完成。

安装执行过程中,会问我吗是不是要更新rake,输入y

3> 

安装进程结束之后,执行命令

pod setup
这里有得等2,3分钟的的样子

如果这中间都没有报错,就说明你安装成功了。

可以试一下看看我们待会要安装的coreplot:

pod search CorePlot
大致会告诉你这样的信息


可以看到最新的CorePlot是1.5.1版本的,也可以看到在github上的源地址。

到这里,cocoapods就安装完成了,接下来我们继续我们的步骤


3. 

在终端中 cd到你的swift工程所在的目录,然后执行下面的命令

pod init

如果一切正常,在你的工程目录下,会出现一个文件名字叫做Podfile,这个相当于cocoapods的配置文件,告诉我们在工程中将引入哪些第三方的控件。

接下来是很重要的一个步骤,用vim或者xcode打开并编辑Podfile文件,一定不要直接双击文件打开并编辑,我就是在这上面吃了亏了,搞了好久好久一直提示出错,因为你的textedit会改变原有的一些你肉眼看不出的格式等等。

执行下面的命令用xcode打开并修改podfile

open -a Xcode Podfile


这里是我修改后的文件:

# Uncomment this line to define a global platform for your project
platform :ios, '8.0'

target 'CorePlot' do

pod 'CorePlot', '~> 1.5.1'

end

target 'CorePlotTests' do

end

可以看到在target  CorePlot,就是我们一开始新建的工程下面,我们加入了pod  CorePlot和相应的版本号。

保存并关闭podfile

4. 

在终端执行命令:

pod install

又是得耐心地等待一段时间后,会得到下面的结果:



表示我们的corePlot已经安装完成了。

注意最后一行字:

[!] Form now on use 'CorePlot.xcworkspace' .

5. 关闭第一步我们建立的Xcode工程。

回头看一下我们的工程目录,你会发现新建了不少东西,其中有一个叫xxx.xcworkspace 的文件,就是以后我们再打开工程时直接双击的文件了。

我们双击打开工程。

6. 

利用我上一篇blog介绍的方法建立xxx-Bridging-Header.h 文件。

就是在我们的工程目录中create一个新的class并选择用objective-c做位语言,这样Xcode会自动帮我们建立桥接头文件,不需要我们手动做操作。

7. 

在刚建好的CorePlot-Bridging-Header.h文件中添加:

#import "CorePlot-CocoaTouch.h"

8. 

打开storyboard,然后在viewcontroller中再添加进来一个view,这个view将作为我们的coreplot控件的承载view,修改这个view的custom class为 CPTGraphHostingView


9. 建立outlet

步骤就不画图了,在storyboard中Assistance Editor模式下,ctrl拖拽刚添加的view到viewcontroller.swift文件中,命名为graphView

10. 

我们先编译一下工程,shift+commond+B,编译成功之后,可能会有一些警告,我把版本从8.3改成了8.1,因为1.5.1 的coreplot似乎最高支持到8.1

接下来我们在viewDidLoad方法中添加进下面这些代码:

<span style="white-space:pre">	</span>//creat graph
        var graph = CPTXYGraph(frame: CGRectZero)
        graph.title = "Hello Graph"
        graph.paddingLeft = 0
        graph.paddingTop = 0
        graph.paddingRight = 0
        graph.paddingBottom = 0
        //hide the axes
        var axes = graph.axisSet as CPTXYAxisSet
        var lineStyle = CPTMutableLineStyle()
        lineStyle.lineWidth = 0
        axes.xAxis.axisLineStyle = lineStyle
        axes.yAxis.axisLineStyle = lineStyle
        
        //add a pie plot
        var pie = CPTPieChart()
        pie.dataSource = self
        pie.pieRadius = (self.view.frame.size.width * 0.9)/2
        graph.addPlot(pie)
        
        self.graphView.hostedGraph = graph

11. 

添加datasource delegate,在开头添加代理: CPTPlotDataSource

12. 

编辑代理方法:

 func numberOfRecordsForPlot(plot: CPTPlot!) -> UInt {
        return 4
    }
    
    func numberForPlot(plot: CPTPlot!, field fieldEnum: UInt, recordIndex idx: UInt) -> NSNumber! {
        return idx+1
    }

整个viewController.swift 看起来是这样的

import UIKit

class ViewController: UIViewController,CPTPlotDataSource {

    @IBOutlet weak var graphView: CPTGraphHostingView!
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
        //creat graph
        var graph = CPTXYGraph(frame: CGRectZero)
        graph.title = "Hello Graph"
        graph.paddingLeft = 0
        graph.paddingTop = 0
        graph.paddingRight = 0
        graph.paddingBottom = 0
        //hide the axes
        var axes = graph.axisSet as CPTXYAxisSet
        var lineStyle = CPTMutableLineStyle()
        lineStyle.lineWidth = 0
        axes.xAxis.axisLineStyle = lineStyle
        axes.yAxis.axisLineStyle = lineStyle
        
        //add a pie plot
        var pie = CPTPieChart()
        pie.dataSource = self
        pie.pieRadius = (self.view.frame.size.width * 0.9)/2
        graph.addPlot(pie)
        
        self.graphView.hostedGraph = graph
    }

    // dataSource delegate 
    func numberOfRecordsForPlot(plot: CPTPlot!) -> UInt {
        return 4
    }
    
    func numberForPlot(plot: CPTPlot!, field fieldEnum: UInt, recordIndex idx: UInt) -> NSNumber! {
        return idx+1
    }
    
    
    
    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }


}

接下来就运行一下你的程序,就能看到一个pie被画在了屏幕上



利用CorePlot还能画柱状图、折线图等等,我也刚开始学,一起研究吧。

目录
相关文章
|
5月前
|
IDE 开发工具 Swift
创建一个Swift项目
创建一个Swift项目
35 1
|
Web App开发 搜索推荐 Linux
20 年的 Debian 开发者被排挤出项目;操作系统 “火龙” 被质疑抄袭;Swift 5.6 发布 | 思否周刊
20 年的 Debian 开发者被排挤出项目;操作系统 “火龙” 被质疑抄袭;Swift 5.6 发布 | 思否周刊
179 0
|
开发工具 Swift iOS开发
iOS 问题 1: OC项目导入swift三方库不兼容问题
iOS 问题 1: OC项目导入swift三方库不兼容问题
885 0
iOS 问题 1: OC项目导入swift三方库不兼容问题
|
前端开发 测试技术 Swift
Swift学习笔记——新建项目
在xcode菜单中选择 new -> project -> single view app 点击next在弹出窗中填写项目名称 这里languge有可以选择object-c或swift作为项目语言。这里我们学习swift,所以选择swift。 如果language选择swift,下面的user interface可以选择swiftUI和storyboard。 SwiftUI是2019 年 WWDC 大会上,苹果在压轴环节向大众宣布了基于 Swift 语言构建的全新 UI 框架,与flutter类似,是用代码编写页面,支持快速预览。
669 0
|
开发工具 Swift iOS开发
Swift学习第二练——Swift项目时光电影
Swift学习第二练——Swift项目时光电影
128 0
Swift学习第二练——Swift项目时光电影
|
JSON 开发工具 iOS开发
在 Xcode 项目中使用 swift package fetch
本文讲的是在 Xcode 项目中使用 swift package fetch,到目前为止,Cocoa with Love 的 git 仓库都使用“git subtrees”来管理相关依赖,所有的依赖都被拷贝并静态存放于依赖方目录下。我希望能找到一种更动态地依赖管理方式来代替现有的方案
1814 0

相关课程

更多