Commit a60daa9
committed
fix: improve streaming text insertion and stop button functionality
Streaming Text Insertion:
- Disable widget updates during text insertion to prevent auto-scroll
- Append using separate QTextCursor on document (doesn't affect visible cursor)
- Only auto-scroll to bottom if user was already at bottom (watching stream)
- Preserve user's scroll position when they scroll up to read earlier content
- Qt version compatibility for QTextCursor.End enum (Qt5/Qt6)
Stop Button Fix:
- Add cancellation check inside streaming generator consumption loop
- Check cancel_request() on each character/chunk during streaming
- Raise TranslationCanceled immediately when stop is requested
- Apply to both single translation and batch mode streaming
- Fixes infinite 'Stopping...' state with large merged translations
Scroll Synchronization:
- Keep simple pixel-based scroll sync (most stable)
- Note: Minor drift can occur with word wrap when languages have different lengths
- Alternative sync methods (line-based, percentage-based) had worse issues1 parent 9042c76 commit a60daa9
2 files changed
Lines changed: 37 additions & 3 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
6 | 6 | | |
7 | 7 | | |
8 | 8 | | |
9 | | - | |
| 9 | + | |
10 | 10 | | |
11 | 11 | | |
12 | 12 | | |
| |||
973 | 973 | | |
974 | 974 | | |
975 | 975 | | |
| 976 | + | |
976 | 977 | | |
977 | 978 | | |
978 | 979 | | |
| |||
1139 | 1140 | | |
1140 | 1141 | | |
1141 | 1142 | | |
1142 | | - | |
| 1143 | + | |
| 1144 | + | |
| 1145 | + | |
| 1146 | + | |
| 1147 | + | |
| 1148 | + | |
| 1149 | + | |
| 1150 | + | |
| 1151 | + | |
| 1152 | + | |
| 1153 | + | |
| 1154 | + | |
| 1155 | + | |
| 1156 | + | |
| 1157 | + | |
| 1158 | + | |
| 1159 | + | |
| 1160 | + | |
| 1161 | + | |
| 1162 | + | |
| 1163 | + | |
| 1164 | + | |
| 1165 | + | |
| 1166 | + | |
| 1167 | + | |
1143 | 1168 | | |
1144 | 1169 | | |
1145 | 1170 | | |
| |||
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
169 | 169 | | |
170 | 170 | | |
171 | 171 | | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
172 | 175 | | |
173 | 176 | | |
174 | 177 | | |
175 | 178 | | |
176 | 179 | | |
177 | 180 | | |
178 | 181 | | |
179 | | - | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
180 | 189 | | |
181 | 190 | | |
182 | 191 | | |
| |||
0 commit comments