data:image/s3,"s3://crabby-images/a1e0b/a1e0b5e9081e9a749e3897f929f3df5ebca43fb5" alt="見出し画像"
【徒然iOS】気ままにUIKit73〜Bar Button Item ナビゲーションバーエリアにWEBリンクボタンを追加〜
概要
このマガジンは四十を過ぎたおっさんが、
を参考にStoryboardでiOSアプリを完全に趣味で楽しんでいるだけな記事を気ままに上げてます。
今回
を参考に、
で、繋いだ各ビューにWEBリンクボタンを追加する操作
をハイ、レッツゴ🕺
前準備
前回同様、念の為、
バックアップ
をいつも通りやってから本題へ💃
data:image/s3,"s3://crabby-images/44776/447762c8cbd0fea495bc47d6db02543ed2b55342" alt=""
本題
今回の操作は、既存のクラスファイルに簡単なコードを組み込んだりと、
めっちゃ簡単なんで〜〜〜〜
要点を踏まえながら早速レッツゴ💃
⒈Bar Button Itemを追加
例えば、前回作ったNavigationContorollerで繋いだ
data:image/s3,"s3://crabby-images/c7d97/c7d97f2b6ce4079c1a2612ca25f3ece37470c642" alt=""
data:image/s3,"s3://crabby-images/df52b/df52b019947228a95dea991159e9c9b84b74a039" alt=""
data:image/s3,"s3://crabby-images/9568d/9568d5592426a35bea1a34685a82e98f6b8e75f2" alt=""
⒉アトリビュートインスペクタを開いて、設定変更
data:image/s3,"s3://crabby-images/9bdc8/9bdc854cb8b847d3c55f1016e15a3a699f0bc5ab" alt=""
data:image/s3,"s3://crabby-images/e14c3/e14c399155ce502ceac7d44120d7e303ac45e109" alt=""
data:image/s3,"s3://crabby-images/2067d/2067d23547919c000f040a8870a0dc1a7d6a1a59" alt=""
イメージビューのところ
で触れたSFSymbolを使ってく〜〜〜
例えば、linkを入力すると、
data:image/s3,"s3://crabby-images/57673/576734e80fc0e6405973a355c8ee819b7e63d87c" alt=""
data:image/s3,"s3://crabby-images/2a251/2a25136cb726dc58765b15ce206a1b46aeedae9c" alt=""
いやいや、WEBなら、🌐だろって人もいると思うので、
data:image/s3,"s3://crabby-images/86956/86956e1550fc1ef0c6c91e12740d963ea1c26c9e" alt=""
data:image/s3,"s3://crabby-images/cca92/cca92f98c09b798cf2e1b8cdbeda67db1b2d1c93" alt=""
とりあえず、🌐マークの方が一般的かもしれないので、こっちで💦
⒊BarButtonItemをいつもどおりアクション接続
なんかのサイトを参考に、以下のコードを組み込む
@IBAction func webButton(_ sender: Any) {
let url = URL(string: "https://www.google.co.jp/")
let safariView = SFSafariViewController(url: url!)
present(safariView, animated: true)
}
data:image/s3,"s3://crabby-images/0de3f/0de3fd2fda38b00c952b4e9cd9ce9b76792fa847" alt=""
data:image/s3,"s3://crabby-images/52771/527713a64dd55cb7acc7cbcd24289eabe60265e2" alt=""
data:image/s3,"s3://crabby-images/875ab/875abd9696b1bff389e6fd924fdfc26d67423a46" alt=""
(いつものアクション接続と逆のやり方)
data:image/s3,"s3://crabby-images/c3290/c3290b452207c8fc3466670f1de9f51883d9c5ea" alt=""
👉接続できた
data:image/s3,"s3://crabby-images/542db/542db4dcfe3f02b6edab6d8cd69aa25cd652a128" alt=""
data:image/s3,"s3://crabby-images/9c3dc/9c3dc187f2dba68c9caecb8302c61154d01f2356" alt=""
⒋シミュレータで実行
data:image/s3,"s3://crabby-images/2074f/2074faccb8e1017f0a5ce513a1cd56ec7c8fcfd6" alt=""
data:image/s3,"s3://crabby-images/8c4e7/8c4e77a1aec64fa61568195467e487191567ed76" alt=""
てのが、基本。このアプリでは、
色々考えたんだけど、
各ビューからこのマガジンの関連する記事を開けるようにしたい
ので、例えば、ボタンビューの記事だと
data:image/s3,"s3://crabby-images/2904f/2904f189d176226e91bc4ea2608ea136abf53cf1" alt=""
data:image/s3,"s3://crabby-images/58d27/58d2762f04ada11c4ebc55c5da85846fa0e69b4d" alt=""
と、ここで
市販の教科書とか、サンプルコードだと
let url = URL(string: "https://note.com/m_kakudo/n/n1811916bff4d")
的な感じでベタ打ちしてるんだけど、これだと変更したい時に、ベタでハードコーディングになっちゃうんで、普通は、
data:image/s3,"s3://crabby-images/0b445/0b445759f2d70797eb686f93aac513f309679b9d" alt=""
data:image/s3,"s3://crabby-images/aa130/aa130a07665cd344cf41493b14156ebb721b1f40" alt=""
data:image/s3,"s3://crabby-images/86731/86731f19c479ec9678cb0014f3c69ccb526a0bf7" alt=""
data:image/s3,"s3://crabby-images/57f88/57f88c6c8e06e7247a1994cccbcd2af3c689f61a" alt=""
の⒋命名規則やコードの書きぶりを意識=コード管理で書いたことがここで生きてくる
クラス名を大文字始まりにしておくと、
引数名を小文字始まりにするだけで、
class ButtonViewController: UIViewController{
@IBOutlet weak var testLabel: UILabel!
@IBAction func webButton(_ sender: Any) {
let url = URL(string: buttonViewController)
let safariView = SFSafariViewController(url: url!)
present(safariView, animated: true)
}
//以下、省略
}
どのクラスファイルで使う引数名かも一目瞭然でわかる🕺
⒌後は同様に、⒈〜⒋の作業を他のビューに繰り返す
ここはちょっとビュー数が多いので時間がかかるけど、以下のコードを参考に頑張る👀
let textFieldViewController = "https://note.com/m_kakudo/n/nef67ad5be119"
let connectionInspectorViewContoroller = "https://note.com/m_kakudo/n/n2322ff099dcf"
let segmentedControllerViewController = "https://note.com/m_kakudo/n/n8737c3889ddc"
let sliderViewController = "https://note.com/m_kakudo/n/ndac4baf98d22"
let switchViewController = "https://note.com/m_kakudo/n/n71ac5346a40f"
let activeIndicatorViewController = "https://note.com/m_kakudo/n/n588325632182"
let progressViewController = "https://note.com/m_kakudo/n/n5ca9896f0668"
let pageContorolViewController = "https://note.com/m_kakudo/n/n2ead7da2f8f5"
let stepperViewController = "https://note.com/m_kakudo/n/nd610a4dc183f"
let autoLayout1ViewController = "https://note.com/m_kakudo/n/nb69117225275"
let autoLayout2ViewController = "https://note.com/m_kakudo/n/n442f10134d69"
let autoLayout3ViewController = "https://note.com/m_kakudo/n/n0b7db7a49a16"
let autoLayout4ViewController = "https://note.com/m_kakudo/n/nefcb32ef9e5f"
let tableViewController = "https://note.com/m_kakudo/n/nd1fc0d622867"
let tableView2Controller = "https://note.com/m_kakudo/n/nbe061e258a1d"
let tableCellViewController = "https://note.com/m_kakudo/n/n6ad9b804fa16"
let tableCellStyleViewController = "https://note.com/m_kakudo/n/nffe2102b38db"
let tableCellCustomViewController = "https://note.com/m_kakudo/n/n76d502d7ffbf"
let tableDelegateViewController = "https://note.com/m_kakudo/n/nf011fff44fbd"
let tableEditModeViewController = "https://note.com/m_kakudo/n/n02573ba83416"
let tableXIBViewController = "https://note.com/m_kakudo/n/n8ab557a2a34f"
let tableKeyboardViewController = "https://note.com/m_kakudo/n/n954ab94e55ee"
let imageViewController = "https://note.com/m_kakudo/n/n08814933979d"
let uiviewViewController = "https://note.com/m_kakudo/n/nf2d420070ea8"
let collectionViewStandardController = "https://note.com/m_kakudo/n/n9ab39f2bdc0a"
let collectionViewCustomController = "https://note.com/m_kakudo/n/n9ab39f2bdc0a"
let collectionSectionViewController = "https://note.com/m_kakudo/n/n5d811317bf49"
let collectionLayoutViewController = "https://note.com/m_kakudo/n/na4eda00c29fa"
let collectionViewDelegateController = "https://note.com/m_kakudo/n/n60726f13926d"
let textViewStandardController = "https://note.com/m_kakudo/n/n57748b7ed8ad"
let textViewStandardLotateRightController = "https://note.com/m_kakudo/n/n89b0e66cc51f"
let scrollStandardViewController = "https://note.com/m_kakudo/n/ne2f615b627de"
let scrollPageViewController = "https://note.com/m_kakudo/n/n8c27c0549bd2"
let scrollKeyboardViewController = "https://note.com/m_kakudo/n/n69ccfefb7351"
let scrollConfigViewController = "https://note.com/m_kakudo/n/n86bb3d14b36d"
let scrollConfig2ViewController = "https://note.com/m_kakudo/n/n86bb3d14b36d"
let dateTimeViewController = "https://note.com/m_kakudo/n/n785df6905e8b"
let pickerStandardViewController = "https://note.com/m_kakudo/n/n844ace61e6d9"
let pickerSecondsCountDownTimerViewController = ""
let blurViewController = "https://note.com/m_kakudo/n/n103599e1afce"
let vibrancyViewController = "https://note.com/m_kakudo/n/nb37f376e7b7a"
let mapKitStandardViewController = "https://note.com/m_kakudo/n/ndba232841848"
let mapPinViewController = "https://note.com/m_kakudo/n/n56779858180c"
let mapAnnotationsViewController = "https://note.com/m_kakudo/n/n221f8840d3a4"
let mapBalloonViewController = "https://note.com/m_kakudo/n/n221f8840d3a4"
let mapDraggableViewController = "https://note.com/m_kakudo/n/n97e38f4aebab"
let mapDragAndLineViewController = "https://note.com/m_kakudo/n/n97e38f4aebab"
let mapLongtapViewController = "https://note.com/m_kakudo/n/n44acb9470d59"
let mapAddressLocationViewController = ""
let mapLongAddressLocationViewController = "https://note.com/m_kakudo/n/n5a21302f1e0f"
let mapCurrentResidenceViewController = "https://note.com/m_kakudo/n/n0ba7f8b8ca2b"
let mapPinResidenceViewController = "https://note.com/m_kakudo/n/nc92e9c04df21"
let mapTracingViewController = "https://note.com/m_kakudo/n/nc92e9c04df21"
let mapSearchingViewController = "https://note.com/m_kakudo/n/n1aeee341ef91"
let mapRouteViewController = "https://note.com/m_kakudo/n/n4d5e54768f25"
let mapOverlayViewController = "https://note.com/m_kakudo/n/n16f4321a6677"
let mapCalloutViewController = "https://note.com/m_kakudo/n/n3f906716406f"
let mapAnimationViewController = "https://note.com/m_kakudo/n/na1bb1e2a7154"
let mapGeodesicPolylineViewController = "https://note.com/m_kakudo/n/na1bb1e2a7154"
let mapChanmaruViewController = "https://note.com/m_kakudo/n/na1bb1e2a7154"
let tapRecognizerViewController = "https://note.com/m_kakudo/n/n402449225a4e"
let pinchGestureViewController = "https://note.com/m_kakudo/n/ne888eac90805"
let rotationGestureViewController = "https://note.com/m_kakudo/n/n806f26476eb6https://note.com/m_kakudo/n/na1bb1e2a7154"
let rotationPinchViewController = "https://note.com/m_kakudo/n/n806f26476eb6"
let swipeGestureViewController = "https://note.com/m_kakudo/n/n0ec72ef463ca"
let swipeLabelMoveViewController = "https://note.com/m_kakudo/n/n0ec72ef463ca"
let panGestureViewController = "https://note.com/m_kakudo/n/n841d11bf0ea8"
let pinRotePanGestureViewController = "https://note.com/m_kakudo/n/ne81d208a2e62"
let pinchRotatePanViewController = "https://note.com/m_kakudo/n/ne81d208a2e62"
let screenEdgePanGestureRecognizerViewController = "https://note.com/m_kakudo/n/n9925165b95db"
let longPressGestureViewController = "https://note.com/m_kakudo/n/nbc1418019458"
間違わずにやる方法は、
①まずは、各ビューのナビゲーションタイトルにボタンだけを一気に追加
↓
②以下のコードを追加
@IBAction func webButton(_ sender: Any) {
let url = URL(string: )
let safariView = SFSafariViewController(url: url!)
present(safariView, animated: true)
}
↓
③アシスタントから、同じようにドラッグして接続
↓
④該当の引数名を追加する
かな。。。💦
data:image/s3,"s3://crabby-images/79e51/79e51515094ba7efc89a8ba4b15ff3cd71a026b2" alt=""
data:image/s3,"s3://crabby-images/61015/6101530e0866a00032cfed31d812a08ab2f775fa" alt=""
data:image/s3,"s3://crabby-images/7e6b8/7e6b8a842e3472be0779d464407dae8f7187dc42" alt=""
SFSafariViewControllerのメリット
例えば、
data:image/s3,"s3://crabby-images/bc80e/bc80edf8a5c19fe454f4f620982615153ab305e3" alt=""
data:image/s3,"s3://crabby-images/a62df/a62df8c28bb119d51b77a3979daf871ee3e48075" alt=""
data:image/s3,"s3://crabby-images/09e54/09e54cbb380e005240b513aef1deaa6dc4c35f9c" alt=""
こんな時に、左下のコンパス(Safari)のマークを押すと〜〜〜
data:image/s3,"s3://crabby-images/ad68d/ad68dc6ce2971cb6920359868111ce9d10b0c947" alt=""
data:image/s3,"s3://crabby-images/75c8b/75c8b8b0f8010a3454ae7a19c2040cc3f17757ca" alt=""
たった、あれだけのコードを各クラスに追加するだけでね。
ここまで書くと、
「だったら、各記事のブラッシュアップの段階で、組み込めばよかったじゃないか!!!!」
て人もいそうなんだけど、
それだと話が脱線する
単なる後処理や確認の操作で、果てしなく操作が長くなり、却って何がメインの記事だったかすらわからなくなる
どうせ今回みたいに、後で一気にまとめて追加できる
からやらなかったのよね〜〜〜〜👀
最大のメリット(2023/3/28追記)
ビューを増やさずにWEBリンク先を開ける
👉このアプリは、あくまでも標準機能網羅を目的としてるから、これだけビューが膨大になってるけど、ビューが増えれば増える分、管理が大変になるので、WEBを単純に開きたいだけならば、ビューを増やさずにやれる方法でやるのが一番シンプルで簡単🕺
結構、触れてない本とかサイトも多いから、知らない人もいるんだよね〜〜〜!
(と、昨夜書き漏れていたからカキコ💦)
と、今回の最後に、
一番最初の入り口ビューに、マガジンのリンクも追加しておきたいので、、、
data:image/s3,"s3://crabby-images/dfd6d/dfd6dfffe41dbb8ded7d7ce3533cd6783f5bb6f8" alt=""
data:image/s3,"s3://crabby-images/47a23/47a232af288e8096b2ea91127d753636fd00889e" alt=""
data:image/s3,"s3://crabby-images/78313/7831353e3f9a7db3b77d4d75c680f06af2c85aad" alt=""
data:image/s3,"s3://crabby-images/896f6/896f67885e24b4e4d6d4f1cda1447061c0a01c14" alt=""
data:image/s3,"s3://crabby-images/a1c86/a1c8690ae6e3dc0f7c13e270ad3878ac85283433" alt=""
data:image/s3,"s3://crabby-images/d5bff/d5bff3f98b6cc42e91a37299ea0b0ee50e78cec5" alt=""
自分の好きなデザインにしてみてね〜〜〜〜💃
まとめ
これで、URLさえ変えれば、自分の好きなリンク先でやることも出来るね。
(日本語ドメインも行けたっけなあ🤔そこはちょっと覚えてないなあ)
Apple公式
さて、次回は
今までどおり、下から上の順で、
から再開しよう。
実はすでに使ったビュー間の矢印にまつわるお話
をレッツゴする🕺