IOS - 杂七杂八

设置子串是不同的颜色

/**
设置子串是不同的颜色

 @param color 颜色
 @param allStr 父串
 @param subString 子串
 @return 带颜色的父串
 */
-(NSMutableAttributedString *)setSubColor:(UIColor *)color : (NSString *)allStr : (NSString *)subString{
    NSMutableAttributedString *noteStr = [[NSMutableAttributedString alloc] initWithString:allStr];
    NSRange redRange = NSMakeRange([[noteStr string] rangeOfString:subString].location, [[noteStr string] rangeOfString:subString].length);
    //需要设置的位置
    [noteStr addAttribute:NSForegroundColorAttributeName value:color range:redRange];
    //设置颜色
    return noteStr;
    
}

 NSString *all = @"该区域共0条相关资源";
            self.statisticsGoogsLable.attributedText =  [all setSubColor:[UIColor redColor] :all :@"0"];
iOS使用NSMutableAttributedString实现富文本小结https://www.jianshu.com/p/583417467e94

NSMutableAttributedString *mutableString = [[NSMutableAttributedString alloc]initWithString:totalFee];
[mutableString addAttribute:NSFontAttributeName
value:[UIFont systemFontOfSize:21.0]
range:NSMakeRange(3, totalFee.length - 3)];//设置字体
[mutableString addAttribute:NSForegroundColorAttributeName
value:[UIColor redColor]
range:NSMakeRange(3, totalFee.length - 3)];//设置颜色
[mutableString addAttribute:NSUnderlineStyleAttributeName
value:[NSNumber numberWithInteger:NSUnderlineStyleSingle]
range:NSMakeRange(0, totalFee.length)];//添加下划线
sumLabel.attributedText = mutableString;

数字是特殊的颜色和字体

-(NSMutableAttributedString *)setGroupStr:(NSString *)content numColor:(UIColor *)numcolor otherColor:(UIColor *)otherolor  fontSize:(CGFloat)size{
    //      1首选初始化对象,正则表达式选取0到9的数字范围
    
    NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:@"[^0-9]" options:0 error:nil];
    
    //     2获取查询结果,得到的数组里面有一行文本中数字的范围
    NSArray *numArr = [regex matchesInString:content options:0 range:NSMakeRange(0, [content length])];
    NSMutableAttributedString *attributedString = [[NSMutableAttributedString alloc] initWithString:content attributes:@{NSForegroundColorAttributeName:numcolor}];
    [attributedString addAttribute:NSFontAttributeName value:[UIFont boldSystemFontOfSize:size ] range:NSMakeRange(0,[content length])];
    //    3循环找到数字的范围用富文本来给这行文本赋值
    for (NSTextCheckingResult *attirbute in numArr) {
        [attributedString setAttributes:@{NSForegroundColorAttributeName:otherolor} range:attirbute.range];
    }
    return attributedString;
}


手势

UITapGestureRecognizer *labelTapGestureRecognizer = [[UITapGestureRecognizer alloc] initWithTarget:self
                                                                                action:@selector(supplyLabelClick)];
// 2. 将点击事件添加到label上
[_supplyUILabel addGestureRecognizer:labelTapGestureRecognizer];

//图片添加手势,需要设置可交互
[imageView setUserInteractionEnabled:YES];

父控件背景半透明而其子控件不透明

view.backgroundColor = [UIColor colorWithWhite:0.5 alpha:0.3];
//还可以使用这个方法,可以设置其他颜色
colorWithRed:green:blue:alpha:

获取文字的宽高

CGSize pSize = [self.model.nickname sizeWithAttributes:@{NSFontAttributeName : Font_System_Regular(11)}];

加载xib

[[NSBundle mainBundle] loadNibNamed:@"selectExpressTitleView" owner:nil options:nil].lastObject

initWithFrame、initWithCoder、awakeFromNib

initWithFrame当控件不是从xib、storyboard中创建时,会调用这个方法
initWithCoder当控件是从xib、storyboard中创建时,会调用这个方法
awakeFromNib在initWithCoder:方法后调用
顺序是:initWithCoder -> awakeFromNib

通过frame加载xib

- (instancetype)initWithFrame:(CGRect)frame {
    
    self = [super initWithFrame:frame];
    
    self = [[[NSBundle mainBundle] loadNibNamed:@"selectExpressTitleView" owner:self options:nil] lastObject];
    return self;
}

动画

tableView的动画效果,tableView逐渐显现,透明逐渐减少,这种动画方式必须要有改变的属性,比如透明的程度

self.OrderTable.alpha = 0;
    [UIView animateWithDuration:1 animations:^{
        self.OrderTable.alpha = 1;
        [self.OrderTable reloadData];
 }];

提示框Alert

UIAlertController* alert = [UIAlertController alertControllerWithTitle:@"提示"
                                                               message:@"您是否记得平台支付密码"
                                                        preferredStyle:UIAlertControllerStyleAlert];

UIAlertAction* defaultAction = [UIAlertAction actionWithTitle:@"忘记了" style:UIAlertActionStyleDefault
                                                      handler:^(UIAlertAction * action) {
                                                          //响应事件
                                                          VerifyPassword *  verifyPassword = [[VerifyPassword alloc]init];
                                                          [self.navigationController pushViewController:verifyPassword animated:YES];
                                                      }];
UIAlertAction* cancelAction = [UIAlertAction actionWithTitle:@"记得" style:UIAlertActionStyleDefault
                                                     handler:^(UIAlertAction * action) {
                                                         //响应事件
                                                         ChangePassword * changePassword = [[ChangePassword alloc]init];
                                                         [self.navigationController pushViewController:changePassword animated:YES];
                                                     }];

[alert addAction:defaultAction];
[alert addAction:cancelAction];
[[UIApplication sharedApplication].keyWindow.rootViewController presentViewController:alert animated:YES completion:nil];

只设置某个圆角

        CAShapeLayer* shape = [[CAShapeLayer alloc] init];
        [shape setPath:rounded.CGPath];
        
        self.baseView.layer.mask = shape;

Button

设置按钮文字向左对齐,并且和左边有十个像素距离

btn1.contentHorizontalAlignment = UIControlContentHorizontalAlignmentLeft;
btn1.titleEdgeInsets = UIEdgeInsetsMake(0, 10, 0, 0);

按钮文字颜色设置

[btn setTitleColor:[UIColor blackColor]forState:UIControlStateNormal];

父子控制器

要添加控制器,已经控制器的view

NEWPageController *newpage = [[NEWPageController alloc]initWithModels:self.fModels];
     newpage.view.frame = CGRectMake(0, 0, self.baseView.width, self.baseView.height);
    [self addChildViewController:newpage];
    [self.baseView addSubview:newpage.view];

显示长图

//根据原始图片比例计算控件高度
            self.dailyPriceImage.bounds =CGRectMake(0, 0,self.dailyPriceImage.image.size.width, screenWidth/ (image.size.width/image.size.height)) ;
            //根据原始图片比例计算约束高度
            self.dailyPriceImageHeight.constant = screenWidth/ (image.size.width/image.size.height);

右滑之类的控件

constant控制布局,frame和alpha才能显示动画,constant改变不会动

 [UIView animateWithDuration:0.3 animations:^{
        self.shenfenHudViewLeading.constant = 0;
        self.shenFenHudView.frame = CGRectMake(screenWidth, self.shenFenHudView.y, self.shenFenHudView.width, self.shenFenHudView.height);
         self.shenfenTableview.alpha = 0;
    }];
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,589评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,615评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,933评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,976评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,999评论 6 393
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,775评论 1 307
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,474评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,359评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,854评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,007评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,146评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,826评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,484评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,029评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,153评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,420评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,107评论 2 356

推荐阅读更多精彩内容

  • 手势识别器 手势识别器将底层的事件处理代码转化为高层次的行为。它们是你可以添加到视图中的对象,让你的视图具备con...
    Randy1993阅读 438评论 0 1
  • 1.CGRectGet**方法 CGRectGet** 共有如下8个方法, 用于对一个Rect进行处理; 2.in...
    votzone阅读 366评论 0 0
  • 手势识别器是附加到视图的对象,将低级别事件处理代码转换为更高级别的操作,它允许视图以控件执行的方式响应操作。 手势...
    坤坤同学阅读 4,086评论 0 9
  • 在开发过程中,大家或多或少的都会碰到令人头疼的手势冲突问题,正好前两天碰到一个类似的bug,于是借着这个机会了解了...
    闫仕伟阅读 5,338评论 2 23
  • 昏暗 沉寂 浪潮一波一波涌来 白茫茫一片 下坠 下坠 在黑暗中下坠 一直跌入未知的虚空之中
    山林c阅读 1,461评论 30 50