map.wxml 54 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887
  1. <view class="page">
  2. <view
  3. class="app-edge-glow app-edge-glow--{{panelTelemetryTone}}"
  4. wx:if="{{panelTelemetryTone === 'orange' || panelTelemetryTone === 'red'}}"
  5. ></view>
  6. <view
  7. class="map-stage"
  8. catchtouchstart="handleTouchStart"
  9. catchtouchmove="handleTouchMove"
  10. catchtouchend="handleTouchEnd"
  11. catchtouchcancel="handleTouchCancel"
  12. >
  13. <view class="map-content">
  14. <canvas
  15. id="mapCanvas"
  16. type="webgl"
  17. canvas-id="mapCanvas"
  18. class="map-canvas map-canvas--base"
  19. ></canvas>
  20. <canvas
  21. id="routeLabelCanvas"
  22. type="2d"
  23. canvas-id="routeLabelCanvas"
  24. class="map-canvas map-canvas--labels"
  25. ></canvas>
  26. </view>
  27. <view class="map-stage__map-pulse {{mapPulseFxClass}}" wx:if="{{mapPulseVisible}}" style="left: {{mapPulseLeftPx}}px; top: {{mapPulseTopPx}}px;"></view>
  28. <view class="map-stage__stage-fx {{stageFxClass}}" wx:if="{{stageFxVisible}}"></view>
  29. <view class="game-punch-feedback game-punch-feedback--{{punchFeedbackTone}} {{punchFeedbackFxClass}}" wx:if="{{punchFeedbackVisible}}">{{punchFeedbackText}}</view>
  30. <view class="game-content-card {{contentCardFxClass}}" wx:if="{{contentCardVisible}}" bindtap="handleCloseContentCard">
  31. <view class="game-content-card__title">{{contentCardTitle}}</view>
  32. <view class="game-content-card__body">{{contentCardBody}}</view>
  33. <view class="game-content-card__hint">点击关闭</view>
  34. </view>
  35. <view class="map-stage__overlay-center-layer" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}">
  36. <view class="center-scale-ruler" wx:if="{{centerScaleRulerVisible}}" style="left: {{centerScaleRulerCenterXPx}}px; top: {{centerScaleRulerZeroYPx}}px; height: {{centerScaleRulerHeightPx}}px;">
  37. <view class="center-scale-ruler__axis" style="bottom: {{centerScaleRulerAxisBottomPx}}px;"></view>
  38. <view class="center-scale-ruler__arrow"></view>
  39. <view wx:if="{{centerScaleRulerZeroVisible}}" class="center-scale-ruler__tick center-scale-ruler__tick--major center-scale-ruler__tick--zero" style="top: {{centerScaleRulerHeightPx}}px;"></view>
  40. <view wx:if="{{centerScaleRulerZeroVisible}}" class="center-scale-ruler__label center-scale-ruler__label--zero" style="top: {{centerScaleRulerHeightPx}}px;">{{centerScaleRulerZeroLabel}}</view>
  41. <view wx:for="{{centerScaleRulerMinorTicks}}" wx:key="key" class="center-scale-ruler__tick {{item.long ? 'center-scale-ruler__tick--major' : ''}}" style="top: {{item.topPx}}px;"></view>
  42. <view wx:for="{{centerScaleRulerMajorMarks}}" wx:key="key" class="center-scale-ruler__label" style="top: {{item.topPx}}px;">{{item.label}}</view>
  43. </view>
  44. </view>
  45. <view class="map-stage__overlay" wx:if="{{!showResultScene}}">
  46. <view class="map-stage__bottom">
  47. <view class="compass-widget">
  48. <view class="compass-widget__heading-wrap">
  49. <view class="compass-widget__heading">{{sensorHeadingText}}</view>
  50. <view class="compass-widget__edge-arrow-wrap">
  51. <view class="compass-widget__edge-arrow"></view>
  52. </view>
  53. </view>
  54. <view class="compass-widget__dial {{orientationMode === 'heading-up' ? 'compass-widget__dial--active' : ''}}">
  55. <view class="compass-widget__glass"></view>
  56. <view class="compass-widget__inner-shadow"></view>
  57. <view class="compass-widget__card" style="transform: rotate({{rotationDeg}}deg);">
  58. <image class="compass-widget__north-arrow" src="../../assets/compass-north-arrow.svg" mode="aspectFit"></image>
  59. <view wx:for="{{compassTicks}}" wx:key="angle" class="compass-widget__tick-anchor" style="transform: translate(-50%, -50%) rotate({{item.angle}}deg);">
  60. <view class="compass-widget__tick {{item.long ? 'compass-widget__tick--long' : 'compass-widget__tick--short'}} {{item.major ? 'compass-widget__tick--major' : ''}}"></view>
  61. </view>
  62. <view wx:for="{{compassLabels}}" wx:key="text" class="compass-widget__mark-anchor" style="transform: translate(-50%, -50%) rotate({{item.angle}}deg);">
  63. <view class="compass-widget__mark {{item.className}}" style="transform: translate(-50%, -50%) translateY(-{{item.radius}}rpx) rotate({{item.rotateBack}}deg);">{{item.text}}</view>
  64. </view>
  65. </view>
  66. <view class="compass-widget__needle-anchor" style="transform: translate(-50%, -50%) rotate({{compassNeedleDeg}}deg);">
  67. <view class="compass-widget__needle-north"></view>
  68. <view class="compass-widget__needle-south"></view>
  69. </view>
  70. <view class="compass-widget__hub"></view>
  71. <view class="compass-widget__hub-core"></view>
  72. </view>
  73. <view class="compass-widget__hint" wx:if="{{compassDeclinationText}}">{{compassDeclinationText}}</view>
  74. </view>
  75. </view>
  76. </view>
  77. </view>
  78. <view class="game-punch-hint" wx:if="{{!showResultScene && showPunchHintBanner && punchHintText}}" style="top: {{topInsetHeight}}px;" catchtouchstart="handlePunchHintTap" catchtouchmove="handlePunchHintTap" catchtouchend="handlePunchHintTap">
  79. <view class="game-punch-hint__text">{{punchHintText}}</view>
  80. <view class="game-punch-hint__close" catchtouchstart="handlePunchHintTap" catchtouchmove="handlePunchHintTap" catchtouchend="handlePunchHintTap" catchtap="handleClosePunchHint">×</view>
  81. </view>
  82. <cover-view class="map-side-toggle {{sideButtonPlacement === 'right' ? 'map-side-toggle--right' : 'map-side-toggle--left'}}" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}" style="top: {{topInsetHeight}}px;" bindtap="handleCycleSideButtons">
  83. <cover-view class="map-side-button map-side-button--icon">
  84. <cover-image class="map-side-button__image" src="{{sideToggleIconSrc}}"></cover-image>
  85. </cover-view>
  86. </cover-view>
  87. <cover-view class="map-side-column {{sideButtonPlacement === 'right' ? 'map-side-column--right-group' : 'map-side-column--left'}} map-side-column--left-group" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel && showLeftButtonGroup}}" style="top: {{topInsetHeight}}px;">
  88. <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>
  89. <cover-view class="{{sideButton2Class}}" bindtap="handleToggleGpsLock">
  90. <cover-image
  91. wx:if="{{gpsLockEnabled}}"
  92. class="map-side-button__action-image"
  93. src="../../assets/btn_locked.png"
  94. ></cover-image>
  95. <cover-image
  96. wx:else
  97. class="map-side-button__action-image"
  98. src="../../assets/btn_unlock.png"
  99. ></cover-image>
  100. </cover-view>
  101. <cover-view class="{{sideButton16Class}}" bindtap="handleSkipAction"><cover-image class="map-side-button__action-image" src="../../assets/btn_skip_cp.png"></cover-image></cover-view>
  102. <cover-view class="{{sideButton11Class}}" bindtap="handleOpenGameInfoPanel"><cover-image class="map-side-button__action-image" src="../../assets/btn_info.png"></cover-image></cover-view>
  103. <cover-view class="{{sideButton12Class}}" bindtap="handleOpenSystemSettingsPanel"><cover-image class="map-side-button__action-image" src="../../assets/btn_settings.png"></cover-image></cover-view>
  104. <cover-view class="{{sideButton4Class}}" bindtap="handleForceExitGame"><cover-image class="map-side-button__action-image" src="../../assets/btn_exit.png"></cover-image></cover-view>
  105. </cover-view>
  106. <cover-view class="map-punch-button {{punchButtonEnabled ? 'map-punch-button--active' : ''}} {{punchButtonFxClass}}" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}" bindtap="handlePunchAction">
  107. <cover-view class="map-punch-button__text">{{punchButtonText}}</cover-view>
  108. </cover-view>
  109. <cover-view class="map-content-entry" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel && pendingContentEntryVisible}}" bindtap="handleOpenPendingContentCard">
  110. <cover-view class="map-content-entry__text">{{pendingContentEntryText}}</cover-view>
  111. </cover-view>
  112. <cover-view class="screen-button-layer screen-button-layer--start-left" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel && showBottomDebugButton && gameSessionStatus !== 'running'}}" bindtap="handleStartGame">
  113. <cover-view class="screen-button-layer__text screen-button-layer__text--start">开始</cover-view>
  114. </cover-view>
  115. <cover-view class="screen-button-layer screen-button-layer--bottom-left" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel && showBottomDebugButton}}" bindtap="handleToggleDebugPanel">
  116. <cover-view class="screen-button-layer__icon">
  117. <cover-view class="screen-button-layer__line"></cover-view>
  118. <cover-view class="screen-button-layer__stand"></cover-view>
  119. </cover-view>
  120. <cover-view class="screen-button-layer__text">调试</cover-view>
  121. </cover-view>
  122. <swiper wx:if="{{!showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}" class="race-panel-swiper" current="{{hudPanelIndex}}" bindchange="handleHudPanelChange" duration="220" easing-function="easeOutCubic">
  123. <swiper-item>
  124. <view class="race-panel race-panel--tone-{{panelTelemetryTone}}">
  125. <view class="race-panel__tag race-panel__tag--top-left">{{panelActionTagText}}</view>
  126. <view class="race-panel__tag race-panel__tag--top-right">里程</view>
  127. <view class="race-panel__tag race-panel__tag--bottom-left">{{panelDistanceTagText}}</view>
  128. <view class="race-panel__tag race-panel__tag--bottom-right">速度</view>
  129. <view class="race-panel__line race-panel__line--center"></view>
  130. <view class="race-panel__line race-panel__line--left-mid"></view>
  131. <view class="race-panel__line race-panel__line--right-mid"></view>
  132. <view class="race-panel__line race-panel__line--left-top"></view>
  133. <view class="race-panel__line race-panel__line--left-bottom"></view>
  134. <view class="race-panel__line race-panel__line--right-top"></view>
  135. <view class="race-panel__line race-panel__line--right-bottom"></view>
  136. <view class="race-panel__grid">
  137. <view class="race-panel__cell race-panel__cell--action">
  138. <view class="race-panel__action-button"><!-- status only -->
  139. <view class="race-panel__action-button-text">{{punchButtonText}}</view>
  140. </view>
  141. </view>
  142. <view class="race-panel__cell race-panel__cell--timer">
  143. <text class="race-panel__timer {{panelTimerFxClass}}">{{panelTimerText}}</text>
  144. </view>
  145. <view class="race-panel__cell race-panel__cell--mileage">
  146. <view class="race-panel__mileage-wrap {{panelMileageFxClass}}">
  147. <text class="race-panel__mileage">{{panelMileageText}}</text>
  148. <view class="race-panel__chevrons">
  149. <view class="race-panel__chevron"></view>
  150. <view class="race-panel__chevron race-panel__chevron--offset"></view>
  151. </view>
  152. </view>
  153. </view>
  154. <view class="race-panel__cell race-panel__cell--distance">
  155. <view class="race-panel__metric-group race-panel__metric-group--left {{panelDistanceFxClass}}">
  156. <text class="race-panel__metric-value race-panel__metric-value--distance">{{panelDistanceValueText}}</text>
  157. <text class="race-panel__metric-unit race-panel__metric-unit--distance">{{panelDistanceUnitText}}</text>
  158. </view>
  159. </view>
  160. <view class="race-panel__cell race-panel__cell--progress">
  161. <text class="race-panel__progress {{panelProgressFxClass}}">{{panelProgressText}}</text>
  162. </view>
  163. <view class="race-panel__cell race-panel__cell--speed">
  164. <view class="race-panel__metric-group race-panel__metric-group--right {{panelSpeedFxClass}}">
  165. <text class="race-panel__metric-value race-panel__metric-value--speed">{{panelSpeedValueText}}</text>
  166. <text class="race-panel__metric-unit race-panel__metric-unit--speed">km/h</text>
  167. </view>
  168. </view>
  169. </view>
  170. </view>
  171. </swiper-item>
  172. <swiper-item>
  173. <view class="race-panel race-panel--tone-{{panelTelemetryTone}}">
  174. <view class="race-panel__tag race-panel__tag--top-left">心率</view>
  175. <view class="race-panel__tag race-panel__tag--top-right">卡路里</view>
  176. <view class="race-panel__tag race-panel__tag--bottom-left">均速</view>
  177. <view class="race-panel__tag race-panel__tag--bottom-right">精度</view>
  178. <view class="race-panel__line race-panel__line--center"></view>
  179. <view class="race-panel__line race-panel__line--left-mid"></view>
  180. <view class="race-panel__line race-panel__line--right-mid"></view>
  181. <view class="race-panel__line race-panel__line--left-top"></view>
  182. <view class="race-panel__line race-panel__line--left-bottom"></view>
  183. <view class="race-panel__line race-panel__line--right-top"></view>
  184. <view class="race-panel__line race-panel__line--right-bottom"></view>
  185. <view class="race-panel__grid">
  186. <view class="race-panel__cell race-panel__cell--action">
  187. <view class="race-panel__metric-group race-panel__metric-group--left race-panel__metric-group--panel {{panelHeartRateFxClass}}">
  188. <text class="race-panel__metric-value race-panel__metric-value--telemetry">{{panelHeartRateValueText}}</text>
  189. <text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelHeartRateUnitText}}</text>
  190. </view>
  191. </view>
  192. <view class="race-panel__cell race-panel__cell--timer">
  193. <text class="race-panel__timer {{panelTimerFxClass}}">{{panelTimerText}}</text>
  194. </view>
  195. <view class="race-panel__cell race-panel__cell--mileage">
  196. <view class="race-panel__metric-group race-panel__metric-group--right race-panel__metric-group--panel">
  197. <text class="race-panel__metric-value race-panel__metric-value--telemetry">{{panelCaloriesValueText}}</text>
  198. <text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelCaloriesUnitText}}</text>
  199. </view>
  200. </view>
  201. <view class="race-panel__cell race-panel__cell--distance">
  202. <view class="race-panel__metric-group race-panel__metric-group--left race-panel__metric-group--panel">
  203. <text class="race-panel__metric-value race-panel__metric-value--telemetry-secondary">{{panelAverageSpeedValueText}}</text>
  204. <text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelAverageSpeedUnitText}}</text>
  205. </view>
  206. </view>
  207. <view class="race-panel__cell race-panel__cell--progress">
  208. <view class="race-panel__zone">
  209. <text class="race-panel__zone-name">{{panelHeartRateZoneNameText}}</text>
  210. <text class="race-panel__zone-range">{{panelHeartRateZoneRangeText}}</text>
  211. </view>
  212. </view>
  213. <view class="race-panel__cell race-panel__cell--speed">
  214. <view class="race-panel__metric-group race-panel__metric-group--right race-panel__metric-group--panel">
  215. <text class="race-panel__metric-value race-panel__metric-value--telemetry-secondary">{{panelAccuracyValueText}}</text>
  216. <text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelAccuracyUnitText}}</text>
  217. </view>
  218. </view>
  219. </view>
  220. </view>
  221. </swiper-item>
  222. </swiper>
  223. <view class="race-panel-pager" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}">
  224. <view class="race-panel-pager__dot {{hudPanelIndex === 0 ? 'race-panel-pager__dot--active' : ''}}"></view>
  225. <view class="race-panel-pager__dot {{hudPanelIndex === 1 ? 'race-panel-pager__dot--active' : ''}}"></view>
  226. </view>
  227. <view class="game-info-modal" wx:if="{{showGameInfoPanel}}" bindtap="handleCloseGameInfoPanel">
  228. <view class="game-info-modal__dialog" catchtap="handleGameInfoPanelTap">
  229. <view class="game-info-modal__header">
  230. <view class="game-info-modal__header-main">
  231. <view class="game-info-modal__eyebrow">GAME INFO</view>
  232. <view class="game-info-modal__title">{{gameInfoTitle}}</view>
  233. <view class="game-info-modal__subtitle">{{gameInfoSubtitle}}</view>
  234. </view>
  235. <view class="game-info-modal__header-actions">
  236. <view class="game-info-modal__close" bindtap="handleCloseGameInfoPanel">关闭</view>
  237. </view>
  238. </view>
  239. <scroll-view class="game-info-modal__content" scroll-y enhanced show-scrollbar="true">
  240. <view class="debug-section debug-section--info">
  241. <view class="debug-section__header">
  242. <view class="debug-section__title">Local</view>
  243. <view class="debug-section__desc">当前设备、本地玩法与实时运行状态</view>
  244. </view>
  245. <view class="info-panel__row" wx:for="{{gameInfoLocalRows}}" wx:key="label">
  246. <text class="info-panel__label">{{item.label}}</text>
  247. <text class="info-panel__value">{{item.value}}</text>
  248. </view>
  249. </view>
  250. <view class="debug-section debug-section--info">
  251. <view class="debug-section__header">
  252. <view class="debug-section__title">Global</view>
  253. <view class="debug-section__desc">联网后接入全局赛事数据,这里先占位</view>
  254. </view>
  255. <view class="info-panel__row" wx:for="{{gameInfoGlobalRows}}" wx:key="label">
  256. <text class="info-panel__label">{{item.label}}</text>
  257. <text class="info-panel__value">{{item.value}}</text>
  258. </view>
  259. </view>
  260. </scroll-view>
  261. </view>
  262. </view>
  263. <view class="result-scene-modal" wx:if="{{showResultScene}}" bindtap="handleCloseResultScene">
  264. <view class="result-scene-modal__dialog" catchtap="handleResultSceneTap">
  265. <view class="result-scene-modal__eyebrow">RESULT</view>
  266. <view class="result-scene-modal__title">{{resultSceneTitle}}</view>
  267. <view class="result-scene-modal__subtitle">{{resultSceneSubtitle}}</view>
  268. <view class="result-scene-modal__hero">
  269. <view class="result-scene-modal__hero-label">{{resultSceneHeroLabel}}</view>
  270. <view class="result-scene-modal__hero-value">{{resultSceneHeroValue}}</view>
  271. </view>
  272. <view class="result-scene-modal__rows">
  273. <view class="result-scene-modal__row" wx:for="{{resultSceneRows}}" wx:key="label">
  274. <text class="result-scene-modal__row-label">{{item.label}}</text>
  275. <text class="result-scene-modal__row-value">{{item.value}}</text>
  276. </view>
  277. </view>
  278. <view class="result-scene-modal__actions">
  279. <view class="result-scene-modal__action result-scene-modal__action--secondary" bindtap="handleCloseResultScene">返回地图</view>
  280. <view class="result-scene-modal__action result-scene-modal__action--primary" bindtap="handleRestartFromResult">再来一局</view>
  281. </view>
  282. </view>
  283. </view>
  284. <view class="game-info-modal" wx:if="{{showSystemSettingsPanel}}" bindtap="handleCloseSystemSettingsPanel">
  285. <view class="game-info-modal__dialog" catchtap="handleSystemSettingsPanelTap">
  286. <view class="game-info-modal__header">
  287. <view class="game-info-modal__header-main">
  288. <view class="game-info-modal__eyebrow">SYSTEM SETTINGS</view>
  289. <view class="game-info-modal__title">系统设置</view>
  290. <view class="game-info-modal__subtitle">用户端偏好与设备级选项</view>
  291. </view>
  292. <view class="game-info-modal__header-actions">
  293. <view class="game-info-modal__close" bindtap="handleCloseSystemSettingsPanel">关闭</view>
  294. </view>
  295. </view>
  296. <scroll-view class="game-info-modal__content" scroll-y enhanced show-scrollbar="true">
  297. <view class="debug-section debug-section--info">
  298. <view class="debug-section__header">
  299. <view class="debug-section__header-row">
  300. <view class="debug-section__header-main">
  301. <view class="debug-section__title">01. 动画性能</view>
  302. <view class="debug-section__desc">根据设备性能切换动画强度,低端机建议精简</view>
  303. </view>
  304. <view class="debug-section__lock {{lockAnimationLevel ? 'debug-section__lock--active' : ''}}" data-key="lockAnimationLevel" bindtap="handleToggleSettingLock">
  305. <text class="debug-section__lock-text">{{lockAnimationLevel ? '已锁' : '可改'}}</text>
  306. </view>
  307. </view>
  308. </view>
  309. <view class="info-panel__row">
  310. <text class="info-panel__label">当前级别</text>
  311. <text class="info-panel__value">{{animationLevel === 'lite' ? '精简' : '标准'}}{{lockAnimationLevel ? ' · 已锁定' : ' · 可编辑'}}</text>
  312. </view>
  313. <view class="control-row">
  314. <view class="control-chip {{animationLevel === 'standard' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAnimationLevel ? 'control-chip--disabled' : ''}}" bindtap="handleSetAnimationLevelStandard">标准</view>
  315. <view class="control-chip {{animationLevel === 'lite' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAnimationLevel ? 'control-chip--disabled' : ''}}" bindtap="handleSetAnimationLevelLite">精简</view>
  316. </view>
  317. </view>
  318. <view class="debug-section debug-section--info">
  319. <view class="debug-section__header">
  320. <view class="debug-section__header-row">
  321. <view class="debug-section__header-main">
  322. <view class="debug-section__title">02. 按钮习惯</view>
  323. <view class="debug-section__desc">切换功能按钮显示在左侧还是右侧,适配左手/右手操作习惯</view>
  324. </view>
  325. <view class="debug-section__lock {{lockSideButtonPlacement ? 'debug-section__lock--active' : ''}}" data-key="lockSideButtonPlacement" bindtap="handleToggleSettingLock">
  326. <text class="debug-section__lock-text">{{lockSideButtonPlacement ? '已锁' : '可改'}}</text>
  327. </view>
  328. </view>
  329. </view>
  330. <view class="info-panel__row">
  331. <text class="info-panel__label">当前习惯</text>
  332. <text class="info-panel__value">{{sideButtonPlacement === 'right' ? '右手' : '左手'}}{{lockSideButtonPlacement ? ' · 已锁定' : ' · 可编辑'}}</text>
  333. </view>
  334. <view class="control-row">
  335. <view class="control-chip {{sideButtonPlacement === 'left' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockSideButtonPlacement ? 'control-chip--disabled' : ''}}" bindtap="handleSetSideButtonPlacementLeft">左手</view>
  336. <view class="control-chip {{sideButtonPlacement === 'right' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockSideButtonPlacement ? 'control-chip--disabled' : ''}}" bindtap="handleSetSideButtonPlacementRight">右手</view>
  337. </view>
  338. </view>
  339. <view class="debug-section debug-section--info">
  340. <view class="debug-section__header">
  341. <view class="debug-section__header-row">
  342. <view class="debug-section__header-main">
  343. <view class="debug-section__title">03. 自动转图</view>
  344. <view class="debug-section__desc">控制地图是否跟随朝向自动旋转,外部按钮与这里保持同步</view>
  345. </view>
  346. <view class="debug-section__lock {{lockAutoRotate ? 'debug-section__lock--active' : ''}}" data-key="lockAutoRotate" bindtap="handleToggleSettingLock">
  347. <text class="debug-section__lock-text">{{lockAutoRotate ? '已锁' : '可改'}}</text>
  348. </view>
  349. </view>
  350. </view>
  351. <view class="info-panel__row">
  352. <text class="info-panel__label">当前状态</text>
  353. <text class="info-panel__value">{{autoRotateEnabled ? '开启' : '关闭'}}{{lockAutoRotate ? ' · 已锁定' : ' · 可编辑'}}</text>
  354. </view>
  355. <view class="control-row">
  356. <view class="control-chip {{autoRotateEnabled ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAutoRotate ? 'control-chip--disabled' : ''}}" bindtap="handleSetAutoRotateEnabledOn">开启</view>
  357. <view class="control-chip {{!autoRotateEnabled ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAutoRotate ? 'control-chip--disabled' : ''}}" bindtap="handleSetAutoRotateEnabledOff">关闭</view>
  358. </view>
  359. </view>
  360. <view class="debug-section debug-section--info">
  361. <view class="debug-section__header">
  362. <view class="debug-section__header-row">
  363. <view class="debug-section__header-main">
  364. <view class="debug-section__title">04. 指北针响应</view>
  365. <view class="debug-section__desc">切换指针的平滑与跟手程度,影响指北针响应手感</view>
  366. </view>
  367. <view class="debug-section__lock {{lockCompassTuning ? 'debug-section__lock--active' : ''}}" data-key="lockCompassTuning" bindtap="handleToggleSettingLock">
  368. <text class="debug-section__lock-text">{{lockCompassTuning ? '已锁' : '可改'}}</text>
  369. </view>
  370. </view>
  371. </view>
  372. <view class="info-panel__row">
  373. <text class="info-panel__label">当前档位</text>
  374. <text class="info-panel__value">{{compassTuningProfileText}}{{lockCompassTuning ? ' · 已锁定' : ' · 可编辑'}}</text>
  375. </view>
  376. <view class="control-row control-row--triple">
  377. <view class="control-chip {{compassTuningProfile === 'smooth' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockCompassTuning ? 'control-chip--disabled' : ''}}" bindtap="handleSetCompassTuningSmooth">顺滑</view>
  378. <view class="control-chip {{compassTuningProfile === 'balanced' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockCompassTuning ? 'control-chip--disabled' : ''}}" bindtap="handleSetCompassTuningBalanced">平衡</view>
  379. <view class="control-chip {{compassTuningProfile === 'responsive' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockCompassTuning ? 'control-chip--disabled' : ''}}" bindtap="handleSetCompassTuningResponsive">跟手</view>
  380. </view>
  381. </view>
  382. <view class="debug-section debug-section--info">
  383. <view class="debug-section__header">
  384. <view class="debug-section__header-row">
  385. <view class="debug-section__header-main">
  386. <view class="debug-section__title">05. 比例尺显示</view>
  387. <view class="debug-section__desc">控制比例尺显示与否,默认沿用你的本地偏好</view>
  388. </view>
  389. <view class="debug-section__lock {{lockScaleRulerVisible ? 'debug-section__lock--active' : ''}}" data-key="lockScaleRulerVisible" bindtap="handleToggleSettingLock">
  390. <text class="debug-section__lock-text">{{lockScaleRulerVisible ? '已锁' : '可改'}}</text>
  391. </view>
  392. </view>
  393. </view>
  394. <view class="info-panel__row">
  395. <text class="info-panel__label">当前状态</text>
  396. <text class="info-panel__value">{{showCenterScaleRuler ? '显示' : '隐藏'}}{{lockScaleRulerVisible ? ' · 已锁定' : ' · 可编辑'}}</text>
  397. </view>
  398. <view class="control-row">
  399. <view class="control-chip {{showCenterScaleRuler ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerVisible ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerVisibleOn">显示</view>
  400. <view class="control-chip {{!showCenterScaleRuler ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerVisible ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerVisibleOff">隐藏</view>
  401. </view>
  402. </view>
  403. <view class="debug-section debug-section--info">
  404. <view class="debug-section__header">
  405. <view class="debug-section__header-row">
  406. <view class="debug-section__header-main">
  407. <view class="debug-section__title">06. 比例尺基准点</view>
  408. <view class="debug-section__desc">设置比例尺零点锚定位置,可跟随屏幕中心或指北针圆心</view>
  409. </view>
  410. <view class="debug-section__lock {{lockScaleRulerAnchor ? 'debug-section__lock--active' : ''}}" data-key="lockScaleRulerAnchor" bindtap="handleToggleSettingLock">
  411. <text class="debug-section__lock-text">{{lockScaleRulerAnchor ? '已锁' : '可改'}}</text>
  412. </view>
  413. </view>
  414. </view>
  415. <view class="info-panel__row">
  416. <text class="info-panel__label">当前锚点</text>
  417. <text class="info-panel__value">{{centerScaleRulerAnchorMode === 'compass-center' ? '指北针圆心' : '屏幕中心'}}{{lockScaleRulerAnchor ? ' · 已锁定' : ' · 可编辑'}}</text>
  418. </view>
  419. <view class="control-row">
  420. <view class="control-chip {{centerScaleRulerAnchorMode === 'screen-center' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerAnchor ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerAnchorScreenCenter">屏幕中心</view>
  421. <view class="control-chip {{centerScaleRulerAnchorMode === 'compass-center' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerAnchor ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerAnchorCompassCenter">指北针圆心</view>
  422. </view>
  423. </view>
  424. <view class="debug-section debug-section--info">
  425. <view class="debug-section__header">
  426. <view class="debug-section__header-row">
  427. <view class="debug-section__header-main">
  428. <view class="debug-section__title">07. 北参考</view>
  429. <view class="debug-section__desc">切换磁北/真北作为地图与指北针参考</view>
  430. </view>
  431. <view class="debug-section__lock {{lockNorthReference ? 'debug-section__lock--active' : ''}}" data-key="lockNorthReference" bindtap="handleToggleSettingLock">
  432. <text class="debug-section__lock-text">{{lockNorthReference ? '已锁' : '可改'}}</text>
  433. </view>
  434. </view>
  435. </view>
  436. <view class="info-panel__row">
  437. <text class="info-panel__label">当前参考</text>
  438. <text class="info-panel__value">{{northReferenceText}}{{lockNorthReference ? ' · 已锁定' : ' · 可编辑'}}</text>
  439. </view>
  440. <view class="control-row">
  441. <view class="control-chip {{northReferenceMode === 'magnetic' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockNorthReference ? 'control-chip--disabled' : ''}}" bindtap="handleSetNorthReferenceMagnetic">磁北</view>
  442. <view class="control-chip {{northReferenceMode === 'true' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockNorthReference ? 'control-chip--disabled' : ''}}" bindtap="handleSetNorthReferenceTrue">真北</view>
  443. </view>
  444. </view>
  445. <view class="debug-section debug-section--info">
  446. <view class="debug-section__header">
  447. <view class="debug-section__header-row">
  448. <view class="debug-section__header-main">
  449. <view class="debug-section__title">08. 心率设备</view>
  450. <view class="debug-section__desc">清除已记住的首选心率带设备,下次重新选择</view>
  451. </view>
  452. <view class="debug-section__lock {{lockHeartRateDevice ? 'debug-section__lock--active' : ''}}" data-key="lockHeartRateDevice" bindtap="handleToggleSettingLock">
  453. <text class="debug-section__lock-text">{{lockHeartRateDevice ? '已锁' : '可改'}}</text>
  454. </view>
  455. </view>
  456. </view>
  457. <view class="control-row">
  458. <view class="control-chip control-chip--secondary {{lockHeartRateDevice ? 'control-chip--disabled' : ''}}" bindtap="handleClearPreferredHeartRateDevice">清除首选设备</view>
  459. </view>
  460. </view>
  461. </scroll-view>
  462. </view>
  463. </view>
  464. <view class="debug-modal" wx:if="{{showDebugPanel}}" bindtap="handleCloseDebugPanel">
  465. <view class="debug-modal__dialog" catchtap="handleDebugPanelTap">
  466. <view class="debug-modal__header">
  467. <view class="debug-modal__header-main">
  468. <view class="debug-modal__eyebrow">DEBUG PANEL</view>
  469. <view class="debug-modal__build">{{buildVersion}}</view>
  470. </view>
  471. <view class="debug-modal__header-actions">
  472. <view class="debug-modal__close" bindtap="handleCloseDebugPanel">关闭</view>
  473. </view>
  474. </view>
  475. <scroll-view class="debug-modal__content" scroll-y enhanced show-scrollbar="true">
  476. <view class="debug-section">
  477. <view class="debug-section__header">
  478. <view class="debug-section__title">Session</view>
  479. <view class="debug-section__desc">当前局状态与主流程控制</view>
  480. </view>
  481. <view class="info-panel__row">
  482. <text class="info-panel__label">Mode</text>
  483. <text class="info-panel__value">{{gameModeText}}</text>
  484. </view>
  485. <view class="info-panel__row">
  486. <text class="info-panel__label">Config</text>
  487. <text class="info-panel__value">{{configSourceText}}</text>
  488. </view>
  489. <view class="info-panel__row">
  490. <text class="info-panel__label">Game</text>
  491. <text class="info-panel__value">{{gameSessionStatus}}</text>
  492. </view>
  493. <view class="info-panel__row">
  494. <text class="info-panel__label">Progress</text>
  495. <text class="info-panel__value">{{panelProgressText}}</text>
  496. </view>
  497. <view class="info-panel__row">
  498. <text class="info-panel__label">Timer</text>
  499. <text class="info-panel__value">{{panelTimerText}}</text>
  500. </view>
  501. <view class="info-panel__row info-panel__row--stack">
  502. <text class="info-panel__label">Punch Hint</text>
  503. <text class="info-panel__value">{{punchHintText}}</text>
  504. </view>
  505. <view class="control-row">
  506. <view class="control-chip {{configSourceText === '顺序赛配置' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleLoadClassicConfig">顺序赛配置</view>
  507. <view class="control-chip {{configSourceText === '积分赛配置' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleLoadScoreOConfig">积分赛配置</view>
  508. </view>
  509. <view class="control-row">
  510. <view class="control-chip control-chip--primary" bindtap="handleRecenter">回到首屏</view>
  511. <view class="control-chip control-chip--secondary" bindtap="handleRotationReset">旋转归零</view>
  512. </view>
  513. <view class="control-row">
  514. <view class="control-chip control-chip--secondary" bindtap="handleClearMapTestArtifacts">清空测试痕迹</view>
  515. </view>
  516. </view>
  517. <view class="debug-section">
  518. <view class="debug-section__header">
  519. <view class="debug-section__title">Sensors</view>
  520. <view class="debug-section__desc">定位、罗盘与心率带连接状态</view>
  521. </view>
  522. <view class="control-row">
  523. <view class="control-chip control-chip--primary" bindtap="handleConnectAllMockSources">一键连接模拟源</view>
  524. <view class="control-chip control-chip--secondary" bindtap="handleOpenWebViewTest">测试 H5</view>
  525. </view>
  526. <view class="debug-group-title">定位</view>
  527. <view class="info-panel__row">
  528. <text class="info-panel__label">GPS</text>
  529. <text class="info-panel__value">{{gpsTrackingText}}</text>
  530. </view>
  531. <view class="info-panel__row">
  532. <text class="info-panel__label">Location Source</text>
  533. <text class="info-panel__value">{{locationSourceText}}</text>
  534. </view>
  535. <view class="info-panel__row info-panel__row--stack">
  536. <text class="info-panel__label">GPS Coord</text>
  537. <text class="info-panel__value">{{gpsCoordText}}</text>
  538. </view>
  539. <view class="info-panel__row info-panel__row--stack">
  540. <text class="info-panel__label">Mock Bridge</text>
  541. <text class="info-panel__value">{{mockBridgeStatusText}}</text>
  542. </view>
  543. <view class="info-panel__row info-panel__row--stack">
  544. <text class="info-panel__label">Mock URL</text>
  545. <view class="debug-inline-stack">
  546. <input
  547. class="debug-input"
  548. value="{{mockBridgeUrlDraft}}"
  549. placeholder="ws://192.168.x.x:17865/mock-gps"
  550. bindinput="handleMockBridgeUrlInput"
  551. />
  552. <view class="control-row control-row--compact">
  553. <view class="control-chip control-chip--secondary" bindtap="handleSaveMockBridgeUrl">保存地址</view>
  554. <view class="control-chip {{mockBridgeConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectMockLocationBridge">连接模拟源</view>
  555. <view class="control-chip control-chip--secondary" bindtap="handleDisconnectMockLocationBridge">断开模拟源</view>
  556. </view>
  557. </view>
  558. </view>
  559. <view class="info-panel__row info-panel__row--stack">
  560. <text class="info-panel__label">Mock Coord</text>
  561. <text class="info-panel__value">{{mockCoordText}}</text>
  562. </view>
  563. <view class="info-panel__row">
  564. <text class="info-panel__label">Mock Speed</text>
  565. <text class="info-panel__value">{{mockSpeedText}}</text>
  566. </view>
  567. <view class="control-row">
  568. <view class="control-chip {{gpsTracking ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleToggleGpsTracking">{{gpsTracking ? '停止定位' : '开启定位'}}</view>
  569. </view>
  570. <view class="control-row">
  571. <view class="control-chip {{locationSourceMode === 'real' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetRealLocationMode">真实定位</view>
  572. <view class="control-chip {{locationSourceMode === 'mock' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetMockLocationMode">模拟定位</view>
  573. </view>
  574. <view class="debug-group-title">心率</view>
  575. <view class="info-panel__row">
  576. <text class="info-panel__label">Heart Rate</text>
  577. <text class="info-panel__value">{{heartRateStatusText}}</text>
  578. </view>
  579. <view class="info-panel__row">
  580. <text class="info-panel__label">Heart Source</text>
  581. <text class="info-panel__value">{{heartRateSourceText}}</text>
  582. </view>
  583. <view class="info-panel__row info-panel__row--stack">
  584. <text class="info-panel__label">HR Device</text>
  585. <text class="info-panel__value">{{heartRateDeviceText}}</text>
  586. </view>
  587. <view class="control-row">
  588. <view class="control-chip {{heartRateSourceMode === 'real' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetRealHeartRateMode">真实心率</view>
  589. <view class="control-chip {{heartRateSourceMode === 'mock' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetMockHeartRateMode">模拟心率</view>
  590. </view>
  591. <view class="info-panel__row" wx:if="{{heartRateSourceMode === 'real'}}">
  592. <text class="info-panel__label">HR Scan</text>
  593. <text class="info-panel__value">{{heartRateScanText}}</text>
  594. </view>
  595. <view class="debug-device-list" wx:if="{{heartRateSourceMode === 'real' && heartRateDiscoveredDevices.length}}">
  596. <view class="debug-device-card" wx:for="{{heartRateDiscoveredDevices}}" wx:key="deviceId">
  597. <view class="debug-device-card__main">
  598. <view class="debug-device-card__title-row">
  599. <text class="debug-device-card__name">{{item.name}}</text>
  600. <text class="debug-device-card__badge" wx:if="{{item.preferred}}">首选</text>
  601. </view>
  602. <text class="debug-device-card__meta">{{item.rssiText}}</text>
  603. </view>
  604. <view class="debug-device-card__action {{item.connected ? 'debug-device-card__action--active' : ''}}" data-device-id="{{item.deviceId}}" bindtap="handleConnectHeartRateDevice">{{item.connected ? '已连接' : '连接'}}</view>
  605. </view>
  606. </view>
  607. <view class="control-row" wx:if="{{heartRateSourceMode === 'real'}}">
  608. <view class="control-chip {{heartRateConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectHeartRate">{{heartRateConnected ? '心率带已连接' : '连接心率带'}}</view>
  609. <view class="control-chip control-chip--secondary" bindtap="handleDisconnectHeartRate">断开心率带</view>
  610. </view>
  611. <view class="control-row" wx:if="{{heartRateSourceMode === 'real'}}">
  612. <view class="control-chip control-chip--secondary" bindtap="handleClearPreferredHeartRateDevice">清除首选</view>
  613. </view>
  614. <view class="info-panel__row info-panel__row--stack" wx:if="{{heartRateSourceMode === 'mock'}}">
  615. <text class="info-panel__label">Mock HR Bridge</text>
  616. <text class="info-panel__value">{{mockHeartRateBridgeStatusText}}</text>
  617. </view>
  618. <view class="info-panel__row info-panel__row--stack" wx:if="{{heartRateSourceMode === 'mock'}}">
  619. <text class="info-panel__label">Mock HR URL</text>
  620. <view class="debug-inline-stack">
  621. <input
  622. class="debug-input"
  623. value="{{mockHeartRateBridgeUrlDraft}}"
  624. placeholder="ws://192.168.x.x:17865/mock-gps"
  625. bindinput="handleMockHeartRateBridgeUrlInput"
  626. />
  627. <view class="control-row control-row--compact">
  628. <view class="control-chip control-chip--secondary" bindtap="handleSaveMockHeartRateBridgeUrl">保存地址</view>
  629. <view class="control-chip {{mockHeartRateBridgeConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectMockHeartRateBridge">连接模拟心率源</view>
  630. <view class="control-chip control-chip--secondary" bindtap="handleDisconnectMockHeartRateBridge">断开模拟心率源</view>
  631. </view>
  632. </view>
  633. </view>
  634. <view class="info-panel__row" wx:if="{{heartRateSourceMode === 'mock'}}">
  635. <text class="info-panel__label">Mock BPM</text>
  636. <text class="info-panel__value">{{mockHeartRateText}}</text>
  637. </view>
  638. <view class="debug-group-title">方向</view>
  639. <view class="info-panel__row">
  640. <text class="info-panel__label">Heading Mode</text>
  641. <text class="info-panel__value">{{orientationModeText}}</text>
  642. </view>
  643. <view class="info-panel__row">
  644. <text class="info-panel__label">Sensor Heading</text>
  645. <text class="info-panel__value">{{sensorHeadingText}}</text>
  646. </view>
  647. <view class="info-panel__row">
  648. <text class="info-panel__label">Device Heading</text>
  649. <text class="info-panel__value">{{deviceHeadingText}}</text>
  650. </view>
  651. <view class="info-panel__row">
  652. <text class="info-panel__label">Pose</text>
  653. <text class="info-panel__value">{{devicePoseText}}</text>
  654. </view>
  655. <view class="info-panel__row">
  656. <text class="info-panel__label">Heading Confidence</text>
  657. <text class="info-panel__value">{{headingConfidenceText}}</text>
  658. </view>
  659. <view class="info-panel__row">
  660. <text class="info-panel__label">Compass Source</text>
  661. <text class="info-panel__value">{{compassSourceText}}</text>
  662. </view>
  663. <view class="info-panel__row">
  664. <text class="info-panel__label">Compass Tune</text>
  665. <text class="info-panel__value">{{compassTuningProfileText}}</text>
  666. </view>
  667. <view class="info-panel__row info-panel__row--stack">
  668. <text class="info-panel__label">Accel</text>
  669. <text class="info-panel__value">{{accelerometerText}}</text>
  670. </view>
  671. <view class="info-panel__row info-panel__row--stack">
  672. <text class="info-panel__label">Gyro</text>
  673. <text class="info-panel__value">{{gyroscopeText}}</text>
  674. </view>
  675. <view class="info-panel__row info-panel__row--stack">
  676. <text class="info-panel__label">Motion</text>
  677. <text class="info-panel__value">{{deviceMotionText}}</text>
  678. </view>
  679. <view class="info-panel__row info-panel__row--stack">
  680. <text class="info-panel__label">North Ref</text>
  681. <text class="info-panel__value">{{northReferenceText}}</text>
  682. </view>
  683. <view class="control-row">
  684. <view class="control-chip control-chip--secondary" bindtap="handleCycleNorthReferenceMode">{{northReferenceButtonText}}</view>
  685. </view>
  686. </view>
  687. <view class="debug-section">
  688. <view class="debug-section__header">
  689. <view class="debug-section__title">Telemetry</view>
  690. <view class="debug-section__desc">HUD 派生数据与心率颜色测试</view>
  691. </view>
  692. <view class="info-panel__row">
  693. <text class="info-panel__label">HR</text>
  694. <text class="info-panel__value">{{panelHeartRateValueText}} {{panelHeartRateUnitText}}</text>
  695. </view>
  696. <view class="info-panel__row">
  697. <text class="info-panel__label">HR Zone</text>
  698. <text class="info-panel__value">{{panelHeartRateZoneNameText}} {{panelHeartRateZoneRangeText}}</text>
  699. </view>
  700. <view class="info-panel__row">
  701. <text class="info-panel__label">Calories</text>
  702. <text class="info-panel__value">{{panelCaloriesValueText}} {{panelCaloriesUnitText}}</text>
  703. </view>
  704. <view class="info-panel__row">
  705. <text class="info-panel__label">Speed</text>
  706. <text class="info-panel__value">{{panelSpeedValueText}} km/h</text>
  707. </view>
  708. <view class="info-panel__row">
  709. <text class="info-panel__label">Avg Speed</text>
  710. <text class="info-panel__value">{{panelAverageSpeedValueText}} {{panelAverageSpeedUnitText}}</text>
  711. </view>
  712. <view class="info-panel__row">
  713. <text class="info-panel__label">Target Dist</text>
  714. <text class="info-panel__value">{{panelDistanceValueText}} {{panelDistanceUnitText}}</text>
  715. </view>
  716. <view class="info-panel__row">
  717. <text class="info-panel__label">Accuracy</text>
  718. <text class="info-panel__value">{{panelAccuracyValueText}} {{panelAccuracyUnitText}}</text>
  719. </view>
  720. <view class="control-row control-row--triple">
  721. <view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateBlue">蓝</view>
  722. <view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRatePurple">紫</view>
  723. <view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateGreen">绿</view>
  724. </view>
  725. <view class="control-row control-row--triple">
  726. <view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateYellow">黄</view>
  727. <view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateOrange">橙</view>
  728. <view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateRed">红</view>
  729. </view>
  730. <view class="control-row">
  731. <view class="control-chip control-chip--secondary" bindtap="handleClearDebugHeartRate">清除</view>
  732. </view>
  733. </view>
  734. <view class="debug-section">
  735. <view class="debug-section__header">
  736. <view class="debug-section__title">Rendering</view>
  737. <view class="debug-section__desc">地图渲染、视角与参考图层</view>
  738. </view>
  739. <view class="info-panel__row">
  740. <text class="info-panel__label">Renderer</text>
  741. <text class="info-panel__value">{{renderMode}}</text>
  742. </view>
  743. <view class="info-panel__row info-panel__row--stack">
  744. <text class="info-panel__label">Projection</text>
  745. <text class="info-panel__value">{{projectionMode}}</text>
  746. </view>
  747. <view class="info-panel__row">
  748. <text class="info-panel__label">Zoom</text>
  749. <text class="info-panel__value">{{zoom}}</text>
  750. </view>
  751. <view class="info-panel__row">
  752. <text class="info-panel__label">Rotation</text>
  753. <text class="info-panel__value">{{rotationText}}</text>
  754. </view>
  755. <view class="info-panel__row">
  756. <text class="info-panel__label">Auto Source</text>
  757. <text class="info-panel__value">{{autoRotateSourceText}}</text>
  758. </view>
  759. <view class="info-panel__row">
  760. <text class="info-panel__label">Calibration</text>
  761. <text class="info-panel__value">{{autoRotateCalibrationText}}</text>
  762. </view>
  763. <view class="control-row">
  764. <view class="control-chip {{osmReferenceEnabled ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleToggleOsmReference">{{osmReferenceText}}</view>
  765. <view class="control-chip" wx:if="{{orientationMode === 'manual'}}" bindtap="handleRotateStep">旋转 +15°</view>
  766. </view>
  767. <view class="control-row control-row--triple">
  768. <view class="control-chip {{orientationMode === 'manual' ? 'control-chip--active' : ''}}" bindtap="handleSetManualMode">手动</view>
  769. <view class="control-chip {{orientationMode === 'north-up' ? 'control-chip--active' : ''}}" bindtap="handleSetNorthUpMode">北朝上</view>
  770. <view class="control-chip {{orientationMode === 'heading-up' ? 'control-chip--active' : ''}}" bindtap="handleSetHeadingUpMode">朝向朝上</view>
  771. </view>
  772. <view class="control-row" wx:if="{{orientationMode === 'heading-up'}}">
  773. <view class="control-chip" bindtap="handleAutoRotateCalibrate">按当前方向校准</view>
  774. </view>
  775. </view>
  776. <view class="debug-section">
  777. <view class="debug-section__header">
  778. <view class="debug-section__title">Diagnostics</view>
  779. <view class="debug-section__desc">配置、瓦片缓存与运行状态</view>
  780. </view>
  781. <view class="info-panel__row info-panel__row--stack">
  782. <text class="info-panel__label">Config</text>
  783. <text class="info-panel__value">{{configStatusText}}</text>
  784. </view>
  785. <view class="info-panel__row info-panel__row--stack">
  786. <text class="info-panel__label">Status</text>
  787. <text class="info-panel__value">{{statusText}}</text>
  788. </view>
  789. <view class="info-panel__row info-panel__row--stack">
  790. <text class="info-panel__label">Tile URL</text>
  791. <text class="info-panel__value">{{tileSource}}</text>
  792. </view>
  793. <view class="info-panel__row">
  794. <text class="info-panel__label">Center Tile</text>
  795. <text class="info-panel__value">{{centerText}}</text>
  796. </view>
  797. <view class="info-panel__row">
  798. <text class="info-panel__label">Tile Size</text>
  799. <text class="info-panel__value">{{tileSizePx}}px</text>
  800. </view>
  801. <view class="info-panel__row">
  802. <text class="info-panel__label">Visible Tiles</text>
  803. <text class="info-panel__value">{{visibleTileCount}}</text>
  804. </view>
  805. <view class="info-panel__row">
  806. <text class="info-panel__label">Ready Tiles</text>
  807. <text class="info-panel__value">{{readyTileCount}}</text>
  808. </view>
  809. <view class="info-panel__row">
  810. <text class="info-panel__label">Memory Tiles</text>
  811. <text class="info-panel__value">{{memoryTileCount}}</text>
  812. </view>
  813. <view class="info-panel__row">
  814. <text class="info-panel__label">Disk Tiles</text>
  815. <text class="info-panel__value">{{diskTileCount}}</text>
  816. </view>
  817. <view class="info-panel__row">
  818. <text class="info-panel__label">Cache Hit</text>
  819. <text class="info-panel__value">{{cacheHitRateText}}</text>
  820. </view>
  821. <view class="info-panel__row">
  822. <text class="info-panel__label">Disk Hits</text>
  823. <text class="info-panel__value">{{diskHitCount}}</text>
  824. </view>
  825. <view class="info-panel__row">
  826. <text class="info-panel__label">Net Fetches</text>
  827. <text class="info-panel__value">{{networkFetchCount}}</text>
  828. </view>
  829. </view>
  830. </scroll-view>
  831. </view>
  832. </view>
  833. </view>