博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
UIButton常用属性和函数详解
阅读量:2339 次
发布时间:2019-05-10

本文共 3096 字,大约阅读时间需要 10 分钟。

特常用的属性说明:

UIButton内有两个控件titleLabelimageView,可以用来显示一个文本和图片,给UIButton设置了titleimage后,图片在左边,文本在图片右边显示,它们两个做为一个整体依赖于buttoncontentHorizontalAlignment居左居右或居中显示。

        1.button.width < image.width时,只显示被压缩后的图片,图片是按fillXY的方式压缩。

        2.button.width > image.width,且 button.width < (image.width + text.width)时,图片正常显示,文本被压缩。

        3.button.width > (image.width + text.width),两者并列默认居中显示,可通过button的属性contentHorizontalAlignment改变水平对齐方式。

想两改变两个子控件的显示位置,可以分别通过setTitleEdgeInsetssetImageEdgeInsets来实现。需要注意的是,对titleLabelimageView设置偏移,是针对它当前的位置起作用的,并不是针对它距离button边框的距离的。

一、属性

  • contentEdgeInsets: default is UIEdgeInsetsZero.设置内容四边距,默认边距为0
  • titleEdgeInsets: default is UIEdgeInsetsZero,文字内边距。默认边距为0.
  • reversesTitleShadowWhenHighlighted: default is NO. if YES, shadow reverses to shift between engrave and emboss appearance。默认状态是 NO,按钮高亮时,阴影出现在相反位置。
  • imageEdgeInsets: default is UIEdgeInsetsZero。图片内边距,默认边距为0;
  • adjustsImageWhenHighlighted : default is YES. if YES, image is drawn darker when highlighted(pressed),当按钮高亮时是否调整图片。默认是 YES
  • adjustsImageWhenDisabled:default is YES. if YES, image is drawn lighter when disabled.默认是 yes,如果是 YES,图形绘制较轻时禁用
  • showsTouchWhenHighlighted:default is NO. if YES, show a simple feedback (currently a glow) while highlighted。默认是 NO,如果是 YES,在高亮期间显示一个简单的反馈(当前发光).如果没有高亮状态,不做任何反馈。
  • tintColor: The tintColor is inherited through the superview hierarchy. See UIView for more information. 这个属性是从 UIView 继承过来的,更多解释信息见 UIView.该属性不应用于UIButtonTypeCustom.,如果Custom 类型的按钮需要使用该属性,应该重写该属性的 set方法。
  • buttonType:按钮样式属性,取值枚举类型
  • currentTitle:normal/highlighted/selected/disabled. can return nil。获取当前的文本。
  • currentTitleColor:normal/highlighted/selected/disabled. always returns non-nil. default is white(1,1)。当前文本颜色,默认白色。
  • currentTitleShadowColor:normal/highlighted/selected/disabled.当前状态下的文本阴影颜色
  • currentImage:normal/highlighted/selected/disabled. can return nil。当前状态下的图片。
  • currentBackgroundImage:normal/highlighted/selected/disabled. can return nil。当前状态下的背景图片
  • currentAttributedTitle:normal/highlighted/selected/disabled. can return nil。当前状态下的文本属性。
  • titleLabel:文本标签属性
  • imageView:图片属性

二、 方法

由于按钮是有状态的,比如:未点击状态,高亮状态,选中状态,不可用状态等。所以按钮所提供的方法当中很多是根据按钮状态来设置的。

  • buttonWithType:类方法,创建按钮对象时,直接指定按钮类型。取值为枚举。
  • setTitle:forState:default is nil. title is assumed to be single line。根据按钮状态设置文字。
  • setTitleColor:forState:default if nil. use opaque white。根据按钮状态设置文字颜色,默认白色。 
  • setTitleShadowColor: forState:  default is nil. use 50% black。 设置文字阴影颜色,默认半透明黑色 
  • setImage: forState: :default is nil. should be same size if different for different states。根据按钮状态设置图片
  • setBackgroundImage: forState:  根据按钮状态设置背景图片
  • setAttributedTitle: forState : default is nil. title is assumed to be single line.根据按钮状态设置文本属性内容(包括文字大小,颜色等)。假设文字是单行的
  • titleForState: these getters only take a single state value。根据按钮状态获取文本
  • titleColorForState:  根据按钮状态获取文本颜色
  • titleShadowColorForState: 根据按钮状态获取文本阴影颜色
  • imageForState: 根据按钮状态获取图片
  • backgroundImageForState: 根据按钮状态获取背景图片
  • attributedTitleForState: 根据按钮状态获取文本属性
  • backgroundRectForBounds: :自定义按钮时,可以更改背景图片在按钮当中的位置
  • contentRectForBounds: 自定义按钮时,可以更改整个内容在按钮当中的位置
  • titleRectForContentRect: 自定义按钮时,可以更改Label在按钮当中的位置
  • imageRectForContentRect: 自定义按钮时,可以更改图片在按钮当中的位置

转载地址:http://zcwvb.baihongyu.com/

你可能感兴趣的文章
ng-if和ng-show / ng-hide有什么区别
查看>>
将Java InputStream的内容写入OutputStream的简便方法
查看>>
用Java复制文件的标准简洁方法?
查看>>
管理webpack中的jQuery插件依赖项
查看>>
删除可能不存在的文件的大多数pythonic方式
查看>>
如何在Eclipse中为Java文本编辑器更改字体大小?
查看>>
我们应该@Override接口的方法实现吗?
查看>>
ng-repeat定义次数而不是重复数组?
查看>>
选择语句以查找某些字段的重复项
查看>>
引导程序中“col-md-4”,“col-xs-1”,“col-lg-2”中数字的含义
查看>>
JavaScript ES6类中的私有属性
查看>>
List vs tuple,何时使用? [重复]
查看>>
默认情况下,如何以管理员身份运行Visual Studio?
查看>>
通过varargs参数可能导致堆污染
查看>>
Git学习笔记1 神奇的git stash
查看>>
Unable to locate package错误解决办法
查看>>
关于service中添加Transaction注解后,service无法注入bean
查看>>
linux shell 自定义函数(定义、返回值、变量作用域)介绍
查看>>
写自己的ASP.NET MVC框架(上)
查看>>
C++和C在linux下编程和与在WINDOWS下有什么区别
查看>>