|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
能不能把这个文本朗读代码优化下,读取的文本颜色乱闪,请大师帮忙
import tkinter as tk
import win32com.client as wincl
from tkinter.scrolledtext import ScrolledText
# 创建 TTS 引擎对象
engine = wincl.Dispatch("SAPI.SpVoice")
# 设置音量
engine.Volume = 100
# 设置语速
engine.Rate = 0
# 打开需要读取的文本文件,并提取文件内容
pth = r'C:\Users\zhenghua\Desktop\webtext.txt'
text_file = open(pth, 'r', encoding='utf-8')
content = text_file.read()
# 创建 Tkinter 应用程序窗口
root = tk.Tk()
root.title('Text-to-Speech')
# 预先定义文本框的默认背景色和朗读时的活动背景色
default_bg = 'white' # 将原来的 `textbox.cget('background')` 修改为纯白色
active_bg = 'yellow'
# 创建带有滚动条的文本框,并用文件内容更新其文本
textbox = ScrolledText(root, font=('Arial', 18), wrap=tk.WORD)
textbox.pack(side=tk.TOP, padx=20, pady=20, fill=tk.BOTH, expand=True)
textbox.insert(tk.END, content)
# 定义读取文本为语音的函数,并增加背景颜色的变化
def speak():
# 禁用“朗读”按钮
button.config(state=tk.DISABLED)
# 获取当前文本框中的内容
line_num = textbox.index('end-1c').split('.')[0] # 获取最后一行的行号
for i in range(int(line_num)):
textbox.config(background=default_bg)
# 刷新窗口
root.update()
current_line = textbox.get(f"{i+1}.0", f"{i+1}.end") # 逐行获取文本
# 使用 TTS 引擎读取文本并播放
engine.Speak(current_line)
textbox.tag_add('blue', f"{i+1}.0", f"{i+1}.end")
root.after(1000, lambda: textbox.tag_remove('blue', f"{i+1}.0", f"{i+1}.end"))
root.after(1000, lambda: textbox.config(background=active_bg))
# 刷新窗口
root.update()
# 恢复“朗读”按钮的状态
button.config(state=tk.NORMAL)
# 创建一个按钮,并连接其 Click 事件与 speak() 函数
button = tk.Button(root, text="朗读", command=speak)
button.pack(side=tk.BOTTOM, padx=20, pady=20)
# 运行 Tkinter 主循环
root.mainloop()
看起来您希望在文本朗读时,当前正在朗读的文本行高亮显示,但是现在所有文本行的颜色都在闪烁。这可能是由于代码中的 root.after() 方法导致的,这个方法会在指定的延迟后执行函数,但是它不会等待这个函数执行完毕就立即返回。
在你的代码中,你设置了在延迟1秒后执行 lambda: textbox.config(background=active_bg) ,然后在下一行立即设置了 textbox.config(background=default_bg) ,这就是为什么背景色会“闪烁”。
下面是一个修改过的版本,它修复了上述问题,并使用文本标签(text tag)在朗读时高亮显示当前行。我也做了一些小的优化,例如关闭了打开的文本文件,这是一种好的编程习惯。
import tkinter as tk
import win32com.client as wincl
from tkinter.scrolledtext import ScrolledText
# 创建 TTS 引擎对象
engine = wincl.Dispatch("SAPI.SpVoice")
# 设置音量
engine.Volume = 100
# 设置语速
engine.Rate = 0
# 打开需要读取的文本文件,并提取文件内容
pth = r'C:\Users\zhenghua\Desktop\webtext.txt'
with open(pth, 'r', encoding='utf-8') as text_file:
content = text_file.read()
# 创建 Tkinter 应用程序窗口
root = tk.Tk()
root.title('Text-to-Speech')
# 创建带有滚动条的文本框,并用文件内容更新其文本
textbox = ScrolledText(root, font=('Arial', 18), wrap=tk.WORD)
textbox.pack(side=tk.TOP, padx=20, pady=20, fill=tk.BOTH, expand=True)
textbox.insert(tk.END, content)
# 定义读取文本为语音的函数,并增加高亮显示当前行的功能
def speak():
# 禁用“朗读”按钮
button.config(state=tk.DISABLED)
# 获取当前文本框中的内容
line_num = textbox.index('end-1c').split('.')[0] # 获取最后一行的行号
for i in range(int(line_num)):
current_line = textbox.get(f"{i+1}.0", f"{i+1}.end") # 逐行获取文本
# 使用 TTS 引擎读取文本并播放
engine.Speak(current_line)
# 高亮显示当前行
textbox.tag_add('highlight', f"{i+1}.0", f"{i+1}.end")
textbox.tag_config('highlight', background='yellow')
# 刷新窗口
root.update()
# 等待朗读完毕,然后取消高亮显示
while engine.WaitUntilDone(1):
continue
textbox.tag_remove('highlight', f"{i+1}.0", f"{i+1}.end")
# 恢复“朗读”按钮的状态
button.config(state=tk.NORMAL)
# 创建一个按钮,并连接其 Click 事件
与 speak() 函数
button = tk.Button(root, text="朗读", command=speak)
button.pack(side=tk.BOTTOM, padx=20, pady=20)
# 运行 Tkinter 主循环
root.mainloop()
这个修改过的版本应该可以解决你的问题。每次朗读一行文本时,这一行会被高亮显示,朗读完成后高亮就会消失。这样,朗读的过程应该会更加清晰易见。
|
|