ホームページ >ウェブフロントエンド >フロントエンドQ&A >html5で立体感を出す方法
#このチュートリアルの動作環境: Windows 10 システム、HTML5&&CSS3 バージョン、DELL G3 コンピューターhtml5 立体感を実現する方法: 1. HTML サンプル ファイルを作成します; 2. 「.img {width: 50px; height: 50px; margin: 0 auto;transform-style:preserve-3d」を渡します;} " 属性を使用して 3 次元効果を実現します。 3. "@-webkit-keyframesrotate {...}" 属性を使用してアニメーション効果を実現します。
3 次元の実現方法HTML5の効果は?
HTML5 特殊効果 ~ 3D キューブ回転
まずはこの特殊効果の最終効果を鑑賞しましょうこの機能は Css3 のいくつかの新しい特性に基づいており、主に hover,transform および @keyframe プロパティに使用されます。この 3 つのプロパティの作用を次に説明します。 ## 使用方法:假定我们有一类、名前:mystyle.修正它的 css 样式的方式是.mystyle{}.修正它的 css ホバー样式的方式是.mystyle:hover{}.
transform
結果:元素が回転、放散、移動または傾斜を実行する
使用方法:回転回転rotate(angle)、放scale(x,y)、移動translate(x,y)、斜めskew(angle)のパラメータはプロパティの変更を実行します
@keyframe
結果: 実行画効果
使用方法:@keyframe 後のアニメーション名{from:初期状態态;to:最終状態态}
<style> /*实现立体效果*/ .img { width: 50px; height: 50px; margin: 0 auto; transform-style: preserve-3d; /*设置动画播放样式:动画对象 播放速度 时间 播放次数*/ animation: rotate linear 20s infinite; } /*实现动画效果*/ @-webkit-keyframes rotate { /*sofari chrome*/ from { transform: rotateX(0deg) rotateY(0deg); } to { transform: rotateX(360deg) rotateY(360deg); } } /*图片样式*/ .pic{ width: 200px; height: 200px; transform: rotateY(0deg) translateZ(100px); }</style>
次は特效实现的完全整代コード
<div class="wrap"> <!--部署内外层图片--> <div class="cube"> <!--前面图片 --> <div class="out_front"> <img src="https://img.php.cn/upload/article/000/000/020/efebb79001a49eda20069a1c0c9bb4e2-0.jpeg" class="pic"> </div> <!--后面图片 --> <div class="out_back"> <img src="https://i.loli.net/2018/10/04/5bb5f23ce7f1e.jpg" class="pic"> </div> <!--左面图片 --> <div class="out_left"> <img src="https://i.loli.net/2018/10/04/5bb5f26e13b28.jpg" class="pic"> </div> <!--右面图片 --> <div class="out_right"> <img src="https://img.php.cn/upload/article/000/000/020/ed16de6f96fb6f509ffd3d176caceca2-3.jpg" class="pic"> </div> <!--上面图片 --> <div class="out_top"> <img src="https://i.loli.net/2018/10/04/5bb5f2725c5c7.jpg" class="pic"> </div> <!--下面图片 --> <div class="out_bottom"> <img src="https://img.php.cn/upload/article/000/000/020/0c1647c0eaf3fedf452e32840e68b09c-5.jpg" class="pic"> </div> <!--小正方体 --> <span class="in_front"> <img src="https://i.loli.net/2018/10/07/5bb9b2e441d7a.jpg" class="in_pic"> </span> <span class="in_back"> <img src="https://i.loli.net/2018/10/07/5bb9b2e712b3f.jpg" class="in_pic"> </span> <span class="in_left"> <img src="https://i.loli.net/2018/10/07/5bb9b2e86ad25.jpg" class="in_pic"> </span> <span class="in_right"> <img src="https://i.loli.net/2018/10/07/5bb9b2eaba148.jpg" class="in_pic"> </span> <span class="in_top"> <img src="https://i.loli.net/2018/10/07/5bb9b2ebe5bd9.jpg" class="in_pic"> </span> <span class="in_bottom"> <img src="https://i.loli.net/2018/10/07/5bb9b2ed867be.jpg" class="in_pic"> </span> </div> <style> /*最外层容器样式*/ .wrap { width: 100px; height: 100px; margin: 150px; position: relative; } /*得到立方体效果*/ .cube { width: 50px; height: 50px; margin: 0 auto; transform-style: preserve-3d; /*设置动画播放样式:动画对象 播放速度 时间 播放次数*/ animation: rotate linear 20s infinite; } /*动画旋转的方式*/ /*得到动画效果*/ @-moz-keyframes rotate { /*firefox*/ from { transform: rotateX(0deg) rotateY(0deg); } to { transform: rotateX(360deg) rotateY(360deg); } } @-webkit-keyframes rotate { /*sofari chrome*/ from { transform: rotateX(0deg) rotateY(0deg); } to { transform: rotateX(360deg) rotateY(360deg); } } @-o-keyframes rotate { /*opera*/ from { transform: rotateX(0deg) rotateY(0deg); } to { transform: rotateX(360deg) rotateY(360deg); } } /*每张图片的样式*/ .cube div { position: absolute; width: 200px; height: 200px; opacity: 0.8; /*过渡效果*/ transition: all .4s; } /*定义所有图片样式*/ .pic { width: 200px; height: 200px; } .cube .out_front { transform: rotateY(0deg) translateZ(100px); } .cube .out_back { transform: translateZ(-100px) rotateY(180deg); } .cube .out_left { transform: rotateY(-90deg) translateZ(100px); } .cube .out_right { transform: rotateY(90deg) translateZ(100px); } .cube .out_top { transform: rotateX(90deg) translateZ(100px); } .cube .out_bottom { transform: rotateX(-90deg) translateZ(100px); } /*定义小正方体样式*/ .cube span { display: block; width: 100px; height: 100px; position: absolute; top: 50px; left: 50px; } .cube .in_pic { width: 100px; height: 100px; } .cube .in_front { transform: rotateY(0deg) translateZ(50px); } .cube .in_back { transform: translateZ(-50px) rotateY(180deg); } .cube .in_left { transform: rotateY(-90deg) translateZ(50px); } .cube .in_right { transform: rotateY(90deg) translateZ(50px); } .cube .in_top { transform: rotateX(90deg) translateZ(50px); } .cube .in_bottom { transform: rotateX(-90deg) translateZ(50px); } /*鼠标移入后样式*/ .cube:hover .out_front { transform: rotateY(0deg) translateZ(200px); } .cube:hover .out_back { transform: translateZ(-200px) rotateY(180deg); } .cube:hover .out_left { transform: rotateY(-90deg) translateZ(200px); } .cube:hover .out_right { transform: rotateY(90deg) translateZ(200px); } .cube:hover .out_top { transform: rotateX(90deg) translateZ(200px); } .cube:hover .out_bottom { transform: rotateX(-90deg) translateZ(200px); } </style> </div>
推荐学习:《
HTML5video教程.img { width: 50px;高さ: 50ピクセル;マージン: 0 自動;変換スタイル: 3d を保存;アニメーション: 20 秒のリニア無限回転 } @-webkit-keyframes 回転 { /*sofari chrome*/ から { 変換: 回転X(0度) 回転Y(0度); } に { 変換: 回転X(360度) 回転Y(360度); } } .pic {幅: 200ピクセル;高さ: 200ピクセル;変換: 回転 Y(0 度) 変換 Z(100 ピクセル) }
以上がhtml5で立体感を出す方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。