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()
}
}
DGCharts barView GradientColor
最后編輯于 :
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
- 文/潘曉璐 我一進(jìn)店門贸典,熙熙樓的掌柜王于貴愁眉苦臉地迎上來视卢,“玉大人,你說我怎么就攤上這事廊驼【莨” “怎么了惋砂?”我有些...
- 文/不壞的土叔 我叫張陵,是天一觀的道長绳锅。 經(jīng)常有香客問我西饵,道長,這世上最難降的妖魔是什么鳞芙? 我笑而不...
- 正文 為了忘掉前任罗标,我火速辦了婚禮,結(jié)果婚禮上积蜻,老公的妹妹穿的比我還像新娘闯割。我一直安慰自己,他們只是感情好竿拆,可當(dāng)我...
- 文/花漫 我一把揭開白布宙拉。 她就那樣靜靜地躺著,像睡著了一般丙笋。 火紅的嫁衣襯著肌膚如雪谢澈。 梳的紋絲不亂的頭發(fā)上,一...
- 文/蒼蘭香墨 我猛地睜開眼钉答,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了杈抢?” 一聲冷哼從身側(cè)響起数尿,我...
- 正文 獨(dú)居荒郊野嶺守林人離奇死亡歼捐,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
- 正文 我和宋清朗相戀三年何陆,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片窥岩。...
- 正文 年R本政府宣布,位于F島的核電站球及,受9級特大地震影響氧骤,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜吃引,卻給世界環(huán)境...
- 文/蒙蒙 一筹陵、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧镊尺,春花似錦朦佩、人聲如沸。這莊子的主人今日做“春日...
- 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至弄砍,卻和暖如春仙畦,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背音婶。 一陣腳步聲響...
- 正文 我出身青樓寸士,卻偏偏與公主長得像,于是被迫代替她去往敵國和親瞳收。 傳聞我的和親對象是個殘疾皇子碉京,可洞房花燭夜當(dāng)晚...
推薦閱讀更多精彩內(nèi)容
- 前言 Google Play應(yīng)用市場對于應(yīng)用的targetSdkVersion有了更為嚴(yán)格的要求厢汹。從 2018 年...
- """1.個性化消息: 將用戶的姓名存到一個變量中螟深,并向該用戶顯示一條消息。顯示的消息應(yīng)非常簡單烫葬,如“Hello ...