質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

0回答

244閲覧

コードが実行されませんでした。

achapy

総合スコア2

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2021/01/08 15:35

最近swiftの勉強を始めたものなのですが、以下のコードを試験的にコピペしてみて実行してみたところ、何も表示されませんでした。これはどういったところが悪いのか、教えていただけると嬉しいです。始めたばかりのもので、アバウトな質問になってしまい申し訳ありません。

import UIKit
import SafariServices

class ViewController: UIViewController, UIPickerViewDelegate, UIPickerViewDataSource, UITextFieldDelegate {

private var myTextField: UITextField! let pickerView = UIPickerView() // ドラムロールボタンの選択肢を配列にして格納 let dataSource = ["Google", "Apple", "Facebook", "Amazon"] override func viewDidLoad() { super.viewDidLoad() // UITextFieldの配置するx,yと幅と高さを設定. let tWidth: CGFloat = 150 let tHeight: CGFloat = 30 let posX: CGFloat = (self.view.bounds.width - tWidth)/2 let posY: CGFloat = (self.view.bounds.height - tHeight)/2 // UITextFieldを作成する. myTextField = UITextField(frame: CGRect(x: posX, y: posY, width: tWidth, height: tHeight)) // 表示する文字を代入する. myTextField.text = "START" myTextField.textAlignment = .center // Delegateを自身に設定する myTextField.delegate = self // 枠を表示する. myTextField.borderStyle = .bezel //カーソル(キャレット)を非表示 myTextField.tintColor = UIColor.clear // myTextFieldをViewに追加する self.view.addSubview(myTextField) // pickerViewの配置するx,yと幅と高さを設定. pickerView.frame = CGRect(x: 0, y: 0, width: UIScreen.main.bounds.size.width, height: pickerView.bounds.size.height) // Delegateを自身に設定する pickerView.delegate = self // 選択肢を自身に設定する pickerView.dataSource = self // pickerViewをViewに追加する let vi = UIView(frame: pickerView.bounds) vi.backgroundColor = UIColor.white vi.addSubview(pickerView) // UITextField編集時に表示されるキーボードをpickerViewに置き換える myTextField.inputView = vi } func pickerView(_ pickerView: UIPickerView, titleForRow row: Int, forComponent component: Int) -> String? { return dataSource[row] } func numberOfComponents(in pickerView: UIPickerView) -> Int { return 1 } func pickerView(_ pickerView: UIPickerView, numberOfRowsInComponent component: Int) -> Int { return dataSource.count } // 各選択肢が選ばれた時の操作 func pickerView(_ pickerView: UIPickerView, didSelectRow row: Int, inComponent component: Int) { switch row { case 0: // Googleが選ばれたらHPにアクセスする guard let url = URL(string: "https://www.google.com/?client=safari") else { return } let safariController = SFSafariViewController(url: url) present(safariController, animated: true, completion: nil) case 1: guard let url = URL(string: "https://www.apple.com/jp/") else { return } let safariController = SFSafariViewController(url: url) present(safariController, animated: true, completion: nil) case 2: guard let url = URL(string: "https://www.facebook.com") else { return } let safariController = SFSafariViewController(url: url) present(safariController, animated: true, completion: nil) case 3: guard let url = URL(string: "https://www.amazon.co.jp") else { return } let safariController = SFSafariViewController(url: url) present(safariController, animated: true, completion: nil) default: break } }

}

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hoshi-takanori

2021/01/08 16:00

これも Swift Playgrounds なら、前回同様に import PlaygroundSupport PlaygroundPage.current.liveView = ViewController() で何かが出るのでは。ところで、前回のやつは動きましたか?
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

会員登録して回答してみよう

アカウントをお持ちの方は

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問