3D魔方小游戏(附源码)

简介: 一说到魔方 想必大家都熟悉的不能再熟悉了 自己或者曾今自己的朋友非常喜欢玩的一款游戏 言归正卷 那么实用前端的技术怎么实现3D的魔方制作呢 从以下几个方面就不难发现 前端实现3D魔方都得需要用上这些技术栈

一、案例效果图

效果图是最能表明一个事务的结果性 也能第一时间了解到我们要达成的目的

mofang.gif

二、魔方的思路

1、先将平面上的6个DIV拼接在一起。形成一张类似于3d立方体图形展开的平面图。

a123.png

2、我们需要将每一个面旋转到相应的位置上,每一个面的旋转轴都是不一样的。上下,左右,分别对应的旋转轴,以及旋转角度分别是:bottom(90deg),top(-90deg),right(90deg),left(-90deg)。同时要注意在旋转后面的时候,旋转轴为Z轴,并不是上下,左右边。浏览器上面的坐标系是这样的:Z轴是屏幕里外两个方向(向外为正,向里为负),X轴的水平方向(向右为正,向左为负);
3、接下来还有一个关键的步骤,就是当变换导致元素在 3D 空间中旋转时,指定当元素背面朝向观察者时不可见;

a1234.png

4、接下来我们要做的就是设置一下所处环境,我们要设置成3D的环境,具体的语法形式如下:transform-style: preserve-3d;
5、然后我们为了让立方体旋转起来,以便更好的实现3D效果。首先找到旋转中心,在3D魔方中,旋转中心就是立方体的几何中心。

三、魔方实现目录

a4.png

从上面的目录也不难看出 我们所需要的一些公共的js和css文件还是挺多的 在此我就不一一列举了 需要的可以 前往传送门获取测试 传送门

四、魔方核心代码

<!DOCTYPE html>
<html>

<head>
    <meta charset="utf-8">
    <meta name="viewport"
        content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no" />
    <meta name="description" content="Rubik’s Cube">
    <meta name="keywords" content="Erno Rubik’s Cube">
    <link rel="stylesheet" type="text/css" href="css/cube.css">
    <link rel="stylesheet" type="text/css" href="css/base.css">
    <link rel="icon" type="image/png" href="img/cuber-favicon-0064x0064.png">
    <link rel="apple-touch-icon" href="img/cuber-favicon-0144x0144.png">

    <title>Cuber</title>

    <script charset="utf-8" src="js/tween.min.js"></script>

    <!--  Three.js  -->
    <script charset="utf-8" src="js/Three.js"></script>
    <script charset="utf-8" src="js/EventDispatcher.js"></script>
    <script charset="utf-8" src="js/Math.js"></script>
    <script charset="utf-8" src="js/Quaternion.js"></script>
    <script charset="utf-8" src="js/Vector2.js"></script>
    <script charset="utf-8" src="js/Vector3.js"></script>
    <script charset="utf-8" src="js/Box3.js"></script>
    <script charset="utf-8" src="js/Sphere.js"></script>
    <script charset="utf-8" src="js/Euler.js"></script>
    <script charset="utf-8" src="js/Matrix3.js"></script>
    <script charset="utf-8" src="js/Matrix4.js"></script>
    <script charset="utf-8" src="js/Object3D.js"></script>
    <script charset="utf-8" src="js/Camera.js"></script>
    <script charset="utf-8" src="js/PerspectiveCamera.js"></script>
    <script charset="utf-8" src="js/Ray.js"></script>
    <script charset="utf-8" src="js/Plane.js"></script>


    <!--  Here are the Cube guts. Enjoy.  -->
    <script charset="utf-8" src="js/ERNO.js"></script>
    <script charset="utf-8" src="js/CSS3DRenderer.js"></script>
    <script charset="utf-8" src="js/utils.js"></script>
    <script charset="utf-8" src="js/Number.js"></script>
    <script charset="utf-8" src="js/String.js"></script>
    <script charset="utf-8" src="js/Array.js"></script>
    <script charset="utf-8" src="js/colors.js"></script>
    <script charset="utf-8" src="js/directions.js"></script>
    <script charset="utf-8" src="js/queues.js"></script>
    <script charset="utf-8" src="js/twists.js"></script>
    <script charset="utf-8" src="js/cubelets.js"></script>
    <script charset="utf-8" src="js/groups.js"></script>
    <script charset="utf-8" src="js/slices.js"></script>
    <script charset="utf-8" src="js/folds.js"></script>
    <script charset="utf-8" src="js/projector.js"></script>
    <script charset="utf-8" src="js/interaction.js"></script>
    <script charset="utf-8" src="js/controls.js"></script>
    <script charset="utf-8" src="js/cubes.js"></script>
    <script charset="utf-8" src="js/solvers.js"></script>
    <script charset="utf-8" src="js/renderer.js"></script>

    <script charset="utf-8" src="js/jquery.js"></script>
    <script charset="utf-8" src="js/iecss3d.js"></script>
    <script charset="utf-8" src="js/ierenderer.js"></script>
    <script charset="utf-8" src="js/locked.js"></script>
    <script charset="utf-8" src="js/deviceMotion.js"></script>
    <script charset="utf-8" src="js/main.js"></script>

</head>

<body class="graydient">
    <div id="container"></div>
    <div id="fail">
        <h1>Sorry,</h1>
        <h2>Cubers broken</h2>
    </div>
</body>

</html>
相关文章
|
9月前
|
人工智能 安全 JavaScript
模拟“嫦娥五号”探月小游戏【附源码】
在实际的探月过程中,这些操作都是由程序精确测量和控制的。而在这个游戏里,则需要玩家手动完成 降落 和 上升对接 这两个操作。
|
前端开发 JavaScript
中秋之美——html+css+js制作中秋网页
中秋之美——html+css+js制作中秋网页
395 0
中秋之美——html+css+js制作中秋网页
|
域名解析 小程序 Linux
朋友圈超火的盲盒交友小程序,完整搭建教程及源码分享~(多图)
朋友圈超火的盲盒交友小程序,完整搭建教程及源码分享~(多图)
朋友圈超火的盲盒交友小程序,完整搭建教程及源码分享~(多图)
|
图形学
Unity 3D游戏-消消乐(三消类)教程和源码
Unity 消消乐教程和源码 本文提供全流程,中文翻译。Chinar坚持将简单的生活方式,带给世人!(拥有更好的阅读体验 —— 高分辨率用户请根据需求调整网页缩放比例) ...
5311 0
|
11天前
|
JavaScript
【UI】 欢快畅游的小鱼特效
【UI】 欢快畅游的小鱼特效
11 1
|
4月前
|
C# 图形学
【Unity】2D游戏-愤怒的小鸟教学实战(附源码和实现步骤 超详细)
【Unity】2D游戏-愤怒的小鸟教学实战(附源码和实现步骤 超详细)
128 1
|
4月前
|
图形学
【Unity 3D】3D游戏跑酷小子实战教学(附源码和步骤 超详细)
【Unity 3D】3D游戏跑酷小子实战教学(附源码和步骤 超详细)
96 0
|
4月前
|
Python
python实现贪吃蛇小游戏(附源码 简单易上手)
python实现贪吃蛇小游戏(附源码 简单易上手)
143 0
|
4月前
泡泡龙游戏开发实战教程(1):泡泡龙游戏的布局
泡泡龙游戏开发实战教程(1):泡泡龙游戏的布局
42 0
|
4月前
|
前端开发
前端必学——实现电商图片放大镜效果(附代码)
放大镜可以说是前端人必须学会的程序之一,今天的案例为大家展示一下怎么实现放大镜的效果! 效果图展示   整个效果就是当鼠标放到展示图上的时候,会出现一个遮罩层以及弹出来一个框展示一个详情图,并且鼠标移动的时候详情图跟着移动,鼠标离开详情图消失。