SwiftUI
Required Version:
1. macOS 10.15 Beta.
2. SwiftUI can be implemented in macOS 10.14.5 Mojave but the issue is that Preview can not be
displayed.
3. UIKit for Mac 13.0+.
4. macOS Catalina 10.15 Beta 3.
5. Xcode 11 beta 2, Xcode 11 beta 3.
Download XCode or macOS Update Version Link:
https://developer.apple.com/news/releases/
Introduction to SwiftUI:
- SwiftUI is a modern way to declare User Interfaces for any Apple Platform. Create Beautiful,
- dynamic apps faster than ever before.
- It helps the developers to easily design with less coding.
- SwiftUI language is easy to read, write and understand code.
- Describe your layout just once.
- Declare the content and layout for any state of your view.
Working with SwiftUI:
SwiftUI
- SwiftUI declares the user interface and behaviour for your app on every platform.
- According to Apple SwiftUI is an innovative new way to build user interfaces across all Apple platforms, so you can create better apps with less code.
- SwiftUI syntax is easy to read and write.
Syntax
- SwiftUI uses a declarative syntax so you can simply state what your user interface
should do . - E.g:- like we can Display Text. so your code is..
data:image/s3,"s3://crabby-images/c6faa/c6faa8d48eff5ae33b9dba572f2a359184e4c4fd" alt=""
data:image/s3,"s3://crabby-images/af841/af841c60d55e2658f1527acab1e69932880f49c3" alt=""
data:image/s3,"s3://crabby-images/1470e/1470ebdca08a709adb749bafe39909b804b00ae4" alt=""
Create New Project:
- Step1:-
- Select the Single View App.
data:image/s3,"s3://crabby-images/0f60b/0f60bf2b36abc4ff32889677c70b5dd95b9e7469" alt=""
- Step 2:-
- Enter your Product Name.
- Select the Language Swift / Objective – C.
- Last Choose a SwiftUI check box for create swiftUI Project..
data:image/s3,"s3://crabby-images/fc6bf/fc6bfb3f4782708d845b8fe68880de89485fb8f6" alt=""
- Then Click the Next button.
- Select your paths where your project is stored, Then Click in Create Button.
Explain Code:
data:image/s3,"s3://crabby-images/8c693/8c693619e352f1d41403c2cc748859fad166aaa7" alt=""
- Declare variable to store textfield value.
- e.g..VStack ie vertical stack which contains image label and textfield vertically, and assigning padding, font, frame, cornerRadius , background Colour etc…
- Assigning PlaceHolder to the TextField.
- Our output code has now been returned:-
data:image/s3,"s3://crabby-images/e0658/e0658a6385a5e7bccbae6b493452f271a70befe1" alt=""
- Now we create secureField for Password TextField.
- 1st we should create one variable which stores password TextField value.
@state private var password: String = “”
data:image/s3,"s3://crabby-images/6fd5b/6fd5b1c33570f1f5c56b18311863fe40e66603c6" alt=""
Output:
data:image/s3,"s3://crabby-images/86617/8661779e5720ca60cbd9ac8aa0d2572c34be9960" alt=""
- So here when we enter password at that time entry must be secured .
- Now we are adding NavigationView for navigation.
data:image/s3,"s3://crabby-images/86a8d/86a8d146ac0b339053842c054f1f502cfe8c7358" alt=""
- Add all the precisely added VStack in the NavigationView and make label with required padding, background colour etc as click for navigation to next view.
- And create NavigationButton and in parameter give destination for navigated to your Second View.
data:image/s3,"s3://crabby-images/af841/af841c60d55e2658f1527acab1e69932880f49c3" alt=""
- Now we are adding new Swift UI View File :
- In Project navigator -> Select Project Folder Tapped Right Click and Select New File. -> Select Swift UI View.
- In Project navigator -> Select Project Folder Tapped Right Click and Select New File. -> Select Swift UI View.
data:image/s3,"s3://crabby-images/4afe7/4afe798aed045103c099068a41a93de59f305bc4" alt=""
- Our New Swift UI view File name is “HomeView.swift”.
Create List Demo in HomeView
- Create Structure for Data
data:image/s3,"s3://crabby-images/22e7b/22e7b0406216e0727922ff066f1397a7c879563b" alt=""
- Create Array of Structure Data in HomeView Body
data:image/s3,"s3://crabby-images/78965/7896578959699f3c987e8c7a1eb3a04bdffa3d49" alt=""
- Create Stories Structure View
data:image/s3,"s3://crabby-images/f6a7c/f6a7c060c810843c5de8f70fed977c69f98d3e6f" alt=""
- let user : Data is variable of Data Structure
- VStack ie vertical stack which contains Image with required frame and give Shadow with CornerRadius, scaleToFit(), clipShape(Circle), overlay for giving stroke line to image
- Also Add 1 Text which displays user name with required fontSize, lineLimit, and Padding up to leading.
- And lastly we set frame for Vstack
- Now we will use Struct Stories in HomeView Body
data:image/s3,"s3://crabby-images/c2fb2/c2fb2484562c52cd40c61a1562294c7d544ec6a7" alt=""
- Create List with VStack which contains text with required fontSize and fontWeight and lastly add Scrollview
- The ScrollView will contains VStack with HStack which will scrolling vertically
- HStack will contain ForEach which contains Stories Struct View and adding NavigationButton for redirect Next View our next View name is userDetailView
- And lastly we add 1st VStack frame with 160 Height and navigationBarTitle
- userDetailView struct View
data:image/s3,"s3://crabby-images/77035/770357dbcd43e5fb33006a54a9bdcd15799e862c" alt=""
- Now we create postView struct View
data:image/s3,"s3://crabby-images/4e000/4e000891e28d8c63059a80c663132b96768aabd1" alt=""
- In postView struct create one variable of Data struct
- Then add Vstack and in Vstack add HStack ie Horizontal stack which contains one Image with require frame and give Shadow with CornerRadius
- Add Second VStack which contain two text. First text will display userName and second text will display timing. With padding to leading & top 8
- And at last adding one text which display userDetail and add Image with required cornerRadius, scaleToFit().
- And this postView struct view add in HomeView Struct view at the end
data:image/s3,"s3://crabby-images/6c18c/6c18c11a87ec5242ea4843d9d7dede1b5982b58a" alt=""
Output:
data:image/s3,"s3://crabby-images/1470e/1470ebdca08a709adb749bafe39909b804b00ae4" alt=""
Reference Link:
Apple Documentation:- https://developer.apple.com/tutorials/SwiftUI/