この記事の内容は、純粋な CSS を使用して 3D を実現するためのコード (立方体、ダイナミックな立体写真アルバム、平面星空) です。コードが必要な場合は、参照してください。
1. 立方体
まず第一に、立方体は 6 つの同一の面で構成されます。 (コードの三次元構造による)
コードは次のとおりです:
nbsp;html> <meta> <meta> <meta> <title>正方体</title> <style> .d3{ height: 300px; width:300px; perspective: 800px; margin:140px auto; border:1px solid #ccc; } .stage{ height: 300px; width: 300px; transform-style: preserve-3d; position: relative; transform: rotateX(45deg) rotateY(45deg); } .role{ height: 300px; width: 300px; position: absolute; } .stage{ animation: dong 3s linear infinite;(这是舞台) } .stage:hover{ animation: paused; } @keyframes dong{(这是使舞台旋转的动画) from{ transform: rotateX(45deg) rotateY(45deg); } to{ transform: rotateX(405deg) rotateY(405deg); } } .di1{(正方体的前面) background: rgb(21, 163, 52); transform: translateZ(150px);(沿着z轴向前移动150px) font-size:100px; font-family:KaiTi; text-align: center; line-height: 300px; } .di2{(正方体的后面) background: blue; transform: translateZ(-150px) rotateY(180deg);(沿着z轴向前移动150px然后沿着y轴旋转180°*注意顺序哦是先移动后旋转) font-size:100px; font-family:KaiTi; text-align: center; line-height: 300px; } .di3{(正方体的左面) background: purple; transform: rotateY(-90deg) translateZ(150px); font-size:100px; font-family:KaiTi; text-align: center; line-height: 300px; } .di4{(正方体的右面) background: pink; transform: rotateY(90deg) translateZ(150px); font-size:100px; font-family:KaiTi; text-align: center; line-height: 300px; } .di5{(正方体的上面) background: red; transform: rotateX(90deg) translateZ(150px); font-size:100px; font-family:KaiTi; text-align: center; line-height: 300px; } .di6{(正方体的下面) background: yellow; transform: rotateX(-90deg) translateZ(150px); font-size:100px; font-family:KaiTi; text-align: center; line-height: 300px; } </style> <div> <div> (将正方体分为六个相同的面) <div>前</div> <div>后</div> <div>左</div> <div>右</div> <div>上</div> <div>下</div> </div> </div>
2. ダイナミックな 3 次元フォト アルバム
フォト アルバムを 3 次元 3D 効果にデザインします
回転、移動、傾き、3D 効果を使用して、アルバムをさらに美しくします。
コードは以下の通りです:
(将第一张定好位置后将后面的依次排列) nbsp;html> <meta> <meta> <meta> <title>事例一</title> <style> body{ height: 100vh; } .div { height: 500px; width: 800px; perspective: 800px; margin: 50px auto; } .div1 { height: 500px; width: 800px; transform-style: preserve-3d; position: relative; /* transform: rotateY(-10deg); */ } .div_0{ height:400px; width:600px; position: absolute; margin-top:110px; margin-left:50px; } .div_1{ height:400px; width:600px; background: url(../day03/timg.jpg); background-size: 600px 400px; border-radius: 20px; transform-origin: right bottom; transition: 3s; } .div_2{ background: url(../day03/timg1.jpg); border-radius: 20px; background-size: 600px 400px; transform-origin: right bottom; transform: rotateZ(2deg) translateZ(-20px) translateX(20px) translateY(-20px); } .div_2:hover{ transform: rotateZ(0) translateZ(0)translateX(0)translateY(0); transition: 1s; } .div_2:hover~.div_1{ /* transform-origin: right bottom; */ transform: rotateZ(2deg) translateZ(20px) translateX(20px) translateY(-20px); transition: 1s; } /* body:hover .div_1{ opacity: 0; transition: 3s; } */ .div_3{ background: url(timg2.jpg); border-radius: 20px; background-size: 600px 400px; transform-origin: right bottom; transform: rotateZ(4deg)translateZ(-40px)translateX(40px)translateY(-40px); } .div_3:hover{ transform: rotateZ(0) translateZ(0)translateX(0)translateY(0); transition: 1s; } .div_4{ background: url(timg4.jpg); border-radius: 20px; background-size: 600px 400px; transform-origin: right bottom; transform: rotateZ(6deg)translateZ(-60px) translateX(60px)translateY(-60px); } .div_4:hover{ transform: rotateZ(0) translateZ(0)translateX(0)translateY(0); transition: 1s; } .div_5{ background: url(timg5.jpg); border-radius: 20px; background-size: 600px 400px; transform-origin: right bottom; transform: rotateZ(8deg)translateZ(-80px) translateX(80px)translateY(-80px); } .div_5:hover{ transform: rotateZ(0) translateZ(0)translateX(0)translateY(0); transition: 1s; } .div_6{ background: url(timg3.jpg) no-repeat; border-radius: 20px; background-size: 600px 400px; transform-origin: right bottom; transform: rotateZ(10deg)translateZ(-100px) translateX(100px)translateY(-100px); } .div_6:hover{ transform: rotateZ(0) translateZ(0)translateX(0)translateY(0); transition: 1s; } </style> <div> <div> <div></div> <div></div> <div></div> <div></div> <div></div> <div></div> </div> </div>
3. 平面星空
コードは以下の通りです:
(jsを使っていないので平面エフェクトのみです。
中心点をマスターすれば簡単です。回転)
nbsp;html> <meta> <meta> <meta> <title>太阳系</title> <style> body { background: url(timg01.jpg) no-repeat; background-size: 100%; } .box1 { height: 600px; width: 600px; margin: 0 auto; border: 1px solid #ccc; border-radius: 50%; } .box1_0 { height: 100px; width: 100px; margin: 0 auto; border: 1px solid white; border-radius: 50%; position: absolute; top: calc(50% - 59px); left: 322px; transform-origin: 345.5px; animation: dong2 5s linear infinite 4s; } @keyframes dong2 { from { transform: rotate(0) } 100% { transform: rotate(360deg); } } .box1_2 { height: 13px; width: 13px; margin: 0 auto; /* border: 1px solid #ccc; */ border-radius: 50%; background: white; position: absolute; top: calc(50% - 7.5px); left: 96px; transform-origin: -45px; animation: dong3 5.5s linear infinite ; /* animation-iteration-count: 200; */ } @keyframes dong3 { from { transform: rotate(0); } 100% { transform: rotate(360deg); } } .box1_1 { height: 15px; width: 15px; margin: 0 auto; /* border: 1px solid #ccc; */ border-radius: 50%; background: rgb(7, 100, 223); position: absolute; top: 45px; left: calc(50% - 16.5px); } .box2 { height: 400px; width: 400px; margin: 0 auto; border: 1px solid #ccc; border-radius: 50%; position: absolute; top: calc(50% - 200px); left: calc(50% - 200px); } .box2_1 { height: 15px; width: 15px; margin: 0 auto; /* border: 1px solid #ccc; */ border-radius: 50%; background: rgb(198, 208, 221); position: absolute; top: calc(50% - 7.5px); left: 43px; transform-origin: 157.5px; animation: dong1 5s linear infinite .5s; } @keyframes dong1 { from { transform: rotate(0) } 100% { transform: rotate(360deg); } } .box2_2 { height: 15px; width: 15px; margin: 0 auto; border-radius: 50%; background: #644e11; position: absolute; top: calc(50% - 7.5px); left: -7px; transform-origin: 207.5px; animation: dong 5s linear infinite; } @keyframes dong { from { transform: rotate(0) } 100% { transform: rotate(360deg); } } .box3 { height: 300px; width: 300px; margin: 0 auto; border: 1px solid #ccc; border-radius: 50%; position: absolute; top: calc(50% - 150px); left: calc(50% - 150px); } .box4 { height: 30px; width: 30px; margin: 0 auto; border-radius: 50%; background: orange; position: absolute; top: calc(50% - 15px); left: calc(50% - 15px); } .boxli{ height: 900px; width: 900px; margin: 0 auto; border: 1px solid #ccc; border-radius: 50%; position: absolute; top:-120px; left:calc(50% - 450px); } .boxli_1{ height: 15px; width: 15px; margin: 0 auto; border-radius: 50%; background: rgb(116, 100, 56); position: absolute; top:500px; left:-6px; transform-origin: 455.5px -38px; animation: dongli 5s linear infinite; } @keyframes dongli { from { transform: rotate(0) } 100% { transform: rotate(360deg); } } </style> <div> <div> <div></div> <div></div> </div> <div> <div></div> <div></div> <div> <div></div> </div> </div> </div> <div> <div></div> </div>
関連する推奨事項:
CSS でカード画像の反転効果を実現するにはどうすればよいですか? (特殊効果の例)
以上が3Dを実現するピュアCSSコード(立方体、ダイナミックな立体写真集、平面的な星空)の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

Goofontsは、開発者妻とデザイナーの夫によって署名されたサイドプロジェクトであり、どちらもタイポグラフィの大ファンです。 Googleにタグを付けています

Pavithra Kodmadは、彼らが変化したWeb開発に関する最も時代を超越した記事のいくつかであると考えていることについて、人々に推奨事項を求めました

GraphQL APIの構築方法を学ぶことは非常に挑戦的です。ただし、10分でGraphQL APIを使用する方法を学ぶことができます!そして、それは私が完璧になったことがあります

ここでは、Yuanchuanからの合法的なCSSの策略があります。このCSSプロパティオフセットパスがあります。むかしむかし、それはモーションパスと呼ばれ、その後改名されました。私


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

MinGW - Minimalist GNU for Windows
このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境
