index.html 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236
  1. <!DOCTYPE html>
  2. <html lang="zh">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>开平碉楼建筑群</title>
  7. </head>
  8. <style>
  9. * {
  10. margin: 0;
  11. padding: 0;
  12. }
  13. body {
  14. width: 100vw;
  15. height: 100vh;
  16. min-width: 1600px;
  17. min-height: 800px;
  18. overflow: auto;
  19. }
  20. .main {
  21. width: 100%;
  22. height: 100%;
  23. background-image: url('./img/bg.jpg');
  24. background-size: 100% 100%;
  25. position: relative;
  26. overflow: hidden;
  27. }
  28. .logo {
  29. position: absolute;
  30. top: 2%;
  31. left: 6.5%;
  32. width: 10%;
  33. }
  34. .title{
  35. position: absolute;
  36. top: 8%;
  37. left: 50%;
  38. transform: translateX(-50%);
  39. width: 60%;
  40. }
  41. .rowBox {
  42. position: absolute;
  43. bottom: 0;
  44. left: 50%;
  45. transform: translateX(-50%);
  46. height: 72%;
  47. width: 60%;
  48. display: flex;
  49. justify-content: space-between;
  50. }
  51. .row {
  52. width: auto;
  53. height: 100%;
  54. cursor: pointer;
  55. transition: all 0.3s;
  56. position: relative;
  57. }
  58. .row:hover {
  59. transform: scale(1.1);
  60. }
  61. .row img {
  62. width: 1auto;
  63. height: 100%;
  64. }
  65. .rowTxt {
  66. position: absolute;
  67. top: 10%;
  68. left: 12%;
  69. width: 20px;
  70. font-size: 20px;
  71. /* font-weight: 700; */
  72. color: #FCE9AC;
  73. text-align: center;
  74. }
  75. .rowTxt img {
  76. width: 100%;
  77. }
  78. .rowTxt p {
  79. position: relative;
  80. left: -12%;
  81. top: 5px;
  82. letter-spacing: 3px;
  83. writing-mode: vertical-rl;
  84. margin-bottom: 5px;
  85. }
  86. .openBox {
  87. position: absolute;
  88. top: 0;
  89. left: 0;
  90. width: 100%;
  91. height: 100%;
  92. overflow: hidden;
  93. opacity: 0;
  94. pointer-events: none;
  95. transition: all 0.3s;
  96. background-color: #fff;
  97. }
  98. .openBox img {
  99. position: absolute;
  100. top: 50%;
  101. transform: translateY(-50%);
  102. right: 20px;
  103. cursor: pointer;
  104. height: 51px;
  105. }
  106. .openBox iframe {
  107. width: 100%;
  108. height: 100%;
  109. border: none;
  110. }
  111. .lodingBox {
  112. position: absolute;
  113. top: 0;
  114. left: 0;
  115. width: 100%;
  116. height: 100%;
  117. z-index: 20;
  118. display: flex;
  119. justify-content: center;
  120. align-items: center;
  121. letter-spacing: 4px;
  122. font-weight: 700;
  123. font-size: 24px;
  124. opacity: 0;
  125. pointer-events: none;
  126. background-color: #fff;
  127. }
  128. </style>
  129. <body>
  130. <div class="main">
  131. <!-- logo -->
  132. <img class="logo" src="./img/logo.png" alt="">
  133. <img class="title" src="./img/title.png" alt="">
  134. <!-- 3个图标 -->
  135. <div class="rowBox">
  136. <div class="row" key="https://kaipingdiaolou.cn/web/#/">
  137. <img src="./img/web.png" alt="">
  138. <div class="rowTxt">
  139. <img src="./img/1.png" alt="">
  140. <p>WEB</p>端入口
  141. </div>
  142. </div>
  143. <div class="row" key="https://4dscene.4dage.com/culturalrelics/KPDL/index.html">
  144. <img src="./img/diaolou.png" alt="">
  145. <div class="rowTxt">
  146. <img src="./img/1.png" alt="">
  147. 碉楼模型入口
  148. </div>
  149. </div>
  150. <div class="row" key="https://4dscene.4dage.com/culturalrelics/KPGJ/index.html">
  151. <img src="./img/goujian.png" alt="">
  152. <div class="rowTxt">
  153. <img src="./img/1.png" alt="">
  154. 构建模型入口
  155. </div>
  156. </div>
  157. </div>
  158. </div>
  159. <div class="lodingBox">加载中...</div>
  160. <div class="openBox">
  161. <img src="./img/icon_home.png" alt="">
  162. <!-- <iframe src="#" frameborder="0"></iframe> -->
  163. </div>
  164. </body>
  165. <script>
  166. const rowDoms = document.querySelectorAll('.row')
  167. const openBoxDom = document.querySelector('.openBox')
  168. const lodingBoxDom = document.querySelector('.lodingBox')
  169. const mainDom = document.querySelector('.main')
  170. rowDoms.forEach(v => {
  171. v.onclick = () => {
  172. mainDom.style.opacity = '0'
  173. lodingBoxDom.style.opacity = '1'
  174. lodingBoxDom.style.pointerEvents = 'auto'
  175. const url = v.getAttribute('key')
  176. const iframeDom = document.createElement('iframe')
  177. iframeDom.src = url
  178. iframeDom.frameBorder = '0'
  179. openBoxDom.appendChild(iframeDom)
  180. iframeDom.onload = () => {
  181. setTimeout(() => {
  182. lodingBoxDom.style.opacity = '0'
  183. lodingBoxDom.style.pointerEvents = 'none'
  184. openBoxDom.style.opacity = '1'
  185. openBoxDom.style.pointerEvents = 'auto'
  186. }, 100);
  187. }
  188. }
  189. })
  190. const homeDom = document.querySelector('.openBox img')
  191. homeDom.onclick = () => {
  192. mainDom.style.opacity = '1'
  193. openBoxDom.style.opacity = '0'
  194. openBoxDom.style.pointerEvents = 'none'
  195. const iframeDom = document.querySelector('.openBox iframe')
  196. iframeDom.remove()
  197. }
  198. </script>
  199. </html>