zoukankan      html  css  js  c++  java
  • 文字颜色渐变 (自己改变 无需操作)

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml" >
    <head>
    <title>无标题页</title>
    </head>
    <body>
    <div id="div1" style="font-size:36px;">我的闪烁文字 abc123</div>
    <span id="span1"></span>
    <script type="text/javascript">
    var begin = getRGB('#33FFAA');
    var end = getRGB('#FF0000');
    var curColor = getRGB('#33FFAA');
    var bo = true;
    var rate = getRate(begin, end);

    function blink()
    {
    window.setInterval(function(){
    curColor.r = getCur(begin.r, end.r, curColor.r, bo, rate.r);
    curColor.g = getCur(begin.g, end.g, curColor.g, bo, rate.g);
    curColor.b = getCur(begin.b, end.b, curColor.b, bo, rate.b);
    document.getElementById('div1').style.color = getColor(curColor);
    document.getElementById('span1').innerHTML = getColor(curColor);
    if(curColor.r == begin.r && curColor.g == begin.g && curColor.b == begin.b)
    {
    bo = true;
    }
    if(curColor.r == end.r && curColor.g == end.g && curColor.b == end.b)
    {
    bo = false;
    }
    } , 100);
    }

    function getCur(beginValue, endValue, curValue, bo, rateValue)
    {
    if(beginValue == endValue)
    {
    return beginValue;
    }

    rateValue = beginValue < endValue ? rateValue : -rateValue;
    curValue += bo ? rateValue : -rateValue;
    if(curValue < Math.min(beginValue, endValue))
    {
    curValue = Math.min(beginValue, endValue);
    }
    if(curValue > Math.max(beginValue, endValue))
    {
    curValue = Math.max(beginValue, endValue);
    }

    return curValue;
    }

    function getRate(b, e)
    {
    var obj = new Object();
    obj.r = Math.abs(b.r - e.r) / 5;
    obj.g = Math.abs(b.g - e.g) / 5;
    obj.b = Math.abs(b.b - e.b) / 5;

    return obj;
    }

    function getRGB(color)
    {
    var obj = new Object();
    obj.r = parseInt(color.substr(1,2), 16);
    obj.g = parseInt(color.substr(3,2), 16);
    obj.b = parseInt(color.substr(5,2), 16);

    return obj;
    }

    function getColor(obj)
    {
    obj.r = Math.round(obj.r);
    obj.g = Math.round(obj.g);
    obj.b = Math.round(obj.b);
    var color = '#';
    color += (obj.r < 16 ? '0':'') + obj.r.toString(16);
    color += (obj.g < 16 ? '0':'') + obj.g.toString(16);
    color += (obj.b < 16 ? '0':'') + obj.b.toString(16);

    return color;
    }

    blink();
    </script>
    </body>
    </html>
    复制代码
  • 相关阅读:
    runtest.sh
    写代码:简单的三元运算
    写代码:用户交互显示类似省市县三级联动的选择
    写代码:列举布尔值是False的所有值
    写代码:求集合
    写代码:利用For循环和while输出1-100
    写代码:利用for循环和range输出9*9乘法表
    写代码:查找列表中元素,移除每个元素的空格,并查找以a或A开头并且以c结尾的元素。
    写代码:利用下划线将列表的每个元素拼接成字符串,li=["alex","eric","rain"]
    写代码:购物车程序
  • 原文地址:https://www.cnblogs.com/MagicalOfD/p/6429777.html
Copyright © 2011-2022 走看看