PiePolylineChartViewController.swift 4.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. //
  2. // PiePolylineChartViewController.swift
  3. // ChartsDemo-iOS
  4. //
  5. // Created by Jacob Christie on 2017-07-09.
  6. // Copyright © 2017 jc. All rights reserved.
  7. //
  8. #if canImport(UIKit)
  9. import UIKit
  10. #endif
  11. import Charts
  12. class PiePolylineChartViewController: DemoBaseViewController {
  13. @IBOutlet var chartView: PieChartView!
  14. @IBOutlet var sliderX: UISlider!
  15. @IBOutlet var sliderY: UISlider!
  16. @IBOutlet var sliderTextX: UITextField!
  17. @IBOutlet var sliderTextY: UITextField!
  18. override func viewDidLoad() {
  19. super.viewDidLoad()
  20. // Do any additional setup after loading the view.
  21. self.title = "Pie Poly Line Chart"
  22. self.options = [.toggleValues,
  23. .toggleXValues,
  24. .togglePercent,
  25. .toggleHole,
  26. .animateX,
  27. .animateY,
  28. .animateXY,
  29. .spin,
  30. .drawCenter,
  31. .saveToGallery,
  32. .toggleData]
  33. self.setup(pieChartView: chartView)
  34. chartView.delegate = self
  35. chartView.legend.enabled = false
  36. chartView.setExtraOffsets(left: 20, top: 0, right: 20, bottom: 0)
  37. sliderX.value = 40
  38. sliderY.value = 100
  39. self.slidersValueChanged(nil)
  40. chartView.animate(xAxisDuration: 1.4, easingOption: .easeOutBack)
  41. }
  42. override func updateChartData() {
  43. if self.shouldHideData {
  44. chartView.data = nil
  45. return
  46. }
  47. self.setDataCount(Int(sliderX.value), range: UInt32(sliderY.value))
  48. }
  49. func setDataCount(_ count: Int, range: UInt32) {
  50. let entries = (0..<count).map { (i) -> PieChartDataEntry in
  51. // IMPORTANT: In a PieChart, no values (Entry) should have the same xIndex (even if from different DataSets), since no values can be drawn above each other.
  52. return PieChartDataEntry(value: Double(arc4random_uniform(range) + range / 5),
  53. label: parties[i % parties.count])
  54. }
  55. let set = PieChartDataSet(entries: entries, label: "Election Results")
  56. set.sliceSpace = 2
  57. set.colors = ChartColorTemplates.vordiplom()
  58. + ChartColorTemplates.joyful()
  59. + ChartColorTemplates.colorful()
  60. + ChartColorTemplates.liberty()
  61. + ChartColorTemplates.pastel()
  62. + [UIColor(red: 51/255, green: 181/255, blue: 229/255, alpha: 1)]
  63. set.valueLinePart1OffsetPercentage = 0.8
  64. set.valueLinePart1Length = 0.2
  65. set.valueLinePart2Length = 0.4
  66. //set.xValuePosition = .outsideSlice
  67. set.yValuePosition = .outsideSlice
  68. let data = PieChartData(dataSet: set)
  69. let pFormatter = NumberFormatter()
  70. pFormatter.numberStyle = .percent
  71. pFormatter.maximumFractionDigits = 1
  72. pFormatter.multiplier = 1
  73. pFormatter.percentSymbol = " %"
  74. data.setValueFormatter(DefaultValueFormatter(formatter: pFormatter))
  75. data.setValueFont(.systemFont(ofSize: 11, weight: .light))
  76. data.setValueTextColor(.black)
  77. chartView.data = data
  78. chartView.highlightValues(nil)
  79. }
  80. override func optionTapped(_ option: Option) {
  81. switch option {
  82. case .toggleXValues:
  83. chartView.drawEntryLabelsEnabled = !chartView.drawEntryLabelsEnabled
  84. chartView.setNeedsDisplay()
  85. case .togglePercent:
  86. chartView.usePercentValuesEnabled = !chartView.usePercentValuesEnabled
  87. chartView.setNeedsDisplay()
  88. case .toggleHole:
  89. chartView.drawHoleEnabled = !chartView.drawHoleEnabled
  90. chartView.setNeedsDisplay()
  91. case .drawCenter:
  92. chartView.drawCenterTextEnabled = !chartView.drawCenterTextEnabled
  93. chartView.setNeedsDisplay()
  94. case .animateX:
  95. chartView.animate(xAxisDuration: 1.4)
  96. case .animateY:
  97. chartView.animate(yAxisDuration: 1.4)
  98. case .animateXY:
  99. chartView.animate(xAxisDuration: 1.4, yAxisDuration: 1.4)
  100. case .spin:
  101. chartView.spin(duration: 2,
  102. fromAngle: chartView.rotationAngle,
  103. toAngle: chartView.rotationAngle + 360,
  104. easingOption: .easeInCubic)
  105. default:
  106. handleOption(option, forChartView: chartView)
  107. }
  108. }
  109. // MARK: - Actions
  110. @IBAction func slidersValueChanged(_ sender: Any?) {
  111. sliderTextX.text = "\(Int(sliderX.value))"
  112. sliderTextY.text = "\(Int(sliderY.value))"
  113. self.updateChartData()
  114. }
  115. }