iOS 之键盘的很常用属性和自定义键盘

//
//  ViewController.h
//  iOS自定义键盘
//
//  Created by 黄权浩 on 14-12-31.
//  Copyright (c) 2014年 黄权浩. All rights reserved.
//

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController
{
    @private
    //自定义输入框来弹出系统的键盘
    UITextField *userFd;
}

@end
.m
//
//  ViewController.m
//  iOS自定义键盘
//
//  Created by 黄权浩 on 14-12-31.
//  Copyright (c) 2014年 黄权浩. All rights reserved.
//

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    
    //实现键盘上边的自定义工具栏
    UIView *toolVw = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 320, 40)];
    //现在我们在上边来实现一些按钮,控件的话可以自己来添加,我这里做一个收回键盘的按钮
    UIButton *hiddenFd = [UIButton buttonWithType:UIButtonTypeCustom];
    [hiddenFd setTitleColor:[UIColor blueColor] forState:UIControlStateNormal];
    [hiddenFd setTitle:@"Done" forState:UIControlStateNormal];
    [hiddenFd addTarget:self action:@selector(hidden) forControlEvents:UIControlEventTouchUpInside];
    hiddenFd.frame = CGRectMake(0, 0, 60, 40);
    [toolVw addSubview:hiddenFd];//这样就把这个按钮加入了这个自定义的工具栏
    
    //创建出我们的输入框
    userFd = [[UITextField alloc] initWithFrame:CGRectMake(20, 100, 280, 40)];
    userFd.inputAccessoryView = toolVw;
    userFd.placeholder = @"用户名";
    userFd.borderStyle = UITextBorderStyleRoundedRect;
    [self.view addSubview:userFd];
}

//收回键盘方法
- (void)hidden
{
    //失去响应者
    [userFd resignFirstResponder];
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end


//自定义键盘的话要相对于复杂一些

//
//  ViewController.m
//  iOS自定义键盘
//
//  Created by 黄权浩 on 14-12-31.
//  Copyright (c) 2014年 黄权浩. All rights reserved.
//

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    // Do any additional setup after loading the view, typically from a nib.
    UIView *toolVw = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 320, 300)];
    toolVw.backgroundColor = [UIColor colorWithRed:193/255.0 green:193/255.0 blue:193/255.0 alpha:1];
    
    //这个循环呢,只是为了将你自定义的一些键盘数值来添加到键盘中.并在点击的时候将值传入输入框内
    for (int i = 0; i<3; i++) {
        UIButton *bu = [UIButton buttonWithType:UIButtonTypeCustom];
        [bu setTitle:[NSString stringWithFormat:@"%d", i] forState:UIControlStateNormal];
        [bu setTitleColor:[UIColor redColor] forState:UIControlStateNormal];
        [bu addTarget:self action:@selector(hidden:) forControlEvents:UIControlEventTouchUpInside];
        bu.tag = i;
        bu.frame = CGRectMake(i*40, 40, 40, 40);
        [toolVw addSubview:bu];
    }
    
    //创建出我们的输入框
    userFd = [[UITextField alloc] initWithFrame:CGRectMake(20, 100, 280, 40)];
    userFd.inputView = toolVw;
    userFd.placeholder = @"用户名";
    userFd.borderStyle = UITextBorderStyleRoundedRect;
    [self.view addSubview:userFd];
}

//收回键盘方法
- (void)hidden:(UIButton *)bt
{
    //相当于拼接字符串。这样在用户看来其实他只是在接着输入而已
    if (bt.tag == 0) {
        userFd.text = [NSString stringWithFormat:@"%@%@",userFd.text, @"1"];
    }else if (bt.tag == 1) {
        userFd.text = [NSString stringWithFormat:@"%@%@",userFd.text, @"2"];
    }else if (bt.tag == 2) {
        userFd.text = [NSString stringWithFormat:@"%@%@",userFd.text, @"3"];
    }
}

- (void)didReceiveMemoryWarning {
    [super didReceiveMemoryWarning];
    // Dispose of any resources that can be recreated.
}

@end

其实对于我们来说,只要做到让用户看上去是真实的,那么实现的方式是各种各样的

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

黄权浩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值