ホームページ >ウェブフロントエンド >CSSチュートリアル >CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

青灯夜游
青灯夜游転載
2022-06-13 10:17:242475ブラウズ

この記事では、CSS3 の新機能 object-view-box 属性を深く理解し、新しい属性の役割と使用法について説明します。皆様のお役に立てれば幸いです。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

開発中、私は常に、画像をトリミングして必要な方向に配置できるネイティブ CSS 方法があればいいのにと思っていました。これは、後で説明するように、追加の HTML 要素とさまざまな CSS プロパティを使用することで実現できます。

この記事では、今年の初めに Jake Archibald によって提案された新しい CSS プロパティ object-view-box について説明します。これにより、<video></video> など、置換された HTML 要素を切り取ったりサイズ変更したりすることができます。 [推奨される学習: css ビデオ チュートリアル ]

質問

以下の例には、トリミングする必要がある画像があります。画像の特定の部分のみが必要であることに注意してください。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

現時点では、次のいずれかの方法でこの問題を解決できます。

  • <img alt="CSS3 の新しい属性 object-view-box について 1 つの記事で学習します" > を使用し、追加の要素でラップします。
  • 画像を background-image として使用し、位置と位置を変更します。 size

追加の要素でラップされています

これは、この問題を解決する一般的な方法です。手順は次のとおりです:

  • 画像を別の要素で囲みます (この場合は <figure></figure>)。
  • 追加 position:relativeoverflow:hidden
  • 画像に position:absolute を追加し、配置を変更しましたこの結果を達成するためにサイズ値が調整されました。
<figure>
    <img src="img/brownies.jpg" alt="">
</figure>
figure {
    position: relative;
    width: 300px;
    aspect-ratio: 1;
    overflow: hidden;
    border-radius: 15px;
}

img {
    position: absolute;
    left: -23%;
    top: 0;
    right: 0;
    bottom: 0;
    width: 180%;
    height: 100%;
    object-fit: cover;
}

画像を背景として配置

このソリューションでは、

を使用して画像を背景として設定し、位置とサイズを変更します。価値。
<div class="brownies"></div>
.brownies {
  width: 300px;
  aspect-ratio: 3 / 2;
  background-image: url("brownies.jpg");
  background-size: 700px auto;
  background-position: 77% 68%;
  background-repeat: no-repeat;
}

それは問題ありませんが、上記の内容を <img alt="CSS3 の新しい属性 object-view-box について 1 つの記事で学習します" > に適用したい場合はどうすればよいでしょうか?それが object-view-box の機能です。

Object-View-Box の紹介

属性 object-view-box Chrome 104 でサポートされる可能性があります。 Chrome Canary で利用できるようになりました。

CSS 仕様による (https://drafts.c​​sswg.org/css-images-4/#the-object-view-box)

object-view-box 属性は、要素のコンテンツをズームまたはパンする <svg viewbox></svg> 属性と同様に、要素の「ビュー ボックス」を指定します。

この属性の値は <basic-shape-rect> = <inset> | <rect> | <xywh></xywh></rect></inset></basic-shape-rect> 。この記事のデモでは、inset() の使用法に焦点を当てます。

この問題に戻りましょう。

object-view-box を使用すると、inset を使用して 4 つの側面 (上、右、下、左) から長方形を描画し、object-fit を適用できます。変形を避けるために をカバーしてください。

<img src="img/brownies.jpg" alt="">
img {
    aspect-ratio: 1;
    width: 300px;
    object-view-box: inset(25% 20% 15% 0%);
}

これはどのように行われますか?下を見てみましょう。

画像の固有サイズ

固有サイズは、デフォルトの画像の幅と高さです。作業している画像サイズは 1194 × 1194 px.

img {
    aspect-ratio: 1;
    width: 300px;
}

です。上記の CSS を使用すると、画像のレンダリング サイズは 300×300px になります。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

# 私たちの目標は、固有の画像上に長方形を描くことです。これを行うには、

inset()values を使用します。

inset の使用

inset()値は元の画像の幅と高さに基づくため、トリミングされた画像になります。画像。これは、margin または padding の処理と同様に、埋め込み四角形を描画し、4 つのエッジを制御するのに役立ちます。

inset 値はインセット四角形を定義します。 margin または padding で行ったのと同じように、4 つのエッジを制御できます。以下の例では、カードのすべての端に 20px のインセットがあります。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

オブジェクト ビュー ボックスに戻る:

img {
    aspect-ratio: 1;
    width: 300px;
    object-view-box: inset(25% 20% 15% 0%);
}

上記の背後にあるもの、値は次のとおりです。

25%、20%、15%0% はそれぞれ上辺、右辺、下辺、左辺を表します。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

修复图像失真

如果图像的尺寸是正方形的,那么裁剪后的结果将是变形的。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

这可以使用 object-fit 属性来解决。

img {
    aspect-ratio: 1;
    width: 300px;
    object-view-box: inset(25% 20% 15% 0%);
    object-fit: cover;
}

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

放大或缩小

我们可以使用 inset 来放大或缩小图像。根据我的测试,过渡或动画不能与object-view-box工作。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

我们也可以用一个负的 inset 值来缩小。

CSS3 の新しい属性 object-view-box について 1 つの記事で学習します

想象一下,这对于能够缩放图像是多么有用,而不需要用一个额外的元素来包装它。

事例

地址:https://codepen.io/shadeed/pen/yLvXJRd

期待这个新的属于尽快来了!

作者:ishadeed 

来源:ishadeed

原文:https://ishadeed.com/article/css-object-view-box/

(学习视频分享:web前端

以上がCSS3 の新しい属性 object-view-box について 1 つの記事で学習しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はsegmentfault.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。