Snail—UI学习之UIButton

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

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

UIButton的一些简单应用 ,现在写的都是一些自己用到的遇到的,一些其他的目前还没有看

#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 whiteColor];/*UIButtonTypeContactAdd 带一个加号标志的按钮UIButtonTypeCustom     自定义按钮 UIButtonTypeDetailDisclosure 就是按钮上一个圆圈 里面一个i 类似于某事物的细节按钮UIButtonTypeRoundedRect 圆角按钮UIButtonTypeSystem     系统按钮样式*/UIButton * button1 = [UIButton buttonWithType:UIButtonTypeSystem];//设置按钮的位置大小button1.frame = CGRectMake(20, 20, 280, 30);//设置按钮的背景颜色button1.backgroundColor = [UIColor blackColor];//设置按钮的标题 及当前按钮的状态为一般状态(未点击状态)/*forState:UIControlStateNormal:正常状态 未被点击UIControlStateHighlighted 高亮状态UIControlStateDisabled 禁用状态UIControlStateSelected 选中状态UIControlStateApplicationUIControlStateReserved  保留状态*/[button1 setTitle:@"点我1" forState:UIControlStateNormal];//设置其标记位button1.tag = 1;//设置按钮是否可按动 YES:可以  NO:不可用button1.enabled = YES;//为按钮添加一个事件/*第一个参数:self指本视图控制器第二个参数:按下按钮后要执行什么操作第三个参数:UIControlEventTouchUpInside 表示当按钮按下并且鼠标抬起的瞬间会触发操作UIControlEventTouchDown:按下去未抬起鼠标时将触发操作UIControlEventTouchDownRepeat 鼠标连续按下多次时将触发下面几个每次操作时,都会有按钮被按下去的操作UIControlEventTouchDragInside 按下按钮,并在此空间范围内拖动时UIControlEventTouchDragOutside 按钮按钮,在此空间范围外拖动*/[button1 addTarget:self action:@selector(click) forControlEvents:UIControlEventTouchUpInside];[self.view addSubview:button1];//再新建一个ButtonUIButton * button2 = [UIButton buttonWithType:UIButtonTypeSystem];button2.frame = CGRectMake(20, 60, 280, 30);button2.tag = 2;button2.backgroundColor = [UIColor redColor];[button2 setTitle:@"点我2" forState:UIControlStateNormal];//此action中得click:是代表有参数的click方法[button2 addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];[self.view addSubview:button2];//自定义按钮  UIButtonTypeCustomUIButton * button3 = [UIButton buttonWithType:UIButtonTypeCustom];button3.frame = CGRectMake(20, 100, 31, 30);[button3 setTitle:@"点我3" forState:UIControlStateNormal];button3.tag = 3;//设置button的初始状态  已经选择的状态button3.selected = NO;//设置自定义按钮两种状态下得不同图片//未选中状态显示的是第一个图片 选中状态后是后边的一个图片[button3 setImage:[UIImage imageNamed:@"star_icon@2x.png"] forState:UIControlStateNormal];[button3 setImage:[UIImage imageNamed:@"star2_Gray@2x.png"] forState:UIControlStateSelected];[button3 addTarget:self action:@selector(click:) forControlEvents:UIControlEventTouchUpInside];[self.view addSubview:button3];}//按下按钮后,将触发的操作写在这里
- (void)click{NSLog(@"你点我了1");
}
//如果有多个按钮要触发同一个操作,但是又想实现不同按钮方法将执行不同操作时,就要判断一下是哪个按钮按下了
- (void)click:(UIButton *)button{NSLog(@"你点我了2");
}- (void)didReceiveMemoryWarning
{[super didReceiveMemoryWarning];// Dispose of any resources that can be recreated.
}@end

运行效果图


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



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

相关文章

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

Vue项目中Element UI组件未注册的问题原因及解决方法

《Vue项目中ElementUI组件未注册的问题原因及解决方法》在Vue项目中使用ElementUI组件库时,开发者可能会遇到一些常见问题,例如组件未正确注册导致的警告或错误,本文将详细探讨这些问题... 目录引言一、问题背景1.1 错误信息分析1.2 问题原因二、解决方法2.1 全局引入 Element

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 ...]