0

所以我升级了我的项目和 pod,以使用 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,但最终遇到了同样的问题,但进一步的调试告诉我,我可能只是将最后一个 Entry 推入 DataSet。如果我设置PieChartDataSet.drawValuesEnabled = true并且PieChartView.legend.enabled = true我在图例中只看到 1 个值和DataSet. 但是我检查了和我的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
}

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

更新#2

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

如何:

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

1 回答 1

1

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

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

有两种前进的方式:

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

2.尝试用ChartsDemo代码复现,贴出你的数据示例代码,我这边可以复现;截图就更好了。

- (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 轴,使用下面的 func 也给你正确的图表和动画:

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

我将发布一个问题,询问同时使用单独的方法是否有效。

于 2015-10-07T01:29:17.080 回答