1219 lines
78 KiB
Plaintext
1219 lines
78 KiB
Plaintext
<view class="page">
|
||
<view
|
||
class="app-edge-glow app-edge-glow--{{panelTelemetryTone}}"
|
||
wx:if="{{panelTelemetryTone === 'orange' || panelTelemetryTone === 'red'}}"
|
||
></view>
|
||
<view
|
||
class="map-stage"
|
||
catchtouchstart="handleTouchStart"
|
||
catchtouchmove="handleTouchMove"
|
||
catchtouchend="handleTouchEnd"
|
||
catchtouchcancel="handleTouchCancel"
|
||
>
|
||
<view class="map-content">
|
||
<canvas
|
||
id="mapCanvas"
|
||
type="webgl"
|
||
canvas-id="mapCanvas"
|
||
class="map-canvas map-canvas--base"
|
||
></canvas>
|
||
<canvas
|
||
id="routeLabelCanvas"
|
||
type="2d"
|
||
canvas-id="routeLabelCanvas"
|
||
class="map-canvas map-canvas--labels"
|
||
></canvas>
|
||
</view>
|
||
|
||
<view class="map-stage__map-pulse {{mapPulseFxClass}}" wx:if="{{mapPulseVisible}}" style="left: {{mapPulseLeftPx}}px; top: {{mapPulseTopPx}}px;"></view>
|
||
<view class="map-stage__stage-fx {{stageFxClass}}" wx:if="{{stageFxVisible}}"></view>
|
||
|
||
<view class="game-punch-feedback game-punch-feedback--{{punchFeedbackTone}} {{punchFeedbackFxClass}}" wx:if="{{punchFeedbackVisible}}">{{punchFeedbackText}}</view>
|
||
<view class="map-stage__overlay-center-layer" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}">
|
||
<view class="center-scale-ruler" wx:if="{{centerScaleRulerVisible}}" style="left: {{centerScaleRulerCenterXPx}}px; top: {{centerScaleRulerZeroYPx}}px; height: {{centerScaleRulerHeightPx}}px;">
|
||
<view class="center-scale-ruler__axis" style="bottom: {{centerScaleRulerAxisBottomPx}}px;"></view>
|
||
<view class="center-scale-ruler__arrow"></view>
|
||
<view wx:if="{{centerScaleRulerZeroVisible}}" class="center-scale-ruler__tick center-scale-ruler__tick--major center-scale-ruler__tick--zero" style="top: {{centerScaleRulerHeightPx}}px;"></view>
|
||
<view wx:if="{{centerScaleRulerZeroVisible}}" class="center-scale-ruler__label center-scale-ruler__label--zero" style="top: {{centerScaleRulerHeightPx}}px;">{{centerScaleRulerZeroLabel}}</view>
|
||
<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>
|
||
<view wx:for="{{centerScaleRulerMajorMarks}}" wx:key="key" class="center-scale-ruler__label" style="top: {{item.topPx}}px;">{{item.label}}</view>
|
||
</view>
|
||
</view>
|
||
<view class="map-stage__overlay" wx:if="{{!showResultScene}}">
|
||
<view class="map-stage__bottom">
|
||
<view class="compass-widget">
|
||
<view class="compass-widget__heading-wrap">
|
||
<view class="compass-widget__heading">{{sensorHeadingText}}</view>
|
||
<view class="compass-widget__edge-arrow-wrap">
|
||
<view class="compass-widget__edge-arrow"></view>
|
||
</view>
|
||
</view>
|
||
<view class="compass-widget__dial {{orientationMode === 'heading-up' ? 'compass-widget__dial--active' : ''}}">
|
||
<view class="compass-widget__glass"></view>
|
||
<view class="compass-widget__inner-shadow"></view>
|
||
<view class="compass-widget__card" style="transform: rotate({{rotationDeg}}deg);">
|
||
<image class="compass-widget__north-arrow" src="../../assets/compass-north-arrow.svg" mode="aspectFit"></image>
|
||
<view wx:for="{{compassTicks}}" wx:key="angle" class="compass-widget__tick-anchor" style="transform: translate(-50%, -50%) rotate({{item.angle}}deg);">
|
||
<view class="compass-widget__tick {{item.long ? 'compass-widget__tick--long' : 'compass-widget__tick--short'}} {{item.major ? 'compass-widget__tick--major' : ''}}"></view>
|
||
</view>
|
||
<view wx:for="{{compassLabels}}" wx:key="text" class="compass-widget__mark-anchor" style="transform: translate(-50%, -50%) rotate({{item.angle}}deg);">
|
||
<view class="compass-widget__mark {{item.className}}" style="transform: translate(-50%, -50%) translateY(-{{item.radius}}rpx) rotate({{item.rotateBack}}deg);">{{item.text}}</view>
|
||
</view>
|
||
</view>
|
||
<view class="compass-widget__needle-anchor" style="transform: translate(-50%, -50%) rotate({{compassNeedleDeg}}deg);">
|
||
<view class="compass-widget__needle-north"></view>
|
||
<view class="compass-widget__needle-south"></view>
|
||
</view>
|
||
<view class="compass-widget__hub"></view>
|
||
<view class="compass-widget__hub-core"></view>
|
||
</view>
|
||
<view class="compass-widget__hint" wx:if="{{compassDeclinationText}}">{{compassDeclinationText}}</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="game-content-card-layer" wx:if="{{contentCardVisible}}" bindtap="handleDismissTransientContentCard">
|
||
<view
|
||
class="game-content-card game-content-card--{{contentCardTemplate}} {{contentCardFxClass}}"
|
||
catchtap="handleContentCardTap"
|
||
>
|
||
<view class="game-content-card__title">{{contentCardTitle}}</view>
|
||
<view class="game-content-card__body">{{contentCardBody}}</view>
|
||
<view wx:if="{{contentCardActions.length}}" class="game-content-card__action-row game-content-card__action-row--split">
|
||
<view class="game-content-card__cta-group" wx:if="{{contentCardActions.length}}">
|
||
<view
|
||
wx:for="{{contentCardActions}}"
|
||
wx:key="key"
|
||
class="game-content-card__action"
|
||
data-type="{{item.type}}"
|
||
data-key="{{item.key}}"
|
||
catchtap="handleOpenContentCardAction"
|
||
>{{item.label}}</view>
|
||
</view>
|
||
<view class="game-content-card__close" catchtap="handleCloseContentCard">关闭</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="game-content-quiz" wx:if="{{contentQuizVisible}}">
|
||
<view class="game-content-quiz__panel">
|
||
<view class="game-content-quiz__header">
|
||
<view class="game-content-quiz__title">答题加分</view>
|
||
<view class="game-content-quiz__countdown">{{contentQuizCountdownText}}</view>
|
||
</view>
|
||
<view class="game-content-quiz__question">{{contentQuizQuestionText}}</view>
|
||
<view class="game-content-quiz__options">
|
||
<view
|
||
wx:for="{{contentQuizOptions}}"
|
||
wx:key="key"
|
||
class="game-content-quiz__option"
|
||
data-key="{{item.key}}"
|
||
catchtap="handleContentQuizAnswer"
|
||
>{{item.label}}</view>
|
||
</view>
|
||
<view
|
||
wx:if="{{contentQuizFeedbackVisible}}"
|
||
class="game-content-quiz__feedback game-content-quiz__feedback--{{contentQuizFeedbackTone}}"
|
||
>{{contentQuizFeedbackText}}</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="game-punch-hint {{punchHintFxClass}}" wx:if="{{!showResultScene && !contentCardVisible && !contentQuizVisible && showPunchHintBanner && punchHintText}}" style="top: {{topInsetHeight}}px;" catchtouchstart="handlePunchHintTap" catchtouchmove="handlePunchHintTap" catchtouchend="handlePunchHintTap">
|
||
<view class="game-punch-hint__text">{{punchHintText}}</view>
|
||
<view class="game-punch-hint__close" catchtouchstart="handlePunchHintTap" catchtouchmove="handlePunchHintTap" catchtouchend="handlePunchHintTap" catchtap="handleClosePunchHint">×</view>
|
||
</view>
|
||
|
||
<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">
|
||
<cover-view class="map-side-button map-side-button--icon">
|
||
<cover-image class="map-side-button__image" src="{{sideToggleIconSrc}}"></cover-image>
|
||
</cover-view>
|
||
</cover-view>
|
||
|
||
<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;">
|
||
<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>
|
||
<cover-view class="{{sideButton2Class}}" bindtap="handleToggleGpsLock">
|
||
<cover-image
|
||
wx:if="{{gpsLockEnabled}}"
|
||
class="map-side-button__action-image"
|
||
src="../../assets/btn_locked.png"
|
||
></cover-image>
|
||
<cover-image
|
||
wx:else
|
||
class="map-side-button__action-image"
|
||
src="../../assets/btn_unlock.png"
|
||
></cover-image>
|
||
</cover-view>
|
||
<cover-view class="{{sideButton16Class}}" bindtap="handleSkipAction"><cover-image class="map-side-button__action-image" src="../../assets/btn_skip_cp.png"></cover-image></cover-view>
|
||
<cover-view class="{{sideButton11Class}}" bindtap="handleOpenGameInfoPanel"><cover-image class="map-side-button__action-image" src="../../assets/btn_info.png"></cover-image></cover-view>
|
||
<cover-view class="{{sideButton12Class}}" bindtap="handleOpenSystemSettingsPanel"><cover-image class="map-side-button__action-image" src="../../assets/btn_settings.png"></cover-image></cover-view>
|
||
<cover-view class="{{sideButton4Class}}" bindtap="handleForceExitGame"><cover-image class="map-side-button__action-image" src="../../assets/btn_exit.png"></cover-image></cover-view>
|
||
</cover-view>
|
||
|
||
<cover-view class="map-punch-button {{punchButtonEnabled ? 'map-punch-button--active' : ''}} {{punchButtonFxClass}}" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}" bindtap="handlePunchAction">
|
||
<cover-view class="map-punch-button__text">{{punchButtonText}}</cover-view>
|
||
</cover-view>
|
||
|
||
<cover-view class="map-content-entry" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel && pendingContentEntryVisible}}" bindtap="handleOpenPendingContentCard">
|
||
<cover-view class="map-content-entry__text">{{pendingContentEntryText}}</cover-view>
|
||
</cover-view>
|
||
|
||
<cover-view class="screen-button-layer screen-button-layer--start-left" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel && showBottomDebugButton && showStartEntryButton && gameSessionStatus !== 'running'}}" bindtap="handleStartGame">
|
||
<cover-view class="screen-button-layer__text screen-button-layer__text--start">开始</cover-view>
|
||
</cover-view>
|
||
|
||
<cover-view class="screen-button-layer screen-button-layer--bottom-left" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel && showBottomDebugButton}}" bindtap="handleToggleDebugPanel">
|
||
<cover-view class="screen-button-layer__icon">
|
||
<cover-view class="screen-button-layer__line"></cover-view>
|
||
<cover-view class="screen-button-layer__stand"></cover-view>
|
||
</cover-view>
|
||
<cover-view class="screen-button-layer__text">调试</cover-view>
|
||
</cover-view>
|
||
|
||
<swiper wx:if="{{!showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}" class="race-panel-swiper" current="{{hudPanelIndex}}" bindchange="handleHudPanelChange" duration="220" easing-function="easeOutCubic">
|
||
<swiper-item>
|
||
<view class="race-panel race-panel--tone-{{panelTelemetryTone}}">
|
||
<view class="race-panel__tag race-panel__tag--top-left">{{panelActionTagText}}</view>
|
||
<view class="race-panel__tag race-panel__tag--top-right">里程</view>
|
||
<view class="race-panel__tag race-panel__tag--bottom-left">{{panelDistanceTagText}}</view>
|
||
<view class="race-panel__tag race-panel__tag--bottom-right">速度</view>
|
||
|
||
<view class="race-panel__line race-panel__line--center"></view>
|
||
<view class="race-panel__line race-panel__line--left-mid"></view>
|
||
<view class="race-panel__line race-panel__line--right-mid"></view>
|
||
<view class="race-panel__line race-panel__line--left-top"></view>
|
||
<view class="race-panel__line race-panel__line--left-bottom"></view>
|
||
<view class="race-panel__line race-panel__line--right-top"></view>
|
||
<view class="race-panel__line race-panel__line--right-bottom"></view>
|
||
|
||
<view class="race-panel__grid">
|
||
<view class="race-panel__cell race-panel__cell--action">
|
||
<view class="race-panel__action-stack">
|
||
<view class="race-panel__action-button {{punchButtonEnabled ? 'race-panel__action-button--active' : ''}}"><!-- status only -->
|
||
<view class="race-panel__action-button-text">{{punchButtonText}}</view>
|
||
</view>
|
||
<text class="race-panel__action-summary">{{panelTargetSummaryText}}</text>
|
||
</view>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--timer">
|
||
<text class="race-panel__timer {{panelTimerFxClass}} {{panelTimerMode === 'countdown' ? 'race-panel__timer--countdown' : ''}}">{{panelTimerText}}</text>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--mileage">
|
||
<view class="race-panel__mileage-wrap {{panelMileageFxClass}}">
|
||
<text class="race-panel__mileage">{{panelMileageText}}</text>
|
||
<view class="race-panel__chevrons">
|
||
<view class="race-panel__chevron"></view>
|
||
<view class="race-panel__chevron race-panel__chevron--offset"></view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--distance">
|
||
<view class="race-panel__metric-group race-panel__metric-group--left {{panelDistanceFxClass}}">
|
||
<text class="race-panel__metric-value race-panel__metric-value--distance">{{panelDistanceValueText}}</text>
|
||
<text class="race-panel__metric-unit race-panel__metric-unit--distance">{{panelDistanceUnitText}}</text>
|
||
</view>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--progress">
|
||
<text class="race-panel__progress {{panelProgressFxClass}}">{{panelProgressText}}</text>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--speed">
|
||
<view class="race-panel__metric-group race-panel__metric-group--right {{panelSpeedFxClass}}">
|
||
<text class="race-panel__metric-value race-panel__metric-value--speed">{{panelSpeedValueText}}</text>
|
||
<text class="race-panel__metric-unit race-panel__metric-unit--speed">km/h</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</swiper-item>
|
||
<swiper-item>
|
||
<view class="race-panel race-panel--tone-{{panelTelemetryTone}}">
|
||
<view class="race-panel__tag race-panel__tag--top-left">心率</view>
|
||
<view class="race-panel__tag race-panel__tag--top-right">卡路里</view>
|
||
<view class="race-panel__tag race-panel__tag--bottom-left">均速</view>
|
||
<view class="race-panel__tag race-panel__tag--bottom-right">精度</view>
|
||
|
||
<view class="race-panel__line race-panel__line--center"></view>
|
||
<view class="race-panel__line race-panel__line--left-mid"></view>
|
||
<view class="race-panel__line race-panel__line--right-mid"></view>
|
||
<view class="race-panel__line race-panel__line--left-top"></view>
|
||
<view class="race-panel__line race-panel__line--left-bottom"></view>
|
||
<view class="race-panel__line race-panel__line--right-top"></view>
|
||
<view class="race-panel__line race-panel__line--right-bottom"></view>
|
||
|
||
<view class="race-panel__grid">
|
||
<view class="race-panel__cell race-panel__cell--action">
|
||
<view class="race-panel__metric-group race-panel__metric-group--left race-panel__metric-group--panel {{panelHeartRateFxClass}}">
|
||
<text class="race-panel__metric-value race-panel__metric-value--telemetry">{{panelHeartRateValueText}}</text>
|
||
<text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelHeartRateUnitText}}</text>
|
||
</view>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--timer">
|
||
<text class="race-panel__timer {{panelTimerFxClass}} {{panelTimerMode === 'countdown' ? 'race-panel__timer--countdown' : ''}}">{{panelTimerText}}</text>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--mileage">
|
||
<view class="race-panel__metric-group race-panel__metric-group--right race-panel__metric-group--panel">
|
||
<text class="race-panel__metric-value race-panel__metric-value--telemetry">{{panelCaloriesValueText}}</text>
|
||
<text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelCaloriesUnitText}}</text>
|
||
</view>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--distance">
|
||
<view class="race-panel__metric-group race-panel__metric-group--left race-panel__metric-group--panel">
|
||
<text class="race-panel__metric-value race-panel__metric-value--telemetry-secondary">{{panelAverageSpeedValueText}}</text>
|
||
<text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelAverageSpeedUnitText}}</text>
|
||
</view>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--progress">
|
||
<view class="race-panel__zone">
|
||
<text class="race-panel__zone-name">{{panelHeartRateZoneNameText}}</text>
|
||
<text class="race-panel__zone-range">{{panelHeartRateZoneRangeText}}</text>
|
||
</view>
|
||
</view>
|
||
<view class="race-panel__cell race-panel__cell--speed">
|
||
<view class="race-panel__metric-group race-panel__metric-group--right race-panel__metric-group--panel">
|
||
<text class="race-panel__metric-value race-panel__metric-value--telemetry-secondary">{{panelAccuracyValueText}}</text>
|
||
<text class="race-panel__metric-unit race-panel__metric-unit--telemetry">{{panelAccuracyUnitText}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</swiper-item>
|
||
</swiper>
|
||
<view class="race-panel-pager" wx:if="{{!showDebugPanel && !showGameInfoPanel && !showResultScene && !showSystemSettingsPanel}}">
|
||
<view class="race-panel-pager__dot {{hudPanelIndex === 0 ? 'race-panel-pager__dot--active' : ''}}"></view>
|
||
<view class="race-panel-pager__dot {{hudPanelIndex === 1 ? 'race-panel-pager__dot--active' : ''}}"></view>
|
||
</view>
|
||
|
||
<view class="game-info-modal" wx:if="{{showGameInfoPanel}}" bindtap="handleCloseGameInfoPanel">
|
||
<view class="game-info-modal__dialog" catchtap="handleGameInfoPanelTap">
|
||
<view class="game-info-modal__header">
|
||
<view class="game-info-modal__header-main">
|
||
<view class="game-info-modal__eyebrow">GAME INFO</view>
|
||
<view class="game-info-modal__title">{{gameInfoTitle}}</view>
|
||
<view class="game-info-modal__subtitle">{{gameInfoSubtitle}}</view>
|
||
</view>
|
||
<view class="game-info-modal__header-actions">
|
||
<view class="game-info-modal__close" bindtap="handleCloseGameInfoPanel">关闭</view>
|
||
</view>
|
||
</view>
|
||
|
||
<scroll-view class="game-info-modal__content" scroll-y enhanced show-scrollbar="true">
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__title">Local</view>
|
||
<view class="debug-section__desc">当前设备、本地玩法与实时运行状态</view>
|
||
</view>
|
||
<view class="info-panel__row" wx:for="{{gameInfoLocalRows}}" wx:key="label">
|
||
<text class="info-panel__label">{{item.label}}</text>
|
||
<text class="info-panel__value">{{item.value}}</text>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__title">Global</view>
|
||
<view class="debug-section__desc">联网后接入全局赛事数据,这里先占位</view>
|
||
</view>
|
||
<view class="info-panel__row" wx:for="{{gameInfoGlobalRows}}" wx:key="label">
|
||
<text class="info-panel__label">{{item.label}}</text>
|
||
<text class="info-panel__value">{{item.value}}</text>
|
||
</view>
|
||
</view>
|
||
</scroll-view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="result-scene-modal" wx:if="{{showResultScene}}" bindtap="handleCloseResultScene">
|
||
<view class="result-scene-modal__dialog" catchtap="handleResultSceneTap">
|
||
<view class="result-scene-modal__eyebrow">FINISH</view>
|
||
<view class="result-scene-modal__title">{{resultSceneTitle}}</view>
|
||
<view class="result-scene-modal__subtitle">{{resultSceneSubtitle}}</view>
|
||
|
||
<view class="result-scene-modal__hero">
|
||
<view class="result-scene-modal__hero-label">{{resultSceneHeroLabel}}</view>
|
||
<view class="result-scene-modal__hero-value">{{resultSceneHeroValue}}</view>
|
||
</view>
|
||
|
||
<view class="result-scene-modal__rows">
|
||
<view class="result-scene-modal__row" wx:for="{{resultSceneRows}}" wx:key="label">
|
||
<text class="result-scene-modal__row-label">{{item.label}}</text>
|
||
<text class="result-scene-modal__row-value">{{item.value}}</text>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="result-scene-modal__countdown">{{resultSceneCountdownText}}</view>
|
||
|
||
<view class="result-scene-modal__actions">
|
||
<view class="result-scene-modal__action result-scene-modal__action--primary" bindtap="handleRestartFromResult">查看成绩</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="game-info-modal" wx:if="{{showSystemSettingsPanel}}" bindtap="handleCloseSystemSettingsPanel">
|
||
<view class="game-info-modal__dialog" catchtap="handleSystemSettingsPanelTap">
|
||
<view class="game-info-modal__header">
|
||
<view class="game-info-modal__header-main">
|
||
<view class="game-info-modal__eyebrow">SYSTEM SETTINGS</view>
|
||
<view class="game-info-modal__title">系统设置</view>
|
||
<view class="game-info-modal__subtitle">用户端偏好与设备级选项</view>
|
||
</view>
|
||
<view class="game-info-modal__header-actions">
|
||
<view class="game-info-modal__close" bindtap="handleCloseSystemSettingsPanel">关闭</view>
|
||
</view>
|
||
</view>
|
||
|
||
<scroll-view class="game-info-modal__content" scroll-y enhanced show-scrollbar="true">
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">01. 动画性能</view>
|
||
<view class="debug-section__desc">根据设备性能切换动画强度,低端机建议精简</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockAnimationLevel ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockAnimationLevel ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前级别</text>
|
||
<text class="info-panel__value">{{animationLevel === 'lite' ? '精简' : '标准'}}{{lockAnimationLevel ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{animationLevel === 'standard' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAnimationLevel ? 'control-chip--disabled' : ''}}" bindtap="handleSetAnimationLevelStandard">标准</view>
|
||
<view class="control-chip {{animationLevel === 'lite' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAnimationLevel ? 'control-chip--disabled' : ''}}" bindtap="handleSetAnimationLevelLite">精简</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">02. 轨迹选项</view>
|
||
<view class="debug-section__desc">控制不显示、彗尾拖尾、全轨迹三种显示方式</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockTrackMode ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockTrackMode ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前模式</text>
|
||
<text class="info-panel__value">
|
||
{{trackDisplayMode === 'none' ? '无' : (trackDisplayMode === 'tail' ? '彗尾' : '全轨迹')}}{{lockTrackMode ? ' · 已锁定' : ' · 可编辑'}}
|
||
</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{trackDisplayMode === 'none' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackMode ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackModeNone">无</view>
|
||
<view class="control-chip {{trackDisplayMode === 'tail' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackMode ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackModeTail">彗尾</view>
|
||
<view class="control-chip {{trackDisplayMode === 'full' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackMode ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackModeFull">全轨迹</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">03. 轨迹尾巴</view>
|
||
<view class="debug-section__desc">拖尾模式下控制尾巴长短,跑得越快会在此基础上再拉长</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockTrackTailLength ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockTrackTailLength ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前长度</text>
|
||
<text class="info-panel__value">
|
||
{{trackTailLength === 'short' ? '短' : (trackTailLength === 'long' ? '长' : '中')}}{{lockTrackTailLength ? ' · 已锁定' : ' · 可编辑'}}
|
||
</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{trackTailLength === 'short' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackTailLength ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackTailLengthShort">短</view>
|
||
<view class="control-chip {{trackTailLength === 'medium' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackTailLength ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackTailLengthMedium">中</view>
|
||
<view class="control-chip {{trackTailLength === 'long' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackTailLength ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackTailLengthLong">长</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">04. 轨迹颜色</view>
|
||
<view class="debug-section__desc">亮色轨迹调色盘,运行中会按速度和心率张力自动提亮</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockTrackColor ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockTrackColor ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前颜色</text>
|
||
<text class="info-panel__value">
|
||
{{trackColorPreset === 'mint' ? '薄荷' : (trackColorPreset === 'cyan' ? '青绿' : (trackColorPreset === 'sky' ? '天蓝' : (trackColorPreset === 'blue' ? '深蓝' : (trackColorPreset === 'violet' ? '紫罗兰' : (trackColorPreset === 'pink' ? '玫红' : (trackColorPreset === 'orange' ? '橙色' : '亮黄'))))))}}{{lockTrackColor ? ' · 已锁定' : ' · 可编辑'}}
|
||
</text>
|
||
</view>
|
||
<view class="control-row control-row--wrap">
|
||
<view class="control-chip {{trackColorPreset === 'mint' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="mint" bindtap="handleSetTrackColorPreset">薄荷</view>
|
||
<view class="control-chip {{trackColorPreset === 'cyan' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="cyan" bindtap="handleSetTrackColorPreset">青绿</view>
|
||
<view class="control-chip {{trackColorPreset === 'sky' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="sky" bindtap="handleSetTrackColorPreset">天蓝</view>
|
||
<view class="control-chip {{trackColorPreset === 'blue' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="blue" bindtap="handleSetTrackColorPreset">深蓝</view>
|
||
</view>
|
||
<view class="control-row control-row--wrap">
|
||
<view class="control-chip {{trackColorPreset === 'violet' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="violet" bindtap="handleSetTrackColorPreset">紫罗兰</view>
|
||
<view class="control-chip {{trackColorPreset === 'pink' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="pink" bindtap="handleSetTrackColorPreset">玫红</view>
|
||
<view class="control-chip {{trackColorPreset === 'orange' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="orange" bindtap="handleSetTrackColorPreset">橙色</view>
|
||
<view class="control-chip {{trackColorPreset === 'yellow' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackColor ? 'control-chip--disabled' : ''}}" data-color="yellow" bindtap="handleSetTrackColorPreset">亮黄</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">05. 轨迹风格</view>
|
||
<view class="debug-section__desc">切换经典线条和流光轨迹风格,默认推荐流光</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockTrackStyle ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockTrackStyle ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前风格</text>
|
||
<text class="info-panel__value">{{trackStyleProfile === 'neon' ? '流光' : '经典'}}{{lockTrackStyle ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{trackStyleProfile === 'classic' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackStyle ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackStyleClassic">经典</view>
|
||
<view class="control-chip {{trackStyleProfile === 'neon' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockTrackStyle ? 'control-chip--disabled' : ''}}" bindtap="handleSetTrackStyleNeon">流光</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">06. GPS点显示</view>
|
||
<view class="debug-section__desc">控制地图上的 GPS 定位点显示与隐藏</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockGpsMarkerVisible ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockGpsMarkerVisible ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前状态</text>
|
||
<text class="info-panel__value">{{gpsMarkerVisible ? '显示' : '隐藏'}}{{lockGpsMarkerVisible ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{gpsMarkerVisible ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerVisible ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerVisibleOn">显示</view>
|
||
<view class="control-chip {{!gpsMarkerVisible ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerVisible ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerVisibleOff">隐藏</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">07. GPS点大小</view>
|
||
<view class="debug-section__desc">控制定位点本体和朝向小三角的整体尺寸</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockGpsMarkerSize ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockGpsMarkerSize ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前大小</text>
|
||
<text class="info-panel__value">{{gpsMarkerSize === 'small' ? '小' : (gpsMarkerSize === 'large' ? '大' : '中')}}{{lockGpsMarkerSize ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{gpsMarkerSize === 'small' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerSize ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerSizeSmall">小</view>
|
||
<view class="control-chip {{gpsMarkerSize === 'medium' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerSize ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerSizeMedium">中</view>
|
||
<view class="control-chip {{gpsMarkerSize === 'large' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerSize ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerSizeLarge">大</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">08. GPS点颜色</view>
|
||
<view class="debug-section__desc">切换定位点主色,默认使用青绿高亮色</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockGpsMarkerColor ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockGpsMarkerColor ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前颜色</text>
|
||
<text class="info-panel__value">
|
||
{{gpsMarkerColorPreset === 'mint' ? '薄荷' : (gpsMarkerColorPreset === 'cyan' ? '青绿' : (gpsMarkerColorPreset === 'sky' ? '天蓝' : (gpsMarkerColorPreset === 'blue' ? '深蓝' : (gpsMarkerColorPreset === 'violet' ? '紫罗兰' : (gpsMarkerColorPreset === 'pink' ? '玫红' : (gpsMarkerColorPreset === 'orange' ? '橙色' : '亮黄'))))))}}{{lockGpsMarkerColor ? ' · 已锁定' : ' · 可编辑'}}
|
||
</text>
|
||
</view>
|
||
<view class="control-row control-row--wrap">
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'mint' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="mint" bindtap="handleSetGpsMarkerColorPreset">薄荷</view>
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'cyan' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="cyan" bindtap="handleSetGpsMarkerColorPreset">青绿</view>
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'sky' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="sky" bindtap="handleSetGpsMarkerColorPreset">天蓝</view>
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'blue' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="blue" bindtap="handleSetGpsMarkerColorPreset">深蓝</view>
|
||
</view>
|
||
<view class="control-row control-row--wrap">
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'violet' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="violet" bindtap="handleSetGpsMarkerColorPreset">紫罗兰</view>
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'pink' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="pink" bindtap="handleSetGpsMarkerColorPreset">玫红</view>
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'orange' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="orange" bindtap="handleSetGpsMarkerColorPreset">橙色</view>
|
||
<view class="control-chip {{gpsMarkerColorPreset === 'yellow' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerColor ? 'control-chip--disabled' : ''}}" data-color="yellow" bindtap="handleSetGpsMarkerColorPreset">亮黄</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">09. GPS点风格</view>
|
||
<view class="debug-section__desc">切换定位点底座风格,影响本体与外圈表现</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockGpsMarkerStyle ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockGpsMarkerStyle ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前风格</text>
|
||
<text class="info-panel__value">{{gpsMarkerStyle === 'dot' ? '圆点' : (gpsMarkerStyle === 'disc' ? '圆盘' : (gpsMarkerStyle === 'badge' ? '徽章' : '信标'))}}{{lockGpsMarkerStyle ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row control-row--wrap">
|
||
<view class="control-chip {{gpsMarkerStyle === 'dot' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerStyle ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerStyleDot">圆点</view>
|
||
<view class="control-chip {{gpsMarkerStyle === 'beacon' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerStyle ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerStyleBeacon">信标</view>
|
||
<view class="control-chip {{gpsMarkerStyle === 'disc' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerStyle ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerStyleDisc">圆盘</view>
|
||
<view class="control-chip {{gpsMarkerStyle === 'badge' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockGpsMarkerStyle ? 'control-chip--disabled' : ''}}" bindtap="handleSetGpsMarkerStyleBadge">徽章</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">10. 按钮习惯</view>
|
||
<view class="debug-section__desc">切换功能按钮显示在左侧还是右侧,适配左手/右手操作习惯</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockSideButtonPlacement ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockSideButtonPlacement ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前习惯</text>
|
||
<text class="info-panel__value">{{sideButtonPlacement === 'right' ? '右手' : '左手'}}{{lockSideButtonPlacement ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{sideButtonPlacement === 'left' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockSideButtonPlacement ? 'control-chip--disabled' : ''}}" bindtap="handleSetSideButtonPlacementLeft">左手</view>
|
||
<view class="control-chip {{sideButtonPlacement === 'right' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockSideButtonPlacement ? 'control-chip--disabled' : ''}}" bindtap="handleSetSideButtonPlacementRight">右手</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">11. 自动转图</view>
|
||
<view class="debug-section__desc">控制地图是否跟随朝向自动旋转,外部按钮与这里保持同步</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockAutoRotate ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockAutoRotate ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前状态</text>
|
||
<text class="info-panel__value">{{autoRotateEnabled ? '开启' : '关闭'}}{{lockAutoRotate ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{autoRotateEnabled ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAutoRotate ? 'control-chip--disabled' : ''}}" bindtap="handleSetAutoRotateEnabledOn">开启</view>
|
||
<view class="control-chip {{!autoRotateEnabled ? 'control-chip--active' : 'control-chip--secondary'}} {{lockAutoRotate ? 'control-chip--disabled' : ''}}" bindtap="handleSetAutoRotateEnabledOff">关闭</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">12. 指北针响应</view>
|
||
<view class="debug-section__desc">切换指针的平滑与跟手程度,影响指北针响应手感</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockCompassTuning ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockCompassTuning ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前档位</text>
|
||
<text class="info-panel__value">{{compassTuningProfileText}}{{lockCompassTuning ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row control-row--triple">
|
||
<view class="control-chip {{compassTuningProfile === 'smooth' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockCompassTuning ? 'control-chip--disabled' : ''}}" bindtap="handleSetCompassTuningSmooth">顺滑</view>
|
||
<view class="control-chip {{compassTuningProfile === 'balanced' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockCompassTuning ? 'control-chip--disabled' : ''}}" bindtap="handleSetCompassTuningBalanced">平衡</view>
|
||
<view class="control-chip {{compassTuningProfile === 'responsive' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockCompassTuning ? 'control-chip--disabled' : ''}}" bindtap="handleSetCompassTuningResponsive">跟手</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">13. 比例尺显示</view>
|
||
<view class="debug-section__desc">控制比例尺显示与否,默认沿用你的本地偏好</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockScaleRulerVisible ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockScaleRulerVisible ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前状态</text>
|
||
<text class="info-panel__value">{{showCenterScaleRuler ? '显示' : '隐藏'}}{{lockScaleRulerVisible ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{showCenterScaleRuler ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerVisible ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerVisibleOn">显示</view>
|
||
<view class="control-chip {{!showCenterScaleRuler ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerVisible ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerVisibleOff">隐藏</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">14. 比例尺基准点</view>
|
||
<view class="debug-section__desc">设置比例尺零点锚定位置,可跟随屏幕中心或指北针圆心</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockScaleRulerAnchor ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockScaleRulerAnchor ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前锚点</text>
|
||
<text class="info-panel__value">{{centerScaleRulerAnchorMode === 'compass-center' ? '指北针圆心' : '屏幕中心'}}{{lockScaleRulerAnchor ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{centerScaleRulerAnchorMode === 'screen-center' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerAnchor ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerAnchorScreenCenter">屏幕中心</view>
|
||
<view class="control-chip {{centerScaleRulerAnchorMode === 'compass-center' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockScaleRulerAnchor ? 'control-chip--disabled' : ''}}" bindtap="handleSetCenterScaleRulerAnchorCompassCenter">指北针圆心</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">15. 北参考</view>
|
||
<view class="debug-section__desc">切换磁北/真北作为地图与指北针参考</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockNorthReference ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockNorthReference ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前参考</text>
|
||
<text class="info-panel__value">{{northReferenceText}}{{lockNorthReference ? ' · 已锁定' : ' · 可编辑'}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{northReferenceMode === 'magnetic' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockNorthReference ? 'control-chip--disabled' : ''}}" bindtap="handleSetNorthReferenceMagnetic">磁北</view>
|
||
<view class="control-chip {{northReferenceMode === 'true' ? 'control-chip--active' : 'control-chip--secondary'}} {{lockNorthReference ? 'control-chip--disabled' : ''}}" bindtap="handleSetNorthReferenceTrue">真北</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section debug-section--info">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__header-row">
|
||
<view class="debug-section__header-main">
|
||
<view class="debug-section__title">16. 心率设备</view>
|
||
<view class="debug-section__desc">局内正式入口,可快速更换、重连或断开当前心率带</view>
|
||
</view>
|
||
<view class="debug-section__lock {{lockHeartRateDevice ? 'debug-section__lock--active' : ''}}">
|
||
<text class="debug-section__lock-text">{{lockHeartRateDevice ? '配置锁定' : '允许调整'}}</text>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">当前状态</text>
|
||
<text class="info-panel__value">{{heartRateStatusText}}{{heartRateSourceMode !== 'real' ? ' · 当前为模拟模式' : ''}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">当前设备</text>
|
||
<text class="info-panel__value">{{heartRateDeviceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row" wx:if="{{heartRateSourceMode === 'real'}}">
|
||
<text class="info-panel__label">扫描状态</text>
|
||
<text class="info-panel__value">{{heartRateScanText}}</text>
|
||
</view>
|
||
<view class="summary" wx:if="{{heartRateSourceMode !== 'real'}}">当前为模拟心率模式,如需连接真实心率带,请先在调试面板切回“真实心率”。</view>
|
||
<view class="control-row" wx:if="{{heartRateSourceMode === 'real'}}">
|
||
<view class="control-chip control-chip--secondary {{lockHeartRateDevice ? 'control-chip--disabled' : ''}}" bindtap="handleOpenHeartRateDevicePicker">更换心率带</view>
|
||
<view class="control-chip {{heartRateConnected ? 'control-chip--active' : 'control-chip--secondary'}} {{lockHeartRateDevice ? 'control-chip--disabled' : ''}}" bindtap="handleConnectHeartRate">{{heartRateConnected ? '重新扫描' : '连接心率带'}}</view>
|
||
<view class="control-chip control-chip--secondary {{lockHeartRateDevice ? 'control-chip--disabled' : ''}}" bindtap="handleDisconnectHeartRate">断开心率带</view>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip control-chip--secondary {{lockHeartRateDevice ? 'control-chip--disabled' : ''}}" bindtap="handleClearPreferredHeartRateDevice">清除首选设备</view>
|
||
</view>
|
||
</view>
|
||
</scroll-view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-modal" wx:if="{{showDebugPanel}}" bindtap="handleCloseDebugPanel">
|
||
<view class="debug-modal__dialog" catchtap="handleDebugPanelTap">
|
||
<view class="debug-modal__header">
|
||
<view class="debug-modal__header-main">
|
||
<view class="debug-modal__eyebrow">DEBUG PANEL</view>
|
||
<view class="debug-modal__build">{{buildVersion}}</view>
|
||
</view>
|
||
<view class="debug-modal__header-actions">
|
||
<view class="debug-modal__close" bindtap="handleCloseDebugPanel">关闭</view>
|
||
</view>
|
||
</view>
|
||
|
||
<scroll-view class="debug-modal__content" scroll-y enhanced show-scrollbar="true">
|
||
<view class="debug-section">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__title">Session</view>
|
||
<view class="debug-section__desc">当前局状态与主流程控制</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Mode</text>
|
||
<text class="info-panel__value">{{gameModeText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Config</text>
|
||
<text class="info-panel__value">{{configSourceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Game</text>
|
||
<text class="info-panel__value">{{gameSessionStatus}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Progress</text>
|
||
<text class="info-panel__value">{{panelProgressText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Timer</text>
|
||
<text class="info-panel__value">{{panelTimerText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Punch Hint</text>
|
||
<text class="info-panel__value">{{punchHintText}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{configSourceText === '顺序赛配置' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleLoadClassicConfig">顺序赛配置</view>
|
||
<view class="control-chip {{configSourceText === '积分赛配置' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleLoadScoreOConfig">积分赛配置</view>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip control-chip--primary" bindtap="handleRecenter">回到首屏</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleRotationReset">旋转归零</view>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleClearMapTestArtifacts">清空测试痕迹</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__title">Sensors</view>
|
||
<view class="debug-section__desc">定位模拟、心率模拟、调试日志与方向状态</view>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{mockBridgeConnected && mockHeartRateBridgeConnected && mockDebugLogBridgeConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectAllMockSources">一键连接开发调试源</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleOpenWebViewTest">测试 H5</view>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">模拟通道号</text>
|
||
<view class="debug-inline-stack">
|
||
<input
|
||
class="debug-input"
|
||
value="{{mockChannelIdDraft}}"
|
||
placeholder="default / runner-a"
|
||
bindinput="handleMockChannelIdInput"
|
||
/>
|
||
<view class="control-row control-row--compact">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleSaveMockChannelId">保存通道号</view>
|
||
</view>
|
||
</view>
|
||
<text class="info-panel__hint">当前通道:{{mockChannelIdText}}</text>
|
||
</view>
|
||
<view class="debug-group-title">定位模拟</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">GPS</text>
|
||
<text class="info-panel__value">{{gpsTrackingText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Location Source</text>
|
||
<text class="info-panel__value">{{locationSourceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">GPS Coord</text>
|
||
<text class="info-panel__value">{{gpsCoordText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">GPS Logo</text>
|
||
<text class="info-panel__value">{{gpsLogoStatusText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">GPS Logo Src</text>
|
||
<text class="info-panel__value">{{gpsLogoSourceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">定位模拟状态</text>
|
||
<text class="info-panel__value">{{mockBridgeStatusText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">定位模拟地址</text>
|
||
<view class="debug-inline-stack">
|
||
<input
|
||
class="debug-input"
|
||
value="{{mockBridgeUrlDraft}}"
|
||
placeholder="ws://192.168.x.x:17865/mock-gps"
|
||
bindinput="handleMockBridgeUrlInput"
|
||
/>
|
||
<view class="control-row control-row--compact">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleSaveMockBridgeUrl">保存地址</view>
|
||
<view class="control-chip {{mockBridgeConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectMockLocationBridge">连接定位模拟</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDisconnectMockLocationBridge">断开定位模拟</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Mock Coord</text>
|
||
<text class="info-panel__value">{{mockCoordText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Mock Speed</text>
|
||
<text class="info-panel__value">{{mockSpeedText}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{gpsTracking ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleToggleGpsTracking">{{gpsTracking ? '停止定位' : '开启定位'}}</view>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{locationSourceMode === 'real' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetRealLocationMode">真实定位</view>
|
||
<view class="control-chip {{locationSourceMode === 'mock' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetMockLocationMode">模拟定位</view>
|
||
</view>
|
||
<view class="debug-group-title">心率模拟</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Heart Rate</text>
|
||
<text class="info-panel__value">{{heartRateStatusText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Heart Source</text>
|
||
<text class="info-panel__value">{{heartRateSourceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">HR Device</text>
|
||
<text class="info-panel__value">{{heartRateDeviceText}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{heartRateSourceMode === 'real' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetRealHeartRateMode">真实心率</view>
|
||
<view class="control-chip {{heartRateSourceMode === 'mock' ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleSetMockHeartRateMode">模拟心率</view>
|
||
</view>
|
||
<view class="info-panel__row" wx:if="{{heartRateSourceMode === 'real'}}">
|
||
<text class="info-panel__label">HR Scan</text>
|
||
<text class="info-panel__value">{{heartRateScanText}}</text>
|
||
</view>
|
||
<view class="control-row" wx:if="{{heartRateSourceMode === 'real'}}">
|
||
<view class="control-chip {{heartRateConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectHeartRate">{{heartRateConnected ? '重新扫描' : '连接心率带'}}</view>
|
||
</view>
|
||
<view class="summary" wx:if="{{heartRateSourceMode === 'real'}}">正式用户入口已放到系统设置;这里仅保留心率源切换与开发调试能力。</view>
|
||
<view class="info-panel__row info-panel__row--stack" wx:if="{{heartRateSourceMode === 'mock'}}">
|
||
<text class="info-panel__label">心率模拟状态</text>
|
||
<text class="info-panel__value">{{mockHeartRateBridgeStatusText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack" wx:if="{{heartRateSourceMode === 'mock'}}">
|
||
<text class="info-panel__label">心率模拟地址</text>
|
||
<view class="debug-inline-stack">
|
||
<input
|
||
class="debug-input"
|
||
value="{{mockHeartRateBridgeUrlDraft}}"
|
||
placeholder="ws://192.168.x.x:17865/mock-hr"
|
||
bindinput="handleMockHeartRateBridgeUrlInput"
|
||
/>
|
||
<view class="control-row control-row--compact">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleSaveMockHeartRateBridgeUrl">保存地址</view>
|
||
<view class="control-chip {{mockHeartRateBridgeConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectMockHeartRateBridge">连接心率模拟</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDisconnectMockHeartRateBridge">断开心率模拟</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="info-panel__row" wx:if="{{heartRateSourceMode === 'mock'}}">
|
||
<text class="info-panel__label">Mock BPM</text>
|
||
<text class="info-panel__value">{{mockHeartRateText}}</text>
|
||
</view>
|
||
<view class="debug-group-title">调试日志</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">日志通道状态</text>
|
||
<text class="info-panel__value">{{mockDebugLogBridgeStatusText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">日志通道地址</text>
|
||
<view class="debug-inline-stack">
|
||
<input
|
||
class="debug-input"
|
||
value="{{mockDebugLogBridgeUrlDraft}}"
|
||
placeholder="ws://192.168.x.x:17865/debug-log"
|
||
bindinput="handleMockDebugLogBridgeUrlInput"
|
||
/>
|
||
<view class="control-row control-row--compact">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleSaveMockDebugLogBridgeUrl">保存地址</view>
|
||
<view class="control-chip {{mockDebugLogBridgeConnected ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleConnectMockDebugLogBridge">连接日志通道</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDisconnectMockDebugLogBridge">断开日志通道</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
<view class="debug-group-title">方向</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Heading Mode</text>
|
||
<text class="info-panel__value">{{orientationModeText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Sensor Heading</text>
|
||
<text class="info-panel__value">{{sensorHeadingText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Device Heading</text>
|
||
<text class="info-panel__value">{{deviceHeadingText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Pose</text>
|
||
<text class="info-panel__value">{{devicePoseText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Heading Confidence</text>
|
||
<text class="info-panel__value">{{headingConfidenceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Compass Source</text>
|
||
<text class="info-panel__value">{{compassSourceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Compass Tune</text>
|
||
<text class="info-panel__value">{{compassTuningProfileText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Accel</text>
|
||
<text class="info-panel__value">{{accelerometerText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Gyro</text>
|
||
<text class="info-panel__value">{{gyroscopeText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Motion</text>
|
||
<text class="info-panel__value">{{deviceMotionText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">North Ref</text>
|
||
<text class="info-panel__value">{{northReferenceText}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleCycleNorthReferenceMode">{{northReferenceButtonText}}</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__title">Telemetry</view>
|
||
<view class="debug-section__desc">HUD 派生数据与心率颜色测试</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">HR</text>
|
||
<text class="info-panel__value">{{panelHeartRateValueText}} {{panelHeartRateUnitText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">HR Zone</text>
|
||
<text class="info-panel__value">{{panelHeartRateZoneNameText}} {{panelHeartRateZoneRangeText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Calories</text>
|
||
<text class="info-panel__value">{{panelCaloriesValueText}} {{panelCaloriesUnitText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Speed</text>
|
||
<text class="info-panel__value">{{panelSpeedValueText}} km/h</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Avg Speed</text>
|
||
<text class="info-panel__value">{{panelAverageSpeedValueText}} {{panelAverageSpeedUnitText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Target Dist</text>
|
||
<text class="info-panel__value">{{panelDistanceValueText}} {{panelDistanceUnitText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Accuracy</text>
|
||
<text class="info-panel__value">{{panelAccuracyValueText}} {{panelAccuracyUnitText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Timer</text>
|
||
<text class="info-panel__value">{{panelTimerText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Timer Mode</text>
|
||
<text class="info-panel__value">{{panelTimerMode === 'countdown' ? '倒计时' : '正计时'}}</text>
|
||
</view>
|
||
<view class="control-row control-row--triple">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugSetSessionRemainingWarning">剩10分钟</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugSetSessionRemainingOneMinute">剩1分钟</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugTimeoutSession">立即超时</view>
|
||
</view>
|
||
<view class="control-row control-row--triple">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateBlue">蓝</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRatePurple">紫</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateGreen">绿</view>
|
||
</view>
|
||
<view class="control-row control-row--triple">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateYellow">黄</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateOrange">橙</view>
|
||
<view class="control-chip control-chip--secondary" bindtap="handleDebugHeartRateRed">红</view>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip control-chip--secondary" bindtap="handleClearDebugHeartRate">清除</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__title">Rendering</view>
|
||
<view class="debug-section__desc">地图渲染、视角与参考图层</view>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Renderer</text>
|
||
<text class="info-panel__value">{{renderMode}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Projection</text>
|
||
<text class="info-panel__value">{{projectionMode}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Zoom</text>
|
||
<text class="info-panel__value">{{zoom}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Rotation</text>
|
||
<text class="info-panel__value">{{rotationText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Auto Source</text>
|
||
<text class="info-panel__value">{{autoRotateSourceText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Calibration</text>
|
||
<text class="info-panel__value">{{autoRotateCalibrationText}}</text>
|
||
</view>
|
||
<view class="control-row">
|
||
<view class="control-chip {{osmReferenceEnabled ? 'control-chip--active' : 'control-chip--secondary'}}" bindtap="handleToggleOsmReference">{{osmReferenceText}}</view>
|
||
<view class="control-chip" wx:if="{{orientationMode === 'manual'}}" bindtap="handleRotateStep">旋转 +15°</view>
|
||
</view>
|
||
<view class="control-row control-row--triple">
|
||
<view class="control-chip {{orientationMode === 'manual' ? 'control-chip--active' : ''}}" bindtap="handleSetManualMode">手动</view>
|
||
<view class="control-chip {{orientationMode === 'north-up' ? 'control-chip--active' : ''}}" bindtap="handleSetNorthUpMode">北朝上</view>
|
||
<view class="control-chip {{orientationMode === 'heading-up' ? 'control-chip--active' : ''}}" bindtap="handleSetHeadingUpMode">朝向朝上</view>
|
||
</view>
|
||
<view class="control-row" wx:if="{{orientationMode === 'heading-up'}}">
|
||
<view class="control-chip" bindtap="handleAutoRotateCalibrate">按当前方向校准</view>
|
||
</view>
|
||
</view>
|
||
|
||
<view class="debug-section">
|
||
<view class="debug-section__header">
|
||
<view class="debug-section__title">Diagnostics</view>
|
||
<view class="debug-section__desc">配置、瓦片缓存与运行状态</view>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Config</text>
|
||
<text class="info-panel__value">{{configStatusText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Status</text>
|
||
<text class="info-panel__value">{{statusText}}</text>
|
||
</view>
|
||
<view class="info-panel__row info-panel__row--stack">
|
||
<text class="info-panel__label">Tile URL</text>
|
||
<text class="info-panel__value">{{tileSource}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Center Tile</text>
|
||
<text class="info-panel__value">{{centerText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Tile Size</text>
|
||
<text class="info-panel__value">{{tileSizePx}}px</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Visible Tiles</text>
|
||
<text class="info-panel__value">{{visibleTileCount}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Ready Tiles</text>
|
||
<text class="info-panel__value">{{readyTileCount}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Memory Tiles</text>
|
||
<text class="info-panel__value">{{memoryTileCount}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Disk Tiles</text>
|
||
<text class="info-panel__value">{{diskTileCount}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Cache Hit</text>
|
||
<text class="info-panel__value">{{cacheHitRateText}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Disk Hits</text>
|
||
<text class="info-panel__value">{{diskHitCount}}</text>
|
||
</view>
|
||
<view class="info-panel__row">
|
||
<text class="info-panel__label">Net Fetches</text>
|
||
<text class="info-panel__value">{{networkFetchCount}}</text>
|
||
</view>
|
||
</view>
|
||
</scroll-view>
|
||
</view>
|
||
</view>
|
||
|
||
<view wx:if="{{showHeartRateDevicePicker}}" class="picker-mask" bindtap="handleCloseHeartRateDevicePicker"></view>
|
||
<view wx:if="{{showHeartRateDevicePicker}}" class="picker-sheet">
|
||
<view class="picker-sheet__header">
|
||
<view class="picker-sheet__title">选择心率带设备</view>
|
||
<button class="picker-sheet__close" bindtap="handleCloseHeartRateDevicePicker">关闭</button>
|
||
</view>
|
||
<view class="summary">扫描状态:{{heartRateScanText}}</view>
|
||
<view wx:if="{{!heartRateDiscoveredDevices.length}}" class="summary">当前还没有发现设备,可先点“重新扫描”。</view>
|
||
<view wx:if="{{heartRateDiscoveredDevices.length}}" class="device-list">
|
||
<view wx:for="{{heartRateDiscoveredDevices}}" wx:key="deviceId" class="device-card">
|
||
<view class="device-card__main">
|
||
<view class="device-card__title-row">
|
||
<text class="device-card__name">{{item.name}}</text>
|
||
<text class="device-card__badge" wx:if="{{item.preferred}}">首选</text>
|
||
<text class="device-card__badge device-card__badge--active" wx:if="{{item.connected}}">已连接</text>
|
||
</view>
|
||
<text class="device-card__meta">{{item.rssiText}}</text>
|
||
</view>
|
||
<button class="btn {{item.connected ? 'btn--ghost' : 'btn--secondary'}} device-card__action" data-device-id="{{item.deviceId}}" bindtap="handleConnectHeartRateDevice">{{item.connected ? '已连接' : '连接'}}</button>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
</view>
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|
||
|