在webgl画布上添加按钮或一个div



我是新手,我有一个index.html文件,我想在那里使用three.js

这是我的代码:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Test</title>
<link rel="stylesheet" href="./style.css"></link>


</head>
<body>
<div class="topnav">
<a class="active" href="#File">File</a>
<a href="#Edit">Edit</a>
<a href="#View">View</a>
<a href="#about">About</a>
<canvas class="webgl"></canvas>
<script src="../libs/three.js"></script>
<script  src="../libs/three.min.js"></script>
<script src="../libs/stats.min.js"></script>
<script src="../libs/OrbitControls.js"></script>
<script type="module" src="./main.js"></script>
</div>
</body>
</html>

我也试了一下:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Test</title>
<link rel="stylesheet" href="./style.css"></link>


</head>
<body>
<canvas class="webgl"></canvas>
<script src="../libs/three.js"></script>
<script  src="../libs/three.min.js"></script>
<script src="../libs/stats.min.js"></script>
<script src="../libs/OrbitControls.js"></script>
<script type="module" src="./main.js"></script>
<div class="topnav">
<a class="active" href="#File">File</a>
<a href="#Edit">Edit</a>
<a href="#View">View</a>
<a href="#about">About</a>
</div>
</body>
</html>

和我的CSS文件

* {
margin: 0;
padding: 0;
}
html,
body {
overflow: hidden;
}
.topnav {
overflow: hidden;
background-color: #333;
}
.topnav a {
float: left;
color: #f2f2f2;
text-align: center;
padding: 14px 16px;
text-decoration: none;
font-size: 17px;
}
.topnav a:hover {
background-color: #ddd;
color: black;
}
.topnav a.active {
background-color: #04aa6d;
color: white;
}
.webgl {
position: fixed;
top: 0;
left: 0;
outline: none;
}

我的问题是div的菜单栏没有显示在画布的前面。

我该怎么办?

谢谢。

将您的HTML转换为如下内容:

<div class="topnav">
<a class="active" href="#File">File</a>
<a href="#Edit">Edit</a>
<a href="#View">View</a>
<a href="#about">About</a>
</div>
<canvas class="webgl"></canvas>
<!-- script tags -->

然后从webgl类中去掉positionlefttop属性。

最新更新