index.vue 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175
  1. <template>
  2. <RightFillPano>
  3. <ui-group title="初始画面" borderBottom>
  4. <ui-group-option>
  5. <div class="init-pic" :class="{ disabled: isEdit }">
  6. <img :src="getFileUrl(setting!.cover)" class="init-puc-cover">
  7. <div class="init-pic-set" @click="enterSetPic">设置</div>
  8. </div>
  9. </ui-group-option>
  10. </ui-group>
  11. <ui-group title="设置天空">
  12. <ui-group-option>
  13. <div class="back-layout">
  14. <div
  15. v-for="back in backs"
  16. :key="back.value"
  17. class="back-item"
  18. :class="{ [back.type]: true, active: setting!.back === back.value}"
  19. @click="setting!.back !== back.value && changeBack(back.value)"
  20. >
  21. <img :src="back.image" v-if="back.type === 'img'">
  22. <i class="iconfont" :class="back.image" v-else-if="back.type === 'icon'" />
  23. <span :style="{background: back.image}" v-else></span>
  24. <p class="back-item-desc">{{ back.label }}</p>
  25. </div>
  26. </div>
  27. </ui-group-option>
  28. </ui-group>
  29. </RightFillPano>
  30. </template>
  31. <script lang="ts" setup>
  32. import { RightFillPano } from '@/layout'
  33. import ltby from '@/assets/pic_ltby@2x.png'
  34. import hmm from '@/assets/pic_hmm@2x.png'
  35. import xk from '@/assets/pic_xk@2x.png'
  36. import yk from '@/assets/pic_yj@2x.png'
  37. import hmm360 from '/images/huimengmeng.jpg'
  38. import ltby360 from '/images/lantianbaiyun.jpg'
  39. import yk360 from '/images/preller_drive_2k.jpg'
  40. import xk360 from '/images/xingkong.jpg'
  41. import { enterEdit, enterOld, setting, isEdit, updataSetting } from '@/store'
  42. import { reactive, ref } from 'vue'
  43. import { togetherCallback, getFileUrl, loadPack } from '@/utils'
  44. import { showRightPanoStack, showRightCtrlPanoStack } from '@/env'
  45. import { sdk } from '@/sdk'
  46. const backs = reactive([
  47. { label: '无', type: 'icon', image: 'icon-without', value: 'none' },
  48. { label: '蓝天白云', type: 'img', image: ltby, value: ltby360 },
  49. { label: '灰蒙蒙', type: 'img', image: hmm, value: hmm360 },
  50. { label: '星空', type: 'img', image: xk, value: xk360 },
  51. { label: '夜间', type: 'img', image: yk, value: yk360 },
  52. { label: '灰色', type: 'color', image: '#333333', value: '#333' },
  53. { label: '黑色', type: 'color', image: '#000000', value: '#000' },
  54. { label: '白色', type: 'color', image: '#ffffff', value: '#fff' },
  55. ])
  56. const enterSetPic = () => {
  57. enterEdit(
  58. togetherCallback([
  59. showRightPanoStack.push(ref(false)),
  60. showRightCtrlPanoStack.push(ref(false)),
  61. ])
  62. )
  63. enterOld(async () => {
  64. const dataURL = await sdk.screenshot(300, 150)
  65. const res = await fetch(dataURL)
  66. const blob = await res.blob()
  67. setting.value = {
  68. ...setting.value!,
  69. cover: { url: dataURL, blob },
  70. pose: sdk.getPose()
  71. }
  72. await updataSetting()
  73. })
  74. }
  75. const initBack = setting.value!.back
  76. let isFirst = true
  77. const changeBack = (back: string) => {
  78. setting.value!.back = back
  79. sdk.setBackdrop(back)
  80. if (isFirst) {
  81. let isSave = false
  82. isFirst = false
  83. enterEdit(() => {
  84. if (!isSave) {
  85. setting.value!.back = initBack
  86. sdk.setBackdrop(initBack)
  87. }
  88. isFirst = true
  89. })
  90. enterOld(async () => {
  91. isSave = true
  92. await loadPack(updataSetting())
  93. })
  94. }
  95. }
  96. </script>
  97. <style scoped lang="scss">
  98. .init-pic {
  99. height: 150px;
  100. border-radius: 4px;
  101. overflow: hidden;
  102. position: relative;
  103. }
  104. .init-puc-cover {
  105. width: 100%;
  106. height: 100%;
  107. object-fit: cover
  108. }
  109. .init-pic-set {
  110. position: absolute;
  111. bottom: 0;
  112. left: 0;
  113. right: 0;
  114. background-color: rgba(0,0,0,0.5);
  115. font-size: 12px;
  116. color: #fff;
  117. line-height: 32px;
  118. z-index: 1;
  119. text-align: center;
  120. cursor: pointer;
  121. }
  122. .back-layout {
  123. display: grid;
  124. grid-template-columns: repeat(3, 1fr);
  125. gap: 20px;
  126. }
  127. .back-item {
  128. > span, .iconfont, img {
  129. display: block;
  130. height: 88px;
  131. cursor: pointer;
  132. outline: 2px solid transparent;
  133. transition: all .3s;
  134. border-radius: 4px;
  135. }
  136. .iconfont {
  137. display: flex;
  138. align-items: center;
  139. justify-content: center;
  140. color: #525252;
  141. font-size: 32px;
  142. }
  143. img {
  144. object-fit: cover;
  145. }
  146. &.active {
  147. > span, .iconfont, img {
  148. outline-color: #00C8AF;
  149. }
  150. }
  151. }
  152. .back-item-desc {
  153. font-size: 14px;
  154. color: #fff;
  155. margin-top: 10px;
  156. text-align: center;
  157. }
  158. </style>