ios 的饼图 - 在 Swift 2.0 中损坏的图表?

PieChart for ios-charts broken in Swift 2.0?

所以我升级了我的项目,pods,以使用 Swift 2.0 和 Xcode 7。但是现在我的 PieChart 不再按预期工作。我的馅饼都是从0度角开始的,这意味着它们都是从同一个地方开始的,彼此之上。

数据的添加方式与以前相同,如果我突出显示它们,我可以看到它们都在那里,但不是来自它们各自的位置。

添加我的代码 pieChartData:

var dataEntries: [ChartDataEntry] = []
var dataPoints: [String] = []

for var i = 0; i < expensesHistory.count; i++ {
    let dataEntry = ChartDataEntry(value: expensesHistory[i].amount, xIndex: i)
    dataEntries.append(dataEntry)
    dataPoints.append(expensesHistory[i].category.rawValue)
}

let pieChartDataSet = PieChartDataSet(yVals: dataEntries)
let pieChartData = PieChartData(xVals: dataPoints, dataSet: pieChartDataSet)
pieChartView.data = pieChartData
var colors = [UIColor]()
colors.append(Colors.blueColor())
pieChartDataSet.colors = colors
pieChartDataSet.drawValuesEnabled = false
pieChartDataSet.sliceSpace = 4.0

数据已正确加载并添加到不同的条目(共有 7 个条目)中,但所有 7 个饼图都从同一个位置开始...因此它们根本不会形成一个圆圈。有什么想法吗?

更新 #1

我尽我所能将 ChartsDemo 翻译成 Swift,但我最终遇到了同样的问题,但进一步的调试告诉我,我可能只是将最后一个条目推送到数据集中。如果我设置 PieChartDataSet.drawValuesEnabled = truePieChartView.legend.enabled = true,我只会看到图例中的 1 个值和 DataSet 的 1 个值。但是我检查了一下,我的 xValsyVals 包含超过 1 个值,但它只显示一个,并且随机选择了哪个。我试图找到它选择条目的模式,但它只是随机选择一个。

我在 PieChartView 中添加了功能,允许我按下一个按钮来突出显示与其关联的条目,所以这就是为什么我认为所有的馅饼都放在彼此之上,但现在我'我认为 PieChartView 可能只显示 1 个值,因为我在显示的图例中只得到 1 个值,而不是所有值都在另一个之上。

这是我从 ChartsDemo 到 Swift 的翻译代码,请记住我使用的是 Swift 2.0(这是这个问题首次出现的地方)。

private func setPieChartData() {

    let mult = UInt32(100)
    let count = Int(4)

    let parties = [
    "Party A", "Party B", "Party C", "Party D", "Party E", "Party F",
    "Party G", "Party H", "Party I", "Party J", "Party K", "Party L",
    "Party M", "Party N", "Party O", "Party P", "Party Q", "Party R",
    "Party S", "Party T", "Party U", "Party V", "Party W", "Party X",
    "Party Y", "Party Z"
    ]

    var yVals1 = [ChartDataEntry]()

    // 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.
    for var i = 0; i < count; i++
    {
        let chartDataEntry = ChartDataEntry(value: Double((arc4random_uniform(mult) + mult/5)), xIndex: i)
        yVals1.append(chartDataEntry)
    }

    var xVals = [String?]()

    for var i = 0; i < count; i++
    {
        xVals.append(parties[i % parties.count])
        //[xVals addObject:parties[i % parties.count]]
    }

    let dataSet = PieChartDataSet(yVals: yVals1, label: "Election Results")
    dataSet.sliceSpace = 3.0

    // add a lot of colors

    var testColors = [UIColor]()
    testColors.append(Colors.blueColor())
    let data = PieChartData(xVals: xVals, dataSet: dataSet)

    pieChartView.data = data

    dataSet.colors = testColors
    dataSet.drawValuesEnabled = true

    dataSet.sliceSpace = 4.0
}

自从我更新到 Swift 2.0 兼容版本的 ios-charts 后,这个问题就开始了,我仍然认为这个问题与那个更新有关。在更新之前的几个月里我没有接触过这段代码,它在以前的版本中工作得很好。据我所知,从调试的角度来看,我所有的值都被正确推送,但似乎没有被 PieChartView.

正确处理

更新 #2

这是一个示例项目,我向您展示了我遇到的问题。我没有包括用按钮突出显示的功能,因为要让它工作需要更多的努力。 Link to sample project

如何:

  1. 你需要 Xcode 7 到 运行 这个。
  2. 您需要安装 CocoaPods。
  3. 安装 CocoaPods 后,使用终端转到项目文件夹并在根目录中键入 "pod install" 以安装图表框架。
  4. 使用 ChartsIssue.xcworkspace 启动项目,而不是 ChartsIssue.xcproj

我尝试模拟您的代码在 ChartsDemo 的饼图视图控制器中执行的操作,如下所示,但没有问题。

我看了你的代码,对我来说也很好。我猜你的数据值可能有问题,比如 class 类型?无论如何,根据目前的信息,我不能说它有什么问题,但看起来这是你项目的问题。

前进有两种方式:

1.You仔细检查数据值并尝试自行调试,找出原因;

2.Try用ChartsDemo代码复现,post你的数据示例代码,所以我可以在我这边复现;有截图就更好了。

- (void)setDataCount:(int)count range:(double)range
{
    double mult = range;

    NSMutableArray *yVals1 = [[NSMutableArray alloc] init];

    // 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.
    for (int i = 0; i < count; i++)
    {
        [yVals1 addObject:[[ChartDataEntry alloc] initWithValue:(arc4random_uniform(mult) + mult / 5) xIndex:i]];
    }

    NSMutableArray *xVals = [[NSMutableArray alloc] init];

    for (int i = 0; i < count; i++)
    {
        [xVals addObject:parties[i % parties.count]];
    }

    PieChartDataSet *dataSet = [[PieChartDataSet alloc] initWithYVals:yVals1 label:@"Election Results"];
    dataSet.sliceSpace = 3.0;

    // add a lot of colors

    NSMutableArray *colors = [[NSMutableArray alloc] init];
    [colors addObject:[UIColor blueColor]];

    PieChartData *data = [[PieChartData alloc] initWithXVals:xVals dataSet:dataSet];
    _chartView.data = data;

    dataSet.colors = colors;
    dataSet.drawValuesEnabled = NO;
    dataSet.sliceSpace = 4.0;
}

更新问题更新 1&2:

我已经下载了你的演示项目并设法让它在我这边工作,我明白你在说什么,只有一个弧形条纹,而你应该有 4 个值;

我认为您遇到了动画错误或者您使用不当:

pieChartView.animate(xAxisDuration: 1.5, easingOption: ChartEasingOption.EaseOutBack)
pieChartView.animate(yAxisDuration: 1.5, easingOption: ChartEasingOption.EaseOutBack)

只要把其中一个注释掉就可以正常显示了(不知道动画好不好),注释两个都可以正常显示,没有动画也可以。

如果你想为 x 轴和 y 轴设置动画,使用下面的函数也能给你正确的图表和动画:

pieChartView.animate(xAxisDuration: 1.5, yAxisDuration: 1.5, easingOption: ChartEasingOption.EaseOutBack)

我会post一个issue询问同时使用不同的方法是否有效。