サウンド設定に「サウンドを出力しない」と「Misskeyがアクティブな時のみサウンドを出力する」を追加 (#12342)
Co-authored-by: osamu <46447427+sam-osamu@users.noreply.github.com>
This commit is contained in:
		| @@ -5,6 +5,12 @@ SPDX-License-Identifier: AGPL-3.0-only | ||||
|  | ||||
| <template> | ||||
| <div class="_gaps_m"> | ||||
| 	<MkSwitch v-model="notUseSound"> | ||||
| 		<template #label>{{ i18n.ts.notUseSound }}</template> | ||||
| 	</MkSwitch> | ||||
| 	<MkSwitch v-model="useSoundOnlyWhenActive"> | ||||
| 		<template #label>{{ i18n.ts.useSoundOnlyWhenActive }}</template> | ||||
| 	</MkSwitch> | ||||
| 	<MkRange v-model="masterVolume" :min="0" :max="1" :step="0.05" :textConverter="(v) => `${Math.floor(v * 100)}%`"> | ||||
| 		<template #label>{{ i18n.ts.masterVolume }}</template> | ||||
| 	</MkRange> | ||||
| @@ -35,7 +41,10 @@ import MkFolder from '@/components/MkFolder.vue'; | ||||
| import { i18n } from '@/i18n.js'; | ||||
| import { definePageMetadata } from '@/scripts/page-metadata.js'; | ||||
| import { defaultStore } from '@/store.js'; | ||||
| import MkSwitch from '@/components/MkSwitch.vue'; | ||||
|  | ||||
| const notUseSound = computed(defaultStore.makeGetterSetter('sound_notUseSound')); | ||||
| const useSoundOnlyWhenActive = computed(defaultStore.makeGetterSetter('sound_useSoundOnlyWhenActive')); | ||||
| const masterVolume = computed(defaultStore.makeGetterSetter('sound_masterVolume')); | ||||
|  | ||||
| const soundsKeys = ['note', 'noteMy', 'notification', 'antenna', 'channel', 'reaction'] as const; | ||||
|   | ||||
| @@ -104,7 +104,7 @@ export async function playFile(file: string, volume: number) { | ||||
|  | ||||
| export function createSourceNode(buffer: AudioBuffer, volume: number) : AudioBufferSourceNode | null { | ||||
| 	const masterVolume = defaultStore.state.sound_masterVolume; | ||||
| 	if (masterVolume === 0 || volume === 0) { | ||||
| 	if (isMute() || masterVolume === 0 || volume === 0) { | ||||
| 		return null; | ||||
| 	} | ||||
|  | ||||
| @@ -117,3 +117,18 @@ export function createSourceNode(buffer: AudioBuffer, volume: number) : AudioBuf | ||||
|  | ||||
| 	return soundSource; | ||||
| } | ||||
|  | ||||
| export function isMute(): boolean { | ||||
| 	if (defaultStore.state.sound_notUseSound) { | ||||
| 		// サウンドを出力しない | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	// noinspection RedundantIfStatementJS | ||||
| 	if (defaultStore.state.sound_useSoundOnlyWhenActive && document.visibilityState === 'hidden') { | ||||
| 		// ブラウザがアクティブな時のみサウンドを出力する | ||||
| 		return true; | ||||
| 	} | ||||
|  | ||||
| 	return false; | ||||
| } | ||||
|   | ||||
| @@ -391,6 +391,14 @@ export const defaultStore = markRaw(new Storage('base', { | ||||
| 		where: 'device', | ||||
| 		default: 0.3, | ||||
| 	}, | ||||
| 	sound_notUseSound: { | ||||
| 		where: 'device', | ||||
| 		default: false, | ||||
| 	}, | ||||
| 	sound_useSoundOnlyWhenActive: { | ||||
| 		where: 'device', | ||||
| 		default: false, | ||||
| 	}, | ||||
| 	sound_note: { | ||||
| 		where: 'device', | ||||
| 		default: { type: 'syuilo/n-aec', volume: 1 }, | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 おさむのひと
					おさむのひと