0

データやラベルなどを関数に挿入して、このような準備ができたgoogle-chartを受け取ることができるように、準備ができたコードを探していました。

ここに画像の説明を入力してください

しかし、私は何も見つかりませんでした。何か案は?

4

1 に答える 1

1

その間に、必要なすべてのパラメーターを受け取り、グーグルチャートを作成して変換する関数を作成しましたUIImage。ここにあります:

-(UIImage )produceGoogleChartImage:(NSString)title

                           xAxis:(NSArray*)axisXLabels
                          yAxis:(NSArray*)axisYLabels
                        andData:(NSArray*)dataValues
                          color:(NSString*)lineColor
                     chartWidth:(NSNumber*)width
                     chartHight:(NSNumber*)hight
                    lagendLabel:(NSString*)legend
                       minScale:(NSNumber*)minScale
                       maxScale:(NSNumber*)maxScale{

NSMutableString *myurl = [NSMutableString stringWithString:@"http://chart.googleapis.com/chart?chxl=0:|"];


//axisXLabels
int countAxisXLabels = [axisXLabels count];

for(NSUInteger i = 0; i < countAxisXLabels; ++i)
{
    NSNumber *value = [axisXLabels objectAtIndex:i];
    [myurl appendFormat:@"%@", value];
    if(i < countAxisXLabels - 1)
        [myurl appendString:@"|"];
}

[myurl appendString:@"|1:|"];


//axisYLabels
 int countAxisYLabels = [axisYLabels count];
for(NSUInteger i = 0; i < countAxisYLabels; ++i)
{
    NSNumber *value = [axisYLabels objectAtIndex:i];
    [myurl appendFormat:@"%@", value];
    if(i < countAxisYLabels - 1)
        [myurl appendString:@"|"];
}

[myurl appendString:@"&chxr=0,0,105|1,3.333,100&chxt=x,y&chs="];

//size
[myurl appendFormat:@"%@x%@&cht=lc&chd=t:", width,hight];

//dataValues
int countDataValues = [dataValues count];

for(NSUInteger i = 0; i < countDataValues; ++i)
{
    NSNumber *value = [dataValues objectAtIndex:i];
    [myurl appendFormat:@"%@", value];
    if(i < countDataValues - 1)
    [myurl appendString:@","];
}

//legend
[myurl appendFormat:@"&chdl=%@&chg=25,50&chls=2&",legend];

//color
[myurl appendFormat:@"chm=o,%@,0,-2,8&chco=%@",lineColor,lineColor];

//title
[myurl appendFormat:@"&chtt=+%@",title];

//scale
[myurl appendFormat:@"&chds=%@,%@",minScale,maxScale];



NSString *theurl=[myurl stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding];

NSMutableURLRequest *theRequest=[NSMutableURLRequest requestWithURL:[NSURL URLWithString:theurl]

cachePolicy:NSURLRequestUseProtocolCachePolicy timeoutInterval:60.0];

NSURLResponse* response;
NSError* error;
NSData *imageData=[NSURLConnection sendSynchronousRequest:theRequest returningResponse:&response

エラー:&エラー]; NSLog(@ "%@"、error); NSLog(@ "%@"、response); NSLog(@ "%@"、imageData);

UIImage *myimage = [[UIImage alloc] initWithData:imageData];


return myimage;

// Chart Wizard: https://developers.google.com/chart/image/docs/chart_wizard
 }

そして、ここにテスト関数があります:

-(void)test {

NSString* title = @"Height History";
NSArray *axisXLabels = [NSArray arrayWithObjects:
                       @"Jan",
                       @"Feb",
                       @"Mar",
                       @"Jun",
                       @"Jul",
                       @"Aug",
                       nil];


NSArray *axisYLabels = [NSArray arrayWithObjects:
                        [NSNumber numberWithInt:0],
                        [NSNumber numberWithInt:50],
                        [NSNumber numberWithInt:150],
                        [NSNumber numberWithInt:200],
                        nil];

NSArray *dataValues = [NSArray arrayWithObjects:
                       [NSNumber numberWithInt:130],
                       [NSNumber numberWithInt:140],
                       [NSNumber numberWithInt:140],
                       [NSNumber numberWithInt:150],
                       [NSNumber numberWithInt:170],
                       [NSNumber numberWithInt:180],
                       nil];

NSString *lineColor = @"FF9900";

NSNumber *width = [NSNumber numberWithInt:300];

NSNumber *hight = [NSNumber numberWithInt:200];

NSNumber *minScale = [NSNumber numberWithInt:0];

NSNumber *maxScale = [NSNumber numberWithInt:200];

NSString *legendLabel = @"cm";

UIImage *myimage =[self produceGoogleChartImage:title xAxis:axisXLabels yAxis:axisYLabels andData:dataValues color:lineColor

chartWidth:width chartHight:hight lagendLabel:legendLabel minScale:minScale maxScale:maxScale];

_chartImage.image=myimage;

}

質問のような画像を取得する必要があります。

于 2012-11-07T16:21:04.370 に答える