突然、リングオーディオプレーヤープログレスバーを作成する必要があります(上の写真のエフェクト)。長い間考えてきましたが、実現できませんでした。最後に、母に確認したところ、CSS にも clipattribute があることがわかりました。これはニーズを完全に満たしています。共有すれば、他の友達にも役立つかもしれません。それが役に立つかどうかはわかりませんが、誰が気にするでしょうか。 OK、話はやめて、行きましょう!
CSS クリップ属性
CSS クリップ属性を簡単に理解しましょう
説明
クリップ属性は、絶対配置された要素をクリップします。このプロパティは、クリッピング四角形を定義するために使用されます。絶対的に定義された要素の場合、四角形内のコンテンツのみが表示されます。このクリッピング領域外のコンテンツは、オーバーフローの値に従って処理されます。
shape 要素の形状を設定します。唯一の有効な形状値は、rect (上、右、下、左)
auto デフォルト値です。クリッピングは適用されません。
inherit は、clip 属性の値が親要素から継承されることを指定します。
使用
実際の原理は、正方形のpにクリッピングで右半分だけを表示させ、そのpにクリッピングで枠線付きの左半円(枠線のサイズはプログレスバーのサイズ)を作成するというものです。 , p は右半分だけを表示するので、この半円を切り取るだけで見えなくなります。次に、回転を組み合わせて半円を回転させ、進行状況バーが 50% を超えたら、p のクリッピングをキャンセルして、半円を使用して進行状況バーの 50% を保存し、100% の進行状況バーを実現します。 。コードを貼り付けて、キーコードをコメントで説明します。
/*Css部分*/ .circleProgress_wrapper{/*设置圆环的大小*/ margin: auto; width: 200px; height: 200px; border-radius: 50%; cursor: pointer; } .slice{ /*这是一个裁去了左半部分,只显示右半部分的p*/ position: absolute; /*必须是绝对定位元素,clip属性才会有效*/ width: 100%; height: 100%; clip:rect(0,200px,200px,100px);/*top:0,right:200,bottom:200,left:100裁剪出右半部*/ } .slice.gt50{/*当进度超过50%时,取消剪裁*/ clip:rect(auto,auto,auto,auto); } .bar,.fill{ /*两个只显示左半部分的半圆*/ position: absolute; box-sizing: border-box; width: 100%; height: 100%; border: 4px rgba(255, 249, 0, 0.77) solid;/*设置进度条大小和颜色值*/ border-radius: 50%; clip: rect(0,100px,200px,0);/*top:0,right:100,bottom:200,left:0裁剪出左半部*/ } .slice.gt50 .fill{/*当进度超过50%时,让fill旋转180度填充50%*/ trans for m: rotate(180deg); } <!--html 部分 --> <p class="circleProgress_wrapper"> <p id="slice_wrapper" class="slice"> <p class="bar pre50"></p> <p class="fill"></p> </p> </p> //javscript部分 <script type="text/ javascript " src="src/audioPlayPlugin. js "></script> <script> var bar= document .querySelector(".slice>.bar"), process=0, circleProgress=document.querySelector(".circleProgress_wrapper"), slice=document.getElementById("slice_wrapper"); var audio= new audioController({ //创建一个音频 对象 src:" file /test1.mp3", " time up date ":function(){//监听timeupdate 事件 ,也就是音频当前播放进度发生改变响应的事件 /* *audio.getAttr(" current Time" 获取当前播放的时间 s *audio.getAttr("duration") 获取音频时长 *它们的比正好就是当前播放进度 *再乘以360转换为进度条应该旋转的角度 */ process=audio.getAttr("currentTime")/audio.getAttr("duration")*360; parseInt(process)===180&&add Class (slice,"gt50");//当等于50%时,使用fill占满50%的进度条 bar.style="transform:rotate("+(process)+"deg)";//根据播放进度设置 更新 进度条 } } }); circleProgress.addEvent List ener("click",function(){ //点击播放 if(audio.getAttr("paused")){ audio.play() } else { audio.pause() } }); function addClass(element,className){/*添加类名,完整代码已省略*/ ... } </script>
完全なデモ。ここでは、オーディオ タグの一般的な操作を単純にカプセル化する audioPlayPlugin.js を作成しました。 Github アドレス、コーディング アドレス
最後に、私が明確に説明していないことや間違ったことを言った場合は、メッセージを残していただければ、一緒に学び、一緒に進歩することができます。
【関連推奨事項】
1. 特別な推奨事項: 「php Programmer Toolbox」V0.1 バージョンのダウンロード
3. Jiijian (2) - CSS ビデオチュートリアル
以上がCSS クリップを使用してオーディオ再生リング プログレス バーを実装するチュートリアルの例の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この投稿では、Blackle Moriは、CohostのHTMLサポートの限界を押し広げようとしている間に見つかったハックのいくつかを示します。あえてこれらを使用してください、あなたもCSS犯罪者とラベル付けされないようにしてください。

CSSを備えたカスタムカーソルは素晴らしいですが、JavaScriptを使用して次のレベルに物事を引き出すことができます。 JavaScriptを使用して、カーソル状態間で移行し、カーソル内に動的テキストを配置し、複雑なアニメーションを適用し、フィルターを適用できます。

2025年には、互いに互いに跳ね返る要素を伴うインタラクティブなCSSアニメーションは、CSSにPongを実装する必要はありませんが、CSSの柔軟性とパワーの増加はLee&#039;の疑いを補強します。

CSSバックドロップフィルタープロパティを使用してユーザーインターフェイスをスタイルするためのヒントとコツ。バックドロップフィルターを複数の要素間でレイヤー化する方法を学び、それらを他のCSSグラフィカル効果と統合して、精巧なデザインを作成します。

まあ、SVG&#039;の組み込みのアニメーション機能は、計画どおりに非推奨されることはありませんでした。確かに、CSSとJavaScriptは負荷を運ぶことができる以上のものですが、以前のようにSmilが水中で死んでいないことを知っておくのは良いことです

イェーイ、テキストワラップのジャンプを見てみましょう:サファリテクノロジーのプレビューにかなり着陸してください!しかし、それがChromiumブラウザーでの仕組みとは異なることに注意してください。

このCSS-Tricksアップデートは、アルマナック、最近のポッドキャスト出演、新しいCSSカウンターガイド、および貴重なコンテンツを提供するいくつかの新しい著者の追加の大幅な進歩を強調しています。

ほとんどの場合、人々はTailwind&#039;の@Apply機能を紹介します。このように展示されたとき、@Applyはまったく有望な音をしません。だからobvio


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター

WebStorm Mac版
便利なJavaScript開発ツール

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

ホットトピック









