成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

ios9學(xué)習(xí)系列:UIStackView如何讓你的開發(fā)更簡單

移動開發(fā)
之前我們闡述了Swift2的新特性。本篇文章的開始我們將涵蓋一些iOS9的很酷的新特性。iOS即將到來的新版本會帶來很多新的特性。對于開發(fā)者來說堆棧視圖(UIStackView)的引入值得一提。我知道對于一些開發(fā)者來說使用autolayout設(shè)計一些復(fù)雜的交互界面是比較困難的。UIStackView正好能幫助到并讓我們的開發(fā)者的工作變得更容易些。

之前我們闡述了Swift2的新特性。本篇文章的開始我們將涵蓋一些iOS9的很酷的新特性。iOS即將到來的新版本會帶來很多新的特性。對于開發(fā)者來說堆棧視圖(UIStackView)的引入值得一提。我知道對于一些開發(fā)者來說使用autolayout設(shè)計一些復(fù)雜的交互界面是比較困難的。UIStackView正好能幫助到并讓我們的開發(fā)者的工作變得更容易些。

UIStackView提供了一個高效的接口用于平鋪一行或一列的視圖組合。對于嵌入到StackView的視圖,你不用再添加自動布局的約束了。Stack View管理這些子視圖的布局,并幫你自動布局約束。也就是說,這些子視圖能夠適應(yīng)不同的屏幕尺寸。此外,你可以嵌入一個stack View到另一個stack view中來創(chuàng)建更為復(fù)雜的用戶界面。不要誤解我的意思,這并不意味著你就不需要處理自動布局了。你仍舊要定義一些布局約束來約束stack view。它只是幫你節(jié)約了為每個UI元素創(chuàng)建約束的時間,同時它更容易的從布局中添加/刪除一個視圖。

1.png

Xcode7提供兩種方式使用UIStackView。你可以從對象庫中拖一個Stack View(水平的/豎直的)放到storyboard的正確位置上。然后你可以拖一些label,button,imageView等視圖放到stack view中。另外,你可以在自動布局欄中使用Stack選項。對于這個方式,你可以簡單的選擇兩個或更多的視圖,之后點擊Stack選項,IB將會把這些視圖嵌入到一個stackview中,并自動的調(diào)整。如果你仍舊對如何使用stack view沒有太多頭緒,沒關(guān)系,接下來我們將在這篇文章中介紹這兩種方式。繼續(xù)往下閱讀,你就會很快明白我的意思的。

我假設(shè)你對auto layout了解。如果不是,請先閱讀這片關(guān)于autolayout的[介紹文章]

Demo App

先瞧一眼我們將要構(gòu)建的demo app。在這篇文章中我將會給你展示如何使用stackview布局一個類似的用戶界面:

stackview-16-2.png

你可以不使用stack view創(chuàng)建一樣的UI,但是,但正如你所看到的,stack view完全改變了布局用戶界面的方式。本文并沒用coding,我們只是集中在使用IB來布局這個用戶界面。

開始前,請下載這個[開始項目](備用[自己新建的開始項目])。你需要使用Xcode7 beta4(或以上版本)來build這個工程。如果你沒有安裝,你要下載個。該項目模板非常簡單,它僅僅預(yù)置了導(dǎo)航控制器和一些示例圖片。  

感謝:實例的照片是由[magdeleine.co]提供。

從對象庫中添加Stack Views 

現(xiàn)在升級Xcode7并打開Main.storyboard。從對象庫中拖出垂直的stack view放到storyboard上的view controller中。Stack View可以在縱向和橫向布局安排其子視圖(稱為安排視圖)。因為我們要布局垂直的圖像視圖,所以我們選擇垂直的Stack View。

stackview-1-fs8.png

接下來,從對象庫中拖出一個圖像視圖,當(dāng)你把圖像視圖放到stack view中,圖像視圖會自動調(diào)整。重復(fù)同樣的操作,添加更多的image view。這就是它神奇的地方:當(dāng)您添加另一個圖像視圖時,stack view會自動布局圖像視圖,為您設(shè)置必要的約束。酷,對嗎?

為Stack View定義布局約束

Stack View節(jié)省了開發(fā)者為每個UI元素定義約束的時間,所說的,您需要提供Stack View的布局約束。對于我們剛剛添加的,我們需要定義以下布局約束:

  • 設(shè)置Stack View的距上,距左和居右的間距,使得Stack View在屏幕的頂部。

  • 為Stack View設(shè)置一個高度約束,使得Stack View視圖的高度占父視圖高度的70%。

現(xiàn)在選擇stack view,點擊布局欄按鈕中的Pin按鈕,設(shè)置距上,距左,居右值分別為10,0,0。然后點擊“Add 3 Constraints”按鈕添加這些約束。

stackview-3-fs8.png

Stack view的當(dāng)前位置不符合約束,你可以在Document Outline點擊警告指示(即黃色的箭頭)糾正位置。

要設(shè)置高度約束,就要在IB的Document Outline中從堆棧視圖到視圖中的控件拖動視圖,釋放按鈕后,選擇“Equal Heights”。

30.png

這是設(shè)置stack view的高度和這個view的高度相等的。然而,stack view僅僅需要高度的75%。所以,選擇“Stack View.height”的約束,選擇Attributes inspector,把Multiplier這項的值從1.0改為0.7.

31.png

#p#

設(shè)置Stack View的屬性

這個stack view 看起來并不是我們期望的。一旦你添加了stack view,你可以改變一些stack view的屬性來改變它的外觀。axis選項決定是否應(yīng)布置的視圖垂直或水平布置。 alignment選項控制這些視圖的對齊方式。比如你如果設(shè)置成Leading,stack view管理的視圖排列按Leading對齊。

32.png

distribution屬性決定了其管理的視圖的大小和位置。默認(rèn)設(shè)置為Fill。這是stack view盡量讓它的所有子視圖在一個合理的距離。現(xiàn)在把它改為Fill Equally。stack view會調(diào)整它所有的子視圖一樣的尺寸。

33.png

spacing屬性讓你設(shè)置視圖之間的間距。把它值改為10來增加圖像視圖之間的間距。

34.png

設(shè)置圖像

接下來,我們設(shè)置image view的相應(yīng)的圖像。選擇第一個image view,選擇Attributes inspector,把image設(shè)置為“nature-1″,把model設(shè)置為“Aspect Fill”,同時勾選上“Clip Subviews”。重復(fù)同樣的步驟設(shè)置余下的image view,但是要把image 設(shè)置為“nature-2″ 和 “nature-3″。這樣你的布局看起來像這樣:

35.png

現(xiàn)在你可以運行項目,預(yù)覽下。可以在模擬器上測試app的UI是否正確的適配所有的設(shè)備。stack view已經(jīng)自動的為你添加好了約束。事實上你可以啟動view debugging選項(要在運行app的時候)來顯示圖像視圖的布局約束。

36.png

使用嵌套Stack View布局標(biāo)簽和按鈕

我們還沒有完成。有幾個標(biāo)簽和按鈕添加到用戶界面。現(xiàn)在將標(biāo)簽從對象庫中拖到視圖,命名“Nature”,并將其定位在stack view下面。把它的字體大小改為30點,使其更大一些。下一步,將另一個標(biāo)簽視圖和名稱標(biāo)簽”A collection of nature photos from magdeleine.co“。放置在Nature標(biāo)簽之下。

再次,您不需要設(shè)置這些標(biāo)簽的布局約束。讓stack view為你做這個魔術(shù)。在本教程的最開始,我提到了使用stack view的方法。之前,是從對象庫中添加了堆棧視圖。現(xiàn)在我會告訴你另一個辦法。

按住命令鍵來選擇標(biāo)簽,然后單擊布局欄中的Stack按鈕。IB自動把這些標(biāo)簽嵌入到垂直堆疊視圖中。

37.gif

下一步,向視圖添加2個按鈕。命名一個按鈕,“Like”,另一個是“Share”。再次,我們不想處理自動布局。所以,在布局欄中選擇按鈕,然后單擊Stack按鈕,將兩個按鈕嵌入到一個水平堆棧視圖中。設(shè)置堆棧視圖的spacing值為5。

38.png

如果你看了最后的布局,這兩個按鈕應(yīng)該放在Nature標(biāo)簽旁邊。你怎么能做到這一步呢?關(guān)于stack view的最重要的是,您可以使用嵌套的多個stack view來構(gòu)建你想要的精確布局。現(xiàn)在將stack view拖到Nature標(biāo)簽的按鈕上。一旦你釋放了按鈕,stack view將被嵌入到另一個stack view中。布局Nature標(biāo)簽和按鈕,選擇兩種視圖,然后將它們添加到另一個stack view中,使用stack選項。默認(rèn)情況下,新堆棧視圖的軸設(shè)置為垂直方向。在屬性檢查中,把它改為水平,這樣就可以把Like和Shared按鈕放置在Nature標(biāo)簽旁邊了。

39.gif

按鈕也需要與Nature標(biāo)簽的基線對齊。選擇stack視圖,并將alignment從Fill改為First Baseline。同時,spacing選項設(shè)置為20,這樣來添加Naturel標(biāo)簽和按鈕之間的間距。

40.png

正如你所看到的,我們只需要使用嵌套的stack view構(gòu)建你需要的精確布局。

#p#

最后,我們?yōu)榘瑘D像的stack view和包含按鈕&標(biāo)簽的stack view之間的設(shè)置布局約束。選擇包含按鈕和標(biāo)簽的堆棧視圖,然后單擊布局欄按鈕中的Pin按鈕。設(shè)置居上、距左和居右的值分別為0、8和0。

41.png

確保描述標(biāo)簽是自動調(diào)整大小,Lines設(shè)置為0和Line Breaks設(shè)置為Word Wrap。太好了你已經(jīng)完成了界面設(shè)計。現(xiàn)在運行該項目來看看結(jié)果。如果您的一切配置正確,您的UI應(yīng)該看起來像這樣:

42.png

如果你把iPhone橫過來,UI應(yīng)該是這樣:

43.png

它看起來不錯,但如果這些圖像想這樣橫向排列的話,是不是更給力?

44.png

使用Size Classes 調(diào)整Stack Views

為了達(dá)到iPhone在不同的方向上布局不一樣,我們必須使stack view自適應(yīng)。在iOS 8中,介紹了Size Classes的概念。下表顯示了iOS設(shè)備及其相應(yīng)的Size Classes:

45.png

你可以使用size classes提供的重寫原來的基本布局。在這種情況下,我們在這兩種size classes情況下要設(shè)置stack view的axis(持有圖像視圖的)從垂直到水平:

  • Compact width-Compact height

  • Regular width-Compact height

現(xiàn)在選擇stack view,在選擇Attributes inspector。在Axis選項下點擊+按鈕。選擇Any Width > Compact height,之后設(shè)置這個size classes下的Axis值為Horizontal。這里,any width包括compact和regular兩種寬度。

46.gif

做完這些,stack view將會在iPhone橫屏的時候設(shè)置為水平。在不同的iOS設(shè)備上運行項目,查看結(jié)果。

總結(jié)

在本教程中,我給你介紹了stack view并演示如何使用這個新組件布局你的UI。stack view讓你使用很少的約束高效的完成UI的布局。你可能有一個問題是,何時使用stack view?蘋果公司的工程師建議開發(fā)者先采用stack view,然后才是需要實際使用的繁瑣的約束。因此,開始設(shè)計你的用戶界面使用stack view!我相信你會喜歡它。

供參考,你可以在這里下載[Xcode項目]。

責(zé)任編輯:倪明 來源: AppCoda
相關(guān)推薦

2015-09-16 09:55:12

ios9學(xué)習(xí)UIKit Dynam

2015-08-20 09:00:23

ios9api

2015-08-24 09:24:21

ios學(xué)習(xí)contacts fr

2015-09-25 09:44:24

ios9MapkitTrans

2015-08-03 10:03:09

iosuistack vie

2016-03-18 11:19:57

ios9replaykit入門

2015-07-02 16:25:09

iOS 9UIStackView

2015-08-24 09:19:05

ios9split scree

2015-07-16 12:59:19

IOS9UIDynamics

2015-07-02 16:10:11

UIStackViewiOS 9

2014-07-11 09:07:10

Windows 9

2020-05-07 10:18:06

JavaScript前端技術(shù)

2023-11-28 10:17:37

2019-09-17 14:31:52

JSJavaScript前端

2015-10-16 14:27:29

iOS9collectionV特性

2018-07-16 00:09:30

數(shù)據(jù)科學(xué)大數(shù)據(jù)機(jī)器學(xué)習(xí)

2015-09-23 10:30:44

iOS 9UIStack Vie

2020-06-01 07:41:52

Gmail郵箱郵件安全電子郵件

2015-02-11 15:40:40

XY蘋果助手iOS9

2009-02-24 08:21:22

Windows 7桌面亮麗
點贊
收藏

51CTO技術(shù)棧公眾號

主站蜘蛛池模板: 亚洲国产在| 国产高清免费 | 国产精品一区二区视频 | 婷婷成人在线 | 欧美日韩精品中文字幕 | 日韩另类 | 91国内视频在线 | 蜜臀久久99精品久久久久野外 | 日韩精品视频一区二区三区 | 久久久日韩精品一区二区三区 | 99久久婷婷国产综合精品电影 | 毛片免费视频 | 亚洲精品第一 | 久久在看| 中文字幕在线观看一区二区 | 亚洲 欧美 日韩 在线 | 国产精品有限公司 | 精品在线播放 | 九九热在线视频 | 成人免费视频 | 成人激情视频网 | 欧美久久精品一级c片 | 精品久草 | 午夜精品久久久久久久久久久久久 | 免费黄色片在线观看 | 国产在线播 | 亚洲一区二区三区四区在线观看 | 国产一区二区三区在线 | 欧美国产视频 | 国产精品久久久久久网站 | 欧美激情精品久久久久久 | 久久久久久久国产精品影院 | 日韩三区在线观看 | 午夜久久久久久久久久一区二区 | 日韩三级电影一区二区 | 全免费a级毛片免费看视频免费下 | 欧美男人亚洲天堂 | 97日日碰人人模人人澡分享吧 | 欧美精品成人一区二区三区四区 | 亚洲精品电影在线观看 | 成年人在线 |