添加emoji1

This commit is contained in:
2025-12-15 13:24:43 +08:00
parent 633e6a9123
commit 6963c8016f
13 changed files with 15733 additions and 19 deletions

View File

@@ -10,12 +10,15 @@
#import "KBKeyboardView.h"
#import "KBFunctionView.h"
#import "KBKey.h"
#import "KBEmojiPanelView.h"
#import "Masonry.h"
#import "KBSkinManager.h"
@interface KBKeyBoardMainView ()<KBToolBarDelegate, KBKeyboardViewDelegate>
@interface KBKeyBoardMainView ()<KBToolBarDelegate, KBKeyboardViewDelegate, KBEmojiPanelViewDelegate>
@property (nonatomic, strong) KBToolBar *topBar;
@property (nonatomic, strong) KBKeyboardView *keyboardView;
@property (nonatomic, strong) KBEmojiPanelView *emojiView;
@property (nonatomic, assign) BOOL emojiPanelVisible;
// /
@end
@implementation KBKeyBoardMainView
@@ -23,8 +26,7 @@
- (instancetype)initWithFrame:(CGRect)frame {
if (self = [super initWithFrame:frame]) {
self.backgroundColor = [KBSkinManager shared].current.keyboardBackground;
//
self.topBar = [[KBToolBar alloc] init];
self.topBar.delegate = self;
@@ -43,18 +45,60 @@
make.bottom.equalTo(self.mas_bottom).offset(-bottomInset);
}];
self.emojiView = [[KBEmojiPanelView alloc] init];
self.emojiView.hidden = YES;
self.emojiView.alpha = 0.0;
self.emojiView.delegate = self;
[self addSubview:self.emojiView];
[self.emojiView mas_makeConstraints:^(MASConstraintMaker *make) {
make.edges.equalTo(self);
}];
[self.topBar mas_makeConstraints:^(MASConstraintMaker *make) {
make.left.right.equalTo(self);
make.top.equalTo(self.mas_top).offset(0);
make.bottom.equalTo(self.keyboardView.mas_top).offset(-barSpacing);
}];
// /
}
return self;
}
- (void)setEmojiPanelVisible:(BOOL)visible animated:(BOOL)animated {
if (self.emojiPanelVisible == visible) return;
self.emojiPanelVisible = visible;
if (visible) {
[self.emojiView reloadData];
self.emojiView.hidden = NO;
[self bringSubviewToFront:self.emojiView];
} else {
self.keyboardView.hidden = NO;
self.topBar.hidden = NO;
}
void (^changes)(void) = ^{
self.emojiView.alpha = visible ? 1.0 : 0.0;
self.keyboardView.alpha = visible ? 0.0 : 1.0;
self.topBar.alpha = visible ? 0.0 : 1.0;
};
void (^completion)(BOOL) = ^(BOOL finished) {
self.emojiView.hidden = !visible;
self.keyboardView.hidden = visible;
self.topBar.hidden = visible;
};
if (animated) {
[UIView animateWithDuration:0.22 delay:0 options:UIViewAnimationOptionCurveEaseInOut animations:changes completion:completion];
} else {
changes();
completion(YES);
}
}
- (void)toggleEmojiPanel {
[self setEmojiPanelVisible:!self.emojiPanelVisible animated:YES];
}
#pragma mark - KBToolBarDelegate
@@ -106,12 +150,15 @@
[self.delegate keyBoardMainView:self didTapKey:key];
}
break;
case KBKeyTypeCustom:
//
case KBKeyTypeCustom: {
if ([key.identifier isEqualToString:KBKeyIdentifierEmojiPanel]) {
[self toggleEmojiPanel];
break;
}
if ([self.delegate respondsToSelector:@selector(keyBoardMainView:didTapKey:)]) {
[self.delegate keyBoardMainView:self didTapKey:key];
}
break;
} break;
case KBKeyTypeShift:
// Shift KBKeyboardView
break;
@@ -121,6 +168,25 @@
//
// KeyboardViewController
#pragma mark - KBEmojiPanelViewDelegate
- (void)emojiPanelView:(KBEmojiPanelView *)panel didSelectEmoji:(NSString *)emoji {
if (emoji.length == 0) return;
if ([self.delegate respondsToSelector:@selector(keyBoardMainView:didSelectEmoji:)]) {
[self.delegate keyBoardMainView:self didSelectEmoji:emoji];
}
}
- (void)emojiPanelViewDidRequestClose:(KBEmojiPanelView *)panel {
[self setEmojiPanelVisible:NO animated:YES];
}
- (void)emojiPanelViewDidTapSearch:(KBEmojiPanelView *)panel {
if ([self.delegate respondsToSelector:@selector(keyBoardMainViewDidTapEmojiSearch:)]) {
[self.delegate keyBoardMainViewDidTapEmojiSearch:self];
}
}
#pragma mark - Theme
- (void)kb_applyTheme {
@@ -130,6 +196,9 @@
self.backgroundColor = hasImg ? [UIColor clearColor] : bg;
self.keyboardView.backgroundColor = hasImg ? [UIColor clearColor] : bg;
[self.keyboardView reloadKeys];
if (self.emojiView) {
[self.emojiView applyTheme:mgr.current];
}
}
@end