iOS: hide edit menu if typing on the input panel
On iOS, if you select some text, the edit menu will show on top of it. And if you tap on the screen (or inside the menu) it will hide. But if you type on the input panel, it will stay open. This is wrong. This patch will keep better track of whether or not the edit menu was opened by us, and if it was, ensure we close it also if the cursor moves by typing on the input panel. Pick-to: 6.0 6.1 5.15 Fixes: QTBUG-90860 Change-Id: I0a51382030560182e7925c8b694b42e50943514e Reviewed-by: Morten Johan Sørvig <morten.sorvig@qt.io>
This commit is contained in:
parent
f7dd793db5
commit
b390812304
@ -92,6 +92,7 @@ static void executeBlockWithoutAnimation(Block block)
|
|||||||
@interface QIOSEditMenu : NSObject
|
@interface QIOSEditMenu : NSObject
|
||||||
@property (nonatomic, assign) BOOL visible;
|
@property (nonatomic, assign) BOOL visible;
|
||||||
@property (nonatomic, readonly) BOOL isHiding;
|
@property (nonatomic, readonly) BOOL isHiding;
|
||||||
|
@property (nonatomic, readonly) BOOL shownByUs;
|
||||||
@property (nonatomic, assign) BOOL reshowAfterHidden;
|
@property (nonatomic, assign) BOOL reshowAfterHidden;
|
||||||
@end
|
@end
|
||||||
|
|
||||||
@ -110,6 +111,7 @@ static void executeBlockWithoutAnimation(Block block)
|
|||||||
[center addObserverForName:UIMenuControllerDidHideMenuNotification
|
[center addObserverForName:UIMenuControllerDidHideMenuNotification
|
||||||
object:nil queue:nil usingBlock:^(NSNotification *) {
|
object:nil queue:nil usingBlock:^(NSNotification *) {
|
||||||
_isHiding = NO;
|
_isHiding = NO;
|
||||||
|
_shownByUs = NO;
|
||||||
if (self.reshowAfterHidden) {
|
if (self.reshowAfterHidden) {
|
||||||
// To not abort an ongoing hide transition when showing the menu, you can set
|
// To not abort an ongoing hide transition when showing the menu, you can set
|
||||||
// reshowAfterHidden to wait until the transition finishes before reshowing it.
|
// reshowAfterHidden to wait until the transition finishes before reshowing it.
|
||||||
@ -144,6 +146,10 @@ static void executeBlockWithoutAnimation(Block block)
|
|||||||
return;
|
return;
|
||||||
|
|
||||||
if (visible) {
|
if (visible) {
|
||||||
|
// UIMenuController is a singleton that can be shown (and hidden) from anywhere.
|
||||||
|
// Try to keep track of whether or not is was shown by us (the gesture recognizers
|
||||||
|
// in this file) to avoid closing it if it was opened from elsewhere.
|
||||||
|
_shownByUs = YES;
|
||||||
// Note that the contents of the edit menu is decided by
|
// Note that the contents of the edit menu is decided by
|
||||||
// first responder, which is normally QIOSTextResponder.
|
// first responder, which is normally QIOSTextResponder.
|
||||||
QRectF cr = QPlatformInputContext::cursorRectangle();
|
QRectF cr = QPlatformInputContext::cursorRectangle();
|
||||||
@ -841,11 +847,9 @@ static void executeBlockWithoutAnimation(Block block)
|
|||||||
if (_cursorLayer.visible) {
|
if (_cursorLayer.visible) {
|
||||||
_cursorLayer.visible = NO;
|
_cursorLayer.visible = NO;
|
||||||
_anchorLayer.visible = NO;
|
_anchorLayer.visible = NO;
|
||||||
// Only hide the edit menu if we had a selection from before, since
|
|
||||||
// the edit menu can also be used for other purposes by others (in
|
|
||||||
// which case we try our best not to interfere).
|
|
||||||
QIOSTextInputOverlay::s_editMenu.visible = NO;
|
|
||||||
}
|
}
|
||||||
|
if (QIOSTextInputOverlay::s_editMenu.shownByUs)
|
||||||
|
QIOSTextInputOverlay::s_editMenu.visible = NO;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user