⇤ ← 2008-08-22 04:45:53時点のリビジョン1
サイズ: 4749
コメント:
|
← 2008-08-22 04:52:41時点のリビジョン2 ⇥
サイズ: 4971
コメント:
|
削除された箇所はこのように表示されます。 | 追加された箇所はこのように表示されます。 |
行 2: | 行 2: |
パスに沿った動き | . animateMotion . animate . animateColor . set ---- === パスに沿った動き === |
行 5: | 行 11: |
{{{ <use xlink:href="#動かす物体"> <animateMotion> <mpath xlink:href="#動きのパス"/> </animateMotion> </use> }}} |
|
行 6: | 行 19: |
<use xlink:href="#動かす物体"> <animateMotion> <mpath xlink:href="#動きのパス"/> </animateMotion> </use> |
---- |
行 16: | 行 23: |
アニメーションを始める時間を指定します。例えば begin="0s" |
. アニメーションを始める時間を指定します。例えば . begin="0s" |
行 20: | 行 27: |
アニメーションの長さを指定します。例えば dur="5s" |
. アニメーションの長さを指定します。例えば . dur="5s" |
行 24: | 行 31: |
アニメーションが終わったあと、物体の表示をどうするか指定します。 指定しないと、useで指定した場所に描かれます。 fill="freeze"とすると最後の場所で止まります。 |
. アニメーションが終わったあと、物体の表示をどうするか指定します。 . 指定しないと、useで指定した場所に描かれます。 . fill="freeze"とすると最後の場所で止まります。 |
行 29: | 行 36: |
繰り返しの回数を指定します。例えば repeatCount="10" 限りなく繰り返すには repeatCount="indefinite" とします。 |
. 繰り返しの回数を指定します。例えば . repeatCount="10" . 限りなく繰り返すには repeatCount="indefinite" とします。 |
行 34: | 行 41: |
動かす物体の向きを指定します。 指定しないと、もとの向きのままで動きます。 パスの向きにしたがって向きを変えるには rotate="auto" とします。 |
. 動かす物体の向きを指定します。 . 指定しないと、もとの向きのままで動きます。 . パスの向きにしたがって向きを変えるには . rotate="auto" . とします。 |
行 40: | 行 47: |
---- | |
行 44: | 行 51: |
{{{ | |
行 51: | 行 58: |
行 57: | 行 64: |
}}} | |
行 72: | 行 79: |
xlink:href="#maru" x="0" y="0" | xlink:href="#maru" x="0" y="0" |
行 77: | 行 84: |
begin="0s" dur="4s" | begin="0s" dur="4s" |
行 81: | 行 88: |
<mpath xlink:href="#path1"/> | <mpath xlink:href="#path1"/> |
行 88: | 行 95: |
いろいろなアニメーション |
---- === いろいろなアニメーション === |
行 94: | 行 101: |
<rect x="10" y="10" width="200" height="20"> <animate attributeName="width" attributeType="XML" from="200" to="20" begin="0s" dur="5s" /> </rect> |
{{{ <rect x="10" y="10" width="200" height="20"> <animate attributeName="width" attributeType="XML" from="200" to="20" begin="0s" dur="5s" /> </rect> }}} |
行 104: | 行 113: |
<rect x="10" y="10" width="200" height="20"> <animate attributeName="width" attributeType="XML" from="200" to="20" begin="0s" dur="5s" /> <animate attributeName="height" attributeType=XML" from="50" to="100" begin="0s" dur="10s" /> </rect> |
{{{ <rect x="10" y="10" width="200" height="20"> <animate attributeName="width" attributeType="XML" from="200" to="20" begin="0s" dur="5s" /> <animate attributeName="height" attributeType=XML" from="50" to="100" begin="0s" dur="10s" /> </rect> }}} |
行 113: | 行 124: |
<text x="50" y="50" style="visibility:hidden;"> <set attributeName="visibility" attributeType="CSS" to="visible" begin="5s" dur="1s" fill="freeze" /> Hello </text> |
{{{ <text x="50" y="50" style="visibility:hidden;"> <set attributeName="visibility" attributeType="CSS" to="visible" begin="5s" dur="1s" fill="freeze" /> Hello </text> }}} |
行 123: | 行 136: |
<circle cx="50" cy="50" r="30" style="fill:#fff; stroke:#000;"> <animateColor attributeName="fill" begin="5s" dur="3s" from="#880" to="#8ff" fill="freeze" /> <animateColor attributeName="stroke" begin="5s" dur="3s" form="#088" to="#000" fill="freeze" /> </circle> |
{{{ <circle cx="50" cy="50" r="30" style="fill:#fff; stroke:#000;"> <animateColor attributeName="fill" begin="5s" dur="3s" from="#880" to="#8ff" fill="freeze" /> <animateColor attributeName="stroke" begin="5s" dur="3s" form="#088" to="#000" fill="freeze" /> </circle> }}} |
行 132: | 行 147: |
<use xlink:href="#name" transform="translate(0,100)"> <animateTransform attributeType="XML" attributeName="transform" type="scale" from="1" to="2 5" begin="0s" dur="5s" /> </use> |
{{{ <use xlink:href="#name" transform="translate(0,100)"> <animateTransform attributeType="XML" attributeName="transform" type="scale" from="1" to="2 5" begin="0s" dur="5s" /> </use> }}} |
アニメーション
- animateMotion
- animate
- animateColor
- set
パスに沿った動き
物体をパスにそって動かすにはつぎのように書きます。
<use xlink:href="#動かす物体"> <animateMotion> <mpath xlink:href="#動きのパス"/> </animateMotion> </use>
animateMotionの属性
begin
- アニメーションを始める時間を指定します。例えば
- begin="0s"
dur
- アニメーションの長さを指定します。例えば
- dur="5s"
fill
- アニメーションが終わったあと、物体の表示をどうするか指定します。
- 指定しないと、useで指定した場所に描かれます。
- fill="freeze"とすると最後の場所で止まります。
repeatCount
- 繰り返しの回数を指定します。例えば
- repeatCount="10"
- 限りなく繰り返すには repeatCount="indefinite" とします。
rotate
- 動かす物体の向きを指定します。
- 指定しないと、もとの向きのままで動きます。
- パスの向きにしたがって向きを変えるには
- rotate="auto"
- とします。
アニメーションの例
青い円をパスに沿って動かすサンプルです。
<defs> <path id="path1" d="M 100 100 L 300 100 L 300 300 L 100 300 Z" /> <g id="maru"> <circle cx="0" cy="0" r="10" fill="blue" /> </g> </defs> <use xlink:href="#maru" x="0" y="0"> <animateMotion begin="0s" dur="4s"> <mpath xlink:href="#path1"/> </animateMotion> </use>
<defs>内に2つの定義があります。
1番目は<path>で形は4角形です。 どのように動くかを<path>で記述します。
2番目は<g>で形は青い円です。 動かす物体です。複雑な形でもかまいません。 <g>を使ってまとめ、名前をつけています。
</defs>より後ろにあるのが実際に表示される部分です。 ここには<use>が1つだけあります。
今回の<use>はいつもの単独タグではなく、開始タグと終了タグがあります。 動かす物体はuseの属性として指定します。ここでは
- xlink:href="#maru" x="0" y="0"
となっています。
<use>の内側に<animateMotion>が入っています。 これがアニメーションの指定です。
- begin="0s" dur="4s"
で時間の指定を0秒目から4秒目としています。
さらにその内側にある
<mpath xlink:href="#path1"/>
でパスを参照し、動きの線を指定しています。
この<use>全体の意味は 「図形maruを0秒目から4秒目の間に、path1にそって動かす」 になります。
いろいろなアニメーション
動きだけでなく、大きさを変えたり、向きを変えるなどいろいろなアニメーションが可能です。
サンプル1
<rect x="10" y="10" width="200" height="20"> <animate attributeName="width" attributeType="XML" from="200" to="20" begin="0s" dur="5s" /> </rect>
長方形の幅を200から20までだんだん小さく変化させるものです。 attributeNameでどの属性を変化させるのか指定し、 値はfromとtoで、時間はbeginとdurで指定します。
サンプル2
<rect x="10" y="10" width="200" height="20"> <animate attributeName="width" attributeType="XML" from="200" to="20" begin="0s" dur="5s" /> <animate attributeName="height" attributeType=XML" from="50" to="100" begin="0s" dur="10s" /> </rect>
animateを2つ使って、widthとheightを別々に変化させています。
サンプル3
<text x="50" y="50" style="visibility:hidden;"> <set attributeName="visibility" attributeType="CSS" to="visible" begin="5s" dur="1s" fill="freeze" /> Hello </text>
一定時間後にHelloと表示します。 animateではなくsetを使って、属性の値を変えています。
サンプル4
<circle cx="50" cy="50" r="30" style="fill:#fff; stroke:#000;"> <animateColor attributeName="fill" begin="5s" dur="3s" from="#880" to="#8ff" fill="freeze" /> <animateColor attributeName="stroke" begin="5s" dur="3s" form="#088" to="#000" fill="freeze" /> </circle>
animateColorを2つ使って、fillとstrokeを変化させています。
サンプル5
<use xlink:href="#name" transform="translate(0,100)"> <animateTransform attributeType="XML" attributeName="transform" type="scale" from="1" to="2 5" begin="0s" dur="5s" /> </use>
5秒後にscale(2 5)に拡大されます。