UITextField输入限制/小数/首位等

本文介绍了如何通过UITextFieldDelegate协议的方法textField:shouldChangeCharactersInRange:replacementString:来实现UITextField输入内容的限制,包括最大长度限制、最多输入两位小数以及完美实现金额输入格式。

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{

功能:

  把textField中位置为range的字符串替换为string字符串;

  此函数在textField内容被修改时调用;

返回值:

  YES,表示修改生效;NO,表示不做修改,textField的内容不变。

参数说明:

  textField:响应UITextFieldDelegate协议的UITextField控件。

  range:    UITextField控件中光标选中的字符串,即被替换的字符串;

          range.length为0时,表示在位置range.location插入string。

  string:    替换字符串;

          string.length为0时,表示删除。

 

一. 限制 textField输入最大长度

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{

    NSLog(@"原字符:%@",textField.text);

    NSLog(@"位置:%ld",range.location);

    NSLog(@"长度:%ld",range.length);

    NSLog(@"替换字符:%@",string);

    //

    if (textField == _textField) {

    

        if (textField == self.textField) {

           

            if (string.length == 0) return YES;

            NSInteger existedLength = textField.text.length;

            NSInteger selectedLength = range.length;

            NSInteger replaceLength = string.length;

            

            if (existedLength - selectedLength + replaceLength > 6) {

                [textField resignFirstResponder];

                return NO;

            }

        }

    }

    return YES;

}

二.最多输入两位 小数

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{

 

  if (textField == _moneyTextField) {

        NSMutableString * futureString = [NSMutableString stringWithString:textField.text];

        [futureString  insertString:string atIndex:range.location];

        

        NSInteger flag=0;

        const NSInteger limited = 2;

        for (NSInteger i = futureString.length-1; i>=0; i--) {

            if ([futureString characterAtIndex:i] == '.') {

                if (flag > limited) {

                    return NO;

                }

                break;

            }

            flag++;

        }

        

        

    }

 

    return YES;

}

 

// 最完美的UITextField中输入金额,只能输入数字和小数点,保留两位小数点且0放在首位

 

@property (nonatomic, assign) BOOL isHaveDian;

@property (nonatomic, assign) BOOL isFirstZero;

 

 

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {

    if (textField == self.amountTextField) {

   

        if ([textField.textrangeOfString:@"."].location==NSNotFound) {

            _isHaveDian = NO;

        }

        if ([textField.textrangeOfString:@"0"].location==NSNotFound) {

            _isFirstZero = NO;

        }

        

        if ([string length]>0)

        {

            unichar single=[string characterAtIndex:0];//当前输入的字符

            if ((single >='0' && single<='9') || single=='.')//数据格式正确

            {

                

                if([textField.text length]==0){

                    if(single == '.'){

                        //首字母不能为小数点

                        return NO;

                    }

                    if (single == '0') {

                        _isFirstZero = YES;

                        return YES;

                    }

                }

                

                if (single=='.'){

                    if(!_isHaveDian)//text中还没有小数点

                    {

                        _isHaveDian=YES;

                        return YES;

                    }else{

                        return NO;

                    }

                }else if(single=='0'){

                    if ((_isFirstZero&&_isHaveDian)||(!_isFirstZero&&_isHaveDian)) {

                        //首位有0有.(0.01)或首位没0有.(10200.00)可输入两位数的0

                        if([textField.textisEqualToString:@"0.0"]){

                            return NO;

                        }

                        NSRange ran=[textField.textrangeOfString:@"."];

                        int tt=(int)(range.location-ran.location);

                        if (tt <= 2){

                            return YES;

                        }else{

                            return NO;

                        }

                    }else if (_isFirstZero&&!_isHaveDian){

                        //首位有0没.不能再输入0

                        return NO;

                    }else{

                        return YES;

                    }

                }else{

                    if (_isHaveDian){

                        //存在小数点,保留两位小数

                        NSRange ran=[textField.textrangeOfString:@"."];

                        int tt= (int)(range.location-ran.location);

                        if (tt <= 2){

                            return YES;

                        }else{

                            return NO;

                        }

                    }else if(_isFirstZero&&!_isHaveDian){

                        //首位有0没点

                        return NO;

                    }else{

                        return YES;

                    }

                }

            }else{

                //输入的数据格式不正确

                return NO;

            }

        }else{

            return YES;

        }

    }

    return YES;

}

 

转载于:https://www.cnblogs.com/daxueshan/p/5977787.html

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值