亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > iOS > 正文

iOS應用UI開發中的字體和按鈕控件使用指南

2020-07-26 03:29:06
字體:
來源:轉載
供稿:網友

UILabel的使用
一、初始化

復制代碼 代碼如下:

UILabel *myLabel = [[UILabel alloc] initWithFrame:CGRectMake(40, 40, 120, 44)];
    
[self.view addSubview:myLabel];

二、設置文字

 ①、設置默認文本

復制代碼 代碼如下:

NSString *text = @"標簽文本";
myLabel.text = text;

效果:

201612692523743.png (87×39)

②、設置標簽文本(此屬性是iOS6.0之后才出現,如若不是必要,不建議使用此屬性)

復制代碼 代碼如下:

NSString *text = @"其實沒什么";
    
NSMutableAttributedString *attributeString = [[NSMutableAttributedString alloc] initWithString:text];
    
[attributeString setAttributes:@{NSForegroundColorAttributeName : [UIColor redColor],   NSFontAttributeName : [UIFont systemFontOfSize:17]} range:NSMakeRange(2, 1)];
    
myLabel.attributedText = attributeString;

效果:

201612692551483.png (98×39)

關鍵字標紅的效果

復制代碼 代碼如下:

NSString *keyword = @"腳本";
NSString *result = @"武林網";
 
// 設置標簽文字
NSMutableAttributedString *attrituteString = [[NSMutableAttributedString alloc] initWithString:result];
 
// 獲取標紅的位置和長度
NSRange range = [result rangeOfString:keyword];
 
// 設置標簽文字的屬性
[attrituteString setAttributes:@{NSForegroundColorAttributeName : [UIColor redColor],   NSFontAttributeName : [UIFont systemFontOfSize:17]} range:range];
 
// 顯示在Label上
label.attributedText = attrituteString;

③、設置字體,如果是使用②中的文本,那在設置AttributeString的屬性時已經設置過Font了和textColor了,直接使用①設置文本時設置文本時,設置字體方法
復制代碼 代碼如下:

myLabel.font = [UIFont systemFontOfSize:13];

④、設置顏色
復制代碼 代碼如下:

myLabel.textColor = [UIColor blueColor];

⑤、設置對齊方式
復制代碼 代碼如下:

myLabel.textAlignment = NSTextAlignmentCenter;//居中

NSTextAlignmentLeft //左對齊
NSTextAlignmentCenter //居中
NSTextAlignmentRight  //右對齊
NSTextAlignmentJustified//最后一行自然對齊
NSTextAlignmentNatural //默認對齊腳本


NSTextAlignmentJustified和 NSTextAlignmentNatural用的時候會報錯,程序崩潰,暫時不知道什么時候可以使用,希望知道的指教一下,感激不盡。

⑥、文字剪裁方式

復制代碼 代碼如下:

NSLineBreakByWordWrapping = 0,//以空格為邊界,保留單詞
NSLineBreakByCharWrapping,    //保留整個字符
NSLineBreakByClipping,        //簡單剪裁,到邊界為止
NSLineBreakByTruncatingHead,  //按照"……文字"顯示
NSLineBreakByTruncatingTail,  //按照"文字……文字"顯示
NSLineBreakByTruncatingMiddle //按照"文字……"顯示

myLabel.lineBreakMode = NSLineBreakByTruncatingHead;


⑦、設置Label enabled屬性
如果設置為No,則文字顏色會變暗,表明其是不可用的,默認值為YES。
復制代碼 代碼如下:

myLabel.enabled = NO;

三、匹配Label上的文字
①、是否根據文本寬度改變字體大小
復制代碼 代碼如下:

myLabel.adjustsFontSizeToFitWidth = YES;

假設文字內容為@"曾在月光之下望煙花,曾共看夕陽漸降下",Label長度為200,則一行顯示不下,若設置此屬性為YES,則會降低字體大小,以顯示全部內容。
前后對比:

201612692633831.png (199×25)

201612692655069.png (197×27)

②、改變字母之間的間距來適應label大小
當這個屬性是YES,標簽可能改變標簽文本的字母間距,以使該文本更適合標簽的邊界內。此屬性的字符串,而不管當前行的行的裁剪模式。該屬性的默認值是NO。

復制代碼 代碼如下:

myLabel.adjustsLetterSpacingToFitWidth = NO;

個人使用了一下,沒發現有什么區別,不知道具體是什么時候發揮作用。
③、設置對齊基線
復制代碼 代碼如下:

myLabel.adjustsFontSizeToFitWidth = YES;//調整基線位置需將此屬性設置為YES

myLabel.baselineAdjustment = UIBaselineAdjustmentAlignBaselines;


此屬性有三個值可選
復制代碼 代碼如下:

UIBaselineAdjustmentAlignBaselines //文本最上端與Label中線對齊,默認值
UIBaselineAdjustmentAlignCenters   //文本中線與Label中線對齊
UIBaselineAdjustmentNone           //文本最下端與Label中線對齊

④、最小字體大小,當字體小于這個最小值時無效,顯示此屬性值
iOS6.0之前:minimumFontSize

iOS6.0之后:minimumScaleFactor

myLabel.minimumScaleFactor = 10.0;//默認值為0,為當前字體大小
⑤、行數

復制代碼 代碼如下:

myLabel.numberOfLines = 2;//Label行數

⑥、高亮
復制代碼 代碼如下:

myLabel.highlighted = YES;//是否高亮
myLabel.highlightedTextColor = [UIColor redColor];//高亮顏色;此屬性在設置按鈕的titleLabel時,無論highlighted是YES還是NO,在按鈕按下時標題都顯示此高亮顏色

⑦、陰影
復制代碼 代碼如下:

myLabel.shadowColor = [UIColor grayColor];//陰影顏色,默認為nil
myLabel.shadowOffset = CGSizeMake(1, 1);//陰影的偏移點

四、Label位置
①、計算UIlabel 隨字體多行后的高度
復制代碼 代碼如下:

CGRect result,bounds;
bounds = CGRectMake(0, 0,200, 300);
heightLabel = [myLabel textRectForBounds:bounds limitedToNumberOfLines:20];//計算20行后的Label的Frame
NSLog(@"%f",heightLabel.size.height);

②、繪制text到指定區域
復制代碼 代碼如下:

- (void)drawTextInRect:(CGRect)rect
//需要重載此方法,然后由子類調用,重寫時調用super可以按默認圖形屬性繪制,若自己完全重寫繪制函數,就不用調用super了

UIButton的簡單使用
Button(按鈕)是使用最頻繁的控件之一,UIButton的使用并不難,但是有一點必須要注意

UIButton默認Type是Rounded Rect button,這個形態是不被App Store所接受的,即便是你給這個button添加了背景圖片,不再是Rounded Rect 的外觀,還是會被App Store所拒,總之Button的類型不能是Rounded Rect。
一、UIButton的外觀

 1.1 UIButton有6種類型, 如下圖所示

復制代碼 代碼如下:

UIButtonTypeCustom         
UIButtonTypeRoundedRect        
UIButtonTypeDetailDisclosure
UIButtonTypeInfoLight
UIButtonTypeInfoDark
UIButtonTypeContactAdd

201612692752467.png (385×266)

1.2 設置buttonType

復制代碼 代碼如下:

UIButton *button = [[UIButton alloc] initWithFrame:CGRectMake(10, 10, 100, 44)];
 
[UIButton buttonWithType:UIButtonTypeCustom];

二、設置背景圖片

2.1可以設置正常狀態,不可點擊狀態,選中狀態等各種形態下的背景圖片

復制代碼 代碼如下:

// 正常狀態下的圖片
    [button setBackgroundImage:[UIImage imageNamed:@"normal.png"] forState:UIControlStateNormal];
 
    // 點擊后的圖片
    [button setBackgroundImage:[UIImage imageNamed:@"pressed.png"] forState:UIControlStateSelected];

2.2 可延伸的圖片,有一張26*46的圖片,但是按鈕是100*46,這時將圖片延伸一下效果就會很好,這樣的話可以使得項目中的圖片文件比較小,為項目瘦身,QQ的會話氣泡也是利用此種方法達到延伸的效果,先上對比圖

201612692809799.png (454×340)

復制代碼 代碼如下:

UIImage *buttonNormal = [UIImage imageNamed:@"button-white-part"];
 
// 進行寬度上的延伸,如果要進行高度上的延伸,改變第一個和第三個參數的值,此方法是保證圖片邊緣的框架的前提下對圖片中間進行高度或者寬度的延伸  
UIImage *stretchNormal = [buttonNormal resizableImageWithCapInsets:UIEdgeInsetsMake(0, 15, 0, 30)];
 
[button setBackgroundImage:stretchNormal forState:UIControlStateNormal];

三、按鈕事件

按鈕事件還有好多種,可以自行查看文檔

復制代碼 代碼如下:

[button addTarget:self action:@selector(buttonPress:) forControlEvents:UIControlEventTouchUpInside];
 
// 點擊事件
- (IBAction)buttonPress:(id)sender {
   NSLog("@"button pressed!");
}

以上是代碼添加。
四、xib添加

4.1 在View中拖動一個Button放入畫布

201612692835668.png (907×516)

4.2 設置button屬性

201612692854956.jpg (1000×700)

4.3 創建映射,以及按鈕事件
選中xib,點擊xcode右上方的Editor

201612692913138.png (117×58)

,讓一個界面為xib,另一個界面為其對應的.h文件。

選中button 右鍵拖拽出一條線到.h文件@interface與@end之間的位置,如果要創建映射則選擇IBOutlet,創建按鈕事件則選擇Action,填寫完成后點擊connet即可

201612692930803.png (661×223)

在.m文件中會出現所創建的點擊事件,在方法里完成對應的操作即可。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产欧美亚洲国产日韩mv天天看完整| 欧美xxxwww| 亚洲欧洲黄色网| 97精品视频在线播放| 国产在线精品播放| 久久久久久久久久国产| 欧美性生交xxxxxdddd| 中文字幕精品av| 激情成人中文字幕| 亚洲精品国产精品自产a区红杏吧| 欧美一级电影免费在线观看| 精品久久久一区二区| zzjj国产精品一区二区| 国产丝袜精品第一页| 色黄久久久久久| 97免费视频在线| 中文欧美日本在线资源| 欧美日韩第一视频| 精品国产欧美成人夜夜嗨| 国产精品自拍小视频| 国产成人一区二区| 亚洲国产成人在线播放| 国产99久久久欧美黑人| 91精品国产自产在线老师啪| www.日韩免费| 亚洲精品国产电影| 夜夜嗨av色一区二区不卡| 欧美成人精品xxx| 国产中文字幕亚洲| 成人精品网站在线观看| 91高清免费在线观看| 国产精品第10页| 国产精品福利久久久| 欧美精品福利在线| 日韩国产中文字幕| 国产精品日韩av| 国产精品伦子伦免费视频| 91爱爱小视频k| 欧美激情免费视频| 日韩国产高清视频在线| 最近2019中文免费高清视频观看www99| 国产成人高清激情视频在线观看| 亚洲欧美激情四射在线日| 欧美午夜精品久久久久久人妖| 欧美肥臀大乳一区二区免费视频| 亚洲影院高清在线| 国产精品狼人色视频一区| 疯狂欧美牲乱大交777| 亚洲激情视频网站| 欧美高清视频在线| 亚洲激情国产精品| 亚洲精品综合久久中文字幕| 伦伦影院午夜日韩欧美限制| 亚洲国产欧美一区| 亚洲人成网站999久久久综合| 欧美香蕉大胸在线视频观看| 96国产粉嫩美女| 欧美精品videosex牲欧美| 久久成年人视频| 精品自拍视频在线观看| 国产日韩欧美一二三区| 亚洲视频综合网| 国产精品盗摄久久久| 国产精品稀缺呦系列在线| 日韩中文字幕亚洲| 日韩免费看的电影电视剧大全| 国产亚洲激情视频在线| 一本大道久久加勒比香蕉| 国产精品露脸自拍| 97国产在线观看| 91国内揄拍国内精品对白| 亚洲成av人影院在线观看| 午夜欧美大片免费观看| 国产一区二区三区视频在线观看| 激情亚洲一区二区三区四区| 日韩av在线免费观看| 亚洲黄一区二区| 亚洲欧洲一区二区三区久久| 国内外成人免费激情在线视频网站| 精品国产美女在线| 日韩精品在线观看网站| 欧美在线亚洲在线| 福利微拍一区二区| 亚洲免费电影一区| 成人国产精品久久久久久亚洲| 91久久久久久久久久久| 久久久久久久久久av| 久久中文久久字幕| 国产成人精品最新| 国产精品一区二区av影院萌芽| 韩国19禁主播vip福利视频| 欧美日韩国产中文精品字幕自在自线| 啪一啪鲁一鲁2019在线视频| 懂色aⅴ精品一区二区三区蜜月| 九九热这里只有精品6| 亚洲成**性毛茸茸| 国产区精品视频| 人人澡人人澡人人看欧美| 亚洲欧洲日产国码av系列天堂| 亚洲另类欧美自拍| 成人h片在线播放免费网站| 日韩中文字幕在线播放| 亚洲精品98久久久久久中文字幕| 成人国产在线视频| 成人黄色免费看| 欲色天天网综合久久| 欧美激情中文字幕在线| 亚洲欧美日韩区| 欧美午夜片在线免费观看| 欧美一区三区三区高中清蜜桃| 中日韩美女免费视频网址在线观看| 视频一区视频二区国产精品| 国产精品99免视看9| 国产婷婷色综合av蜜臀av| 91色在线观看| 国产女人18毛片水18精品| 日韩中文字幕亚洲| 久久精品国产v日韩v亚洲| 日韩在线视频国产| 成人国产精品日本在线| 欧美日韩在线观看视频| 2019中文字幕在线| 欧美精品一本久久男人的天堂| 久久在线观看视频| 日韩电影免费观看在线| 中文字幕亚洲综合| 4p变态网欧美系列| 日韩在线国产精品| 国产精品亚洲一区二区三区| 91精品国产91久久久久久| 日韩一中文字幕| 久久影视电视剧凤归四时歌| 欧美视频免费在线观看| 日本伊人精品一区二区三区介绍| 国产成人精品在线视频| 欧美成人中文字幕在线| 疯狂做受xxxx欧美肥白少妇| 日韩激情视频在线| 国产高清在线不卡| 亚洲精品99999| 欧美日韩成人免费| 亚洲国产精品一区二区久| 欧美一级片在线播放| 国产精品福利观看| 亚洲精品在线观看www| 一区二区三区 在线观看视| 国产在线98福利播放视频| 最好看的2019年中文视频| 91色精品视频在线| 在线视频亚洲欧美| 国产性猛交xxxx免费看久久| 欧美第一黄色网| 精品国产区一区二区三区在线观看| 国产亚洲一区二区在线| 久久天天躁狠狠躁夜夜躁| 亚洲天堂开心观看| 国产女人18毛片水18精品| 韩国国内大量揄拍精品视频| 国产欧美一区二区白浆黑人| 日韩中文字幕在线播放| 久热精品视频在线免费观看| 亚洲专区在线视频| www.久久撸.com| 成人激情黄色网|