目次
CSS で円を分割する
ホームページ ウェブフロントエンド CSSチュートリアル JavaScript を使用せずに CSS を使用して、円を等しいサイズまたはさまざまなサイズにセグメント化するにはどうすればよいですか?

JavaScript を使用せずに CSS を使用して、円を等しいサイズまたはさまざまなサイズにセグメント化するにはどうすればよいですか?

Oct 27, 2024 am 08:54 AM

How can I segment circles into equal or varying sizes using CSS without JavaScript?

CSS で円を分割する

CSS では、border-radius プロパティを使用して円形を作成できます。ただし、これらの円にセグメントを追加するには、さらに調査する必要があります。 JavaScript を使用せずにこれを実現する方法を詳しく見てみましょう。

<h3>等しいサイズのセグメント</h3>

セグメントが HTML 要素を必要とせず、同じサイズであれば、次のことが可能です。 SCSS を利用して conic-gradient() のストップのリストを生成します。カスタム SCSS 関数を作成してストップを均等に分散できます:

<code class="scss">@function stops($c) {
    $n: length($c); // number of slices
    $p: 100%/$n; // slice angle as a % of circle
    $l: (); // list of stops, initially empty
    
    @for $i from 1 through $n {
        $l: $l, nth($c, $i) 
            if($i &gt; 1, 0%, unquote(''))
            if($i &lt; $n, round($i*$p), unquote(''))
    }
    
    @return $l
}</code>
ログイン後にコピー

この関数を使用すると、conic-gradient() 内のセグメントの色と角度を定義できます:

<code class="css">.pie {
    width: 20em; /* desired pie diameter */
    aspect-ratio: 1; /* square element */
    border-radius: 50%; /* disc shape */
    background: conic-gradient(stops(#f94144, #f3722c, #f8961e, #f9c74f, 
        #90be6d, #43aa8b, #577590))
}</code>
ログイン後にコピー

これにより、同じサイズのセグメントが円周上に均等に配置された円が作成されます。

<h3>さまざまなサイズのセグメント</h3>

セグメントにさまざまなサイズが必要な場合は、同様の戦略を引き続き利用できます。 stop() 関数は、各セグメントの開始角度と終了角度を定義する追加のパラメーターを受け取るように変更できます。グラデーション定義内で、各カラー ストップに対してこれらの角度を指定できます。

さらに、セグメントにコンテンツやアニメーションを含める必要がある場合は、HTML 要素を使用し、CSS 変換を使用して円内に配置できます。サイズや角度を細かく調整することで、重なったように見えるセグメントを作り、複雑なデザインを表現することができます。

以上がJavaScript を使用せずに CSS を使用して、円を等しいサイズまたはさまざまなサイズにセグメント化するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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

ホットな記事タグ

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

WordPressブロックと要素にボックスシャドウを追加します WordPressブロックと要素にボックスシャドウを追加します Mar 09, 2025 pm 12:53 PM

WordPressブロックと要素にボックスシャドウを追加します

Smart Forms Frameworkを使用してJavaScript連絡フォームを作成する Smart Forms Frameworkを使用してJavaScript連絡フォームを作成する Mar 07, 2025 am 11:33 AM

Smart Forms Frameworkを使用してJavaScript連絡フォームを作成する

満足している属性を持つインラインテキストエディターを作成します 満足している属性を持つインラインテキストエディターを作成します Mar 02, 2025 am 09:03 AM

満足している属性を持つインラインテキストエディターを作成します

GraphQLキャッシングの使用 GraphQLキャッシングの使用 Mar 19, 2025 am 09:36 AM

GraphQLキャッシングの使用

スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティス スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティス Mar 08, 2025 am 09:45 AM

スクリーンリーダーの分解:アクセス可能なフォームとベストプラクティス

最初のカスタムSvelteトランジションを作成します 最初のカスタムSvelteトランジションを作成します Mar 15, 2025 am 11:08 AM

最初のカスタムSvelteトランジションを作成します

5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する 5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する Mar 04, 2025 am 10:22 AM

5つの最高のPHPフォームビルダー(および3つの無料スクリプト)を比較する

node.jsとexpressのMulterを使用してファイルアップロードします node.jsとexpressのMulterを使用してファイルアップロードします Mar 02, 2025 am 09:15 AM

node.jsとexpressのMulterを使用してファイルアップロードします

See all articles