原森情報技術研究所 WEBコンテンツ企画・制作・運営・サポート / 兵庫県 神戸市 明石市 /

div図形

css3のみでdiv図形実験

サンプル1

四角

四角
四角
四角

divに幅・高さ・ボーダー・背景色を指定した普通の四角

ひし形・平行四辺形

ひし形
2
3
4

四角を45deg回転しテキストを逆回転
2 : skewY(15deg) 3 : skewX(15deg) 4 : skew(15deg,15deg)

円・楕円

1楕円
2楕円
3楕円

border-radiusで角を[50%] 正方形は円、長方形は楕円。2 : 角を[100% 0] 正方形はレモン型の楕円 1の楕円は葉っぱの形

サンプル2

台形

四角
四角
台形
台形

ボーダーを太くすると台形が現れる。4 : 下ボーダーだけ太くして左右ボーダーの色を透明に

三角形1

台形の幅を0で三角。w:50px h:25px
bottom、top、right、leftの選択でいろんな方向に

三角形2

長さをボーダーの幅で調節。1:左右が30 下が60。2:左30 下60の直角三角形などをベースにborderの tbrl を調節

サンプル3

三角を重ねてみる (before・afterで最大3つ)

before、afterで三角を作って重ねてみた例

矢印ボックス

div
div
div
div

三角と四角の組み合わせ

六角・八角

div
div
div
div

上下に三角や台形

サンプル4

吹き出し1

上三角
下三角
右三角
左三角

divにbefore等で三角をくっつけた形

吹き出し2

上三角
下三角
右三角
左三角

divにbefore等で三角をくっつけた形

リボン等

リボンタイトル
ネームプレート
折れ曲り

divにbefore・after等で三角をくっつけた形

サンプル5

div1個で複数の円や四角を表示(boxshadow)

上から円のグラデ、四角のグラデ、円の色違い、四角の色違い

div1個で複数の四角を上下左右に配置

上下左右に影を配置

div1個で複数の円を上下左右に配置

円にして、上下左右に影を配置

サンプル6

div1個でローディングイメージ風

円にして、色・位置・サイズ調整でローディングイメージとか

div1個でローディングイメージ風2

四角とrotate 45deg before の組み合わせ

div1個でローディングイメージ風3

before after で無理やり長方形のローディングイメージ。右側は分かりやすくしたもの

サンプル7

divとbox-shadowでドット絵アイコン画像

box-shadowでお絵かき ドットのBOX幅を 4px、2px、1px
※原森個人のwebサイトでIE3N4時代から使っている火星の人面岩をパロディしたロゴアイコンです。

divとbox-shadowでドット絵アイコン画像2

ドット想定のdivボックスを円にしたもの。2px、1pxは小さすぎて円にならなかった。

divとbox-shadowでドット絵アイコン画像3

その他のアイコンお絵かき
[1] [2] [3] [4] [5]

div図形についての考察

div図形で使えそうなものは、ちょっとした説明を表示するための「吹き出し」や柔らかい雰囲気のための角丸ボックス装飾程度ではないかと思う今日この頃…

勝手に命名している『div図形』とは、divやspanタグの四角いボックスとそのbefore・afterなどを三角・円・楕円などに変形したものを組み合わせ、四角以外の形を表現・装飾したものです。(検索したら、css図形、cssで図形を描く、cssで図形表現、のように呼び方はいろいろです)

利用してるCMS等のタグ・css・jsなどで制限の多い個人ブログ・スタッフブログについては、簡易的な装飾としてリボンタイトルや丸ボックスでボタンリンク、ひし形ボックスで番号表示など、ちょっとした装飾のためにdiv図形のテクニックが使われているのを見かけたりします。
ですが、デザイナーがちゃんとデザインし、お金もらってプロの仕事として制作・納品するWEBサイトでは、div図形の装飾だけではチープな印象になる場合もあるかもしれません。(あくまで個人の感想です)

CSSのみでいろんな形のアイコンを表現して紹介しているサイトもあったりしますが、それがHTML的に意味のないdivやspanを大量に使っているものだった場合は、アイコン画像を貼るのが良いかもしれません。
HTML5対応ブラウザの場合、イラストレータで描いたイラストや複雑な図形をSVGで表示させることも可能なので、そういう技術を使うとプロの仕事としてアピールできるかもしれない、と思ったりもします。(あくまで個人の感想です)

文字表示のアニメなどは、近年のwebテクニック系ブログ記事のよく見るタイトルネタ「実は意外と簡単な方法で●○ができるんです、続きはグ★シーで…」と同様の印象としてよく見かける「jQueryで簡単に●○できる」について、jQueryプラグインをそのまま使っているものがあったりしますが、お金もらって受注して作るサイトに面識のない人が作ったjsプラグインを入れ、どこの国の人やねん、という雰囲気のコピーライトが書いてあったりするのが微妙な気がします…今は商用利用フリーとか書いてあっても、権利を買い取ったりした某国の人がいきなり●○年から有料にしてますので金払うアル、なんていきなりメールを送ってくる可能性が本当にないのか不安で夜も眠れません…。(あくまで個人の感想です)

また、時々CSSのテクニックサイトで、ボックスに特殊な影をつける演出で、before や after で描いた影を z-index:-1; でボックスの背後に配置する例を見かけますが、ページ内にはいろんな要素が重ねられていることも多く、z-index:-1 のテクニックはよく調べておかないと「z-index 効かない」と検索することになりかねないかと思われます。
単純にどこでも使えると思って配置すると、親ボックスの下に配置されてしまい、見えなくなってしまうからです。
なので、cssのテクニック紹介記事として、「z-index:-1」を使うものは、木(パーツの作り方)だけを見てて森(webサイト全体の制作)を見てない印象があるため、記事にされる方は上手くいかない場合と対処法についての注釈があるといいかもしれません。
(※20181010追記)どこでも使える方法について判明しましたので、現在記事を用意しています。

昔はわざわざ四隅に角丸画像を配置し、さらにテーブルレイアウトしていた「角丸デザイン」が、border-radius のおかげで簡単に作れるようになっているので、角丸装飾はCSSでやるのが正しいと思われます。

また、マウスホバーでツールチップ(フキダシのようなもの)を表示し、ボタンメニューの簡単な説明文を表示する、というものについては、「jQueryで簡単に」よりもCSSのみでできるようになりましたので、そのためのCSS装飾としてフキダシ風のdiv図形は案外許されるのではないかと思ったりもします。(これも背景画像でうまくやった方が奇麗な場合も…)

サンプルについて

サンプル1、2で基本の図形、3以降でそれらを組み合わせた例を表示してみました。あくまでお遊び的なものとして。

また、divは一つだけで、before・afterにより最大3つの図形で装飾しています。(1要素のために複数のspan等をなるべく使わないという条件で作っています)

最後に、今回サンプル作ってる途中で思いついた、divは一つだけで、before・afterにより最大3つの図形を組み合わせる以外に、同じ形のもの(四角なら四角、円なら円)などを影(boxshadow)で表現することができる、と言う例をサンプル5~6で例示しています。

また、boxshadowの応用でドット絵アイコンを描くなどのお遊びネタを、サンプル7で例示しています。
boxshadowでアイコン作成については、(画像作る方が早いので) 実際のwebサイトでは使わないものだと思ったりしますので、暇つぶしのお遊びネタになります。
根気と集中力でCSS記述するのはしんどすぎるので、ドット塗りしてお絵かき後にソースを自動作成するようなjavascriptツールを作って、サンプル7などの画像を作ってみました。
(ツールは描いた絵を復活の呪文でバックアップする機能を付加したり、最初からドット塗りするのが面倒になったので、画像を読み込んで色データを取得して自動作成できるようにしたりで、案外高機能だったりしますが、普通はboxshadowでアイコン作ったりしないかと思いますので、非公開にしています)

原森の個人的な考察まとめ

制作納品仕事として、cssで図形を組み合わせて装飾するテクニックで使えるものは、ツールチップのフキダシと、そのままcssで実現する角丸ボックス、などではないかと思います。(個人的に)

制作会社がデザイン・制作・納品する企業向けサイトなどではcssで無理やりリボンや付箋などを描いて装飾するより、ちゃんと意図を持ってデザインした絵を使う方がプロっぽいと思います。
高いお金を払ってデザインしてもらったのに、どこかで拾ってきたcss図形をコピペしてたりすると、残念な気持ちになってしまうかもしれません。(デザインにマッチしていればOKですけど)

div図形(cssで図形描画)は、個人ブログやサイト内の特に意味を持たない部分ちょっとだけ使うお遊びネタ程度にしておくのがいいかと思われます。なので、必死で図形を組み合わせて何かを作り出そうとするよりは、絵を書いた方が早いと思います。
→ div や span でピクトグラムやアイコン作って紹介しているサイトもありますが、あくまでweb制作者がテクニックの競い合いを楽しむためだけのお遊びネタだと思います。

絵で書いて貼るだけで済むものを div や span タグ増殖させてまでやろうしたり、cssだけでできるものをjQueryプラグイン入れてまでやるのは本末転倒ではないか、などと思ったりします。(あくまで個人の感想です)

主なcssやテクニック

border-radius
ボックスの角を丸くするCSS。最新版FF以外はベンダープレフィックスが必要。(2014.11.23 現在)
transform:rotateZ(Rdeg)
Z軸方向に(R)deg回転させる。
transform:skewX(Rdeg)
X軸方向に角度(R)degで傾斜変形
transform:skewY(Rdeg)
Y軸方向に角度(R)degで傾斜変形
transform:skew(Rdeg,rdeg)
X軸方向に角度(R)deg、Y軸方向に角度(r)degで傾斜変形
rgba(0,0,0,0)
色指定でα値を0にしているので、透明になる。※transparent も透明指定だが、色指定する方が確実かと思われる。

ページトップへ

top > css3実験 > 
div図形

Transition ソース作成ツール ver1.0
Animation ソース作成ツール ver1.0
keyframes ソース作成ツール ver2.0
Transform ソース作成ツール ver1.0
ベンダープレフィックスを付加する ソース作成ツール ver1.0
進数変換ツール ver1.0
positionソース作成支援ツール ver1.0
liタグを自動付加するソース作成支援ツール ver1.0
checkbox radio ソース作成支援ツール ver1.0
連番ソース作成支援ツール ver1.0
10進←→16進カラー変換ツール ver1.0
セーフカラーマップ ver1.0
黄金/白銀比率計算ツール ver1.0

サブメニューがスライドする効果実験 / メニューは最初すべて非表示実験
記事や本文の指定id付き p or span 等で挟んだ時にアニメ効果js実験
SVGで立体表現実験
拡大画像を表示する(lightbox風)効果実験

フォーム入力用の演出
パララックス効果実験
ページめくり効果実験(複数ページ版 / ie10対応)
記事が上から降りてくる効果実験
記事ボックスが回転する効果実験

divが自動で回転アニメ 四角形
divが自動で正面向き回転アニメ
divがホバー方向別に異なるtransform
ボタンマウスオーバー方向で異なる入力インターフェイス実験

div図形
メニューいろいろ実験1/縦メニュ(サブなし)
メニューいろいろ実験2/横メニュー
選択表示 div box
cssだけでフキダシツールチップ表示
css3でアニメーション部品
css3でdivbox装飾
css3 + html5 でキャプション表示
css3でlist装飾
css3でホバーアニメボタン
css3で文字装飾
css3でflash代替キャッチアニメ

カテゴリMENU
お問い合せ