js实现颜色阶梯渐变效果(Gradient算法)


Posted in Javascript onMarch 21, 2017

html中颜色可以使用rgb和hex方式来表示。

在色彩中,色相、明度、纯度也都可以产生渐变效果,并会表现出具有丰富层次的美感。本文主要讲述两种颜色RGB数值的梯级渐变算法。

其中如如16进制颜色如#336600分别表示rgb模式中r的值为16进制33(即),g的值为16进制的66,和b为16进制的00,转换后用rgb完整表述为:rgb(51,102,0)。

其中使用16进制进行加减乘除不方便,尤其还使用了rgb的16进制颜色组合(#336600)。因此我们可以将16进制转换为rgb单个进行梯级运算在进行组合。

已知:RStart=50,REnd=200,RStart、REnd之间平均分成3份(Step=3),求每份的数值(StepN)分别是多少。

公式:Gradient = RStart+ (REnd-RStart) / Step * N (第N步的颜色rgb中R的值)

实现方法非常简单,只是需要将颜色从rgb到hex的互转。

实现代码:

<script type="text/javascript">
 /*
 // 作者 yanue
 // 参数:
 // startColor:开始颜色hex
 // endColor:结束颜色hex
 // step:几个阶级(几步)
 */
 function gradientColor(startColor,endColor,step){
  startRGB = this.colorRgb(startColor);//转换为rgb数组模式
  startR = startRGB[0];
  startG = startRGB[1];
  startB = startRGB[2];
  endRGB = this.colorRgb(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 = this.colorHex('rgb('+parseInt((sR*i+startR))+','+parseInt((sG*i+startG))+','+parseInt((sB*i+startB))+')');
   colorArr.push(hex);
  }
  return colorArr;
 }
 // 将hex表示方式转换为rgb表示方式(这里返回rgb数组模式)
 gradientColor.prototype.colorRgb = function(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表示方式
 gradientColor.prototype.colorHex = function(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;
  }
 }
 var gradient = new gradientColor('#013548','#554851',10);
 console.log(gradient);//控制台输出
 alert(gradient);
</script>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
javascript一点特殊用法
May 28 Javascript
Prototype 学习 工具函数学习($w,$F方法)
Jul 12 Javascript
让firefox支持IE的一些方法的javascript扩展函数代码
Jan 02 Javascript
JQuery最佳实践之精妙的自定义事件
Aug 11 Javascript
Bootstrap每天必学之轮播(Carousel)插件
Apr 25 Javascript
AngularJs每天学习之总体介绍
Aug 07 Javascript
微信小程序报错:this.setData is not a function的解决办法
Sep 27 Javascript
vue+webpack 打包文件 404 页面空白的解决方法
Feb 28 Javascript
three.js搭建室内场景教程
Dec 30 Javascript
移动端(微信等使用vConsole调试console的方法
Mar 05 Javascript
vue实现动态按钮功能
May 13 Javascript
微信小程序间使用navigator跳转传值问题实例分析
Mar 27 Javascript
详解Vue 实例中的生命周期钩子
Mar 21 #Javascript
十大热门的JavaScript框架和库
Mar 21 #Javascript
Bootstrap 设置datetimepicker在屏幕上面弹出设置方法
Mar 21 #Javascript
js中编码函数:escape,encodeURI与encodeURIComponent详解
Mar 21 #Javascript
Omi v1.0.2发布正式支持传递javascript表达式
Mar 21 #Javascript
jQuery插件HighCharts绘制简单2D柱状图效果示例【附demo源码】
Mar 21 #jQuery
jQuery插件HighCharts绘制简单2D折线图效果示例【附demo源码】
Mar 21 #jQuery
You might like
php 判断网页是否是utf8编码的方法
2014/06/06 PHP
什么是OneThink oneThink后台添加插件步骤
2016/04/13 PHP
PHP实现限制IP访问及提交次数的方法详解
2017/07/17 PHP
php桥接模式应用案例分析
2019/10/23 PHP
JQuery 学习笔记 选择器之六
2009/07/23 Javascript
jquery判断checkbox(复选框)是否被选中的代码
2010/10/20 Javascript
jQuery学习笔记[1] jQuery中的DOM操作
2010/12/03 Javascript
jQuery.holdReady()方法用法实例
2014/12/27 Javascript
javascript使用正则表达式实现去掉空格之后的字符
2015/02/15 Javascript
jquery简单插件制作(fn.extend)完整实例
2016/05/24 Javascript
jQuery+ajax实现修改密码验证功能实例详解
2017/07/06 jQuery
JS获取子、父、兄节点方法小结
2017/08/14 Javascript
Vue.js进行查询操作的实例详解
2017/08/25 Javascript
JavaScript判断输入是否为数字类型的方法总结
2017/09/28 Javascript
基于vue2实现上拉加载功能
2017/11/28 Javascript
解决VUE框架 导致绑定事件的阻止冒泡失效问题
2018/02/24 Javascript
JS实现的集合去重,交集,并集,差集功能示例
2018/03/13 Javascript
优雅的在React项目中使用Redux的方法
2018/11/10 Javascript
vue工程全局设置ajax的等待动效的方法
2019/02/22 Javascript
Jquery ajax书写方法代码实例解析
2020/06/12 jQuery
js实现右键弹出自定义菜单
2020/09/08 Javascript
在Python上基于Markov链生成伪随机文本的教程
2015/04/17 Python
Python中内置的日志模块logging用法详解
2016/07/12 Python
基于Django静态资源部署404的解决方法
2019/07/28 Python
Python协程操作之gevent(yield阻塞,greenlet),协程实现多任务(有规律的交替协作执行)用法详解
2019/10/14 Python
使用Keras预训练好的模型进行目标类别预测详解
2020/06/27 Python
python批量生成条形码的示例
2020/10/10 Python
Pyside2中嵌入Matplotlib的绘图的实现
2021/02/22 Python
JavaScript+Canvas实现自定义画板的示例代码
2019/05/13 HTML / CSS
Cecil Mode法国在线商店:女性时尚
2021/01/08 全球购物
无犯罪记录证明范本
2014/09/15 职场文书
庆祝国庆节标语
2014/10/09 职场文书
2015年世界水日活动总结
2015/02/09 职场文书
音乐课《小猫钓鱼》教学反思
2016/02/18 职场文书
离婚协议书范文2016
2016/03/18 职场文书
Python爬虫数据的分类及json数据使用小结
2021/03/29 Python