ホームページ  >  記事  >  ウェブフロントエンド  >  css3の繰り返しグラデーションとは何ですか?使い方? (コード例)

css3の繰り返しグラデーションとは何ですか?使い方? (コード例)

青灯夜游
青灯夜游オリジナル
2018-11-06 10:05:074811ブラウズ

この記事の内容は、CSS3の繰り返しグラデーションとは何なのかをご紹介するものです。使い方? (コード例)。困っている友人は参考にしていただければ幸いです。

まず最初に、繰り返しグラデーションとは何ですか?

CSS3 では、線形グラデーション [linear-gradient()] と放射状グラデーション [radial-gradient()] に加えて、繰り返しグラデーションも実装できます。 css3 の繰り返しグラデーションは、次の 2 つのタイプに分類できます。

繰り返し線形グラデーション: testing-linear-gradient()

繰り返し放射状グラデーション:peeping-radial-gradient()

次に、簡単なコード例を通して、2 つの 繰り返しグラデーションがどのように使用されるかを見てみましょう

リピート グラデーション。レンダリング時、終了カラーは両方向に無限に繰り返され、その位置は最後に指定された終了カラーの位置と最初に指定された複数のシフトの位置の差になります。 。たとえば、repeat-linear-gradient(red 10px, blue 50px) は、linear-gradient(..., red -30px, blue 10px, red 10px, blue 50px, red 50px, blue 90px, ...) と同等です。最後のストップ カラーと最初のストップ カラーは常に各グループの境界で一致するため、グラデーションが同じ色で始まり同じ色で終わらない場合、鋭い遷移が生じることに注意してください。

実際、繰り返しグラデーションの構文は、非繰り返しグラデーションの構文と同じです。例:

repeating-linear-gradient(red, blue 20px, red 40px);

レンダリング:

css3の繰り返しグラデーションとは何ですか?使い方? (コード例)##

repeating-radial-gradient(red, blue 20px, red 40px);

css3の繰り返しグラデーションとは何ですか?使い方? (コード例)

repeating-radial-gradient(circle closest-side at 20px 30px, red, yellow, green 100%, yellow 150%, red 200%);

css3の繰り返しグラデーションとは何ですか?使い方? (コード例)

最初のストップ カラーと最後のストップ カラーの間の距離がゼロではないが、物理的な解像度を知るのに十分なほど小さい場合出力デバイス グラデーションをレンダリングできるほど忠実ではありませんが、効果を達成するには、グラデーションの平均色を見つけて、そのグラデーションを平均色と等しい単色イメージにレンダリングする必要があります。

最初と最後の終端カラー間の距離がゼロ (または実装の制限によりゼロに丸められる) の場合、同じ番号と終端カラーを持つグラデーションの平均色を見つける必要がありますが、最初と最後の終了色はゼロ以外の距離で停止し、残りの色はそれらの間の等間隔を維持する必要があります。次に、グラデーションを平均色と等しい単色イメージにレンダリングする必要があります。

繰り返し放射状グラデーションの終了形状の幅がゼロではなく、高さがゼロ、またはゼロに近い場合、実装はグラデーションの平均色を見つけて、グラデーションを単色でレンダリングする必要があります。平均的な色と等しい画像。

次の手順でグラデーションの平均色を見つけることができます

: 1. RGBA カラーの初期の空のリストとしてリストを定義し、合計を定義します。最初の色の長さ 最初の色と最後の色の間の距離。

2. 隣接するカラー パッチの各ペアについて、2 つのカラー パッチ間の距離を全長で割った値として重みを定義します。 2 つのエントリのリストを追加します。最初のリストは、RGBA の最初のカラーストップを表す色によって取得され、すべてのコンポーネントを重みによってスケールします。2 番目のリストは、同じ方法で 2 番目のカラーストップによって取得されます。

3. リストのエントリを合計して平均色を生成し、それを返します。

まとめ: この記事で紹介した内容は以上です。皆様の学習に少しでもお役に立てれば幸いです。

以上がcss3の繰り返しグラデーションとは何ですか?使い方? (コード例)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。