検索
ホームページウェブフロントエンドCSSチュートリアル完全な CSS 円セクターを作成する方法

最近、私は CSS ジャックポット ルーレットを構築しました。これは、針が指すセクターを動的に強調表示するという、ユニークな課題を提示したプロジェクトです。 ルーレットには応答性と可変セクター数が必要で、単純な画像や SVG ソリューションは除外されました。 幾何学的な計算は不可欠でした。

私のアプローチでは、円の中心を中心にスパンを回転し、半径に沿ってクリップする必要がありました。 以下に詳しく説明されている初期設定 (さらに下のリンクから完全に入手できます) には、基本的なスタイル設定とスパンの増分回転 (360/sectors.length 度) が含まれていました。 この段階ではまだ視覚的に洗練されていませんでした。

セクターを強調表示するには、半径と角度を指定した円上の 2 点間の距離が必要でした。 式は次のとおりです:

<code>2 * radius * Math.sin(θ / 2)</code>

ここで、θ はラジアン単位の角度です。 使用するために変換されました:

<code>2 * radius * Math.sin(Math.PI / sectors.length)</code>

次に、重複を防ぐためにセクターのクリッピングに取り組みました。私の最初の試みは、斜めのクリップパスを使用しました:

<code>clip-path: polygon(100% 0, 0 50%, 100% 100%);</code>

これは多くのセクターで適切に機能しましたが、以下に示すように、セクターが少なく、特に 3 つだけのセクターでは欠陥が明らかになりました。

How to create perfect CSS circle sectors

解決策には、スパンと円の間の交点を計算し、その点から中心までクリッピングすることが含まれていました。これによりクリッピングが修正されました:

How to create perfect CSS circle sectors

研究により、交点を結ぶ線によって水平線上に作成されるセグメントの式が得られました。

中央セグメント:

<code>radius * (1 - Math.cos(θ / 2))</code>

外側セグメント:

<code>radius * Math.cos(θ / 2)</code>

(θはラジアン単位)

これらのセグメント間の比率によってクリッピング ポイントが決まり、次のことが起こります。

<code>const clipPosition = Math.cos(Math.PI / sectors.length) * 100</code>

修正された clip-path:

<code>{
  'clip-path': `polygon(100% 0, ${clipPosition}% 0, 0 50%, ${
    clipPosition
  }% 100%, 100% 100%)`
}</code>

最終的な Vue ベースの結果では、センター クリックによるランダム スピンとセクター クリックによるターゲット スピンが可能になります。 (原文どおり、完全なコードへのリンクは省略されています)。 このプロジェクトは、実践的な三角法の貴重なレッスンを提供しました。

以上が完全な CSS 円セクターを作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
PixijsとWebGLを使用して画像ギャラリーを構築しますPixijsとWebGLを使用して画像ギャラリーを構築しますApr 11, 2025 am 11:06 AM

時々、必要なUIを作成するには、HTML、CSS、およびJavaScriptよりも少し先に進まなければならず、代わりにSVG、WebGL、Canvasなどの他のリソースを使用する必要があります。

PHPはテンプレートのA-OKですPHPはテンプレートのA-OKですApr 11, 2025 am 11:04 AM

PHPテンプレートは、多くの場合、サブパーコードを促進するために悪いラップを取得しますが、そうである必要はありません。 PHPプロジェクトが基本を実施する方法を見てみましょう

WordPressテーマでVueコンポーネントを構築する方法WordPressテーマでVueコンポーネントを構築する方法Apr 11, 2025 am 11:03 AM

インラインテンプレートディレクティブにより、既存のWordPressマークアップに対する進行性の強化として、リッチVUEコンポーネントを構築できます。

私たちが望むウェブを構築します私たちが望むウェブを構築しますApr 11, 2025 am 10:55 AM

Microsoft Edgeチームでは、オープンウェブに取り組んでおり、イノベーションを前進させるのを支援しているため、新しいイニシアチブを開始しました。

Webアクセシビリティカラーコントラストガイドラインと比率の理解Webアクセシビリティカラーコントラストガイドラインと比率の理解Apr 11, 2025 am 10:51 AM

あなたのウェブデザインの色のコントラストについて苦情を受けたとき、あなたは何をすべきですか?あなたが読むことができるので、それはあなたには完全に大丈夫だと思われるかもしれません

あなたのウェブサイトでの画像の読み込みを改善するためにこれを行いますあなたのウェブサイトでの画像の読み込みを改善するためにこれを行いますApr 11, 2025 am 10:32 AM

以下に埋め込まれたビデオでは、ジェンシモンズは、幅と高さの属性を使用して画像の負荷を改善する方法を説明しています。問題は、Jankがたくさんあることです

ブロックの新しいフレームワーク、Svelteに精通するブロックの新しいフレームワーク、Svelteに精通するApr 11, 2025 am 10:29 AM

過去6年間、Vue、Angular、およびReactは、フロントエンドコンポーネントフレームワークの世界を実行してきました。 GoogleとFacebookには独自のスポンサーフレームワークがあります。

JavaScriptがHTMLを食べている理由JavaScriptがHTMLを食べている理由Apr 11, 2025 am 10:28 AM

Web開発は常に変化しています。特に1つの傾向は最近非常に人気があり、それは根本的に従来の知恵に反しています

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

EditPlus 中国語クラック版

EditPlus 中国語クラック版

サイズが小さく、構文の強調表示、コード プロンプト機能はサポートされていません

WebStorm Mac版

WebStorm Mac版

便利なJavaScript開発ツール

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

Eclipse を SAP NetWeaver アプリケーション サーバーと統合します。

SublimeText3 Mac版

SublimeText3 Mac版

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