summaryrefslogtreecommitdiffstats
path: root/layout/reftests/svg/smil/anim-feFuncR-tableValues-01.svg
blob: 2b51091862daf20b5ad2e093e4ba6c9e8438ae65 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
<svg xmlns="http://www.w3.org/2000/svg"
     xmlns:xlink="http://www.w3.org/1999/xlink"
     class="reftest-wait">
  <title>Test animation of the &lt;number-list&gt; attribute on the 'text' element</title>
  <script xlink:href="smil-util.js" type="text/javascript"/>

  <linearGradient id="gradient">
    <stop offset="0" stop-color="black" />
    <stop offset="100%" stop-color="red" />
  </linearGradient>

  <!-- The difference between respective numbers in the effective 'from' and
       'to' lists below is carefully designed to be a factor of 3. That way
       our reference file (which checks against a one third complete animation)
       can contain whole numbers, which is necessary to avoid failure due to
       hard coded rounded numbers in the reference not matching platform
       specific rounding behaviour.
    -->


  <!-- Test calcMode="linear". -->

  <filter id="f_calcMode_linear_to" x="0%" y="0%" width="100%" height="100%">
    <feComponentTransfer>
      <feFuncR type="table" tableValues="-1 3 3 -1">

        <!-- At 1s the animVal should be "0 2 2 0". -->
        <animate attributeName="tableValues"
                 calcMode="linear"
                 begin="0s" dur="3s"
                 to="2 0 0 2"
                 fill="freeze"/>

      </feFuncR>
    </feComponentTransfer>
  </filter>
  <rect x="20" y="20" width="256" height="20" fill="url(#gradient)"
        filter="url(#f_calcMode_linear_to)"/>


  <!-- Test 'by' animation. -->

  <filter id="f_calcMode_linear_by" x="0%" y="0%" width="100%" height="100%">
    <feComponentTransfer>
      <feFuncR type="table" tableValues="-1 3 3 -1">

        <!-- At 1s the animVal should be "0 2 2 0". -->
        <animate attributeName="tableValues"
                 calcMode="linear"
                 begin="0s" dur="3s"
                 by="3 -3 -3 3"
                 fill="freeze"/>

      </feFuncR>
    </feComponentTransfer>
  </filter>
  <rect x="20" y="60" width="256" height="20" fill="url(#gradient)"
        filter="url(#f_calcMode_linear_by)"/>


  <!-- Test calcMode="paced". -->

  <filter id="f_calcMode_paced" x="0%" y="0%" width="100%" height="100%">
    <feComponentTransfer>
      <feFuncR type="table" tableValues="-1 3 3 -1">

        <!-- At 1s the animVal should be "0 2 2 0". -->
        <animate attributeName="tableValues"
                 calcMode="paced"
                 begin="0s" dur="3s"
                 values="-1 3 3 -1; 1 1 1 1; 2 0 0 2"
                 fill="freeze"/>

      </feFuncR>
    </feComponentTransfer>
  </filter>
  <rect x="20" y="100" width="256" height="20" fill="url(#gradient)"
        filter="url(#f_calcMode_paced)"/>


  <!-- Test calcMode="discrete". -->

  <filter id="f_calcMode_discrete" x="0%" y="0%" width="100%" height="100%">
    <feComponentTransfer>
      <feFuncR type="table" tableValues="0 0 0 0">

        <!-- The value should be "0 2 2 0" from 1s onwards. -->
        <animate attributeName="tableValues"
                 calcMode="discrete"
                 begin="0s" dur="2s"
                 to="0 2 2 0"
                 fill="freeze"/>

      </feFuncR>
    </feComponentTransfer>
  </filter>
  <rect x="20" y="140" width="256" height="20" fill="url(#gradient)"
        filter="url(#f_calcMode_discrete)"/>

  <script type="text/javascript">
    function doTest() {
      setTimeAndSnapshot(1, true);
    }
    window.addEventListener("MozReftestInvalidate", doTest, false);
  </script>
</svg>