menu.vue 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387
  1. <template>
  2. <div class="pinBottom-container">
  3. <div class="pinBottom center">
  4. <div id="view-controllers"></div>
  5. </div>
  6. <div class="pinBottom left">
  7. <div>
  8. <div class="viewContainer">
  9. <div
  10. id="previous"
  11. class="previous desktop-only ui-icon"
  12. style="display: none"
  13. >
  14. <a>
  15. <img
  16. rel="tooltip"
  17. title=""
  18. :src="require('@/assets/images/play.png')"
  19. width="24"
  20. height="24"
  21. data-original-title="播放"
  22. />
  23. </a>
  24. </div>
  25. <div
  26. id="play"
  27. class="ui-icon"
  28. rel="tooltip"
  29. data-original-title="播放"
  30. >
  31. <a>
  32. <img
  33. title=""
  34. :src="require('@/assets/images/icon/play.png')"
  35. width="24"
  36. height="24"
  37. />
  38. </a>
  39. </div>
  40. <div id="pause" class="ui-icon" style="display: none">
  41. <a>
  42. <img
  43. rel="tooltip"
  44. title=""
  45. :src="require('@/assets/images/icon/pause.png')"
  46. width="24"
  47. height="24"
  48. data-original-title="暂停"
  49. />
  50. </a>
  51. </div>
  52. <div
  53. id="next"
  54. class="next desktop-only ui-icon wide"
  55. style="display: none"
  56. >
  57. <a>
  58. <i
  59. rel="tooltip"
  60. title=""
  61. class="icon icon-dpad-right"
  62. data-original-title="下一个"
  63. ></i>
  64. </a>
  65. </div>
  66. <div id="gui-modes-map" class="ui-icon double active">
  67. <div
  68. data-original-title="导览"
  69. @click="isGuide = !isGuide"
  70. id="pullTab"
  71. rel="tooltip"
  72. title=""
  73. >
  74. <img
  75. class="icon icon-inside"
  76. :src="
  77. require(`@/assets/images/icon/auto${
  78. !isGuide ? '_active' : ''
  79. }.png`)
  80. "
  81. title="navigation icon"
  82. />
  83. </div>
  84. <div
  85. data-original-title="全景漫游"
  86. id="gui-modes-inside"
  87. rel="tooltip"
  88. >
  89. <img
  90. class="icon icon-inside"
  91. :src="require('@/assets/images/icon/inside.png')"
  92. title="navigation icon"
  93. />
  94. <img
  95. class="icon icon-inside active"
  96. :src="require('@/assets/images/icon/inside_active.png')"
  97. title="navigation icon"
  98. />
  99. </div>
  100. <div
  101. data-original-title="迷你模型"
  102. id="gui-modes-dollhouse"
  103. rel="tooltip"
  104. >
  105. <img
  106. class="icon icon-inside"
  107. :src="require('@/assets/images/icon/dollhouse.png')"
  108. title="navigation icon"
  109. />
  110. <img
  111. class="icon icon-inside active"
  112. :src="require('@/assets/images/icon/dollhouse_active.png')"
  113. title="navigation icon "
  114. />
  115. </div>
  116. <div
  117. data-original-title="俯视图"
  118. id="gui-modes-floorplan"
  119. rel="tooltip"
  120. title=""
  121. >
  122. <img
  123. class="icon icon-inside"
  124. :src="require('@/assets/images/icon/floor.png')"
  125. title="navigation icon"
  126. />
  127. <img
  128. class="active icon icon-inside active"
  129. :src="require('@/assets/images/icon/floor_active.png')"
  130. title="navigation icon"
  131. />
  132. </div>
  133. <div
  134. data-original-title="VR"
  135. id="vr"
  136. rel="tooltip"
  137. title=""
  138. style="display: none"
  139. >
  140. <img
  141. class="icon icon-inside"
  142. :src="require('@/assets/images/VR.png')"
  143. title="navigation icon"
  144. />
  145. </div>
  146. <!-- <div
  147. data-original-title="热点列表"
  148. id="hotList"
  149. rel="tooltip"
  150. title=""
  151. style="display: none"
  152. >
  153. <img
  154. class="icon icon-inside"
  155. :src="require('@/assets/images/hotlist.png')"
  156. title="navigation icon"
  157. />
  158. <img
  159. class="icon icon-inside active"
  160. :src="require('@/assets/images/hotlist.png')"
  161. title="navigation icon"
  162. />
  163. </div> -->
  164. <div
  165. data-original-title="消除外壳"
  166. id="gui-remove-face"
  167. rel="tooltip"
  168. title=""
  169. style="display: none; float: left"
  170. >
  171. <img
  172. class="icon icon-inside"
  173. :src="require('@/assets/images/face.jpg')"
  174. title="navigation icon"
  175. />
  176. </div>
  177. </div>
  178. </div>
  179. </div>
  180. </div>
  181. <div class="pinBottom right hideTarget">
  182. <div class="rightViewContainer clearfix">
  183. <div class="gui-floor">
  184. <div class="gui-floor-title"></div>
  185. <div class="gui-floor-icon">
  186. <span class="gui-floor-number"></span>
  187. </div>
  188. <div class="container"></div>
  189. </div>
  190. <div class="bgandshare">
  191. <div id="volume" @click="switchBGM" class="ui-icon wide">
  192. <div>
  193. <img :src="require('@/assets/images/icon/musicon.png')" />
  194. </div>
  195. </div>
  196. <div @click="isShare = !isShare">
  197. <div>
  198. <img
  199. :src="
  200. require(`@/assets/images/icon/share${
  201. !isShare ? 'on' : 'off'
  202. }.png`)
  203. "
  204. />
  205. </div>
  206. </div>
  207. </div>
  208. <div id="vr" class="ui-icon wide hidden" style="display: none">
  209. <a>
  210. <i
  211. rel="tooltip"
  212. title="{[{ VIEW_IN_VR }]}"
  213. class="icon icon-webvr"
  214. ></i>
  215. </a>
  216. </div>
  217. <div id="sharing" class="ui-icon wide hidden" style="display: none">
  218. <a>
  219. <i
  220. rel="tooltip"
  221. title="{[{ SOCIAL_SHARING }]}"
  222. class="icon icon-share"
  223. ></i>
  224. </a>
  225. </div>
  226. <div
  227. id="gui-fullscreen"
  228. class="ui-icon wide"
  229. data-placement="top"
  230. rel="tooltip"
  231. title="{[{ VIEW_FULLSCREEN }]}"
  232. >
  233. <a>
  234. <i class="icon icon-fullscreen"></i>
  235. </a>
  236. </div>
  237. <div
  238. id="gui-fullscreen-exit"
  239. class="ui-icon wide"
  240. data-placement="top"
  241. rel="tooltip"
  242. title="{[{ EXIT_FULLSCREEN }]}"
  243. style="display: none"
  244. >
  245. <a>
  246. <i class="icon icon-fullscreen-exit"></i>
  247. </a>
  248. </div>
  249. <div class="pull-right terms terms2">
  250. <a>{[{ TERMS }]}</a>
  251. </div>
  252. </div>
  253. </div>
  254. </div>
  255. </template>
  256. <script>
  257. export default {
  258. components: {},
  259. data() {
  260. return {
  261. isGuide: true,
  262. isShare: false,
  263. };
  264. },
  265. computed: {},
  266. watch:{
  267. isShare(newVal){
  268. if (newVal) {
  269. this.$showShare()
  270. }
  271. }
  272. },
  273. mounted(){
  274. this.$bus.$on('closeShare',()=>{
  275. this.isShare = false
  276. })
  277. },
  278. methods: {
  279. switchBGM() {
  280. if ($("#volume img")[0].src.indexOf("on.png") > -1) {
  281. window.manage.switchBgmState(true);
  282. } else if ($("#volume img")[0].src.indexOf("off.png") > -1) {
  283. window.manage.switchBgmState(false);
  284. }
  285. },
  286. },
  287. };
  288. </script>
  289. <style lang="less" scoped>
  290. @wh: 90px;
  291. @margin: 10px;
  292. #play,
  293. #pause {
  294. margin-right: @margin;
  295. img {
  296. width: @wh;
  297. height: @wh;
  298. }
  299. }
  300. #gui-modes-map {
  301. > div {
  302. margin-right: @margin;
  303. > img {
  304. width: @wh;
  305. height: @wh;
  306. display: block;
  307. }
  308. .active {
  309. display: none;
  310. }
  311. }
  312. .active {
  313. > img {
  314. display: none;
  315. }
  316. .active {
  317. display: block;
  318. }
  319. }
  320. }
  321. .bgandshare {
  322. display: flex;
  323. justify-content: center;
  324. align-items: center;
  325. > div {
  326. background: none !important;
  327. width: @wh!important;
  328. cursor: pointer;
  329. img {
  330. width: 100%;
  331. }
  332. }
  333. }
  334. @media only screen and (max-width: 487px) {
  335. @wh: 70px;
  336. #play,
  337. #pause {
  338. margin-right: @margin;
  339. img {
  340. width: @wh;
  341. height: @wh;
  342. }
  343. }
  344. #gui-modes-map {
  345. > div {
  346. margin-right: @margin;
  347. > img {
  348. width: @wh;
  349. height: @wh;
  350. display: block;
  351. }
  352. .active {
  353. display: none;
  354. }
  355. }
  356. .active {
  357. > img {
  358. display: none;
  359. }
  360. .active {
  361. display: block;
  362. }
  363. }
  364. }
  365. .bgandshare {
  366. display: flex;
  367. position: fixed;
  368. top: 12%;
  369. right: 6px;
  370. flex-direction: column;
  371. > div {
  372. width: @wh!important;
  373. img {
  374. width: 100%;
  375. }
  376. }
  377. }
  378. }
  379. </style>