Snail—UI学习之UILabel

2024-05-05 04:32
文章标签 学习 ui uilabel snail

本文主要是介绍Snail—UI学习之UILabel,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

看一下UILabel的属性学习一下

在开始写代码之前,要保证新建了一个工程 然后新建一个RootViewController 作为window的根视图

代码要都写在RooViewController里面

我的WJJRootViewController.m文件里写的是创建UILabel的各种方法

#import "WJJRootViewController.h"@interface WJJRootViewController ()@end@implementation WJJRootViewController- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil
{self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];if (self) {// Custom initialization}return self;
}- (void)viewDidLoad
{[super viewDidLoad];// Do any additional setup after loading the view.self.view.backgroundColor = [UIColor grayColor];/*iPhone中 是在关于视图组件时的坐标系是以左上角为原点向右 横坐标为正向下 纵坐标为正*///实例化一个UILabel  初始化它的边框大小  需要一个Rect的参数(x,y,width,height)UILabel * label1 = [[UILabel alloc] initWithFrame:CGRectMake(30, 30, 290, 30)];//设置label的属性//设置label的文本label1.text = @"Snail倒萨啊啊啊啊飒飒的的飒飒撒";//设置label的背景颜色label1.backgroundColor = [UIColor redColor];//设置label的文本对齐方式/*NSTextAlignmentLeft 左对齐NSTextAlignmentRight右对齐NSTextAlignmentCenter 居中*/label1.textAlignment = NSTextAlignmentRight;//设置文本的字体大小 设置字体为20label1.font = [UIFont systemFontOfSize:20];//设置字体加粗及字体的大小 下面关于字体的效果会覆盖上面这个方法label1.font = [UIFont boldSystemFontOfSize:20];//设置文本的颜色label1.textColor = [UIColor blackColor];//设置lable的透明度  0-1  0是透明  并且父视图的透明度会影响到子视图或者文本的透明度label1.alpha = 0.5;//设置lable隐藏 yes即是隐藏label1.hidden = NO;//设置lable的边框颜色label1.layer.backgroundColor = [[UIColor blackColor] CGColor] ;//设置label边框的宽度label1.layer.borderWidth = 2;//设置label边框的弧度 如果label是正方形 弧度=边长/2的时候 为圆形label1.layer.cornerRadius = 10;//把label添加到主视图中[self.view addSubview:label1];//设置文本的自适应label 宽度或者高度固定,相应高度或宽度可以根据文字大小、多小相应的变化//这里我们会让label的宽度固定 类似qq或者微信发的消息//要显示的文字NSString * string = @"wuwuuwuweuwuwwwwwweuashsjkdshjdfshjdsfhjdsafhdfsghadfsghjafhdfshgjfhdfshdsfhgjdfhshgfdshasdhjfds";/*主要是计算文本的高度第一个参数:我们的label固定为宽为300,MAXFLOAT设置高度为无限大第二个参数:只知道文本要显示多行的时候 就写这个参数第三个参数:文本的一些属性第四个参数:nil*/CGRect rect = [string boundingRectWithSize:CGSizeMake(290, MAXFLOAT) options:NSStringDrawingUsesLineFragmentOrigin attributes:@{NSFontAttributeName:[UIFont systemFontOfSize:20]} context:nil];//创建一个label 根据计算出来的矩形大小来创建的labelUILabel * label2 = [[UILabel alloc] initWithFrame:CGRectMake(30, 80, rect.size.width, rect.size.height)];//设置label的文本大小要跟计算文本高度时文字的大小label2.font = [UIFont systemFontOfSize:20];label2.backgroundColor = [UIColor greenColor];//设置label的行数 0代表无限行 如果不设置 文本不换多行显示 上面的工作也就白做了label2.numberOfLines = 0;label2.text = string;[self.view addSubview:label2];
}- (void)didReceiveMemoryWarning
{[super didReceiveMemoryWarning];// Dispose of any resources that can be recreated.
}@end

下面附上运行在模拟器上得效果图


这篇关于Snail—UI学习之UILabel的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/960807

相关文章

Python中的可视化设计与UI界面实现

《Python中的可视化设计与UI界面实现》本文介绍了如何使用Python创建用户界面(UI),包括使用Tkinter、PyQt、Kivy等库进行基本窗口、动态图表和动画效果的实现,通过示例代码,展示... 目录从像素到界面:python带你玩转UI设计示例:使用Tkinter创建一个简单的窗口绘图魔法:用

element-ui下拉输入框+resetFields无法回显的问题解决

《element-ui下拉输入框+resetFields无法回显的问题解决》本文主要介绍了在使用ElementUI的下拉输入框时,点击重置按钮后输入框无法回显数据的问题,具有一定的参考价值,感兴趣的... 目录描述原因问题重现解决方案方法一方法二总结描述第一次进入页面,不做任何操作,点击重置按钮,再进行下

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识