IOS 纯代码自定义UIView案例

devtools/2024/9/25 21:30:42/
#import <UIKit/UIKit.h>NS_ASSUME_NONNULL_BEGIN@interface OrderAfterPeriodSelectNumView : UIView
//左边标题
@property (nonatomic,strong) UILabel *titleLab;
//数量
@property (nonatomic,strong) UILabel *numLab;@end

#import "OrderAfterPeriodSelectNumView.h"
@interface OrderAfterPeriodSelectNumView()
@property (nonatomic, assign) CGFloat titleLabWidth;
@end@implementation OrderAfterPeriodSelectNumView#pragma mark - 原始初始化方法// 1、首先调用init方法
- (instancetype)init{if (self = [super init]) {[self initUI];}return self;
}// 2、然后调用initWithFrame方法
- (instancetype)initWithFrame:(CGRect)frame{if (self =[super initWithFrame:frame]) {[self initUI];}return self;
}
// 初始化UI控件
- (void) initUI{UILabel *titleLab = [[UILabel alloc] init];titleLab.textColor = [UIColor colorWithHexString:@"333333"];titleLab.font = [UIFont systemFontOfSize:14];titleLab.textAlignment = NSTextAlignmentLeft;titleLab.text = @"退款数量";[self addSubview:titleLab];_titleLab = titleLab;UILabel *numLab = [[UILabel alloc] init];titleLab.textColor = [UIColor colorWithHexString:@"333333"];numLab.font = [UIFont systemFontOfSize:14];numLab.textAlignment = NSTextAlignmentRight;numLab.text = @"0";[self addSubview:numLab];_numLab = numLab;//获取字符串的宽高CGRect rect = [titleLab.text boundingRectWithSize:CGSizeMake(SCREENWIDTH, MAXFLOAT) options:NSStringDrawingTruncatesLastVisibleLine | NSStringDrawingUsesLineFragmentOrigin | NSStringDrawingUsesFontLeading attributes:@{NSFontAttributeName: [UIFont systemFontOfSize:14]} context:nil];_titleLabWidth = rect.size.width;}
// 设置UI控件的frame
- (void)layoutSubviews{[super layoutSubviews];// 1.获取当前控件的尺寸CGFloat width = self.frame.size.width;CGFloat height = self.frame.size.height;// 2.设置子控件的frameself.titleLab.frame = CGRectMake(16, 0, self.titleLabWidth, height);self.numLab.frame = CGRectMake(16+self.titleLabWidth, 0, width - (16+self.titleLabWidth+16), height);}@end

添加到UIStackView

OrderAfterPeriodSelectNumView *numView = [[OrderAfterPeriodSelectNumView alloc] init];
[numView mas_makeConstraints:^(MASConstraintMaker *make) {make.height.equalTo(@(50));}];
self.numView = numView;
[self.stackView addArrangedSubview:numView];


http://www.ppmy.cn/devtools/19005.html

相关文章

BUUCTF——[RoarCTF 2019]Easy Java

BUUCTF——[RoarCTF 2019]Easy Java 1.既然是登录框嘛&#xff0c;不得随便输入个弱口令&#xff0c;进行尝试 2.使用弱口令爆破了一下&#xff0c;直接就是429,无果 3.查看版本信息 4.帮助文档这里测试啦任意文件读取&#xff0c;无果 5.知道服务器的名称是openresty 6.…

【stomp 实战】Spring websocket使用详解和基本原理

spring框架对websocket有很好的支持&#xff0c;stomp协议作为websocket的子协议&#xff0c;Spring也做了很多封装&#xff0c;让我们在开发中易于使用。 学习使用Spring的Websocket模块&#xff0c;当然最好的办法就是看官网说明了。本篇文章对官网做一些简述和个人的理解。 …

怎么理解Fiber,Fiber解决了什么问题

问题 JavaScript引擎和浏览器的渲染引擎两个线程是互斥的,当有一个线程在执行的时候,另一个线程只能挂起等待。 如果JavaScript线程长时间占用主线程,那么渲染引擎的线程就得长时间等待,页面长时间不更新,会导致页面的响应度变差,给用户的感觉就是页面很卡。 这也是Re…

【前端技术】CSS基本语法(二)

一、 flex布局 flex布局称之为弹性布局给父元素设置display:flex&#xff0c;子元素可以自动挤压或拉伸内容&#xff0c;主轴方向默认为水平方向&#xff08;从左至右&#xff09; <!DOCTYPE html> <html lang"en"><head><meta charset"…

# IDEA2019 如何打开 Run Dashboard 运行仪表面板

IDEA2019 如何打开 Run Dashboard 运行仪表面板 段子手168 1、依次点击 IDEA 上面工具栏 —> 【View】 视图。 —> 【Tool Windows】 工具。 —> 【Run Dashboard】 运行仪表面板。 2、如果 【Tool Windows 】工具包 没有 【Run Dashboard】 运行仪表面板 项 依次…

Tensorflow2.0笔记 - BatchNormalization

本笔记记录BN层相关的代码。关于BatchNormalization&#xff0c;可以自行百度&#xff0c;或参考这里&#xff1a; 一文读懂Batch Normalization - 知乎神经网络基础系列&#xff1a; 《深度学习中常见激活函数的原理和特点》《过拟合: dropout原理和在模型中的多种应用》深度…

电销外呼系统有哪些用途?ai智能语音机器人系统部署各版本

现在由于网络技术的发展十分快速&#xff0c;让我们的工作方式、生活方式都向智能化方向转变&#xff0c;而电销外呼系统&#xff0c;可以应用于很多行业&#xff0c;那电销外呼系统有哪些用途呢&#xff1f;我们一起来看看 1、电销外呼系统一般用于什么场景 电销外呼系统是提…

第二证券|股票做短线要关注什么?

在股市中短线交易因其快速的盈利时机而招引了众多投资者&#xff0c;但做短线想要挣钱也不是那么容易的。对于股票做短线要重视什么&#xff0c;第二证券下面就为我们具体介绍一下。 短线交易需重视&#xff1a; 1、商场短期趋势。短线投资者首先需要重视的是全体商场趋势&am…