Charts下的MakerView和ValueFormatter

上次我們說(shuō)到了動(dòng)態(tài)的刷新數(shù)據(jù), 這次我們說(shuō)下 MarkerView 和 ValueFormatter

由于公司之前用的是 Charts 2.x, 更新之后很多方法都變了, 剛好需要修改這部分的代碼

先上代碼

    open var xAxisValueFormatter: IAxisValueFormatter?
    open var color: UIColor?
    open var arrowSize = CGSize(width: 15, height: 11)
    open var font: UIFont?
    open var textColor: UIColor?
    open var insets = UIEdgeInsets()
    open var minimumSize = CGSize()
    
    fileprivate var labelns: NSString?
    fileprivate var _labelSize: CGSize = CGSize()
    fileprivate var _paragraphStyle: NSMutableParagraphStyle?
    fileprivate var _drawAttributes = [String : AnyObject]()
    
    public init(color: UIColor,colorStock: UIColor, font: UIFont, insets: UIEdgeInsets, xAxisValueFormatter: IAxisValueFormatter)
    {
        super.init()
        
        self.color = color
        self.font = font
        self.textColor = colorStock
        self.insets = insets
        self.xAxisValueFormatter = xAxisValueFormatter
        
        _paragraphStyle = NSParagraphStyle.default.mutableCopy() as? NSMutableParagraphStyle
        _paragraphStyle?.alignment = .center
    }
    
    open override func offsetForDrawing(atPoint point: CGPoint) -> CGPoint
    {
        let size = self.size
        var point = point
        point.x -= size.width / 2.0
        point.y -= size.height
        return super.offsetForDrawing(atPoint: point)
    }
    
    open override func draw(context: CGContext, point: CGPoint)
    {
        if labelns == nil
        {
            return
        }
        
        let offset = self.offsetForDrawing(atPoint: point)
        let size = self.size
        
        var rect = CGRect(
            origin: CGPoint(
                x: point.x + offset.x,
                y: point.y + offset.y),
            size: size)
        rect.origin.x -= size.width / 2.0
        rect.origin.y -= size.height
        
        context.saveGState()
        
        if let color = color
        {
            context.setFillColor(color.cgColor)
            context.beginPath()
            context.move(to: CGPoint(
                x: rect.origin.x,
                y: rect.origin.y))
            context.addLine(to: CGPoint(
                x: rect.origin.x + rect.size.width,
                y: rect.origin.y))
            context.addLine(to: CGPoint(
                x: rect.origin.x + rect.size.width,
                y: rect.origin.y + rect.size.height - arrowSize.height))
            context.addLine(to: CGPoint(
                x: rect.origin.x + (rect.size.width + arrowSize.width) / 2.0,
                y: rect.origin.y + rect.size.height - arrowSize.height))
            context.addLine(to: CGPoint(
                x: rect.origin.x + rect.size.width / 2.0,
                y: rect.origin.y + rect.size.height))
            context.addLine(to: CGPoint(
                x: rect.origin.x + (rect.size.width - arrowSize.width) / 2.0,
                y: rect.origin.y + rect.size.height - arrowSize.height))
            context.addLine(to: CGPoint(
                x: rect.origin.x,
                y: rect.origin.y + rect.size.height - arrowSize.height))
            context.addLine(to: CGPoint(
                x: rect.origin.x,
                y: rect.origin.y))
            context.fillPath()
        }
        
        rect.origin.y += self.insets.top
        rect.size.height -= self.insets.top + self.insets.bottom
        
        UIGraphicsPushContext(context)
        
        labelns?.draw(in: rect, withAttributes: _drawAttributes)
        
        UIGraphicsPopContext()
        
        context.restoreGState()
    }
    
    open override func refreshContent(entry: ChartDataEntry, highlight: Highlight)
    {
        setLabel(entry)
    }
    
    open func setLabel(_ entry: ChartDataEntry)
    {
        
        labelns = String(format: "7日年化收益率: %.2f%%\n時(shí)間: %@", Float(entry.y) * 100, xAxisValueFormatter!.stringForValue(entry.x, axis: nil)) as NSString?
        
        _drawAttributes.removeAll()
        _drawAttributes[NSFontAttributeName] = self.font
        _drawAttributes[NSParagraphStyleAttributeName] = _paragraphStyle
        _drawAttributes[NSForegroundColorAttributeName] = UIColor.white
        
        _labelSize = labelns?.size(attributes: _drawAttributes) ?? CGSize.zero
        
        var size = CGSize()
        size.width = _labelSize.width + self.insets.left + self.insets.right
        size.height = _labelSize.height + self.insets.top + self.insets.bottom
        size.width = max(minimumSize.width, size.width)
        size.height = max(minimumSize.height, size.height)
        self.size = size
    }

代碼大部分都是我直接從 Charts 的官方 Demo 上 copy 下來(lái)的, 只有 setLabel 的部分地方重新修改了下, 之前 Charts 2.x 的時(shí)候

public override func refreshContent(entry entry: ChartDataEntry, highlight: ChartHighlight, XAxisValue: String)

是有 XAxisValue 的參數(shù)的, 并且參數(shù)是 String 類型, 3.x 之后在refreshContent 方法里去掉了 XAxisValue 參數(shù), 而且我查看 ChartDataEntryHighlight 下屬性都是 Double 類型
關(guān)于上圖的實(shí)現(xiàn)我想到了先傳入秒數(shù), 用 ValueFormatter 來(lái)計(jì)算日期格式顯示到 x 軸, 在 markerView 下就可以取到秒數(shù), 在換算成日期就可以, 這個(gè)就是換算方面的問(wèn)題了
還有一個(gè)方法就是把 ValueFormatter 當(dāng)做參數(shù)傳進(jìn)去, 讓內(nèi)部進(jìn)行換算之類的, 可以省去幾行代碼
關(guān)于 MarkerView 使用方法也很簡(jiǎn)單, chartView.marker = [CustomMarkerView new] 即可

下面在說(shuō)一下自定義 ValueFormatter, 只需要繼承 NSObject, 遵循IChartAxisValueFormatter 代理, 然后在
- (NSString *)stringForValue:(double)value axis:(ChartAxisBase *)axis
協(xié)議寫(xiě)你需要的格式或者其他特定坐標(biāo)值就可以了, 使用時(shí)```chartView.xAxis.valueFormatter = [CustomValueFormatter new]


由于 Charts 封裝的功能已經(jīng)十分具體, 詳細(xì), 詳細(xì)代碼就不放出來(lái)了, 在 Charts 的官方 Demo 還是可以找到的, 如果在使用當(dāng)中遇到什么問(wèn)題或者難以解決的需求, 可以給我留言共同探討
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子雕欺,更是在濱河造成了極大的恐慌漠魏,老刑警劉巖狈癞,帶你破解...
    沈念sama閱讀 218,525評(píng)論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件首启,死亡現(xiàn)場(chǎng)離奇詭異饱岸,居然都是意外死亡还棱,警方通過(guò)查閱死者的電腦和手機(jī)载慈,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)珍手,“玉大人办铡,你說(shuō)我怎么就攤上這事辞做。” “怎么了寡具?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,862評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵秤茅,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我童叠,道長(zhǎng)框喳,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,728評(píng)論 1 294
  • 正文 為了忘掉前任厦坛,我火速辦了婚禮五垮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘杜秸。我一直安慰自己放仗,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,743評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布撬碟。 她就那樣靜靜地躺著诞挨,像睡著了一般。 火紅的嫁衣襯著肌膚如雪呢蛤。 梳的紋絲不亂的頭發(fā)上亭姥,一...
    開(kāi)封第一講書(shū)人閱讀 51,590評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音顾稀,去河邊找鬼。 笑死坝撑,一個(gè)胖子當(dāng)著我的面吹牛静秆,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播巡李,決...
    沈念sama閱讀 40,330評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼抚笔,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了侨拦?” 一聲冷哼從身側(cè)響起殊橙,我...
    開(kāi)封第一講書(shū)人閱讀 39,244評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎狱从,沒(méi)想到半個(gè)月后膨蛮,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡季研,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,885評(píng)論 3 336
  • 正文 我和宋清朗相戀三年敞葛,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片与涡。...
    茶點(diǎn)故事閱讀 40,001評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡惹谐,死狀恐怖持偏,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情氨肌,我是刑警寧澤鸿秆,帶...
    沈念sama閱讀 35,723評(píng)論 5 346
  • 正文 年R本政府宣布,位于F島的核電站怎囚,受9級(jí)特大地震影響卿叽,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜桩了,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,343評(píng)論 3 330
  • 文/蒙蒙 一附帽、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧井誉,春花似錦蕉扮、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,919評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至在岂,卻和暖如春奔则,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蔽午。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,042評(píng)論 1 270
  • 我被黑心中介騙來(lái)泰國(guó)打工易茬, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人及老。 一個(gè)月前我還...
    沈念sama閱讀 48,191評(píng)論 3 370
  • 正文 我出身青樓抽莱,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親骄恶。 傳聞我的和親對(duì)象是個(gè)殘疾皇子食铐,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,955評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 國(guó)家電網(wǎng)公司企業(yè)標(biāo)準(zhǔn)(Q/GDW)- 面向?qū)ο蟮挠秒娦畔?shù)據(jù)交換協(xié)議 - 報(bào)批稿:20170802 前言: 排版 ...
    庭說(shuō)閱讀 10,974評(píng)論 6 13
  • 點(diǎn)擊查看原文 Web SDK 開(kāi)發(fā)手冊(cè) SDK 概述 網(wǎng)易云信 SDK 為 Web 應(yīng)用提供一個(gè)完善的 IM 系統(tǒng)...
    layjoy閱讀 13,764評(píng)論 0 15
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫(kù)、插件僧鲁、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,104評(píng)論 4 62
  • 前言 先直接上圖看設(shè)計(jì)師要求的圖片吧 看到這個(gè)首頁(yè)效果的時(shí)候覺(jué)得微微有點(diǎn)蛋疼虐呻,但覺(jué)得應(yīng)該是可以的,沒(méi)多想后來(lái)才知道...
    CZF峰峰閱讀 16,774評(píng)論 75 84
  • 親愛(ài)的兒子: 你好寞秃! 老媽一直以來(lái)都有個(gè)心結(jié):繁忙的工作使得我一直沒(méi)有抽時(shí)間和你聊聊斟叼,深感愧疚。今天春寿,突然想到書(shū)信...
    梅桂之約閱讀 242評(píng)論 1 3