From a34eaecfa66d9aa0d30fbca1f391530025416eec Mon Sep 17 00:00:00 2001 From: rlarldud1234 Date: Fri, 4 Feb 2022 15:22:57 +0900 Subject: [PATCH] =?UTF-8?q?=E2=9A=A1=EF=B8=8F::=20Bar=20Radius=20Custom?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Source/Charts/Renderers/BarChartRenderer.swift | 15 +++++++++++---- Source/Charts/Renderers/PieChartRenderer.swift | 2 +- 2 files changed, 12 insertions(+), 5 deletions(-) diff --git a/Source/Charts/Renderers/BarChartRenderer.swift b/Source/Charts/Renderers/BarChartRenderer.swift index 2aa69a828f..8c36913c45 100644 --- a/Source/Charts/Renderers/BarChartRenderer.swift +++ b/Source/Charts/Renderers/BarChartRenderer.swift @@ -41,6 +41,8 @@ open class BarChartRenderer: BarLineScatterCandleBubbleRenderer internal lazy var accessibilityOrderedElements: [[NSUIAccessibilityElement]] = accessibilityCreateEmptyOrderedElements() private typealias Buffer = [CGRect] + + internal let barCornerRadius = CGFloat(5.0) @objc open weak var dataProvider: BarChartDataProvider? @@ -323,7 +325,7 @@ open class BarChartRenderer: BarLineScatterCandleBubbleRenderer guard let e = dataSet.entryForIndex(i) as? BarChartDataEntry else { continue } x = e.x - + _barShadowRectBuffer.origin.x = CGFloat(x - barWidthHalf) _barShadowRectBuffer.size.width = CGFloat(barWidth) @@ -337,6 +339,7 @@ open class BarChartRenderer: BarLineScatterCandleBubbleRenderer _barShadowRectBuffer.size.height = viewPortHandler.contentHeight context.setFillColor(dataSet.barShadowColor.cgColor) + context.fill(_barShadowRectBuffer) } } @@ -351,7 +354,10 @@ open class BarChartRenderer: BarLineScatterCandleBubbleRenderer guard viewPortHandler.isInBoundsRight(barRect.origin.x) else { break } context.setFillColor(dataSet.barShadowColor.cgColor) - context.fill(barRect) + + let bezierPath = UIBezierPath(roundedRect: barRect, cornerRadius: barCornerRadius) + context.addPath(bezierPath.cgPath) + context.drawPath(using: .fill) } } @@ -361,7 +367,6 @@ open class BarChartRenderer: BarLineScatterCandleBubbleRenderer { context.setFillColor(dataSet.color(atIndex: 0).cgColor) } - // In case the chart is stacked, we need to accomodate individual bars within accessibilityOrdereredElements let isStacked = dataSet.isStacked let stackSize = isStacked ? dataSet.stackSize : 1 @@ -379,7 +384,9 @@ open class BarChartRenderer: BarLineScatterCandleBubbleRenderer context.setFillColor(dataSet.color(atIndex: j).cgColor) } - context.fill(barRect) + let bezierPath = UIBezierPath(roundedRect: barRect, byRoundingCorners: [.topLeft, .topRight], cornerRadii: CGSize(width: 10, height: 10)) + context.addPath(bezierPath.cgPath) + context.drawPath(using: .fill) if drawBorder { diff --git a/Source/Charts/Renderers/PieChartRenderer.swift b/Source/Charts/Renderers/PieChartRenderer.swift index 18f571bc79..103fd14e92 100644 --- a/Source/Charts/Renderers/PieChartRenderer.swift +++ b/Source/Charts/Renderers/PieChartRenderer.swift @@ -930,7 +930,7 @@ open class PieChartRenderer: NSObject, DataRenderer return element } - + public func createAccessibleHeader(usingChart chart: ChartViewBase, andData data: ChartData, withDefaultDescription defaultDescription: String) -> NSUIAccessibilityElement { return AccessibleHeader.create(usingChart: chart, andData: data, withDefaultDescription: defaultDescription) }