6
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

PleasanterAdvent Calendar 2019

Day 9

OSSのプリザンターにSVGテキストアニメーションを入れてみた!

Last updated at Posted at 2019-12-08


SVGとCSSの勉強がてらプリザンターで遊んでいたら割と良さげなものが出来てしまったのでサクッとまとめていこうかなと思います。 #プリザンターとは? プリザンターとは株式会社インプリムが開発しているオープンソースのWebデータベースです。 データ管理やら業務アプリがマウス操作だけ(ノンプログラミング)でサクッと作れてしまう超有能なプラットフォーム(**しかもOSSなので無料という!**)なのですな。
[オープンソースで脱エクセル!Pleasanter公式サイト](https://pleasanter.org/)
本体コードも自由に変えられるし、スタイルやスクリプト等の拡張機能も豊富なので個人的には勉強した内容を試す場としても最適だと思うんですよね~。 # SVGテキストアニメーションを入れてみた! ということで、アニメーションを入れていきましょう!

"Hello, Pleasanter!"の表示

Implem.Pleasanter/Implem.Pleasanter/Models/Sites/SiteUtilities.csのSiteTopメソッドに追記しています。

コピー用として追記した赤枠の部分を以下に記載します。

Implem.Pleasanter/Implem.Pleasanter/Models/Sites/SiteUtilities.cs
Svg(
    id: "helloPleasanter",
    action: () => hb
        .SvgText(
            text: "Hello, Pleasanter!",
            x: 270,
            y: 300),   
    _using: !siteConditions.Any());

あとでCSSでいじるためにidを"helloPleasanter"と設定しています。
x、y項目は位置を、_using項目は表示する条件を表しています。

アニメーション

Implem.Pleasanter/Implem.Pleasanter/Styles/Site.cssに追記しています。

Implem.Pleasanter/Implem.Pleasanter/Styles/Site.css
#helloPleasanter {
    width: 2000px;
    height: 1000px;
}

#helloPleasanter text {
    stroke: black;
    fill: black;
    font-size: 150px;
    font-style: italic;
    stroke-dasharray: 1400px;
    stroke-width: 1px;
    -webkit-animation: stroke-anim 8s linear;
    animation: stroke-anim 8s linear;
}

@-webkit-keyframes stroke-anim {
    0% {
        stroke-dashoffset: 1400px;
        fill: transparent;
    }
    
    50% {
        fill: transparent;
    }
 
    100% {
        stroke-dashoffset: 0%;
        fill: black;
    }
}

@keyframes stroke-anim {
    0% {
        stroke-dashoffset: 1400px;
        fill: transparent;
    }
    
    50% {
        fill: transparent;
    }

    100% {
        stroke-dashoffset: 0%;
        fill: black;
    }
}

stroke-dasharrayだけだと破線になってしまうので、stroke-dashoffsetでその破線の位置を動かしていきます。keyframesが100%に近づくとともにstroke-dashoffsetを0%にしていくことで最終的に文字が出来上がるという流れですな。
おまけにfill: blackで塗りつぶすという感じ。

(よくよく思ったんですが、これkeyframesの50%部分は書く必要なかった気もしますがそこはまあ良いとしましょうww)

おわりに

以上でSVGテキストアニメーションの内容は終わりです。
上手く動くとこんな感じのアニメーションになるはず!
SVGアニメーション.gif


今後はこれを応用して手書きの似顔絵っぽいやつ→その人の写真が出る的なのも作ってみたいな~と思っています。
ではでは!また!
6
1
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
6
1

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?