How to add a toolbar to the BOTTOM of a UITableView obj-c/ios/xcode

后端 未结 4 1647
误落风尘
误落风尘 2021-02-06 15:07

how do I add Programmaticaly a toolbar with uitextfield at the bottom of a tableview? Like a chat or sms app.. thank you in advance..

4条回答
  •  醉话见心
    2021-02-06 16:01

    Use a UIViewController subclass instead of UITableViewController subclass.

    it should be something like this :

    @interface ChatViewController : UIViewController
    @end
    
    
    #import "ChatViewController.h"
    
    @interface ChatViewController()  
    @property (nonatomic, strong) UITableView *tableView;
    @property (nonatomic, strong) UIToolbar *toolbar;
    @property (nonatomic, strong) UITextField *textField;
    @end
    
    @implementation ChatViewController
    
    -(UITableView *)tableView
    {
        if (!_tableView) {
            _tableView = [UITableView alloc] init];
            CGRect frame = self.view.bounds;
            frame.size.height = frame.size.height - 44;
            _tableView.frame = frame;
            _tableView.delegate = self;
            _tableView.dataSource = self;
        }
        return _tableView;
    }
    
    -(UIToolbar *)toolbar
    {
        if (!_toolbar) {
            _toolbar = [[UIToolbar alloc] initWithFrame:CGRectMake(0,self.tableView.frame.size.height,self.view.frame.size.width, 44)];
        self.textField = [[UITextField alloc] initWithFrame:CGRectMake(0,0,_toolbar.frame.size.width -20)];
        self.textField.delegate = self;
        UIBarButtonItem *textFieldItem = [[UIBarButtonItem alloc] initWithCustomView:self.textField];
        UIBarButtonItem *flexibleSpace = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace
                                                                                       target:nil
                                                                                       action:nil];
        // You'll need to add a button to send you text
        _toolbar.items = [NSArray arrayWithObjects:flexibleSpace, textFieldItem, flexibleSpace, nil];
        }
        return _toolbar;
    }
    
    -(void)viewDidLoad
    {
        [super viewDidLoad];
        [self.view addSubview:self.tableView];
        [self.view addSubview:self.toolbar];
        [[NSNotificationCenter defaultCenter] addObserver:self 
                                                 selector:@selector(keyboardWillHideOrShow:) 
                                                     name:UIKeyboardWillHideNotification 
                                                   object:nil];
        [[NSNotificationCenter defaultCenter] addObserver:self 
                                                 selector:@selector(keyboardWillHideOrShow:) 
                                                     name:UIKeyboardWillShowNotification 
                                                   object:nil];
    }
    
    - (void)viewDidUnload
    {
        [[NSNotificationCenter defaultCenter] removeObserver:self];
        [super viewDidUnload];
    }
    
    
    - (void)keyboardWillHideOrShow:(NSNotification *)note
    {
        NSDictionary *userInfo = note.userInfo;
        NSTimeInterval duration = [[userInfo objectForKey:UIKeyboardAnimationDurationUserInfoKey] doubleValue];
        UIViewAnimationCurve curve = [[userInfo objectForKey:UIKeyboardAnimationCurveUserInfoKey] intValue];
    
        CGRect keyboardFrame = [[userInfo objectForKey:UIKeyboardFrameEndUserInfoKey] CGRectValue];
        CGRect keyboardFrameForToolbar = [self.toolbar.superview convertRect:keyboardFrame fromView:nil];
        CGRect keyboardFrameForTableView = [self.tableView.superview convertRect:keyboardFrame fromView:nil];
    
        CGRect newToolbarFrame = self.toolbar.frame;
        newToolbarFrame.origin.y = keyboardFrameForToolbar.origin.y - newToolbarFrame.size.height;
    
        CGRect newTableViewFrame = self.tableView.frame;
        newTableViewFrame.size.height = keyboardFrameForTableView.origin.y - newToolbarFrame.size.height;
    
        [UIView animateWithDuration:duration 
                              delay:0 
                            options:UIViewAnimationOptionBeginFromCurrentState | curve 
                         animations:^{self.toolbar.frame = newToolbarFrame;
                             self.tableView.frame =newTableViewFrame;} 
                         completion:nil];  
    }
    

    This would handle laying out the views and animating keyboard appearance. You'll need to handle delegate and datasource methods for the table view and the text field.

提交回复
热议问题