JS生成渐变颜色
2017-05-10 17:27
295 查看
最近在使用百度的echarts插件做一个图表,分享一下做图的心得。
这是echarts默认的颜色:
echarts默认的颜色列表只有10个颜色。
既然如此,那么我们修改一下这个color列表的颜色就好了。先上效果图
调用方法赋值给color属性
本文代码参考:http://www.cnblogs.com/guofei0925/p/5761333.html#commentform
原文中关于正则表达式分割rgb颜色有点问题,在这里我已经修改好了。直接拿去用就好了。
这是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颜色有点问题,在这里我已经修改好了。直接拿去用就好了。
相关文章推荐
- js控制DIV渐变颜色
- 封装了一个自动生成渐变字的JS类(clip)
- js 随机生成颜色
- js实现按钮颜色渐变动画效果
- android自定义button边框,颜色渐变,圆角button快速生成
- js文字特效(鼠标放上去,颜色渐变,酷)
- JS实现的颜色实时渐变效果完整实例
- jQuery/js实现颜色渐变
- 【js学习笔记-114】----<canvas>矩形、颜色、透明度、渐变及图案
- js随机颜色生成
- JS 颜色渐变动画
- 封装了一个自动生成渐变字的JS类(clip)
- JS生成随机颜色
- 一个模仿图片透明渐变做的表格颜色渐变效果 js脚本特效
- js自动生成颜色表
- 利用递增的数字返回循环渐变的颜色的js代码
- JS生成随机颜色
- js 颜色渐变
- CSS3可视化渐变背景颜色代码生成插件
- JS实现的颜色实时渐变效果完整实例