美文网首页
iOS-雷达图(RadarChart)

iOS-雷达图(RadarChart)

作者: 码渣 | 来源:发表于2018-12-26 12:07 被阅读20次

前言:最近喜欢上封装一些东西,一来提升自己的封装能力,二来为以后的复用提供便利

功能如下:

  • 可设置不超过20个元素的雷达图
  • 文字可点击
  • 分割值可显示

来看下效果图

Snip20181226_5.png

1.如何使用

直接看代码,使用起来非常简单。

    NSMutableArray *items = [NSMutableArray array];
    NSArray *values = @[@8,@5,@7,@3,@6];
    NSArray *descs = @[@"苹果",@"香蕉",@"花生",@"橙子",@"车厘子"];
    for (int i = 0; i < values.count; i++) {
        
        GBRadarChartDataItem *item = [GBRadarChartDataItem dataItemWithValue:[values[i] floatValue] description:descs[i]];
        [items addObject:item];
    }

    GBRadarChart *radarChart = [[GBRadarChart alloc] initWithFrame:CGRectMake(0, 100, CGRectGetWidth(self.view.bounds), 400) items:items valueDivider:2];
    radarChart.isShowGraduation = YES;
    [radarChart strokeChart];
    [self.view addSubview:radarChart];

2.看下源代码,了解一下实现过程

首先是.h中的属性和方法

@interface GBRadarChart : UIView

/**
 初始化图表

 @param frame frame
 @param items 模型数组
 @param unitValue 均分值
 @return 对象
 */
- (id)initWithFrame:(CGRect)frame items:(NSArray <GBRadarChartDataItem *> *)items valueDivider:(CGFloat)unitValue;

/** 绘制图表 */
- (void)strokeChart;

/**
 更新图表
 
 @param chartData 模型数组
 */
- (void)updateChartWithChartData:(NSArray *)chartData;

/** Array of `RadarChartDataItem` objects, one for each corner. */
@property (nonatomic) NSArray <GBRadarChartDataItem *> *chartData;
/** The unit of this chart ,default is 1 */
@property (nonatomic) CGFloat valueDivider;
/** The maximum for the range of values to display on the chart */
@property (nonatomic) CGFloat maxValue;
/** Default is gray. */
@property (nonatomic) UIColor *webColor;
/** Default is green , with an alpha of 0.7 */
@property (nonatomic) UIColor *plotFillColor;
/** Default is green*/
@property (nonatomic) UIColor *plotStrokeColor;
/** Default is black */
@property (nonatomic) UIColor *fontColor;
/** Default is orange */
@property (nonatomic) UIColor *graduationColor;
/** Default is 12 */
@property (nonatomic) CGFloat fontSize;
/** Tap the label will display detail value ,default is YES. */
@property (nonatomic, assign) BOOL isLabelTouchable;
/** is show graduation on the chart ,default is NO. */
@property (nonatomic, assign) BOOL isShowGraduation;
/** is display animated, default is YES */
@property (nonatomic, assign) BOOL displayAnimated;

@end

.m中代码就不粘贴,最后直接上demo吧
传送门:RadarChartDemo
大家有什么不理解的或者好的意见,评论回复吧~~~

相关文章

  • iOS-雷达图(RadarChart)

    前言:最近喜欢上封装一些东西,一来提升自己的封装能力,二来为以后的复用提供便利 功能如下: 可设置不超过20个元素...

  • 【R语言】--- 基本雷达图

    基本简介 雷达图(Radar Charts)也称蜘蛛图或极坐标图。本文我们使用 fmsb 包的radarchart...

  • 2016.05.15 iOS开发笔记之RadarChart(雷达

    2016.05.15 iOS开发笔记之RadarChart(雷达图) 这也我们产品提的一个较为奇葩的需求, 一开始...

  • iOS雷达图 iOS RadarChart实现

    刚拿到设计稿的时候大概看了一眼,当时心里想着放张背景图,然后计算下相应点的坐标,在最上面画一层就OK了,其实一开始...

  • R语言可视化(二十一):雷达图绘制

    21. 雷达图绘制 清除当前环境中的变量 设置工作目录 使用fmsb包绘制雷达图 使用ggradar包绘制雷达图

  • R实战| 雷达图(Radar Chart)

    R实战| 雷达图(Radar Chart) 雷达图(radar chart),又称蜘蛛网图(spider plot...

  • 数据雷达图

    最近公司项目,需要用到雷达图的效果,echarts的雷达图不太符合公司的需求,所以自己用canvas写了个雷达图的...

  • pyecharts--雷达图

    数据准备 普通雷达图 雷达图的基本框架出来以后,就需要精细的调整,包括颜色填充,线条调整,以及字体放大等等 雷达图...

  • iOS使用Charts框架绘制—雷达图

    首先先看一下效果: 一、创建雷达图对象 二、设置雷达图样式 1. 设置雷达图线条样式 雷达图的线条有两部分构成, ...

  • iOS学习目录

    iOS-基础 iOS这张图有多大AppDelegate生命周期[iOS证书][APP配置打包上传] iOS-项目基...

网友评论

      本文标题:iOS-雷达图(RadarChart)

      本文链接:https://www.haomeiwen.com/subject/hxxhlqtx.html