我是Shinobi Tools的新手,我有一套点,我想连接到一个系列。我看到shinobi将此功能作为SChartLineSeries提供。有人可以这么好并向我解释:D?我真的没有得到文件。 代码示例会很好!!
答案 0 :(得分:1)
你读过这个:https://www.shinobicontrols.com/ios/shinobicharts/quickstartguide?事实上相当不错,但他们的页面并不是那么用户友好,起初我遇到了麻烦。
以下解决方案在Objective-C中,但将其转换为Swift应该很简单。
简而言之: 首先导入框架:
#import <ShinobiCharts/ShinobiChart.h>
然后创建图表对象和轴:
// in viewDidLoad
ShinobiChart* _chart;
_chart.xAxis = [[SChartNumberAxis alloc] init];
_chart.yAxis = [[SChartNumberAxis alloc] init];
_chart = [[ShinobiChart alloc] initWithFrame:self.view.bounds];
[self.view addSubview:_chart];
然后实现数据源<SChartDatasource>
:
// in viewDidLoad
_chart.datasource = self;
- (int)numberOfSeriesInSChart:(ShinobiChart *)chart {
return 2;
}
-(SChartSeries *)sChart:(ShinobiChart *)chart seriesAtIndex:(int)index {
SChartLineSeries *lineSeries = [[SChartLineSeries alloc] init];
if (index == 0) {
lineSeries.title = [NSString stringWithFormat:@"y = cos(x)"];
} else {
lineSeries.title = [NSString stringWithFormat:@"y = sin(x)"];
}
return lineSeries;
}
- (int)sChart:(ShinobiChart *)chart numberOfDataPointsForSeriesAtIndex:(int)seriesIndex {
return 100;
}
- (id<SChartData>)sChart:(ShinobiChart *)chart dataPointAtIndex:(int)dataIndex forSeriesAtIndex:(int)seriesIndex {
SChartDataPoint *datapoint = [[SChartDataPoint alloc] init];
// both functions share the same x-values
double xValue = dataIndex / 10.0;
datapoint.xValue = [NSNumber numberWithDouble:xValue];
// compute the y-value for each series
if (seriesIndex == 0) {
datapoint.yValue = [NSNumber numberWithDouble:cosf(xValue)];
} else {
datapoint.yValue = [NSNumber numberWithDouble:sinf(xValue)];
}
return datapoint;
}
免责声明:数据源实施是从快速入门指南到我上面提到的链接。
- 编辑 -
要曲线图,您需要自己添加更多数据点(计算值并设置超过5个点)。请参阅Shinobi Chart支持论坛的讨论:https://www.shinobicontrols.com/forum/shinobicontrols/2015/6/spline-line-chart。
答案 1 :(得分:0)
免责声明:我是Shinobi Controls的开发人员。
我们目前的SChartLineSeries并不能直接支持流畅的线条。
但是,这是一项经常被请求的功能,因此我们的下一版图表包含的功能可以更轻松地实现平滑的线条。
同时,您可以通过向图表添加更多数据点来实现平滑线条,为它们提供绘制曲线的数据值。正如Vive在她的回答中解释的那样。
我们将在发布包含此功能的版本时更新此帖子。
亲切的问候,
Andrew Polkinghorn。