请把文本朗读代码优化,读取的文本颜色乱闪,请大师帮忙
能不能把这个文本朗读代码优化下,读取的文本颜色乱闪,请大师帮忙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('.') # 获取最后一行的行号
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() 以下是优化后的文本朗读代码,实现了文本颜色不再乱闪:
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 file:
content = file.read()
# 创建 Tkinter 应用程序窗口
root = tk.Tk()
root.title('Text-to-Speech')
# 预先定义文本框的默认背景色和朗读时的活动背景色
default_bg = 'white'
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('.')
for i in range(int(line_num)):
# 将当前行的文字变为蓝色
textbox.tag_add('blue', f"{i+1}.0", f"{i+1}.end")
# 将当前行背景色改为活动背景色
textbox.config(background=active_bg)
# 移除文字的颜色标记和背景色变化,等待一秒再执行下一条语句
root.after(1000, lambda x=i+1: textbox.tag_remove('blue', f"{x}.0", f"{x}.end"))
root.after(1000, lambda: textbox.config(background=default_bg))
# 刷新窗口
root.update()
# 使用 TTS 引擎读取文本并播放
current_line = textbox.get(f"{i+1}.0", f"{i+1}.end")
engine.Speak(current_line)
# 恢复“朗读”按钮的状态
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('.') # 获取最后一行的行号
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()
这个修改过的版本应该可以解决你的问题。每次朗读一行文本时,这一行会被高亮显示,朗读完成后高亮就会消失。这样,朗读的过程应该会更加清晰易见。 可以使用 `tkinter` 模块中的 `Text` 组件代替 `ScrolledText`,并通过 `tag_config()` 方法设置文本颜色,避免在朗读过程中因为闪烁导致视觉不适。修改后的代码如下:
import tkinter as tk
import win32com.client as wincl
# 创建 TTS 引擎对象
engine = wincl.Dispatch("SAPI.SpVoice")
engine.Volume = 100# 设置音量
engine.Rate = 0# 设置语速
# 打开需要读取的文本文件,并提取文件内容
file_path = r'C:\Users\zhenghua\Desktop\webtext.txt'
with open(file_path, 'r', encoding='utf-8') as f:
content = f.read()
# 创建 Tkinter 应用程序窗口
root = tk.Tk()
root.title('Text-to-Speech')
# 预先定义文本框的默认背景色和朗读时的活动背景色
default_bg = 'white'
active_bg = 'yellow'
# 创建文本框,并用文件内容更新其文本
textbox = tk.Text(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)
# 设置文本样式
textbox.tag_config('red', foreground='red')
textbox.tag_config('blue', foreground='blue')
# 定义读取文本为语音的函数,并增加背景颜色及文本颜色的变化
def speak():
# 禁用“朗读”按钮
button.config(state=tk.DISABLED)
# 获取当前文本框中的内容
line_num = textbox.index('end-1c').split('.')# 获取最后一行的行号
for i in range(int(line_num)):
current_line = textbox.get(f"{i+1}.0", f"{i+1}.end")# 逐行获取文本
textbox.tag_add('blue', f"{i+1}.0", f"{i+1}.end")# 设置文本颜色
textbox.see(i+1)# 滚动到当前行
textbox.config(background=default_bg)# 设置背景颜色
root.update()# 刷新窗口
engine.Speak(current_line)# 使用 TTS 引擎读取文本并播放
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()
其中,`Text.tag_config()` 方法用于设置文本样式,例如 `foreground='red'` 表示将文本颜色设为红色;`Text.tag_add()` 方法则用于选中给定范围内的文本并设置其样式,比如在这里用于在朗读当前行文本时将其字体颜色设置为蓝色。另外,`Text.see()` 方法可以将当前文本框滚动到指定行。
有用请设置最佳答案
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\cenghua\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('.') # 获取最后一行的行号
for i in range(int(line_num)):
print(i)
current_line = textbox.get(f"{i+1}.0", f"{i+1}.end") # 逐行获取文本
# 高亮显示当前行
textbox.tag_add('highlight', f"{i+1}.0", f"{i+1}.end")
textbox.tag_config('highlight', background='yellow')
root.update()# 刷新窗口
engine.Speak(current_line)# 使用 TTS 引擎读取文本并播放
root.update()
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()
页:
[1]