Skip to content

Commit a546b75

Browse files
committed
修复音量条在调整音量时实际音量与显示的数值不一致的问题(#2606
1 parent 8686ecf commit a546b75

3 files changed

Lines changed: 36 additions & 39 deletions

File tree

publish/changeLog.md

Lines changed: 1 addition & 26 deletions
Original file line numberDiff line numberDiff line change
@@ -1,31 +1,6 @@
11
我们很高兴地宣布新项目 Any Listen 的桌面版已发布,目前已支持列表跟随本地文件自动更新、加载并播放WebDAV上的歌曲等功能,更多功能仍在积极开发中,桌面版与Web版将同步更新。
22
对于有播放本地音乐或播放服务器上音乐需求的人可以试试,若遇到任何问题可以发 issue 反馈。
33

4-
### 新增
5-
6-
- 新增「设置 → 其他设置 → 主窗口使用软件内置的圆角及阴影」选项 (#2360)
7-
*默认启用,关闭后将使用系统原生的窗口样式,该选项重启软件后生效*
8-
- 开放 API 新增播放器声音大小、静音、播放进度控制、完整歌词获取,详情看接入文档 (#2386)
9-
- 新增「设置 → 播放设置 → 调换歌词翻译与歌词罗马音位置」选项,默认关闭 (#2451)
10-
- 新增启动参数 `-hidden`,在启动时将软件最小化到系统托盘 (#2459)
11-
- 新增 Any Listen 歌词(用于支持已下载歌曲的歌词逐字播放)标签数据读取与播放 (#2485)
12-
- 新增 Any Listen 歌词(包含逐字歌词、翻译、罗马音歌词,如果有)嵌入与下载,默认启用
13-
- 下载列表菜单新增歌曲添加弹窗,允许将所选歌曲的在线版本添加到收藏列表 (#2537)
14-
154
### 修复
165

17-
- 尝试修复进度为0时仍然显示下载完成的问题 (#2471)
18-
- 修复TX源搜索失败 (#2575 @Folltoshe)
19-
- 修复MG源歌单加载失败
20-
- 修复MG源评论加载失败
21-
22-
### 变更
23-
24-
- 调换「歌词翻译」与「歌词罗马音」的位置,现在歌词罗马音在歌词翻译的上方展示
25-
*若你想要恢复以前的行为,可以开启「调换歌词翻译与歌词罗马音位置」选项*
26-
- 更新代理配置规则,现在不启用代理时,图片、音频加载将不再走系统代理 (#2382 @Folltoshe)
27-
- 字体设置可以最多设置两种字体([any-listen#82](https://github.com/any-listen/any-listen/issues/82)
28-
29-
### 其他
30-
31-
- 更新 Electron 到 37.6.0
6+
- 修复音量条在调整音量时实际音量与显示的数值不一致的问题(#2606

src/renderer/components/base/SliderBar.vue

Lines changed: 34 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -29,6 +29,10 @@ export default {
2929
type: Number,
3030
required: true,
3131
},
32+
step: {
33+
type: Number,
34+
default: 1,
35+
},
3236
disabled: {
3337
type: Boolean,
3438
default: false,
@@ -39,33 +43,51 @@ export default {
3943
const sliderEvent = {
4044
isMsDown: false,
4145
msDownX: 0,
42-
msDownValue: 0,
46+
msDownRatio: 0,
4347
}
4448
const dom_sliderBar = ref(null)
4549
50+
const clampValue = val => {
51+
if (val < props.min) return props.min
52+
if (val > props.max) return props.max
53+
return val
54+
}
55+
const getSteppedValue = val => {
56+
const step = props.step > 0 ? props.step : 1
57+
const stepped = Math.round((val - props.min) / step) * step + props.min
58+
return clampValue(Number(stepped.toFixed(10)))
59+
}
60+
const getSliderWidth = () => dom_sliderBar.value?.clientWidth || 0
61+
const getRange = () => props.max - props.min
62+
const emitSteppedValue = rawValue => {
63+
const value = getSteppedValue(rawValue)
64+
emit('change', value)
65+
return value
66+
}
67+
4668
const handleSliderMsDown = event => {
4769
if (props.disabled) return
70+
const width = getSliderWidth()
71+
if (!width) return
4872
4973
sliderEvent.isMsDown = true
5074
sliderEvent.msDownX = event.clientX
5175
52-
sliderEvent.msDownValue = event.offsetX / dom_sliderBar.value.clientWidth
53-
let val = sliderEvent.msDownValue * (props.max - props.min) + props.min
54-
if (val < props.min) val = props.min
55-
if (val > props.max) val = props.max
56-
emit('change', val)
57-
58-
// if (isMute.value) window.app_event.setSliderIsMute(false)
76+
const rawValue = (event.offsetX / width) * getRange() + props.min
77+
const value = emitSteppedValue(rawValue)
78+
sliderEvent.msDownRatio = getRange() === 0 ? 0 : (value - props.min) / getRange()
5979
}
6080
const handleSliderMsUp = () => {
6181
sliderEvent.isMsDown = false
6282
}
6383
const handleSliderMsMove = event => {
6484
if (!sliderEvent.isMsDown || props.disabled) return
65-
let value = (sliderEvent.msDownValue + (event.clientX - sliderEvent.msDownX) / dom_sliderBar.value.clientWidth) * (props.max - props.min) + props.min
66-
if (value > props.max) value = props.max
67-
else if (value < props.min) value = props.min
68-
emit('change', value)
85+
const width = getSliderWidth()
86+
if (!width) return
87+
88+
const ratio = sliderEvent.msDownRatio + (event.clientX - sliderEvent.msDownX) / width
89+
const rawValue = ratio * getRange() + props.min
90+
emitSteppedValue(rawValue)
6991
}
7092
7193
document.addEventListener('mousemove', handleSliderMsMove)

src/renderer/components/common/VolumeBtn.vue

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -16,7 +16,7 @@
1616
@update:model-value="saveVolumeIsMute($event)"
1717
/>
1818
</div>
19-
<base-slider-bar :class="$style.slider" :value="volume" :min="0" :max="1" @change="handleUpdateVolume" />
19+
<base-slider-bar :class="$style.slider" :value="volume" :min="0" :max="1" :step="0.01" @change="handleUpdateVolume" />
2020
</div>
2121
</template>
2222
</material-popup-btn>

0 commit comments

Comments
 (0)