Github上Fork代码,及源码修改

iOS开发中经常遇到这种情况,你使用的第三方库不能完全满足自己项目需要,只能修改源码来解决。
我们以前的解决办法是,添加到项目中直接修改源码。这样就有一个问题,不能和源库同步,当作者更新后你不能(pod update)更新,否则自己原来的修改就被冲掉了。所以只能选择不更新,或者更新后重新修改源码。

当第三方库更新时如何同步更新?Git的Fork功能解决了这种问题,当你fork别人的开源代码后,你可以随意的修改。当然你对自己的修改满意还可以请求合并到(pull request)原作者项目中去。

今天具体讲解如何在Github上Fork别人的代码,进行二次开发。下面以iOS-Charts为例,上一篇文章中我对这个开源库做了介绍。

1.首先你要有自己的Github账号
2.进入https://github.com/danielgindi/Charts 你要Fork项目的首页点击右上角Fork
3.到自己项目列表就可以看到刚刚Fork的项目了

现在你就可以当做自己的项目,随意的更改了。如果修改完之后你想和原来库合并,贡献自己的代码,就点击自己项目中的“New Pull Request”请求合并。作者同意后就可以在项目中看到自己贡献的代码了。

下面讲解本文的重点,如何修改源码满足自己项目需求。修改时注意一下几点:

1.改源码首先当然是读懂源码了,读懂后才知道从何下手。
2.查看源码时一开始不止如何下手,对于一些UI控件我的解决方式是采用“注释法”,先把不知道的代码注释掉然后运行查看效果,通过对比界面可以简单直接的看到代码在操控那里。
3.修改时要考虑如何最小的改动满足自己需求,可以尝试添加子类或者分类的形式解决。
4.实在没办法只能修改源码了,修改源码的地方最好做上标记,方便自己查看、修改。

举个例子,我们想要修改点击Charts高亮时的高亮线的形式,改之前的效果如下:


我们想要隐藏掉水平高亮线,只显示垂直高亮线,如下图所示:

通过查看源码我们可以知道LineChartDateSet的属性drawVerticalHighlightIndicatorEnabled是控制是否显示垂直高亮线的,我们简单推理,通过搜索这个属性我们应该能找到如何绘制高亮线的代码。

通过全局搜索 drawVerticalHighlightIndicatorEnabled结果如下图:

并没有找到绘制高亮线的代码,查看属性定义的地方发现drawVerticalHighlightIndicatorEnabled是存储属性,还有一个对应的计算性属性isVerticalHighlightIndicatorEnabled,我们接下来全局搜索isVerticalHighlightIndicatorEnabled ,结果如下:

通过注意查看,我们可以确定LineScatterCandleRadarChartRenderer.swift有绘制高亮线的地方,如下图:

可以发现35-38行是控制如何绘制竖直高亮线的代码,我们注释掉,

换成使用图片来绘制的代码,修改成如下代码(前提准备一张高亮图”highlight_line”):

CGContextSaveGState(context);
//获得高亮线图片
let lineImage = NSUIImage(named: "highlight_line")
//绘制
lineImage?.drawInRect(CGRectMake(point.x-5.0/2.0, viewPortHandler.contentTop, 5, viewPortHandler.contentBottom - viewPortHandler.contentTop))

CGContextRestoreGState( context );

运行看下效果轻松搞定。

文章转载自:lvesli

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,921评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,635评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,393评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,836评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,833评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,685评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,043评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,694评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,671评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,670评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,779评论 1 332
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,424评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,027评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,984评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,214评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,108评论 2 351
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,517评论 2 343

推荐阅读更多精彩内容

  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,463评论 25 707
  • 刚才在二更视频上看了一个摄影师,她喜欢拍成都的帅哥美女,
    一个会画画的文字控阅读 176评论 0 0
  • 查询当前仓库的所有标签 git tag git标签分为两种类型:轻量标签和附注标签。轻量标签是指向提交对象的引用,...
    SamHxm阅读 575评论 0 0
  • 寫歌的李格弟 寫詩的夏宇 心底裏永遠的秘語 都关于你
    鯨魚兒阅读 237评论 3 1
  • 近期最想实现的愿望目标是年底有一份属于自己的事业,可以轻松喜悦赚到20万。 +今天供养父母5元 供养道场一元 +南...
    ActorsagentXiao阅读 154评论 0 0