• iOS 学习


    思路:

      1.new 一个 Empty 后缀为 .txt 文件,内容随笔拷贝一段

      2.用 NSString 接收本地文件,再用一个标题拼接字符串

      3.创建一个 NSMutableParagraphStyle 实例,设置标题居中、标题距离正文间隔

      4.创建一个 NSMutableParagraphStyle 实例,设置正文左对齐、每段开头缩进 10

      5.创建一个基础动画的实例,用代理监听动画结束

    话不多说上代码

    #pragma mark -- 拼接字符
    - (void)loadData:(NSString *)filename {
        
        //第一个段落
        NSMutableParagraphStyle *first = [[NSMutableParagraphStyle alloc]init];
        first.alignment = NSTextAlignmentCenter;
        first.lineSpacing = 10;
        
        //第二个段落
        NSMutableParagraphStyle *second = [[NSMutableParagraphStyle alloc]init];
        //从左开始写
        second.alignment = NSTextAlignmentLeft;
        //首行缩进
        second.firstLineHeadIndent = 10;
        //间距
        second.lineSpacing = 10;
        
        UIFont *titleFont = [UIFont systemFontOfSize:16];
        UIFont *contextFont = [UIFont systemFontOfSize:13];
        
        NSMutableAttributedString *str1 = [[NSMutableAttributedString alloc]initWithString:@"游戏许可及服务协议" attributes:@{NSParagraphStyleAttributeName:first,NSFontAttributeName:titleFont}];
        
        //标题拼接正文,正文前加换行符
        NSString *str = [NSString stringWithFormat:@"
    %@",filename];
        
        NSMutableAttributedString *str2 = [[NSMutableAttributedString alloc]initWithString:str attributes:@{NSParagraphStyleAttributeName:second,NSFontAttributeName:contextFont}];
        
        [str1 appendAttributedString:str2];
        _textView.attributedText = str1;
    }
    
    #pragma mark -- 关闭动画
    - (void)closeAniamtion:(UIView *)view {
        CABasicAnimation *animation = [CABasicAnimation animation];
        animation.keyPath = @"transform.scale";
        animation.toValue = @0.9;
        animation.duration = 0.4;
        animation.delegate = self;
        animation.removedOnCompletion = NO;
        animation.fillMode = kCAFillModeForwards;
        [view.layer addAnimation:animation forKey:@"closeAnimation"];
    }
    
    #pragma mark -- 本地 txt 文件内容
    - (NSString *)filename {
        //本地 txt 文件
        NSString *path = [[NSBundle mainBundle]pathForResource:@"浅遇时光,静好无恙.txt" ofType:nil];
        //取出内容
        NSString *filename = [[NSString alloc]initWithContentsOfFile:path encoding:NSUTF8StringEncoding error:nil];
        return filename;
    }
    #pragma mark -- 代理监听动画停止
    - (void)animationDidStop:(CAAnimation *)anim finished:(BOOL)flag {
    
        if ([_bgView.layer animationForKey:@"closeAnimation"] == anim) {
            [_bgView removeFromSuperview];
        }
    }

    字体间距,中文的文字宽度是相等的,英文和数字的宽度不一样

    - (void)baseChinese:(UILabel *)label loadFirst:(NSString *)firstStr second:(NSString *)secondStr
    {
        //第一个段落
        NSMutableParagraphStyle *first = [[NSMutableParagraphStyle alloc]init];
        //第二个段落
        NSMutableParagraphStyle *second = [[NSMutableParagraphStyle alloc]init];
        
        int a = (int)firstStr.length;
        int b = (int)secondStr.length;
        
        if (a>b) {
    
            NSDictionary *dict1 = @{NSParagraphStyleAttributeName:first};
            NSMutableAttributedString *firstAttr = [[NSMutableAttributedString alloc]initWithString:firstStr attributes:dict1];
            /** 计算间距 **/
            CGFloat lineGap = label.font.pointSize *(a-b)/(b-1);
            
            NSString *longSecondStr = [NSString stringWithFormat:@"
    %@",secondStr];
            NSMutableAttributedString *secondAttr = [[NSMutableAttributedString alloc]initWithString:longSecondStr attributes:@{NSParagraphStyleAttributeName:second}];
            NSRange range = {0,b};
            /** 添加间距属性 **/
            [secondAttr addAttribute:NSKernAttributeName value:[NSNumber numberWithFloat:lineGap] range:range];
            /** 拼接字符串 **/
            [firstAttr appendAttributedString:secondAttr];
            label.attributedText = firstAttr;
            
        }else if(b>a){
            
            NSRange range = {0,a};
            /** 计算间距 **/
            CGFloat lineGap = label.font.pointSize *(b-a)/(a-1);
            NSDictionary *dict1 = @{NSParagraphStyleAttributeName:first};
            NSMutableAttributedString *firstAttr = [[NSMutableAttributedString alloc]initWithString:firstStr attributes:dict1];
            /** 添加间距属性 **/
            [firstAttr addAttribute:NSKernAttributeName value:[NSNumber numberWithFloat:lineGap] range:range];
            
            NSString *longSecondStr = [NSString stringWithFormat:@"
    %@",secondStr];
            NSMutableAttributedString *secondAttr = [[NSMutableAttributedString alloc]initWithString:longSecondStr attributes:@{NSParagraphStyleAttributeName:second}];
            /** 拼接字符串 **/
            [firstAttr appendAttributedString:secondAttr];
            label.attributedText = firstAttr;
            
        }else{
            /** 如果相等,直接拼接 **/
            label.text = [NSString stringWithFormat:@"%@
    %@",firstStr,secondStr];
        }
    }

    完整代码在 github 上,传送门

  • 相关阅读:
    ES6(四)字符串的扩展
    ES6(三)数组的扩展
    ES6(二) Destructuring-变量的解构赋值
    ES6(一) let and const
    canvas(七) 文字编写
    canvas(五)createPattern
    canvas(四) Gradient- demo
    canvas(三) star- demo
    jQuery之简单动画效果
    web开发小白之路
  • 原文地址:https://www.cnblogs.com/asamu/p/5887989.html
Copyright © 2020-2023  润新知