DGCharts barView GradientColor

import UIKit
import DGCharts

class GradientBarChartRenderer: BarChartRenderer {
    
    override func drawDataSet(context: CGContext, dataSet: BarChartDataSetProtocol, index: Int) {
                 guard let dataProvider = dataProvider else { return }
           let transformer = dataProvider.getTransformer(forAxis: dataSet.axisDependency)
        
        let phaseY = animator.phaseY
        
        // Determine bar width
        let entryCount = dataSet.entryCount
        let barWidth: CGFloat
        
        if entryCount <= 5 {
            let totalSpace = viewPortHandler.contentWidth / CGFloat(entryCount + 2) // Leave one space for padding
            barWidth = 36.0 / totalSpace
        } else {
            barWidth = 0.67//CGFloat(dataProvider.barData?.barWidth ?? 0.85)
        }
        
        dataProvider.barData?.barWidth = Double(barWidth)
        
        // Prepare the buffer
        var buffer = [CGRect](repeating: CGRect(), count: entryCount)
        
        for i in 0 ..< entryCount {
            guard let e = dataSet.entryForIndex(i) as? BarChartDataEntry else { continue }
            
            let left = e.x - barWidth / 2.0
            let right = e.x + barWidth / 2.0
            let top = e.y * Double(phaseY)
            let bottom = 0.0
            
            buffer[i] = CGRect(x: left, y: bottom, width: right - left, height: top)
        }
        
        transformer.rectValuesToPixel(&buffer)
        
        // Draw the bars
        for i in 0 ..< buffer.count {
            context.saveGState()
            
            let gradientColors = [ChartColorTemplates.colorFromString("#ff0000").cgColor,
                                  ChartColorTemplates.colorFromString("#00ff00").cgColor] as CFArray
            let colorLocations:[CGFloat] = [0.0, 1.0]
            let gradient = CGGradient(colorsSpace: CGColorSpaceCreateDeviceRGB(), colors: gradientColors, locations: colorLocations)
            
            if let gradient = gradient {
                context.clip(to: buffer[i])
                context.drawLinearGradient(gradient, start: CGPoint(x: buffer[i].minX, y: buffer[i].minY), end: CGPoint(x: buffer[i].minX, y: buffer[i].maxY), options: [])
            }
            
            context.restoreGState()
        }
}
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市侠碧,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌缠黍,老刑警劉巖弄兜,帶你破解...
    沈念sama閱讀 217,406評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異瓷式,居然都是意外死亡替饿,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,732評論 3 393
  • 文/潘曉璐 我一進(jìn)店門贸典,熙熙樓的掌柜王于貴愁眉苦臉地迎上來视卢,“玉大人,你說我怎么就攤上這事廊驼【莨” “怎么了惋砂?”我有些...
    開封第一講書人閱讀 163,711評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長绳锅。 經(jīng)常有香客問我西饵,道長,這世上最難降的妖魔是什么鳞芙? 我笑而不...
    開封第一講書人閱讀 58,380評論 1 293
  • 正文 為了忘掉前任罗标,我火速辦了婚禮,結(jié)果婚禮上积蜻,老公的妹妹穿的比我還像新娘闯割。我一直安慰自己,他們只是感情好竿拆,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,432評論 6 392
  • 文/花漫 我一把揭開白布宙拉。 她就那樣靜靜地躺著,像睡著了一般丙笋。 火紅的嫁衣襯著肌膚如雪谢澈。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,301評論 1 301
  • 那天御板,我揣著相機(jī)與錄音锥忿,去河邊找鬼。 笑死怠肋,一個胖子當(dāng)著我的面吹牛敬鬓,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播笙各,決...
    沈念sama閱讀 40,145評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼钉答,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了杈抢?” 一聲冷哼從身側(cè)響起数尿,我...
    開封第一講書人閱讀 39,008評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎惶楼,沒想到半個月后右蹦,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,443評論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡歼捐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,649評論 3 334
  • 正文 我和宋清朗相戀三年何陆,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片窥岩。...
    茶點(diǎn)故事閱讀 39,795評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡甲献,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出颂翼,到底是詐尸還是另有隱情晃洒,我是刑警寧澤慨灭,帶...
    沈念sama閱讀 35,501評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站球及,受9級特大地震影響氧骤,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吃引,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,119評論 3 328
  • 文/蒙蒙 一筹陵、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧镊尺,春花似錦朦佩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,731評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至弄砍,卻和暖如春仙畦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背音婶。 一陣腳步聲響...
    開封第一講書人閱讀 32,865評論 1 269
  • 我被黑心中介騙來泰國打工慨畸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人衣式。 一個月前我還...
    沈念sama閱讀 47,899評論 2 370
  • 正文 我出身青樓寸士,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瞳收。 傳聞我的和親對象是個殘疾皇子碉京,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,724評論 2 354

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

  • 前言 Google Play應(yīng)用市場對于應(yīng)用的targetSdkVersion有了更為嚴(yán)格的要求厢汹。從 2018 年...
    申國駿閱讀 64,088評論 14 98
  • """1.個性化消息: 將用戶的姓名存到一個變量中螟深,并向該用戶顯示一條消息。顯示的消息應(yīng)非常簡單烫葬,如“Hello ...
    她即我命閱讀 2,890評論 0 5
  • 我們都是軟弱的人界弧,所以才會說謊。我們都是膽小的人搭综,所以才要武裝垢箕。我們都是一群笨蛋,所以才會互相傷害兑巾。
    所羅門的偽證_dc0a閱讀 2,057評論 0 3
  • 為了讓我有一個更快速条获、更精彩、更輝煌的成長蒋歌,我將開始這段刻骨銘心的自我蛻變之旅帅掘!從今天開始委煤,我將每天堅持閱...
    李薇帆閱讀 1,717評論 0 2
  • 似乎最近一直都在路上,每次出來走的時候感受都會很不一樣修档。 1碧绞、感恩一直遇到好心人,很幸運(yùn)吱窝。在路上總是...
    時間里的花Lily閱讀 1,188評論 0 1