界面实例--旋转的3d立方体
好吧,这里直接编辑源码并不允许设置css和js……毕竟会有危险……那直接放代码吧
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1.0">
<title>vue-test</title>
<link rel="stylesheet" href="cube.css"><!--css-->
<script src="jquery-3.3.1.min.js"></script><!--引入jquery-->
<style>
.contain{
margin-top:100px;
position:relative;
width:800px;
height:400px;
background:black;
padding:20px;
text-align:center; }
.row{
position:relative;
}
.contain .button-container{ }
.contain .cube-container{ width:300px;
height:300px;
margin:auto;
}
.content-container{
color:white;
border:1px solid white;
width:300px;
max-height:400px;
overflow:auto;
position:absolute;
left:20px;
top:20px;
display:none;
}
.contain .button-container .control-button{
width:40px;
height:40px;
background:black;
color:white;
border-radius:20px;
outline: none;
}
.contain .button-container .control-button.choose{
background:white;
color:black;
}
</style>
</head>
<body>
<div class="contain">
<div class="row">
<div class="cube-container">
<div class="cube animation-rotating">
<div class="surface surface1">1</div>
<div class="surface surface2">2</div>
<div class="surface surface3">3</div>
<div class="surface surface4">4</div>
<div class="surface surface5">5</div>
<div class="surface surface6">6</div><!---->
</div>
</div>
<div class="content-container">
<div class="content-title"></div>
<div class="content"></div>
</div>
</div>
<div class="button-container">
<button class="control-button choose">0</button>
<button class="control-button">1</button>
<button class="control-button">2</button>
<button class="control-button">3</button>
<button class="control-button">4</button>
<button class="control-button">5</button>
<button class="control-button">6</button> </div>
</div> <script>
var content=[
{'title':'越人歌','content':'今夕何夕兮,搴舟中流。今日何日兮,得与王子同舟。蒙羞被好兮,不訾诟耻。心几烦而不绝兮,得知王子。山有木兮木有枝,心悦君兮君不知。'},
{'title':'木兰花·拟古决绝词柬友','content':'人生若只如初见,何事秋风悲画扇。等闲变却故人心,却道故人心易变。骊山语罢清宵半,泪雨霖铃终不怨。何如薄幸锦衣郎,比翼连枝当日愿。'},
{'title':'江城子·乙卯正月二十日夜记梦','content':'十年生死两茫茫,不思量,自难忘。千里孤坟,无处话凄凉。纵使相逢应不识,尘满面,鬓如霜。夜来幽梦忽还乡,小轩窗,正梳妆。相顾无言,惟有泪千行。料得年年肠断处,明月夜,短松冈'},
{'title':'离思五首·其四','content':'曾经沧海难为水,除却巫山不是云。取次花丛懒回顾,半缘修道半缘君。'},
{'title':'南歌子词二首 / 新添声杨柳枝词','content':'一尺深红胜曲尘,天生旧物不如新。合欢桃核终堪恨,里许元来别有人。井底点灯深烛伊,共郎长行莫围棋。玲珑骰子安红豆,入骨相思知不知。'},
{'title':'卜算子·我住长江头','content':'我住长江头,君住长江尾。日日思君不见君,共饮长江水。 此水几时休,此恨何时已。只愿君心似我心,定不负相思意。'},
];
$(document).ready(function(){
$('.cube .surface').hover(
function(e){
$(this).addClass('hover').siblings().removeClass('hover');
index=$(this).index()+1;//被指向哪一面,数值1-6
$('.control-button').eq(index).addClass('choose').siblings().removeClass('choose');//那一面绑定的按钮处于选择状态
$(this).parent().attr('class','cube show'+index);//正方体停止旋转并转向该面
//显示内容
$('.content-container .content-title').html(content[index-1]['title']);
$('.content-container .content').html(content[index-1]['content']);
$('.content-container').css({'display':'block'});
},
function(e){
$(this).removeClass('hover');
$(this).parent().attr('class','cube animation-rotating');
$('.control-button').eq(0).addClass('choose').siblings().removeClass('choose');
$('.content-container').css({'display':'none'}); });
$('.control-button').on('click',function(){
index = $(this).index();//按钮的顺序,0是返回原始状态,1-6分别对应6个面
console.log(index);
if(index==0){//返回原始状态
$('.control-button').eq(0).addClass('choose').siblings().removeClass('choose');
$('.cube').attr('class','cube animation-rotating');//正方体重新运转
$('.hover').each(function(){//没有任何一面处于hover状态
$(this).removeClass('hover');
});
$('.content-container').css({'display':'none'}); }
else{//触发1-6面被hover的状态
$('.cube .surface').eq(index-1).trigger('mouseenter');
} }); });
</script> </body>
</html>
index.html
.cube-container{
perspective:1000px;
-webkit-perspective:1000px;
transform:scale(0.8);
}
.cube{
height: 200px;
width: 200px;
position: relative;
margin:auto;
transform-style:preserve-3d;/*定义3d转换*/
transition: all 1s;
}
.cube.show1{
transform:rotateX(0deg) rotateY(0deg);
}
.cube.show2{
transform:rotateX(0deg) rotateY(180deg);
}
.cube.show3{
transform:rotateX(0deg) rotateY(90deg);
}
.cube.show4{
transform:rotateX(0deg) rotateY(-90deg);
}
.cube.show5{
transform:rotateX(-90deg) rotateY(0deg);
}
.cube.show6{
transform:rotateX(90deg) rotateY(0deg);
}
.animation-rotating{
animation:rotating 8s infinite;/*animation:动画名字 时长 无限循环 线性速度(匀速)*/
}
/*动画效果,也可以以百分百的方式。默认逆时针的方向旋转。*/
@keyframes rotating{
from{transfrom:rotate3d(0.5,-0.5,0,0deg)}
to{transform:rotate3d(0.5,-0.5,0,-360deg)}
}
.cube .surface{
height: 100%;
width: 100%;
opacity: 0.6;
position: absolute;
text-align: center;
background: black;
color:#fff;
line-height: 200px;
font-size: 30px;
border:1px solid #fff;
transition: all 1s;
}
.cube .surface1{
transform:translateZ(100px);
}
.cube .surface2{
transform:rotateY(180deg) translateZ(100px);
}
.cube .surface3{
transform:rotateY(-90deg) translateZ(100px);
}
.cube .surface4{
transform:rotateY(90deg) translateZ(100px);
}
.cube .surface5{
transform:rotateX(90deg) translateZ(100px);
}
.cube .surface6{
transform:rotateX(-90deg) translateZ(100px);
}
.cube .surface1:hover, .cube .surface1.hover{
transform:translateZ(200px);
background:white;
color:black;
}
.cube .surface2:hover, .cube .surface2.hover{
transform:rotateY(180deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface3:hover, .cube .surface3.hover{
transform:rotateY(-90deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface4:hover, .cube .surface4.hover{
transform:rotateY(90deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface5:hover, .cube .surface5.hover{
transform:rotateX(90deg) translateZ(200px);
background:white;
color:black;
}
.cube .surface6:hover, .cube .surface6.hover{
transform:rotateX(-90deg) translateZ(200px);
background:white;
color:black;
}
cube.css
界面实例--旋转的3d立方体的更多相关文章
- 纯CSS3实现一个旋转的3D立方体盒子
简单介绍 上网易前端微专业课程,里面有一个课外作业是实现一个3D旋转立方体.花了点时间做了下.还有点意思.写个简单教程.供大家学习. 先放上终于要实现的效果 注:代码在chrome 43.0.2357 ...
- CSS动画实例:3D立方体
CSS3支持3D转换,与3D转换有关的属性有: transform:向元素应用 2D或3D 转换. transform-origin:改变被转换元素的位置. transform-style:规定被嵌套 ...
- css3-实现3D立方体旋转
核心内容: 1.CSS3 中 animation.perspective 属性的熟练运用. 2.CSS3 中的变形属性 transform,在 3D 立体效果中的运用. 3.3D 立方体旋转实现原理. ...
- 基于css3新属性transform及原生js实现鼠标拖动3d立方体旋转
基于css3新属性transform,实现3d立方体的旋转 通过原生JS,点击事件,鼠标按下.鼠标抬起和鼠标移动事件,实现3d立方体的拖动旋转,并将旋转角度实时的反应至界面上显示 实现原理:通过获取鼠 ...
- 基于css3的3D立方体旋转特效
今天给大家分享一款基于css3的3D立方体旋转特效.这款特效适用浏览器:360.FireFox.Chrome.Safari.Opera.傲游.搜狗.世界之窗. 不支持IE8及以下浏览器.效果图如下 : ...
- js拖拽3D立方体旋转
这段时间有点闲,所以就自己找些小玩意来练习练习.今天做了一个可以拖拽页面内空白位置3D立方体就会跟着转动的小例子,布局方面用到css3 3D转换技术,通过transform控制旋转实现的. 上个图 代 ...
- Opengl ES 1.x NDK实例开发之七:旋转的纹理立方体
开发框架介绍请參见:Opengl ES NDK实例开发之中的一个:搭建开发框架 本章在第六章(Opengl ES 1.x NDK实例开发之六:纹理贴图)的基础上绘制一个旋转的纹理立方体,原理和纹理贴图 ...
- CSS3 3D立方体效果-transform也不过如此
CSS3系列已经学习了一段时间了,第一篇文章写了一些css3的奇技淫巧,原文戳这里,还获得了较多网友的支持,在此谢过各位,你们的支持是我写文章最大的动力^_^. 那么这一篇文章呢,主要是通过一个3D立 ...
- css3实践—创建3D立方体
css3实践-创建3D立方体 要想实现3D的效果,其实非常简单,只需指定一个元素为容器并设置transform-style:preserve-3d,那么它的后代元素便会有3D效果.不过有很多需要注意的 ...
随机推荐
- 【cocos2d-x 3.7 飞机大战】 决战南海I (四) 敌机管理
敌方飞机应该不定时的出现,有自己的生命周期.运动轨迹.这个类用来管理敌机的产生.移动.爆炸.销毁等. 敌机管理类主要函数例如以下 //绑定控制器(更新分数) void bindController(C ...
- Visual Code中的智能提示
https://code.visualstudio.com/docs/editor/intellisense C# https://marketplace.visualstudio.com/items ...
- PullToRefreshListView中嵌套ViewPager滑动冲突的解决
PullToRefreshListView中嵌套ViewPager滑动冲突的解决 最近恰好遇到PullToRefreshListView中需要嵌套ViewPager的情况,ViewPager 作为头部 ...
- Linux常用截图软件
1.Gnome-screenshot 是一款 GNOME 截图工具,顾名思义,它是一款用来对整个屏幕.一个特定的窗口或者用户所定义一些其他区域进行捕获的工具.该工具提供了几个其他的功能,包括对所捕获的 ...
- visual studio 添加库文件
我在visual studio中使用OpenGL时需要添加额外的库 一 首先下载库文件,里面将会有一些.h文件和.lib文件,打开visual studio安装目录下打开: D:\program\VS ...
- perl编程问题
一.Hash类型 1.hash遍历输出:如果hash遍历输出的时候不是按key则会按数组输出. my %hash=(); ${hash}{"a"}="1"; $ ...
- JSP从选择到放弃
JSP为什么会出现?出现的原因? ①因为在开发web网站时候,返现servlet做界面比较麻烦,于是出现了jsp. 运行在服务端(Java server pages)基于servlet,对servle ...
- Onvif开发之客户端搜索篇
关于ONVIF的广播,有客户端搜索和服务端发现的区别:客户端向固定的网段和固定的端口发送广播消息,服务端在对应的端口回复广播请求消息本文首先介绍客户端如何进行广播的已经对广播回复的信息的基本处理. 客 ...
- HDU 2564 饭卡
饭卡 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submissi ...
- 百度Echarts-免费的商业产品图表库
官方网站:http://echarts.baidu.com/ 民间网站:http://fansunion.cn/echarts/ 下载地址:https://codeload.github.com/ec ...