275 lines
8.7 KiB
Python
275 lines
8.7 KiB
Python
"""
|
|
语音控制插件
|
|
为EG引擎提供完整的语音识别和语音合成功能
|
|
"""
|
|
|
|
from .core.voice_manager import VoiceManager
|
|
from .recognition.speech_recognizer import SpeechRecognizer
|
|
from .synthesis.speech_synthesizer import SpeechSynthesizer
|
|
from .commands.command_processor import CommandProcessor
|
|
from .audio.audio_manager import AudioManager
|
|
from .events.event_handler import VoiceEventHandler
|
|
from .nlp.nlp_processor import NLPProcessor
|
|
from .config.config_manager import VoiceConfigManager
|
|
from .editor.voice_editor import VoiceEditor
|
|
from .utils.voice_utils import VoiceUtils
|
|
|
|
class VoiceControlPlugin:
|
|
"""
|
|
语音控制插件主类
|
|
整合所有语音控制功能模块
|
|
"""
|
|
|
|
def __init__(self, engine):
|
|
"""
|
|
初始化语音控制插件
|
|
|
|
Args:
|
|
engine: EG引擎实例
|
|
"""
|
|
self.engine = engine
|
|
self.name = "VoiceControl"
|
|
self.version = "1.0.0"
|
|
self.author = "EG Plugin System"
|
|
|
|
# 功能模块
|
|
self.voice_manager = None
|
|
self.speech_recognizer = None
|
|
self.speech_synthesizer = None
|
|
self.command_processor = None
|
|
self.audio_manager = None
|
|
self.event_handler = None
|
|
self.nlp_processor = None
|
|
self.config_manager = None
|
|
self.voice_editor = None
|
|
self.voice_utils = None
|
|
|
|
# 插件状态
|
|
self.enabled = False
|
|
self.initialized = False
|
|
|
|
# 性能统计
|
|
self.stats = {
|
|
'commands_processed': 0,
|
|
'speech_recognized': 0,
|
|
'speech_synthesized': 0,
|
|
'audio_devices': 0,
|
|
'recognition_errors': 0,
|
|
'synthesis_errors': 0
|
|
}
|
|
|
|
print(f"✓ 语音控制插件 v{self.version} 已创建")
|
|
|
|
def initialize(self) -> bool:
|
|
"""
|
|
初始化插件
|
|
|
|
Returns:
|
|
是否初始化成功
|
|
"""
|
|
try:
|
|
print("正在初始化语音控制插件...")
|
|
|
|
# 初始化核心组件
|
|
self.voice_manager = VoiceManager(self)
|
|
self.speech_recognizer = SpeechRecognizer(self)
|
|
self.speech_synthesizer = SpeechSynthesizer(self)
|
|
self.command_processor = CommandProcessor(self)
|
|
self.audio_manager = AudioManager(self)
|
|
self.event_handler = VoiceEventHandler(self)
|
|
self.nlp_processor = NLPProcessor(self)
|
|
self.config_manager = VoiceConfigManager(self)
|
|
self.voice_editor = VoiceEditor(self)
|
|
self.voice_utils = VoiceUtils(self)
|
|
|
|
# 初始化各个模块
|
|
modules = [
|
|
self.voice_manager,
|
|
self.speech_recognizer,
|
|
self.speech_synthesizer,
|
|
self.command_processor,
|
|
self.audio_manager,
|
|
self.event_handler,
|
|
self.nlp_processor,
|
|
self.config_manager,
|
|
self.voice_editor,
|
|
self.voice_utils
|
|
]
|
|
|
|
for module in modules:
|
|
if module and not module.initialize():
|
|
print(f"✗ 模块初始化失败: {module.__class__.__name__}")
|
|
return False
|
|
|
|
self.initialized = True
|
|
print("✓ 语音控制插件初始化完成")
|
|
return True
|
|
|
|
except Exception as e:
|
|
print(f"✗ 语音控制插件初始化失败: {e}")
|
|
import traceback
|
|
traceback.print_exc()
|
|
return False
|
|
|
|
def enable(self) -> bool:
|
|
"""
|
|
启用插件
|
|
|
|
Returns:
|
|
是否启用成功
|
|
"""
|
|
try:
|
|
if not self.initialized:
|
|
print("✗ 插件未初始化")
|
|
return False
|
|
|
|
print("正在启用语音控制插件...")
|
|
|
|
# 启用各个模块
|
|
modules = [
|
|
self.voice_manager,
|
|
self.speech_recognizer,
|
|
self.speech_synthesizer,
|
|
self.command_processor,
|
|
self.audio_manager,
|
|
self.event_handler,
|
|
self.nlp_processor,
|
|
self.config_manager,
|
|
self.voice_editor,
|
|
self.voice_utils
|
|
]
|
|
|
|
for module in modules:
|
|
if module and not module.enable():
|
|
print(f"✗ 模块启用失败: {module.__class__.__name__}")
|
|
return False
|
|
|
|
self.enabled = True
|
|
print("✓ 语音控制插件已启用")
|
|
return True
|
|
|
|
except Exception as e:
|
|
print(f"✗ 语音控制插件启用失败: {e}")
|
|
import traceback
|
|
traceback.print_exc()
|
|
return False
|
|
|
|
def disable(self):
|
|
"""禁用插件"""
|
|
try:
|
|
if not self.enabled:
|
|
return
|
|
|
|
print("正在禁用语音控制插件...")
|
|
|
|
# 禁用各个模块
|
|
modules = [
|
|
self.voice_manager,
|
|
self.speech_recognizer,
|
|
self.speech_synthesizer,
|
|
self.command_processor,
|
|
self.audio_manager,
|
|
self.event_handler,
|
|
self.nlp_processor,
|
|
self.config_manager,
|
|
self.voice_editor,
|
|
self.voice_utils
|
|
]
|
|
|
|
for module in modules:
|
|
if module:
|
|
module.disable()
|
|
|
|
self.enabled = False
|
|
print("✓ 语音控制插件已禁用")
|
|
|
|
except Exception as e:
|
|
print(f"✗ 语音控制插件禁用失败: {e}")
|
|
import traceback
|
|
traceback.print_exc()
|
|
|
|
def finalize(self):
|
|
"""清理插件资源"""
|
|
try:
|
|
print("正在清理语音控制插件资源...")
|
|
|
|
# 清理各个模块
|
|
modules = [
|
|
self.voice_manager,
|
|
self.speech_recognizer,
|
|
self.speech_synthesizer,
|
|
self.command_processor,
|
|
self.audio_manager,
|
|
self.event_handler,
|
|
self.nlp_processor,
|
|
self.config_manager,
|
|
self.voice_editor,
|
|
self.voice_utils
|
|
]
|
|
|
|
for module in modules:
|
|
if module:
|
|
module.finalize()
|
|
|
|
self.initialized = False
|
|
print("✓ 语音控制插件资源已清理")
|
|
|
|
except Exception as e:
|
|
print(f"✗ 语音控制插件资源清理失败: {e}")
|
|
import traceback
|
|
traceback.print_exc()
|
|
|
|
def update(self, dt: float):
|
|
"""
|
|
更新插件状态
|
|
|
|
Args:
|
|
dt: 时间增量(秒)
|
|
"""
|
|
try:
|
|
if not self.enabled:
|
|
return
|
|
|
|
# 更新各个模块
|
|
modules = [
|
|
self.voice_manager,
|
|
self.speech_recognizer,
|
|
self.speech_synthesizer,
|
|
self.command_processor,
|
|
self.audio_manager,
|
|
self.event_handler,
|
|
self.nlp_processor,
|
|
self.config_manager,
|
|
self.voice_editor,
|
|
self.voice_utils
|
|
]
|
|
|
|
for module in modules:
|
|
if module:
|
|
module.update(dt)
|
|
|
|
except Exception as e:
|
|
print(f"✗ 语音控制插件更新失败: {e}")
|
|
import traceback
|
|
traceback.print_exc()
|
|
|
|
def get_stats(self) -> dict:
|
|
"""
|
|
获取插件统计信息
|
|
|
|
Returns:
|
|
统计信息字典
|
|
"""
|
|
return self.stats.copy()
|
|
|
|
def reset_stats(self):
|
|
"""重置统计信息"""
|
|
self.stats = {
|
|
'commands_processed': 0,
|
|
'speech_recognized': 0,
|
|
'speech_synthesized': 0,
|
|
'audio_devices': 0,
|
|
'recognition_errors': 0,
|
|
'synthesis_errors': 0
|
|
}
|
|
print("✓ 语音控制统计信息已重置") |