map.wxml 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. <view class="page">
  2. <view
  3. class="map-stage"
  4. catchtouchstart="handleTouchStart"
  5. catchtouchmove="handleTouchMove"
  6. catchtouchend="handleTouchEnd"
  7. catchtouchcancel="handleTouchCancel"
  8. >
  9. <view class="map-content">
  10. <canvas
  11. id="mapCanvas"
  12. type="webgl"
  13. canvas-id="mapCanvas"
  14. class="map-canvas map-canvas--base"
  15. ></canvas>
  16. <canvas
  17. id="routeLabelCanvas"
  18. type="2d"
  19. canvas-id="routeLabelCanvas"
  20. class="map-canvas map-canvas--labels"
  21. ></canvas>
  22. </view>
  23. <view class="map-stage__crosshair"></view>
  24. <view class="game-punch-hint" wx:if="{{punchHintText}}">{{punchHintText}}</view>
  25. <view class="game-punch-feedback game-punch-feedback--{{punchFeedbackTone}}" wx:if="{{punchFeedbackVisible}}">{{punchFeedbackText}}</view>
  26. <view class="game-content-card" wx:if="{{contentCardVisible}}" bindtap="handleCloseContentCard">
  27. <view class="game-content-card__title">{{contentCardTitle}}</view>
  28. <view class="game-content-card__body">{{contentCardBody}}</view>
  29. <view class="game-content-card__hint">点击关闭</view>
  30. </view>
  31. <view class="map-stage__overlay">
  32. <view class="map-stage__bottom">
  33. <view class="compass-widget">
  34. <view class="compass-widget__heading">{{sensorHeadingText}}</view>
  35. <view class="compass-widget__edge-arrow"></view>
  36. <view class="compass-widget__dial {{orientationMode === 'heading-up' ? 'compass-widget__dial--active' : ''}}">
  37. <view class="compass-widget__glass"></view>
  38. <view class="compass-widget__inner-shadow"></view>
  39. <view class="compass-widget__card" style="transform: rotate({{rotationDeg}}deg);">
  40. <image class="compass-widget__north-arrow" src="../../assets/compass-north-arrow.svg" mode="aspectFit"></image>
  41. <view wx:for="{{compassTicks}}" wx:key="angle" class="compass-widget__tick-anchor" style="transform: translate(-50%, -50%) rotate({{item.angle}}deg);">
  42. <view class="compass-widget__tick {{item.long ? 'compass-widget__tick--long' : 'compass-widget__tick--short'}} {{item.major ? 'compass-widget__tick--major' : ''}}"></view>
  43. </view>
  44. <view wx:for="{{compassLabels}}" wx:key="text" class="compass-widget__mark-anchor" style="transform: translate(-50%, -50%) rotate({{item.angle}}deg);">
  45. <view class="compass-widget__mark {{item.className}}" style="transform: translate(-50%, -50%) translateY(-{{item.radius}}rpx) rotate({{item.rotateBack}}deg);">{{item.text}}</view>
  46. </view>
  47. </view>
  48. <view class="compass-widget__needle-anchor" style="transform: translate(-50%, -50%) rotate({{compassNeedleDeg}}deg);">
  49. <view class="compass-widget__needle-north"></view>
  50. <view class="compass-widget__needle-south"></view>
  51. </view>
  52. <view class="compass-widget__hub"></view>
  53. <view class="compass-widget__hub-core"></view>
  54. </view>
  55. <view class="compass-widget__hint" wx:if="{{compassDeclinationText}}">{{compassDeclinationText}}</view>
  56. </view>
  57. </view>
  58. </view>
  59. </view>
  60. <cover-view class="map-side-toggle" wx:if="{{!showDebugPanel}}" style="top: {{topInsetHeight}}px;" bindtap="handleCycleSideButtons">
  61. <cover-view class="map-side-button map-side-button--icon">
  62. <cover-image wx:if="{{sideButtonMode === 'left'}}" class="map-side-button__image" src="../../assets/btn_more2.png"></cover-image>
  63. <cover-image wx:elif="{{sideButtonMode === 'hidden'}}" class="map-side-button__image" src="../../assets/btn_more1.png"></cover-image>
  64. <cover-image wx:else class="map-side-button__image" src="../../assets/btn_more3.png"></cover-image>
  65. </cover-view>
  66. </cover-view>
  67. <cover-view class="map-side-column map-side-column--left map-side-column--left-group" wx:if="{{!showDebugPanel && showLeftButtonGroup}}" style="top: {{topInsetHeight}}px;">
  68. <cover-view class="map-side-button map-side-button--icon" bindtap="handleToggleMapRotateMode"><cover-image class="map-side-button__rotate-image {{orientationMode === 'heading-up' ? 'map-side-button__rotate-image--active' : ''}}" src="../../assets/btn_map_rotate_cropped.png"></cover-image></cover-view>
  69. <cover-view class="map-side-button map-side-button--muted"><cover-view class="map-side-button__text">LOC</cover-view></cover-view>
  70. <cover-view class="map-side-button"><cover-view class="map-side-button__text">LOCK</cover-view></cover-view>
  71. <cover-view class="map-side-button map-side-button--active"><cover-view class="map-side-button__text">SUN</cover-view></cover-view>
  72. <cover-view class="map-side-button"><cover-view class="map-side-button__text">EXIT</cover-view></cover-view>
  73. </cover-view>
  74. <cover-view class="map-side-column map-side-column--right-main" wx:if="{{!showDebugPanel && showRightButtonGroups}}" style="top: {{topInsetHeight}}px;">
  75. <cover-view class="map-side-button"><cover-view class="map-side-button__text">N</cover-view></cover-view>
  76. <cover-view class="map-side-button map-side-button--active"><cover-view class="map-side-button__text">DIR</cover-view></cover-view>
  77. <cover-view class="map-side-button"><cover-view class="map-side-button__text">COMP</cover-view></cover-view>
  78. <cover-view class="map-side-button map-side-button--active"><cover-view class="map-side-button__text">GUIDE</cover-view></cover-view>
  79. <cover-view class="map-side-button map-side-button--muted"><cover-view class="map-side-button__text">NET</cover-view></cover-view>
  80. <cover-view class="map-side-button map-side-button--active"><cover-view class="map-side-button__text">GO</cover-view></cover-view>
  81. </cover-view>
  82. <cover-view class="map-side-column map-side-column--right-sub" wx:if="{{!showDebugPanel && showRightButtonGroups}}" style="top: {{topInsetHeight}}px;">
  83. <cover-view class="map-side-button"><cover-view class="map-side-button__text">INFO</cover-view></cover-view>
  84. <cover-view class="map-side-button"><cover-view class="map-side-button__text">SET</cover-view></cover-view>
  85. <cover-view class="map-side-button"><cover-view class="map-side-button__text">m</cover-view></cover-view>
  86. <cover-view class="map-side-button"><cover-view class="map-side-button__text">PIN</cover-view></cover-view>
  87. <cover-view class="map-side-button"><cover-view class="map-side-button__text">LIST</cover-view></cover-view>
  88. <cover-view class="map-side-button"><cover-view class="map-side-button__text">USER</cover-view></cover-view>
  89. </cover-view>
  90. <cover-view class="map-punch-button {{punchButtonEnabled ? 'map-punch-button--active' : ''}}" wx:if="{{!showDebugPanel}}" bindtap="handlePunchAction">
  91. <cover-view class="map-punch-button__text">{{punchButtonText}}</cover-view>
  92. </cover-view>
  93. <cover-view class="screen-button-layer screen-button-layer--start-left" wx:if="{{!showDebugPanel && showBottomDebugButton && gameSessionStatus === 'idle'}}" bindtap="handleStartGame">
  94. <cover-view class="screen-button-layer__text screen-button-layer__text--start">开始</cover-view>
  95. </cover-view>
  96. <cover-view class="screen-button-layer screen-button-layer--bottom-left" wx:if="{{!showDebugPanel && showBottomDebugButton}}" bindtap="handleToggleDebugPanel">
  97. <cover-view class="screen-button-layer__icon">
  98. <cover-view class="screen-button-layer__line"></cover-view>
  99. <cover-view class="screen-button-layer__stand"></cover-view>
  100. </cover-view>
  101. <cover-view class="screen-button-layer__text">调试</cover-view>
  102. </cover-view>
  103. <view class="race-panel">
  104. <view class="race-panel__tag race-panel__tag--top-left">目标</view>
  105. <view class="race-panel__tag race-panel__tag--top-right">里程</view>
  106. <view class="race-panel__tag race-panel__tag--bottom-left">点距</view>
  107. <view class="race-panel__tag race-panel__tag--bottom-right">速度</view>
  108. <view class="race-panel__line race-panel__line--center"></view>
  109. <view class="race-panel__line race-panel__line--left-mid"></view>
  110. <view class="race-panel__line race-panel__line--right-mid"></view>
  111. <view class="race-panel__line race-panel__line--left-top"></view>
  112. <view class="race-panel__line race-panel__line--left-bottom"></view>
  113. <view class="race-panel__line race-panel__line--right-top"></view>
  114. <view class="race-panel__line race-panel__line--right-bottom"></view>
  115. <view class="race-panel__grid">
  116. <view class="race-panel__cell race-panel__cell--action">
  117. <view class="race-panel__action-button"><!-- status only -->
  118. <view class="race-panel__action-button-text">{{punchButtonText}}</view>
  119. </view>
  120. </view>
  121. <view class="race-panel__cell race-panel__cell--timer">
  122. <text class="race-panel__timer">{{panelTimerText}}</text>
  123. </view>
  124. <view class="race-panel__cell race-panel__cell--mileage">
  125. <view class="race-panel__mileage-wrap">
  126. <text class="race-panel__mileage">{{panelMileageText}}</text>
  127. <view class="race-panel__chevrons">
  128. <view class="race-panel__chevron"></view>
  129. <view class="race-panel__chevron race-panel__chevron--offset"></view>
  130. </view>
  131. </view>
  132. </view>
  133. <view class="race-panel__cell race-panel__cell--distance">
  134. <view class="race-panel__metric-group race-panel__metric-group--left">
  135. <text class="race-panel__metric-value race-panel__metric-value--distance">{{panelDistanceValueText}}</text>
  136. <text class="race-panel__metric-unit race-panel__metric-unit--distance">m</text>
  137. </view>
  138. </view>
  139. <view class="race-panel__cell race-panel__cell--progress">
  140. <text class="race-panel__progress">{{panelProgressText}}</text>
  141. </view>
  142. <view class="race-panel__cell race-panel__cell--speed">
  143. <view class="race-panel__metric-group race-panel__metric-group--right">
  144. <text class="race-panel__metric-value race-panel__metric-value--speed">{{panelSpeedValueText}}</text>
  145. <text class="race-panel__metric-unit race-panel__metric-unit--speed">km/h</text>
  146. </view>
  147. </view>
  148. </view>
  149. </view>
  150. <view class="debug-modal" wx:if="{{showDebugPanel}}" bindtap="handleCloseDebugPanel">
  151. <view class="debug-modal__dialog" catchtap="handleDebugPanelTap">
  152. <view class="debug-modal__header">
  153. <view>
  154. <view class="debug-modal__eyebrow">DEBUG PANEL</view>
  155. <view class="debug-modal__title">地图调试信息</view>
  156. </view>
  157. <view class="debug-modal__close" bindtap="handleCloseDebugPanel">关闭</view>
  158. </view>
  159. <scroll-view class="debug-modal__content" scroll-y enhanced show-scrollbar="true">
  160. <view class="info-panel__row">
  161. <text class="info-panel__label">Build</text>
  162. <text class="info-panel__value">{{buildVersion}}</text>
  163. </view>
  164. <view class="info-panel__row info-panel__row--stack">
  165. <text class="info-panel__label">Config</text>
  166. <text class="info-panel__value">{{configStatusText}}</text>
  167. </view>
  168. <view class="info-panel__row">
  169. <text class="info-panel__label">Heading Mode</text>
  170. <text class="info-panel__value">{{orientationModeText}}</text>
  171. </view>
  172. <view class="info-panel__row">
  173. <text class="info-panel__label">Sensor Heading</text>
  174. <text class="info-panel__value">{{sensorHeadingText}}</text>
  175. </view>
  176. <view class="info-panel__row info-panel__row--stack">
  177. <text class="info-panel__label">North Ref</text>
  178. <text class="info-panel__value">{{northReferenceText}}</text>
  179. </view>
  180. <view class="info-panel__row">
  181. <text class="info-panel__label">Zoom</text>
  182. <text class="info-panel__value">{{zoom}}</text>
  183. </view>
  184. <view class="info-panel__row">
  185. <text class="info-panel__label">Rotation</text>
  186. <text class="info-panel__value">{{rotationText}}</text>
  187. </view>
  188. <view class="info-panel__row info-panel__row--stack">
  189. <text class="info-panel__label">Status</text>
  190. <text class="info-panel__value">{{statusText}}</text>
  191. </view>
  192. <view class="info-panel__row">
  193. <text class="info-panel__label">GPS</text>
  194. <text class="info-panel__value">{{gpsTrackingText}}</text>
  195. </view>
  196. <view class="info-panel__row info-panel__row--stack">
  197. <text class="info-panel__label">GPS Coord</text>
  198. <text class="info-panel__value">{{gpsCoordText}}</text>
  199. </view>
  200. <view class="info-panel__row">
  201. <text class="info-panel__label">Renderer</text>
  202. <text class="info-panel__value">{{renderMode}}</text>
  203. </view>
  204. <view class="info-panel__row info-panel__row--stack">
  205. <text class="info-panel__label">Projection</text>
  206. <text class="info-panel__value">{{projectionMode}}</text>
  207. </view>
  208. <view class="info-panel__row">
  209. <text class="info-panel__label">Auto Source</text>
  210. <text class="info-panel__value">{{autoRotateSourceText}}</text>
  211. </view>
  212. <view class="info-panel__row">
  213. <text class="info-panel__label">Calibration</text>
  214. <text class="info-panel__value">{{autoRotateCalibrationText}}</text>
  215. </view>
  216. <view class="info-panel__row info-panel__row--stack">
  217. <text class="info-panel__label">Tile URL</text>
  218. <text class="info-panel__value">{{tileSource}}</text>
  219. </view>
  220. <view class="info-panel__row">
  221. <text class="info-panel__label">Center Tile</text>
  222. <text class="info-panel__value">{{centerText}}</text>
  223. </view>
  224. <view class="info-panel__row">
  225. <text class="info-panel__label">Tile Size</text>
  226. <text class="info-panel__value">{{tileSizePx}}px</text>
  227. </view>
  228. <view class="info-panel__row">
  229. <text class="info-panel__label">Visible Tiles</text>
  230. <text class="info-panel__value">{{visibleTileCount}}</text>
  231. </view>
  232. <view class="info-panel__row">
  233. <text class="info-panel__label">Ready Tiles</text>
  234. <text class="info-panel__value">{{readyTileCount}}</text>
  235. </view>
  236. <view class="info-panel__row">
  237. <text class="info-panel__label">Memory Tiles</text>
  238. <text class="info-panel__value">{{memoryTileCount}}</text>
  239. </view>
  240. <view class="info-panel__row">
  241. <text class="info-panel__label">Disk Tiles</text>
  242. <text class="info-panel__value">{{diskTileCount}}</text>
  243. </view>
  244. <view class="info-panel__row">
  245. <text class="info-panel__label">Cache Hit</text>
  246. <text class="info-panel__value">{{cacheHitRateText}}</text>
  247. </view>
  248. <view class="info-panel__row">
  249. <text class="info-panel__label">Disk Hits</text>
  250. <text class="info-panel__value">{{diskHitCount}}</text>
  251. </view>
  252. <view class="info-panel__row">
  253. <text class="info-panel__label">Net Fetches</text>
  254. <text class="info-panel__value">{{networkFetchCount}}</text>
  255. </view>
  256. <view class="control-row">
  257. <view class="control-chip control-chip--primary" bindtap="handleRecenter">回到首屏</view>
  258. <view class="control-chip control-chip--secondary" bindtap="handleRotationReset">旋转归零</view>
  259. </view>
  260. <view class="control-row">
  261. <view class="control-chip {{gpsTracking ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleToggleGpsTracking">{{gpsTracking ? '停止定位' : '开启定位'}}</view>
  262. <view class="control-chip {{osmReferenceEnabled ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleToggleOsmReference">{{osmReferenceText}}</view>
  263. </view>
  264. <view class="control-row control-row--triple">
  265. <view class="control-chip {{orientationMode === 'manual' ? 'control-chip--active' : ''}}" bindtap="handleSetManualMode">手动</view>
  266. <view class="control-chip {{orientationMode === 'north-up' ? 'control-chip--active' : ''}}" bindtap="handleSetNorthUpMode">北朝上</view>
  267. <view class="control-chip {{orientationMode === 'heading-up' ? 'control-chip--active' : ''}}" bindtap="handleSetHeadingUpMode">朝向朝上</view>
  268. </view>
  269. <view class="control-row">
  270. <view class="control-chip control-chip--secondary" bindtap="handleCycleNorthReferenceMode">{{northReferenceButtonText}}</view>
  271. </view>
  272. <view class="control-row" wx:if="{{orientationMode === 'heading-up'}}">
  273. <view class="control-chip" bindtap="handleAutoRotateCalibrate">按当前方向校准</view>
  274. </view>
  275. <view class="control-row" wx:if="{{orientationMode === 'manual'}}">
  276. <view class="control-chip" bindtap="handleRotateStep">旋转 +15°</view>
  277. </view>
  278. </scroll-view>
  279. </view>
  280. </view>
  281. </view>