iOS 动画绘制线条颜色渐变的折线图

效果图

....................783575-20160224105038396-680408863.gif

概述

  • 现状

      折线图的应用比较广泛,为了增强用户体验,很多应用中都嵌入了折线图。折线图可以更加直观的表示数据的变化。网络上有很多绘制折线图的demo,有的也使用了动画,但是线条颜色渐变的折线图的demo少之又少,甚至可以说没有。该Blog阐述了动画绘制线条颜色渐变的折线图的实现方案,以及折线图线条颜色渐变的实现原理,并附以完整的示例。
  • 成果
    • 本人已将折线图封装到了一个UIView子类中,并提供了相应的接口。该自定义折线图视图,基本上可以适用于大部分需要集成折线图的项目。若你遇到相应的需求可以直接将文件拖到项目中,调用相应的接口即可
    • 项目文件中包含了大量的注释代码,若你的需求与折线图的实现效果有差别,那么你可以对项目文件的进行修改,也可以依照思路定义自己的折线图视图
  • Blog中涉及到的知识点
    • CALayer
      • 图层,可以简单的看做一个不接受用户交互的UIView
      • 每个图层都具有一个CALayer类型mask属性,作用与蒙版相似
      • Blog中主要用到的CALayer子类有
        • CAGradientLayer,绘制颜色渐变的背景图层
        • CAShapeLayer,绘制折线图
    • CAAnimation
      • 核心动画的基类(不可实例化对象),实现动画操作
    • Quartz 2D
      • 一个二维的绘图引擎,用来绘制折线(Path)和坐标轴信息(Text)

实现思路

  • 折线图视图
    • 整个折线图将会被自定义到一个UIView子类中
  • 坐标轴绘制
    • 坐标轴直接绘制到折线图视图上,在自定义折线图视图的 drawRect 方法中绘制坐标轴相关信息(线条和文字)
    • 注意坐标系的转换
  • 线条颜色渐变
    • 失败的方案
      • 开始的时候,为了实现线条颜色渐变,我的思考方向是,如何改变路径(UIBezierPath)的渲染颜色(strokeColor)。但是strokeColor只可以设置一种,所以最终无法实现线条颜色的渐变。
    • 成功的方案
      • 在探索过程中找到了CALayer的CALayer类型的mask()属性,最终找到了解决方案,即:使用UIView对象封装渐变背景视图(frame为折线图视图的减去坐标轴后的frame),创建一个CAGradientLayer渐变图层添加到背景视图上。
      • 创建一个CAShapeLayer对象,用于绘制线条,线条的渲染颜色(strokeColor)为whiteColor,填充颜色(fillColor)为clearColor,从而显示出渐变图层的颜色。将CAShapeLayer对象设置为背景视图的mask属性,即背景视图的蒙版。
  • 折线
    • 使用 UIBezierPath 类来绘制折线
    • 折线转折处尖角的处理,使用 kCALineCapRound 与 kCALineJoinRound 设置折线转折处为圆角
    • 折线起点与终点的圆点的处理,可以直接在 UIBezierPath 对象上添加一个圆,设置远的半径为路径宽度的一半,从而保证是一个实心的圆而不是一个圆环
  • 折线转折处的点
    • 折线转折处点使用一个类来描述(不使用CGPoint的原因是:折线转折处的点需要放到一个数组中)
  • 坐标轴信息
    • X轴、Y轴的信息分别放到一个数组中
    • X轴显示的是最近七天的日期,Y轴显示的是最近七天数据变化的幅度
  • 动画
    • 使用CABasicAnimation类来完成绘制折线图时的动画
    • 需要注意的是,折线路径在一开始时需要社会线宽为0,开始绘制时才设置为适当的线宽,保证一开折线路径是隐藏的
  • 标签
    • 在动画结束时,向折线图视图上添加一个标签(UIButton对象),显示折线终点的信息
    • 标签的位置,需要根据折线终点的位置计算

具体实现

  • 折线转折处的点
    • 使用一个类来描述折线转折处的点,代码如下:

      // 接口
      /** 折线图上的点 */
      @interface IDLineChartPoint : NSObject
      /** x轴偏移量 */
      @property (nonatomic, assign) float x;
      /** y轴偏移量 */
      @property (nonatomic, assign) float y;
      /** 工厂方法 */
      + (instancetype)pointWithX:(float)x andY:(float)y;
      @end// 实现
      @implementation IDLineChartPoint
      + (instancetype)pointWithX:(float)x andY:(float)y {IDLineChartPoint *point = [[self alloc] init];point.x = x;point.y = y;return point;
      }
      @end
  • 自定义折线图视图
    • 折线图视图是一个自定义的UIView子类,代码如下:

      // 接口
      /** 折线图视图 */
      @interface IDLineChartView : UIView
      /** 折线转折点数组 */
      @property (nonatomic, strong) NSMutableArray<IDLineChartPoint *> *pointArray;
      /** 开始绘制折线图 */
      - (void)startDrawlineChart;
      @end// 分类
      @interface IDLineChartView ()
      @end// 实现
      @implementation IDLineChartView
      // 初始化
      - (instancetype)initWithFrame:(CGRect)frame {if (self = [super initWithFrame:frame]) {// 设置折线图的背景色self.backgroundColor = [UIColor colorWithRed:243/255.0 green:243/255.0 blue:243/255.0 alpha:1.0];}return self;
      }
      @end
    • 效果如图

      783575-20160224105137193-10944930.png

  • 绘制坐标轴信息
    • 与坐标轴绘制相关的常量

      /** 坐标轴信息区域宽度 */
      static const CGFloat kPadding = 25.0;
      /** 坐标系中横线的宽度 */
      static const CGFloat kCoordinateLineWith = 1.0;
    • 在分类中添加与坐标轴绘制相关的成员变量

      /** X轴的单位长度 */
      @property (nonatomic, assign) CGFloat xAxisSpacing;
      /** Y轴的单位长度 */
      @property (nonatomic, assign) CGFloat yAxisSpacing;
      /** X轴的信息 */
      @property (nonatomic, strong) NSMutableArray<NSString *> *xAxisInformationArray;
      /** Y轴的信息 */
      @property (nonatomic, strong) NSMutableArray<NSString *> *yAxisInformationArray;
    • 与坐标轴绘制相关的成员变量的get方法

      - (CGFloat)xAxisSpacing {if (_xAxisSpacing == 0) {_xAxisSpacing = (self.bounds.size.width - kPadding) / (float)self.xAxisInformationArray.count;}return _xAxisSpacing;
      }
      - (CGFloat)yAxisSpacing {if (_yAxisSpacing == 0) {_yAxisSpacing = (self.bounds.size.height - kPadding) / (float)self.yAxisInformationArray.count;}return _yAxisSpacing;
      }
      - (NSMutableArray<NSString *> *)xAxisInformationArray {if (_xAxisInformationArray == nil) {// 创建可变数组_xAxisInformationArray = [[NSMutableArray alloc] init];// 当前日期和日历NSDate *today = [NSDate date];NSCalendar *currentCalendar = [NSCalendar currentCalendar];// 设置日期格式NSDateFormatter *dateFormatter = [[NSDateFormatter alloc] init];dateFormatter.dateFormat = @"MM-dd";// 获取最近一周的日期NSDateComponents *components = [[NSDateComponents alloc] init];for (int i = -7; i<0; i++) {components.day = i;NSDate *dayOfLatestWeek = [currentCalendar dateByAddingComponents:components toDate:today options:0];NSString *dateString = [dateFormatter stringFromDate:dayOfLatestWeek];[_xAxisInformationArray addObject:dateString];}}return _xAxisInformationArray;
      }
      - (NSMutableArray<NSString *> *)yAxisInformationArray {if (_yAxisInformationArray == nil) {_yAxisInformationArray = [NSMutableArray arrayWithObjects:@"0", @"10", @"20", @"30", @"40", @"50", nil];}return _yAxisInformationArray;
      }
      // 折线图上的点(重写get方法,后期需要暴露接口)
      - (NSMutableArray<IDLineChartPoint *> *)pointArray {if (_pointArray == nil) {_pointArray = [NSMutableArray arrayWithObjects:[IDLineChartPoint pointWithX:1 andY:1], [IDLineChartPoint pointWithX:2 andY:2], [IDLineChartPoint pointWithX:3 andY:1.5], [IDLineChartPoint pointWithX:4 andY:2], [IDLineChartPoint pointWithX:5 andY:4], [IDLineChartPoint pointWithX:6 andY:1], [IDLineChartPoint pointWithX:7 andY:2], nil];}return _pointArray;
      }
    • 绘制坐标轴的相关信息

      - (void)drawRect:(CGRect)rect {// 获取上下文CGContextRef context = UIGraphicsGetCurrentContext();// x轴信息[self.xAxisInformationArray enumerateObjectsUsingBlock:^(NSString * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {// 计算文字尺寸UIFont *informationFont = [UIFont systemFontOfSize:10];NSMutableDictionary *attributes = [NSMutableDictionary dictionary];attributes[NSForegroundColorAttributeName] = [UIColor colorWithRed:158/255.0 green:158/255.0 blue:158/255.0 alpha:1.0];attributes[NSFontAttributeName] = informationFont;CGSize informationSize = [obj sizeWithAttributes:attributes];// 计算绘制起点float drawStartPointX = kPadding + idx * self.xAxisSpacing + (self.xAxisSpacing - informationSize.width) * 0.5;float drawStartPointY = self.bounds.size.height - kPadding + (kPadding - informationSize.height) / 2.0;CGPoint drawStartPoint = CGPointMake(drawStartPointX, drawStartPointY);// 绘制文字信息[obj drawAtPoint:drawStartPoint withAttributes:attributes];}];// y轴[self.yAxisInformationArray enumerateObjectsUsingBlock:^(NSString * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {// 计算文字尺寸UIFont *informationFont = [UIFont systemFontOfSize:10];NSMutableDictionary *attributes = [NSMutableDictionary dictionary];attributes[NSForegroundColorAttributeName] = [UIColor colorWithRed:158/255.0 green:158/255.0 blue:158/255.0 alpha:1.0];attributes[NSFontAttributeName] = informationFont;CGSize informationSize = [obj sizeWithAttributes:attributes];// 计算绘制起点float drawStartPointX = (kPadding - informationSize.width) / 2.0;float drawStartPointY = self.bounds.size.height - kPadding - idx * self.yAxisSpacing - informationSize.height * 0.5;CGPoint drawStartPoint = CGPointMake(drawStartPointX, drawStartPointY);// 绘制文字信息[obj drawAtPoint:drawStartPoint withAttributes:attributes];// 横向标线CGContextSetRGBStrokeColor(context, 231 / 255.0, 231 / 255.0, 231 / 255.0, 1.0);CGContextSetLineWidth(context, kCoordinateLineWith);CGContextMoveToPoint(context, kPadding, self.bounds.size.height - kPadding - idx * self.yAxisSpacing);CGContextAddLineToPoint(context, self.bounds.size.width, self.bounds.size.height - kPadding - idx * self.yAxisSpacing);CGContextStrokePath(context);}];
      }
    • 效果如图

      783575-20160224105230224-1176047858.png

  • 渐变背景视图
    • 在分类中添加与背景视图相关的常量

      /** 渐变背景视图 */
      @property (nonatomic, strong) UIView *gradientBackgroundView;
      /** 渐变图层 */
      @property (nonatomic, strong) CAGradientLayer *gradientLayer;
      /** 颜色数组 */
      @property (nonatomic, strong) NSMutableArray *gradientLayerColors;
    • 在初始化方法中添加调用设置背景视图方法的代码

      [self drawGradientBackgroundView];
    • 设置渐变视图方法的具体实现

      - (void)drawGradientBackgroundView {// 渐变背景视图(不包含坐标轴)self.gradientBackgroundView = [[UIView alloc] initWithFrame:CGRectMake(kPadding, 0, self.bounds.size.width - kPadding, self.bounds.size.height - kPadding)];[self addSubview:self.gradientBackgroundView];/** 创建并设置渐变背景图层 *///初始化CAGradientlayer对象,使它的大小为渐变背景视图的大小self.gradientLayer = [CAGradientLayer layer];self.gradientLayer.frame = self.gradientBackgroundView.bounds;//设置渐变区域的起始和终止位置(范围为0-1),即渐变路径self.gradientLayer.startPoint = CGPointMake(0, 0.0);self.gradientLayer.endPoint = CGPointMake(1.0, 0.0);//设置颜色的渐变过程self.gradientLayerColors = [NSMutableArray arrayWithArray:@[(__bridge id)[UIColor colorWithRed:253 / 255.0 green:164 / 255.0 blue:8 / 255.0 alpha:1.0].CGColor, (__bridge id)[UIColor colorWithRed:251 / 255.0 green:37 / 255.0 blue:45 / 255.0 alpha:1.0].CGColor]];self.gradientLayer.colors = self.gradientLayerColors;//将CAGradientlayer对象添加在我们要设置背景色的视图的layer层[self.gradientBackgroundView.layer addSublayer:self.gradientLayer];
      }
    • 效果如图

      783575-20160224105255880-2026252952.png

  • 折线
    • 在分类中添加与折线绘制相关的成员变量

      /** 折线图层 */
      @property (nonatomic, strong) CAShapeLayer *lineChartLayer;
      /** 折线图终点处的标签 */
      @property (nonatomic, strong) UIButton *tapButton;
    • 在初始化方法中添加调用设置折线图层方法的代码

      [self setupLineChartLayerAppearance];
    • 设置折线图层方法的具体实现

      - (void)setupLineChartLayerAppearance {/** 折线路径 */UIBezierPath *path = [UIBezierPath bezierPath];[self.pointArray enumerateObjectsUsingBlock:^(IDLineChartPoint * _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {// 折线if (idx == 0) {[path moveToPoint:CGPointMake(self.xAxisSpacing * 0.5 + (obj.x - 1) * self.xAxisSpacing, self.bounds.size.height - kPadding - obj.y * self.yAxisSpacing)];} else {[path addLineToPoint:CGPointMake(self.xAxisSpacing * 0.5 + (obj.x - 1) * self.xAxisSpacing, self.bounds.size.height - kPadding - obj.y * self.yAxisSpacing)];}// 折线起点和终点位置的圆点if (idx == 0 || idx == self.pointArray.count - 1) {[path addArcWithCenter:CGPointMake(self.xAxisSpacing * 0.5 + (obj.x - 1) * self.xAxisSpacing, self.bounds.size.height - kPadding - obj.y * self.yAxisSpacing) radius:2.0 startAngle:0 endAngle:2 * M_PI clockwise:YES];}}];/** 将折线添加到折线图层上,并设置相关的属性 */self.lineChartLayer = [CAShapeLayer layer];self.lineChartLayer.path = path.CGPath;self.lineChartLayer.strokeColor = [UIColor whiteColor].CGColor;self.lineChartLayer.fillColor = [[UIColor clearColor] CGColor];// 默认设置路径宽度为0,使其在起始状态下不显示self.lineChartLayer.lineWidth = 0;self.lineChartLayer.lineCap = kCALineCapRound;self.lineChartLayer.lineJoin = kCALineJoinRound;// 设置折线图层为渐变图层的maskself.gradientBackgroundView.layer.mask = self.lineChartLayer;
      }
    • 效果如图(初始状态不显示折线)

      783575-20160224105316177-1577497841.png

  • 动画的开始与结束
    • 动画开始

      /** 动画开始,绘制折线图 */
      - (void)startDrawlineChart {// 设置路径宽度为4,使其能够显示出来self.lineChartLayer.lineWidth = 4;// 移除标签,if ([self.subviews containsObject:self.tapButton]) {[self.tapButton removeFromSuperview];}// 设置动画的相关属性CABasicAnimation *pathAnimation = [CABasicAnimation animationWithKeyPath:@"strokeEnd"];pathAnimation.duration = 2.5;pathAnimation.repeatCount = 1;pathAnimation.removedOnCompletion = NO;pathAnimation.fromValue = [NSNumber numberWithFloat:0.0f];pathAnimation.toValue = [NSNumber numberWithFloat:1.0f];// 设置动画代理,动画结束时添加一个标签,显示折线终点的信息pathAnimation.delegate = self;[self.lineChartLayer addAnimation:pathAnimation forKey:@"strokeEnd"];
      }
    • 动画结束,添加标签

      /** 动画结束时,添加一个标签 */
      - (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag {if (self.tapButton == nil) { // 首次添加标签(避免多次创建和计算)CGRect tapButtonFrame = CGRectMake(self.xAxisSpacing * 0.5 + ([self.pointArray[self.pointArray.count - 1] x] - 1) * self.xAxisSpacing + 8, self.bounds.size.height - kPadding - [self.pointArray[self.pointArray.count - 1] y] * self.yAxisSpacing - 34, 30, 30);self.tapButton = [[UIButton alloc] initWithFrame:tapButtonFrame];self.tapButton.enabled = NO;[self.tapButton setBackgroundImage:[UIImage imageNamed:@"bubble"] forState:UIControlStateDisabled];[self.tapButton.titleLabel setFont:[UIFont systemFontOfSize:10]];[self.tapButton setTitle:@"20" forState:UIControlStateDisabled];}[self addSubview:self.tapButton];
      }
  • 集成折线图视图

    • 创建折线图视图
      • 添加成员变量

        /** 折线图 */
        @property (nonatomic, strong) IDLineChartView *lineCharView;
      • 在viewDidLoad方法中创建折线图并添加到控制器的view上

        self.lineCharView = [[IDLineChartView alloc] initWithFrame:CGRectMake(35, 164, 340, 170)];
        [self.view addSubview:self.lineCharView];
    • 添加开始绘制折线图视图的按钮

      • 添加成员变量

        /** 开始绘制折线图按钮 */
        @property (nonatomic, strong) UIButton *drawLineChartButton;
      • 在viewDidLoad方法中创建开始按钮并添加到控制器的view上

        self.drawLineChartButton = [UIButton buttonWithType:UIButtonTypeSystem];
        self.drawLineChartButton.frame = CGRectMake(180, 375, 50, 44);
        [self.drawLineChartButton setTitle:@"开始" forState:UIControlStateNormal];
        [self.drawLineChartButton addTarget:self action:@selector(drawLineChart) forControlEvents:UIControlEventTouchUpInside];
        [self.view addSubview:self.drawLineChartButton];
      • 开始按钮的点击事件

        // 开始绘制折线图
        - (void)drawLineChart {[self.lineCharView startDrawlineChart];
        }
    • 效果如图

      783575-20160224105332458-504319299.gif

声明:若需要工程文件,请在评论中联系我,非常愿意与广大技术爱好者沟通交流。下一篇博客将会介绍如何使用UICollectionView实现具有签到功能的日历

转载于:https://www.cnblogs.com/theDesertIslandOutOfTheWorld/p/5212183.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/430838.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

android使碎片切换界面,玩转Android中的碎片Fragment

引言&#xff1a;在Android开发中&#xff0c;我们都知道一些界面的展示经常会用到的就是Activity,但是Activity存在着很大的局限性,比如说手机上的界面显示在平板上面就会发生各种变形的问题,Activity也无法实现局部的数据刷新,所以Android3.0之后出来了Fragment,Fragment通常…

html GPS坐标实现,JavaScript 实现GPS坐标点距离计算(两个经/纬度间的距离计算)...

在LBS(基于位置服务)的一些应用中&#xff0c;有时我们会需要计算两个用户或两个坐标点之间的距离。要解决这类问题&#xff0c;就要了解空间几何的概念并结合数学中在三角函数公式计算两点之间的值。本文介绍基于经度/纬度的&#xff0c;两个坐标点之间的距离计算&#xff0c;…

机器学习基于skcilearn tensorflow电子书_Tensorflow机器学习模型的跨平台上线

本篇文章转载自博客园&#xff0c;作者: 刘建平Pinard在用PMML实现机器学习模型的跨平台上线中&#xff0c;我们讨论了使用PMML文件来实现跨平台模型上线的方法&#xff0c;这个方法当然也适用于tensorflow生成的模型&#xff0c;但是由于tensorflow模型往往较大&#xff0c;使…

html5 observer api,基于HTML5新特性Mutation Observer实现编辑器的撤销和回退操作

MutationObserver介绍MutationObserver给开发者们提供了一种能在某个范围内的DOM树发生变化时作出适当反应的能力.该API设计用来替换掉在DOM3事件规范中引入的Mutation事件.Mutation Observer(变动观察器)是监视DOM变动的接口。当DOM对象树发生任何变动时&#xff0c;Mutation …

Maven(五)使用Nexus搭建Maven私服

文章装载于&#xff1a;http://blog.csdn.net/jun55xiu/article/details/39497089 Nexus介绍 Nexus是Maven仓库管理器&#xff0c;如果你使用Maven&#xff0c;你可以从Maven中央仓库下载所需要的构件&#xff08;artifact&#xff09;&#xff0c;但这通常不是一个好的做法&am…

计算机学测打多少字,速度测试,一分钟能打多少字?

六、速度测试——检验学习效果经过一段时间的练习&#xff0c;输入速度提高了不少吧&#xff0c;赶快来测试一下现在一分钟可以输入多少英文或汉字。金山打字通2010的“速度测试”功能不仅有基本的“屏幕对照”速度测试&#xff0c;还有“书本对照”测试及要求较高的“同声录入…

HDFS入门(1)

2015.07.12笔记 1.HDFS Distributed File System&#xff08;操作系统实现人机交互&#xff0c;最重要的功能是文件管理&#xff0c;使用文件管理系统&#xff0c;windows、Linux文件管理系统有共性&#xff1a;用户可创建文件/夹&#xff0c;删除&#xff0c;修改权限&#xf…

竞赛图 计算机网络 应用题,我校学子获2020年“中国高校计算机大赛-网络技术挑战赛”全国总决赛一等奖(图)...

近日&#xff0c;2020年“中国高校计算机大赛-网络技术挑战赛”全国总决赛在温州浙南科技城落下帷幕。我校计算机与信息安全学院陈俊彦、雷晓春老师指导的“智载车队”团队(成员&#xff1a;林楷浩、陈澳格、黄湖)在创业先锋C系列中获得全国一等奖&#xff0c;在创新创意A系列中…

建立远程桌面连接计算机无密码,win7远程桌面空密码的步骤_win7系统如何设置让远程桌面登录无需密码-win7之家...

在日常工作中&#xff0c;可能经常会使用到远程连接桌面功能&#xff0c;我们要远程桌面的话&#xff0c;通常是要输入密码才可以的&#xff0c;但是有些用户觉得麻烦&#xff0c;那么win7系统如何设置让远程桌面登录无需密码呢&#xff1f;带着大家的这个问题&#xff0c;本文…

tkinter如何lable重复显示到同一行中_如何创建包含 CAD 导入和选择的仿真 App

在使用 COMSOL 软件二次开发的过程中&#xff0c;你可能会遇到这样的问题&#xff1a;如何使用 App 开发器创建可以处理 CAD 导入并能让用户交互式选择边界条件的仿真 App&#xff1f;我需要了解编程吗&#xff1f;今天我们将为您介绍在 COMSOL 软件中创建包含 CAD 导入和选择的…

计算机科学导论课后单词,计算机科学导论课后总结

计算机科学导论课后总结1老师上课给我们演示了一个迷宫的程序&#xff0c;然后我上网查找了一下&#xff0c;大致学习了一下这个程序的思想。迷宫这个题目和数据结构—图有关迷宫的随机生成和路径搜索主要和图的遍历有关&#xff0c;一般来说图的遍历主要有两种方式&#xff1a…

表单内如何直接贴图而不用上传图片_表单如何添加图片?

表单其实就是我们平常经常看到的收集信息的框框&#xff0c;如姓名、电话等&#xff0c;当然易表单就远不止这些哦&#xff0c;还可制作调查问卷&#xff0c;报名登记、投票评选和考试测评。平时大家都擅长于制作表单的文字内容&#xff0c;实际上表单里边添加一些图片会让表单…

Android应用的安全的攻防之战

一、前言 在前两篇破解的文章中&#xff0c;我们介绍了如何使用动态调试来破解apk&#xff0c;一个是通过调试smali源码&#xff0c;一个是通过调试so代码来进行代码的跟踪破解&#xff0c;那么今天我们就这两篇文章的破解方法&#xff0c;来看看Android中开发应用的过程中如何…

标准正态分布表_表达矩阵的归一化和标准化,去除极端值,异常值

我们阅读量破万的综述&#xff1a;RNA-seq这十年(3万字长文综述)给粉丝朋友们带来了很多理解上的挑战&#xff0c;所以我们开辟专栏慢慢介绍其中的一些概念性的问题&#xff0c;上一期&#xff1a;RNA-seq的counts值&#xff0c;RPM, RPKM, FPKM, TPM 的异同在数据挖掘过程&…

计算机网络关于封装成帧题目,上海第二工业大学-计算机网络通信期中试卷答案...

上海第二工业大学 (试卷编号&#xff1a; )2014-2015学年第2学期 计算机网络与通信 期中考试试卷姓名&#xff1a; 学号&#xff1a; 班级&#xff1a; 成绩&#xff1a;一、 填空题 (每空1分&#xff0c;共18分)1. 当前广泛提及的三网融合中的三网分别是 电信网络 、 电视网络…

微星主板超频_内存超频能力依旧拔群!微星MEG Z490 ACE主板评测

一、前言&#xff1a;内存超频首选的新板子来了一直以来&#xff0c;微星主板都以强悍的内存超频能力而著称&#xff0c;而高频内存对于许多游戏带来的提升都是肉眼可见。随着全新Intel 10代酷睿处理器的上市&#xff0c;微星的MEG系列的Z490主板会给大家带来哪些惊喜呢&#x…

g++ 内存不够_手机内存老是不足?这三招,让你马上腾出12个G

不知道朋友们遇到手机卡慢、空间不足的第一反应是什么&#xff1f;A&#xff1a;换个手机。B&#xff1a;内存满了&#xff0c;找清理软件狂删啊&#xff01;使用智能手机的人大家肯定和小编一样恋旧&#xff0c;觉得换手机很麻烦所以不断尝试各种清理软件&#xff0c;清理手机…

stringbuilder寻找字符串位置可能存在多个 java_Java 语言基础amp;String

Java 语言基础String 字符串的不可变性 定义一个字符串使用变量来赋值变量 String s2 s; s2 保存了相同的引用值&#xff0c; 因为他们代表同一个对象 字符串连接 s s.concat("ef"); s 中保存的是一个重新创建出来的 string 对象的引用 总结一旦一个 str…

cogs 547:[HAOI2011] 防线修建

★★★☆ 输入文件&#xff1a;defense.in 输出文件&#xff1a;defense.out 简单对比                      时间限制&#xff1a;1 s 内存限制&#xff1a;128 MB 题目描述&#xff1a; 近来A国和B国的矛盾激化&#xff0c;为了预防不测&#…

人工智能和计算机软件,人工智能在计算机软件方面有什么应用?

人工智能(Artificial Intelligence) &#xff0c;英文缩写为AI。它是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门新的技术科学。人工智能是计算机科学的一个分支&#xff0c;它企图了解智能的实质&#xff0c;并生产出一种新的能以人类智能相似…