JS生成渐变颜色
来源:互联网 发布:剑网3秀萝捏脸数据图片 编辑:程序博客网 时间:2024/06/07 23:10
最近在使用百度的echarts插件做一个图表,分享一下做图的心得。
这是echarts默认的颜色:
echarts默认的颜色列表只有10个颜色。
既然如此,那么我们修改一下这个color列表的颜色就好了。先上效果图
/*// startColor:开始颜色hex// endColor:结束颜色hex// step:几个阶级(几步)*/function gradientColor(startColor,endColor,step){ startRGB = colorToRgb(startColor);//转换为rgb数组模式 startR = startRGB[0]; startG = startRGB[1]; startB = startRGB[2]; endRGB = colorToRgb(endColor); endR = endRGB[0]; endG = endRGB[1]; endB = endRGB[2]; sR = (endR-startR)/step;//总差值 sG = (endG-startG)/step; sB = (endB-startB)/step; var colorArr = []; for(var i=0;i<step;i++){ //计算每一步的hex值 var hex = colorToHex('rgb('+parseInt((sR*i+startR))+','+parseInt((sG*i+startG))+','+parseInt((sB*i+startB))+')'); colorArr.push(hex); } return colorArr;}// 将hex表示方式转换为rgb表示方式(这里返回rgb数组模式)function colorToRgb(sColor){ var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/; var sColor = sColor.toLowerCase(); if(sColor && reg.test(sColor)){ if(sColor.length === 4){ var sColorNew = "#"; for(var i=1; i<4; i+=1){ sColorNew += sColor.slice(i,i+1).concat(sColor.slice(i,i+1)); } sColor = sColorNew; } //处理六位的颜色值 var sColorChange = []; for(var i=1; i<7; i+=2){ sColorChange.push(parseInt("0x"+sColor.slice(i,i+2))); } return sColorChange; }else{ return sColor; }};// 将rgb表示方式转换为hex表示方式function colorToHex(rgb){ var _this = rgb; var reg = /^#([0-9a-fA-f]{3}|[0-9a-fA-f]{6})$/; if(/^(rgb|RGB)/.test(_this)){ var aColor = _this.replace(/(?:\(|\)|rgb|RGB)*/g,"").split(","); var strHex = "#"; for(var i=0; i<aColor.length; i++){ var hex = Number(aColor[i]).toString(16); hex = hex<10 ? 0+''+hex :hex;// 保证每个rgb的值为2位 if(hex === "0"){ hex += hex; } strHex += hex; } if(strHex.length !== 7){ strHex = _this; } return strHex; }else if(reg.test(_this)){ var aNum = _this.replace(/#/,"").split(""); if(aNum.length === 6){ return _this; }else if(aNum.length === 3){ var numHex = "#"; for(var i=0; i<aNum.length; i+=1){ numHex += (aNum[i]+aNum[i]); } return numHex; } }else{ return _this; }}
调用方法赋值给color属性 lineOption.color=gradientColor('#e82400','#8ae800',_fwqsSize)
本文代码参考:http://www.cnblogs.com/guofei0925/p/5761333.html#commentform
原文中关于正则表达式分割rgb颜色有点问题,在这里我已经修改好了。直接拿去用就好了。
1 0
- JS生成渐变颜色
- JS 完成颜色渐变~~
- JS 颜色渐变动画
- [JS]颜色渐变
- jQuery/js实现颜色渐变
- js颜色渐变,算法原理
- Flex生成颜色渐变值算法
- js实现页面加载颜色渐变进度条
- JS实现方块颜色的渐变
- 仅通过js实现颜色渐变
- JS生成随机颜色
- js 随机生成颜色
- js 随机生成颜色
- js随机生成颜色
- js 生成随机颜色
- js 生成随机颜色
- js随机颜色生成
- 颜色渐变
- NestedScrolling 机制深入解析
- 结果集分页的两种方式
- drawableTop 图片大小
- linux 下查看机器是cpu是几核的
- Picasso的缓存理解及简单的封装
- JS生成渐变颜色
- POI的使用
- 【已解决】Apk签名后报so找不到
- OpenCV 行列值与坐标的对应关系
- java I/O系统(1)-File类
- 【剑指offer之二维数组中的查找 】
- 深入C语言可变参数(va_arg,va_list,va_start,va_end,_INTSIZEOF)
- http状态码清单
- spring4.1.6配置MVC注解