型を作っておこうかなと思い。
まずはチュートリアルをやってみます!
https://developer.apple.com/tutorials/swiftui/
4時間25分らしいです!頑張りましょう!
SwiftUI essentials Creating and combining views
data:image/s3,"s3://crabby-images/0b405/0b40587946afbe50615ae4ad14c0fe4f1d791a8d" alt=""
swiftUIの必需品!ビューを作るぞー
section 1 ハローワールドだ!
App作成!
data:image/s3,"s3://crabby-images/ace1b/ace1b30efcd9c2f347e3e98a9b2a8f1a2d5628fa" alt=""
Interface : SwiftUI
data:image/s3,"s3://crabby-images/bfd10/bfd109d1657f12e3922edb8be5cea774744ce2b3" alt=""
LandmarksAppを選択すると
@mainがあってここから開始って感じですね
data:image/s3,"s3://crabby-images/7b80f/7b80fa7716f602bbf837d4a01f9e80c72bc2ab1b" alt=""
ContentViewを見ると Building … が結構長いです.
ただ開いただけ Prepareing iPhone Simulatorも時間かかる
5分位くらい待っているような?
プレビュー出ました
data:image/s3,"s3://crabby-images/83d47/83d474e0a9cc22ef3524a710f87d6ae6e94b0881" alt=""
data:image/s3,"s3://crabby-images/1ac82/1ac827d2425a700692467e432b1ebadc786f5d43" alt=""
Editor > Canvas で表示方法選択できるようです
Automatically Refresh Canvasになっているので自動で表示できるようです
消しておくことも
data:image/s3,"s3://crabby-images/18c87/18c8701240b58b2bc81f14f01ed94a13ade8a250" alt=""
Textの中を変えると反映されました。
Section 2 Text View をカスタマイズ
data:image/s3,"s3://crabby-images/0c009/0c009c5eddaaba043957755c443c298a1765ca0c" alt=""
プレビューの左下
左から
Live / Selectable
でSelectableを選択するとテキストをクリックで選択できました。
data:image/s3,"s3://crabby-images/11d41/11d41122b6125e085bdc23e3e768a7efdb49f44d" alt=""
CTRL + command + クリックで
Show SwiftUI Inspector…などのメニューが表示されます
data:image/s3,"s3://crabby-images/fbfbc/fbfbc98433485d6554d94d1b274729da74852224" alt=""
Textを変えてみる
data:image/s3,"s3://crabby-images/d1491/d1491eda068aa6eac821f12ec69c3de00d86a2d8" alt=""
Font を Title / Color を Greenにして反映
data:image/s3,"s3://crabby-images/950b1/950b18c9c705ebba58a0a4379c93c93d620b105f" alt=""
codeを更新でももちろん反映
コードを消すと自動でプレビューが反映されます。
Liveモードに戻す。
Section 3 スタックを使用してビューを結合
data:image/s3,"s3://crabby-images/e510f/e510fe16f600789526e6b83d6fb2a903fb0ef731" alt=""
最初からVStackに入っていましたが、一旦消して
Textの上で CTRL+クリックで Embed in VStackを選択
VStack { Text("Turtle Rock") .font(.title) }
VStackに囲まれる。慣れれば手書きでいいですね
data:image/s3,"s3://crabby-images/ec527/ec527f87c35ea3f99bb6ec51e40a589444dd3e35" alt=""
右上のプラスボタンをクリックすると
Library が表示されます。
data:image/s3,"s3://crabby-images/28e08/28e086f54b0e5b927e522d49836cf00fd6ec75ed" alt=""
Textを追加
Text("Joshua Tree National Park") .font(.subheadline)
fontを設定
data:image/s3,"s3://crabby-images/f5827/f58278fa8c46b413994014b3161c2458413a6e8a" alt=""
VStackに alignment:.leadingを入れると 左揃えに
data:image/s3,"s3://crabby-images/9cc37/9cc375ab9d7301bcc1489073f81ee363052a987b" alt=""
subheadlineのところをHStackに入れて、そこにTextを追加すると横並びに!
data:image/s3,"s3://crabby-images/76527/7652722096969524d444d44ac632ce3b2a4b221f" alt=""
Textの間にSpacer()を入れると両側に離れて
VStackに.paddingを入れると外周に余白が入りました!
section 4 image view 画像をいれる!
data:image/s3,"s3://crabby-images/86e09/86e09658253e913e0887fd00a6e761cd1a1d7606" alt=""
Assetsに画像を入れてみました。JPGと大文字の拡張子は警告が出ましたが、jpgにしたら消えました。
data:image/s3,"s3://crabby-images/21ad5/21ad5871ecdb53c9d31fa637217cf0bd671eb3a6" alt=""
File > New > File で SwiftUI View で Next
ファイル名をCircleImage.swiftで保存
data:image/s3,"s3://crabby-images/363f1/363f1cfe2634b6067c074bfd190794552c300e97" alt=""
ImageをいれてclipShape(Circle())にしました。
画像が大きすぎた。はて
struct CircleImage: View { var body: some View { Image("DSC00426_r") .frame(width: 300) .clipShape(Circle()) .overlay{ Circle().stroke(.white,lineWidth: 4) }.shadow(radius:7) } }
適当にframeでサイズをつけて、白枠とシャドーでok
section 5 Use SwiftUI views from other frameworks
?どういう意味かな?
SwiftUI Viewに map viewを入れてみる漢字かな?
File > New > File で SwiftUI View を MapView.swift を作成
import MapKit
data:image/s3,"s3://crabby-images/c2451/c245118d54a7c341e5fffdc062feb77ec1b56ded" alt=""
region 座標 と マップ呼び出しを入れると地図が出ました。
section 6 Compose the detail view 詳細ビューを作成?
content view に統合するっぽい
- VStackでさらに囲います。
- MapViewを入れてframeで高さ指定
- CircleImageを追加して、offset, padding
data:image/s3,"s3://crabby-images/97252/97252d007b75a4d62c3ed20eb0955290dc371c0e" alt=""
こんな感じ表示、下に Spacer()を入れると上寄せに!
data:image/s3,"s3://crabby-images/d5680/d56809b894904649a8526c8a1536950a50f6ee70" alt=""
ほーという感じですね。1枚だけはこれで作れそうです^^v
チュートリアルのページを最後まで読むと練習問題が4問
data:image/s3,"s3://crabby-images/2d3c3/2d3c3a39ebae369d93cf13a843b1b51dc18d15de" alt=""
とりあえず良いのかな?
次は!
v2 リスト作成とナビゲーション!楽しみですね!
data:image/s3,"s3://crabby-images/65bfd/65bfdc971079b7f5435bfa0bba832cd034dc1f61" alt=""
コメント