125
115

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

CSSAdvent Calendar 2022

Day 14

【CSS】ホバーするとキラキラ光って見えるカードを作る

Last updated at Posted at 2022-11-28

はじめに

みなさんは、どんなトレーディングカードゲームをやったことがありますか?

僕が触れたことがあるトレーディングカードゲームは、遊戯王デュエマポケカくらいですが、他にも、1993年からあるマジック:ザ・ギャザリングや最近のワンピース などなどいろいろなトレーディングカードゲームが存在します。

それらのほとんどのトレーディングカードゲームには、カードにレアリティと呼ばれる希少度の段階があるため、カードゲームで対戦するだけでなく、コレクションされたり、高額になったりと奥が深いです。

今回は、そんなカードゲームのレアリティを表現をCSSとJavaScriptを使って、ホバーするとキラキラ光って見えるカードを作っていこうと思います。

完成形

完成形は、↓こんな感じです。

See the Pen Light Card by でぐぅー | Qiita (@sp_degu) on CodePen.

hoverしたところにハイライトが当たったり、マウスの位置に合わせて、グラデーションが移動したりすることで、キラキラ光って見えるように表現しています。

また、CSSのプロパティの観点では、repeating-radial-gradientlinear-gradientmix-blend-modeを使って、いい感じに画像を加工していて、キラキラ光って見えるように表現しています。

詳しい作り方は、これから解説していきます。

作り方

1. 構成を理解する

まずは、今回作成するキラキラ光って見えるような表現の構成解説していきます。

image1.png

キラキラ光って見えるような表現は、↑このように「画像層」「パターン層」「カラー層」「ハイライト層」の4層で作成しています。これらの層で、mix-blend-mode を使ってそれっぽくしています。

  • 画像層
    • 画像層は、キラキラ光らせたい画像を置きます。
  • パターン層
    • パターン層は、光らせる模様を置きます。 SVG等の画像でも可能です。
  • カラー層
    • カラー層は、光らせるグラデーションを置きます。 複雑なグラデーションだとそれっぽくさが増します。
  • ハイライト層
    • ハイライト層は、ホバーした時のハイライトを作る層です。

2. HTMLを作成する

1の構成になるように、HTMLの構造を以下のように作成していきます。

sample.html
<div class="card-wrapper">
  <img class="card" src="../../image.jpeg" />
  <div class="card pattern"></div>
  <div class="card color"></div>
  <div class="card highlight"></div>
</div>

<img>::before ::after :hover を駆使しても、いい感じに作ることができますが、
わかりやすさ重視で <div> で分けて作成しています。

また、:hover している位置を取得して輝きの表現をするため、
位置取得するための <div class="card-wrapper"> でラップします。

3. 各層を重ねて、形を整える

次に画像層パターン層カラー層ハイライト層をCSS Gridと position: absolute; を使って重ねて、形を整えて行きます。

sample.css
/*形を整える*/
.card {
  aspect-ratio: 3 / 4;
  border-radius: 4.5% / 3.5%;
  box-shadow: 0px 4px 8px rgba(0, 0, 0, .2);
  height: 100%;
  position: absolute;
  width: 100%;
}

.card-wrapper {
  aspect-ratio: 3 / 4;
  display: grid;
  height: calc(100% - 32px);
  max-width: 100%;
  place-items: center;
  position: absolute;
}

/*真ん中に持ってきている*/
body {
  background-color: #212529;
  display: grid;
  height: calc(100vh - 32px);
  margin: 0;
  padding: 16px;
  place-items: center;
  position: relative;
  width: calc(100% - 32px);
}

 

4. パターン層とカラー層のCSSを作成する

次にパターン層カラー層のCSSを作成します。

パターン層

sample.css
.pattern {
  background: repeating-radial-gradient(circle at -150% -25%, #fff, #777 3px, #fff 3px);
  background-position: 50% 50%;
  background-size: 120% 120%;
  mix-blend-mode: color-dodge;
  opacity: 0.3;
}

パターン層は、repeating-radial-gradient を使って、白黒のパターンを作成します。
また、:hoverbackground-position で移動させるため、 background-size を120%にしています。

mix-blend-modeopacity で、画像を加工すると、以下のように画像が加工されます。
image2.png

カラー層

sample.css
.color {
  background: linear-gradient(115deg, transparent 20%, #40A4BF 30%, transparent 48% 52%, #404FBF 70%, transparent);
  background-position: 50% 50%;
  background-size: 200% 200%;
  mix-blend-mode: overlay;
}

カラー層は、linear-gradient を使って、グラデーションを作成します。
また、:hoverbackground-position で移動させるため、 background-size を200%にしています。

mix-blend-modeで、画像を加工すると、以下のように画像が加工されます。
image3.png

5. マウスの位置に応じた、アニメーションを作成する

カード内のマウスの位置を取得する

sample.js
console.clear()

const CARD = document.querySelector('.card-wrapper')

const UPDATE = ({ x, y }) => {
  const BOUNDS = CARD.getBoundingClientRect()
  const posX = x - BOUNDS.x
  const posY = y - BOUNDS.y
  const ratioX = posX / BOUNDS.width
  const ratioY = posY / BOUNDS.height
  CARD.style.setProperty('--ratio-x', ratioX)
  CARD.style.setProperty('--ratio-y', ratioY)
}

document.body.addEventListener('pointermove', UPDATE)

addEventListener'pointermove' で、マウスポインターの位置を取得します。

また、マウスポインターがカード内のどの位置にあるのかをいい感じに計算しした値を
cssの変数(--ratio-x--ratio-y)で使えるように、.card-wrapperのstyle属性に定義して、います。

以下の画像のように計算しています。
image4.png

カード内の要素がマウスの位置に応じて動くようにする

sample.css
.card-wrapper:hover > .pattern {
  background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}

.card-wrapper:hover > .color {
  background-position: calc(50% + (var(--ratio-x) * -50%)) calc(50% + (var(--ratio-y) * -50%));
}

.card-wrapper:hover > .highlight {
  background: radial-gradient(circle at calc(var(--ratio-x) * 100%) calc(var(--ratio-y) * 100%), hsl(0 0% 100% / 0.2), transparent 50%);
  background-repeat: no-repeat;
}

.pattern.colorは、マウスポインターの位置に応じて、background-positionの位置を変更しています。

.highlightは、radial-gradient の中心点をマウスポインターの位置にしてマウスに追従する形にしています。

完成

このようにhoverしたところにハイライトが当たったり、マウスの位置に合わせて、グラデーションが移動したりすることで、キラキラ光って見えるように表現しています。

See the Pen Light Card by でぐぅー | Qiita (@sp_degu) on CodePen.

まとめ

今回は、トレーディングカードゲームのレアリティを表現のようなホバーするとキラキラ光って見えるカードを
CSSとJavaScriptを使って作りました。

キラキラ光って見えるカードの構成イメージがわかるようにシンプルになるように意識して作りましたが、ここからパターン層のパターンをSVG等の画像にして複雑なものにしたり、カラー層のグラデーションを複雑でたくさんの色を使うことで、トレーディングカードゲームのレアリティを表現にもっとも近づくと思います。

この表現がトレーディングカードゲームのカードのweb通販のサイトや、クレジットカードの比較アフィリエイトサイトとかで、使われると見るだけで楽しいものになるのかなとかと感じました。

↓この記事のカードを立体的にアニメーションを追加するとなおクオリティが高くなります。


最後まで読んでくださってありがとうございます!

普段はデザインやフロントエンドを中心にQiitaに記事を投稿しているので、ぜひQiitaのフォローとX(Twitter)のフォローをお願いします。

125
115
3

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
125
115

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?