cdts/xdts-ios 3/TreeHole/CYHResetCode/CYH/QMUIKit/QMUIComponents/QMUIEmotionInputManager.h

74 lines
4.8 KiB
C
Raw Normal View History

2023-07-27 09:20:00 +08:00
/**
* Tencent is pleased to support the open source community by making QMUI_iOS available.
* Copyright (C) 2016-2021 THL A29 Limited, a Tencent company. All rights reserved.
* Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at
* http://opensource.org/licenses/MIT
* Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
*/
//
// QMUIEmotionInputManager.h
// qmui
//
// Created by QMUI Team on 16/9/8.
//
#import <Foundation/Foundation.h>
#import <UIKit/UIKit.h>
@class QMUIEmotionView;
/**
* `UITextField``UITextView`
* 使
* 1. 使 init
* 2. `boundTextField` `boundTextView` 使 `QMUITextField` `QMUITextView` warning
* 3. `self.emotionView.emotions` `QMUIEmotion` `displayName` 使[]
* 4. `self.emotionView` add
*
* @warning `QMUIEmotionInputManager``boundTextField``boundTextView`使`boundTextField`
* @warning `QMUIEmotionInputManager``boundTextView.text``setText:``UITextViewDelegate``textViewDidChange:``UITextViewTextDidChangeNotification` `UITextField` `UIControlEventEditingChanged` enabled状态时可能不及时使 `QMUITextView` `UITextView` `QMUITextField` `UITextField``shouldResponseToProgrammaticallyTextChanges` `YES` `YES`
* @warning `selectedRangeForBoundTextInput`
*/
@interface QMUIEmotionInputManager : NSObject
/// 要绑定的 UITextField
@property(nonatomic, weak) UITextField *boundTextField;
/// 要绑定的 UITextView
@property(nonatomic, weak) UITextView *boundTextView;
/**
* `selectedRangeForBoundTextInput`使
*
*
* - resignFirstResponderendEditing:
* - <UITextViewDelegate>`textViewDidChangeSelection:`
* - `selectedRangeForBoundTextInput`0
*/
@property(nonatomic, assign) NSRange selectedRangeForBoundTextInput;
/**
* `didSelectEmotionBlock``didSelectDeleteButtonBlock``QMUIEmotionInputManager``emotionView`
*/
@property(nonatomic, strong, readonly) QMUIEmotionView *emotionView;
/**
* `selectedRangeForBoundTextInput`
* @param forceDelete YES表示强制删掉NO表示不删
* @return YES
*/
- (BOOL)deleteEmotionDisplayNameAtCurrentSelectedRangeForce:(BOOL)forceDelete;
/**
* `UITextViewDelegate` `textView:shouldChangeTextInRange:replacementText:` `QMUITextFieldDelegate` `textField:shouldChangeTextInRange:replacementText:` `deleteEmotionDisplayNameAtCurrentSelectedRangeForce:`
@param range range
@param text
@return `YES` `deleteEmotionDisplayNameAtCurrentSelectedRangeForce:` `NO` 使
*/
- (BOOL)shouldTakeOverControlDeleteKeyWithChangeTextInRange:(NSRange)range replacementText:(NSString *)text;
@end