背景画像を自在に配置する
特定のHTML要素の背景に画像を配置する際は、background-positionプロパティで表示位置を指定します。
調整前のCSS コード例
section {
background-image: url(./images/star.svg);
background-position: right 10% bottom 10%;
background-repeat: no-repeat;
background-size: 40% auto;
}
HTML コード例
<section>
<h2>背景画像の位置を指定する</h2>
<p>背景に画像を配置する場合、background-positionプロパティを使います。</p>
</section>
data:image/s3,"s3://crabby-images/35d72/35d72d237bf97df701035653973c12fc3062b283" alt="表示例"
背景画像の位置の指定方法について、いくつかのパターンを交えながら解説していきます。
左右、上下、中央のみ指定する
あらかじめ用意された「left」や「center」などの値を使って、x軸とy軸の位置をそれぞれ指定する最もシンプルで手軽な方法です。
指定できる値には次の6種類があります。
向き | 値 |
---|---|
X軸 | left、center、right |
Y軸 | top、center、bottom |
値のイメージはこのようになります。
「center」は共通で使用できる値です。
data:image/s3,"s3://crabby-images/f0cb1/f0cb1b749872b0d14576543ad7dca7358ed225b7" alt="位置のイメージ"
続いて、具体的な指定例を確認していきましょう。
値を1つだけ指定する
値は1つ指定した場合はX軸、Y軸のいずれか(指定されなかった方は 「center」)となります。
CSS コード例
/* background-positioプロパティに「left」を指定 */
section {
background-image: url(./images/star.svg);
background-position: left;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/4ad7b/4ad7bf5a48a7934ff9c4005c3b2afc7c35323864" alt="表示例"
CSS コード例
/* background-positioプロパティに「bottom」を指定 */
section {
background-image: url(./images/star.svg);
background-position: bottom;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/18b22/18b226f31723f6e63d343459e61945b9306b2a10" alt="表示例"
CSS コード例
/* background-positioプロパティに「bottom」を指定 */
section {
background-image: url(./images/star.svg);
background-position: center;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/8417e/8417ee84b9eca2b7cb4fd9cc73aa7113df70a798" alt="表示例"
値を2つ指定する
値を2つ指定していきます。
X軸、Y軸のどちらから指定しても大丈夫です。
CSS コード例
/* background-positioプロパティに「right bottom」を指定 */
section {
background-image: url(./images/star.svg);
background-position: right bottom;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/3876d/3876d036f20ee90738ccbd53196767ad74d74474" alt="表示例"
CSS コード例
/* background-positioプロパティに「left top」を指定 */
section {
background-image: url(./images/star.svg);
background-position: left top;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/e397d/e397dc7445ea775a13398a1d819dae2632f9d909" alt="表示例"
数値を使って位置を詳細に指定する
背景画像の位置は上記の「left」などの値に加えて、具体的に数値で指定することもできます。
CSS コード例
/* 右から35%、下から5%の位置を指定 */
section {
background-image: url(./images/star.svg);
background-position: right 35% bottom 5%;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/60a9d/60a9d6d3af41044b152058ab936a5684d230b1b0" alt="表示例"
X軸かY軸のどちらか1つだけ指定する形でも問題ありません。
CSS コード例
/* X軸は「right」、Y軸のみ数値で下から20pxを指定 */
section {
background-image: url(./images/star.svg);
background-position: right bottom 20px;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/04d9e/04d9e9477a7689128c890369d933a35553e1a9a1" alt="表示例"
数値のみで指定することも可能です。
その場合は1つ目はX軸の指定、2つ目はY軸の指定となります。
また、それぞれで「px」や「%」のように異なる単位を指定できます。
CSS コード例
/* X軸は「right」、Y軸のみ数値で下から20pxを指定 */
section {
background-image: url(./images/star.svg);
background-position: 50% 150px;
background-repeat: no-repeat;
background-size: 40% auto;
}
data:image/s3,"s3://crabby-images/8c32a/8c32a37deea482896756352a0e8b3adbfb99546f" alt="表示例"