1

コアプロットチャートを追加する6つのUIViewを持つ親ビューがあります(これは正常に機能していますが、何らかの理由で1秒おきのチャートしか表示されません!)

- (void)viewDidLoad
{
[super viewDidLoad];
// Do any additional setup after loading the view from its nib.
if(!chartVC1){
    chartVC1 = [[ChartVC alloc] initWithIdentifier:@"plot1"];
    //[chartVC1 setKPlotIdentifier:@"plot1"];
    [chartVC1.view setFrame:self.Panel1.frame];
}
[self.Panel1 addSubview:chartVC1.view];

if(!chartVC3){
    chartVC3 = [[ChartVC alloc] initWithIdentifier:@"plot2"];
    [chartVC3.view setFrame:self.Panel3.frame];
}
[self.Panel3 addSubview:chartVC3.view];

if(!chartVC2){
    chartVC2 = [[ChartVC alloc] initWithIdentifier:@"plot3"];
    [chartVC2.view setFrame:self.Panel2.frame];
}

[self.Panel2 addSubview:chartVC2.view];

if(!chartVC4){
    chartVC4 =  [[ChartVC alloc] initWithIdentifier:@"plot4"];
    [chartVC4.view setFrame:self.Panel4.frame];
}
[self.Panel4 addSubview:chartVC4.view];

if(!chartVC5){
    chartVC5 =  [[ChartVC alloc] initWithIdentifier:@"plot5"];
    [chartVC5.view setFrame:self.Panel5.frame];

}
[self.Panel5 addSubview:chartVC5.view];

if(!chartVC6){
    chartVC6 = [[ChartVC alloc] initWithIdentifier:@"plot6"];
    [chartVC6.view setFrame:self.Panel6.frame];
}
[self.Panel6 addSubview:chartVC6.view];
}

クラスChartVCのコードの一部を次に示します

-(void)renderInLayer { CPTXYGraph *graph = [[[CPTXYGraph alloc] initWithFrame:self.view.bounds] autorelease];

[self addGraph:graph toHostingView:self.view];
[self applyTheme:nil toGraph:graph withDefault:[CPTTheme themeNamed:kCPTDarkGradientTheme]];

//[self setTitleDefaultsForGraph:graph withBounds:self.view.bounds];
//[self setPaddingDefaultsForGraph:graph withBounds:self.view.bounds];

graph.plotAreaFrame.paddingTop    = -20.0;
 graph.plotAreaFrame.paddingRight  = -20.0;
 graph.plotAreaFrame.paddingBottom = -20.0;
 graph.plotAreaFrame.paddingLeft      = -20.0;

graph.plotAreaFrame.plotArea.frame = self.view.bounds;

graph.backgroundColor = [[UIColor whiteColor] CGColor];
// Grid line styles
CPTMutableLineStyle *majorGridLineStyle = [CPTMutableLineStyle lineStyle];
majorGridLineStyle.lineWidth = 0.75;
majorGridLineStyle.lineColor = [[CPTColor colorWithGenericGray:0.2] colorWithAlphaComponent:0.75];

CPTMutableLineStyle *minorGridLineStyle = [CPTMutableLineStyle lineStyle];
minorGridLineStyle.lineWidth = 0.25;
minorGridLineStyle.lineColor = [[CPTColor whiteColor] colorWithAlphaComponent:0.1];

// Axes
// X axis
CPTXYAxisSet *axisSet = (CPTXYAxisSet *)graph.axisSet;
CPTXYAxis *x          = axisSet.xAxis;
x.labelingPolicy              = CPTAxisLabelingPolicyAutomatic;
x.orthogonalCoordinateDecimal = CPTDecimalFromUnsignedInteger(0);
x.majorGridLineStyle          = majorGridLineStyle;
x.minorGridLineStyle          = minorGridLineStyle;
x.minorTicksPerInterval       = 9;
//x.title                         = @"X Axis";
//x.titleOffset               = 35.0;
NSNumberFormatter *labelFormatter = [[NSNumberFormatter alloc] init];
labelFormatter.numberStyle = NSNumberFormatterNoStyle;
x.labelFormatter           = labelFormatter;
[labelFormatter release];

// Y axis
CPTXYAxis *y = axisSet.yAxis;
y.labelingPolicy              = CPTAxisLabelingPolicyAutomatic;
y.orthogonalCoordinateDecimal = CPTDecimalFromUnsignedInteger(0);
y.majorGridLineStyle          = majorGridLineStyle;
y.minorGridLineStyle          = minorGridLineStyle;
y.minorTicksPerInterval       = 3;
//y.labelOffset               = 5.0;
//y.title                         = @"Y Axis";
//y.titleOffset               = 30.0;
y.axisConstraints             = [CPTConstraints constraintWithLowerOffset:0.0];

// Rotate the labels by 45 degrees, just to show it can be done.
x.labelRotation = M_PI * 0.25;

// Create the plot
CPTScatterPlot *dataSourceLinePlot1 = [[[CPTScatterPlot alloc] init] autorelease];
dataSourceLinePlot1.identifier    = [self kPlotIdentifier];
//NSLog(@"set identifier: %@", [self kPlotIdentifier]);
dataSourceLinePlot1.cachePrecision = CPTPlotCachePrecisionDouble;

CPTMutableLineStyle *lineStyle1 = [[dataSourceLinePlot1.dataLineStyle mutableCopy] autorelease];
lineStyle1.lineWidth                 = 1.0;
lineStyle1.lineColor                 = [CPTColor redColor];
dataSourceLinePlot1.dataLineStyle = lineStyle1;

dataSourceLinePlot1.dataSource = self;
[graph addPlot:dataSourceLinePlot1];

 // Plot space
 CPTXYPlotSpace *plotSpace = (CPTXYPlotSpace *)graph.defaultPlotSpace;
 plotSpace.xRange = [CPTPlotRange plotRangeWithLocation:CPTDecimalFromUnsignedInteger(0) length:CPTDecimalFromUnsignedInteger(kMaxDataPoints - 1)];
 plotSpace.yRange = [CPTPlotRange plotRangeWithLocation:CPTDecimalFromUnsignedInteger(0) length:CPTDecimalFromUnsignedInteger(100)];

}

最初のグラフだけが表示された場合、問題は自分のせいだと思いますが、2番目のグラフが表示されるたびに表示されるので、私には意味がありません..

私の唯一の推測では、ある種のタイミングの問題ですが、デバッグして各チャートの作成を遅らせましたが、違いはありませんでした..

3 番目、5 番目のグラフを削除して、他のグラフがレンダリングされているかどうかを確認しましたが、以前は表示されなかった同じ 3 つのグラフがまだ表示されていないため、本当に気が遠くなりました.. (つまり、4 つの有効なグラフのうち、最初のグラフのみが表示されました! )

これについての助けは大歓迎です...

問題なく画面上で一度に 6 つのグラフをサポートするのは非常に軽量であるため、加速度計のデータをレンダリングする Apple Developer Library のコードを使用するだけでかまいません...

Core-Plotは、私が推測するタスクに対応していないようです...

4

1 に答える 1

1

どのグラフが表示されていないとは言われませんでしたが、常に同じグラフなので、ビュー階層に問題があると思われます。変更してみる

`[chartVC1.view setFrame:self.Panel1.frame];`

`[chartVC1.view setFrame:self.Panel1.bounds];`

グラフごとに。

于 2012-04-11T01:06:05.907 に答える