javascript - 如何将 svg "rgb()"属性的随机数值放入 "fill"中?

标签 javascript html animation svg random

我的网站上有一个 svg 元素,我想对其进行动画处理,以便它从随机颜色值更改为另一个随机颜色值。我现在拥有的看起来像这样:

<?xml version="1.0" standalone="no"?>
<svg width="8cm" height="3cm" viewBox="0 0 800 300" xmlns="http://www.w3.org/2000/svg">
  <desc>Example anim01 - demonstrate animation elements</desc>
  <rect x="1" y="1" width="900" height="400"
        fill="none" stroke="none" stroke-width="2" />
  <!-- The following illustrates the use of the 'animate' element
        to animate a rectangles x, y, and width attributes so that
        the rectangle grows to ultimately fill the viewport. -->
  <rect id="RectElement" x="300" y="100" width="300" height="100"
        fill="rgb(0,255,0)"  >
    <animate attributeName="fill" begin="0" dur="1.3"
    fill="remove" from="rgb(0,255,0)" to="rgb(255,0,0)" repeatCount="indefinite"/>
    <animate attributeName="x" begin="0s" dur="1.3s"
             fill="freeze" from="300" to="0" repeatCount="indefinite"/>
    <animate attributeName="y" begin="0s" dur="1.3s"
             fill="freeze" from="100" to="0" repeatCount="indefinite"/>
    <animate attributeName="width" begin="0s" dur="1.3s"
             fill="freeze" from="300" to="800" repeatCount="indefinite"/>
    <animate attributeName="height" begin="0s" dur="1.3s"
             fill="freeze" from="100" to="300" repeatCount="indefinite"/>
    
    
  </rect>
  <!-- Set up a new user coordinate system so that
        the text string's origin is at (0,0), allowing
        rotation and scale relative to the new origin -->
  <g transform="translate(100,100)" >
    <!-- The following illustrates the use of the 'set', 'animateMotion',
         'animate' and 'animateTransform' elements. The 'text' element
         below starts off hidden (i.e., invisible). At 3 seconds, it:
           * becomes visible
           * continuously moves diagonally across the viewport
           * changes color from blue to dark red
           * rotates from -30 to zero degrees
           * scales by a factor of three. -->
    <text id="TextElement" x="0" y="0"
          font-family="Verdana" font-size="35.27" visibility="hidden"  >
      Buy our crap!
      <set attributeName="visibility" to="visible"
           begin="0s" dur="1.3s" fill="freeze" repeatCount="indefinite"/>
      <animateMotion path="M 0 0 L 100 100"
           begin="0s" dur="1.3s" fill="freeze" repeatCount="indefinite"/>
      
      <animateTransform attributeName="transform"
           type="rotate" from="-30" to="0"
           begin="0s" dur="1.3s" fill="freeze" repeatCount="indefinite"/>
      <animateTransform attributeName="transform"
           type="scale" from="0.5" to="2" additive="sum"
           begin="0s" dur="1.3s" fill="freeze" repeatCount="indefinite"/>
    </text>
  </g>
</svg>

但我想要的是为矩形分配一个随机颜色值(类似于“rgb(random #,random #,random #)”)。

我该如何做才能确保每种颜色都是可能的结果?

最佳答案

let refreshRate = 1300;

function rand(max){
  return Math.floor(Math.random() * (max+1));
};

setInterval(function(){

document.getElementById("RectElement").setAttribute("fill","rgb("+rand(255)+", "+rand(255)+", "+rand(255)+")");

},refreshRate);

关于javascript - 如何将 svg "rgb()"属性的随机数值放入 "fill"中?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60858893/

相关文章:

jquery - 如何在点击功能中使用动画更改元素的背景颜色?

android - 如何动画 ListView 展开和折叠

javascript - 将图像一层层堆叠

javascript - Onclick 没有被注册,一直告诉我它是未定义的

javascript - 在js中迭代一个数组,同时仅将整数复制到另一个数组

JavaScript 函数虽然已加载但未定义

html - 在 CSS 中创建挖空透明边框

javascript - 背景图片CSS不显示

javascript - 复制 Google+ 蓝色箭头广告

php - 消除ajax搜索中的空白