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

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

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

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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

解決済

カスタムセルで作成したボタンを押下出来ない

Ka_ya_
Ka_ya_

総合スコア0

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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

1回答

0評価

0クリップ

478閲覧

投稿2020/08/01 05:05

質問失礼します。

コードのみでテーブルビューを作成したいです。

ボタンのあるカスタムセルクラスを使用したいのですが、
下記の様に記載したところ、ボタンを押下しても反応がありません。

これは何が原因なのでしょうか。

どなたかご教授いただけますと嬉しいです。
よろしくお願い致します。

Swift

import UIKit class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource { //スクリーンサイズ var screenSize = CGSize() ///背景画像 let imageView :UIImageView = { let image:UIImage = UIImage(named:"noimage")! let iv = UIImageView(image:image) iv.contentMode = .scaleAspectFill iv.frame = UIScreen.main.bounds return iv }() ///テーブルビュー let tableView :UITableView = { let tv = UITableView() tv.backgroundColor = .clear tv.separatorStyle = .none //カスタムセルを登録する tv.register(CustomCell.self, forCellReuseIdentifier: "customCell") tv.translatesAutoresizingMaskIntoConstraints = false return tv }() //ヘッダー var headerView = UIView() override func viewDidLoad() { super.viewDidLoad() //スクリーンサイズの取得 screenSize = self.view.frame.size //背景画像の設定 self.view.addSubview(imageView) //ヘッダービューを設定 headerView.frame = CGRect(x: 0, y: 0, width: screenSize.width, height: screenSize.height / 6) headerView.backgroundColor = UIColor(red: 88 / 255, green: 0 / 255, blue: 88 / 255, alpha: 1.0) view.addSubview(headerView) //テーブルビューを設定 view.addSubview(tableView) tableView.topAnchor.constraint(equalTo: headerView.bottomAnchor).isActive = true tableView.leadingAnchor.constraint(equalTo: view.leadingAnchor).isActive = true tableView.trailingAnchor.constraint(equalTo: view.trailingAnchor).isActive = true tableView.bottomAnchor.constraint(equalTo: view.bottomAnchor).isActive = true tableView.delegate = self tableView.dataSource = self } //セルの個数 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return 5 } //セルの高さ func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { return (screenSize.height - headerView.frame.size.height) / 8 } //セルの設定 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { ///カスタムセルを使用する let cell = tableView.dequeueReusableCell(withIdentifier: "customCell", for: indexPath) as! CustomCell return cell } }

Swift

import UIKit class CustomCell: UITableViewCell { ///セル背景画像 let bgImageView :UIImageView = { let image:UIImage = UIImage(named:"noimage")! let iv = UIImageView(image:image) iv.backgroundColor = .clear iv.translatesAutoresizingMaskIntoConstraints = false return iv }() ///コメントラベル let commentLabel: UILabel = { let label = UILabel() label.font = UIFont.systemFont(ofSize: 18) label.textColor = UIColor.black label.textAlignment = .center label.text = "テスト" label.translatesAutoresizingMaskIntoConstraints = false return label }() ///ボタン・ラベル格納用スタックビュー let stackView :UIStackView = { let sv: UIStackView = UIStackView() sv.distribution = .equalSpacing sv.axis = .horizontal sv.translatesAutoresizingMaskIntoConstraints = false return sv }() //ボタン var button :UIButton = { let btn = UIButton() btn.backgroundColor = .red btn.translatesAutoresizingMaskIntoConstraints = false btn.addTarget(self, action: #selector(CustomCell.tap(_:)), for: .touchUpInside) return btn }() ///ラベル let label: UILabel = { let label = UILabel() label.font = UIFont.systemFont(ofSize: 12) label.textColor = UIColor.black label.textAlignment = .center label.adjustsFontSizeToFitWidth = true label.translatesAutoresizingMaskIntoConstraints = false label.text = "テスト" return label }() //ここにUI部品を追加していく override init(style: UITableViewCell.CellStyle, reuseIdentifier: String?) { super.init(style: style, reuseIdentifier: reuseIdentifier) //背景の設定 addSubview(bgImageView) bgImageView.centerXAnchor.constraint(equalTo: self.centerXAnchor).isActive = true bgImageView.centerYAnchor.constraint(equalTo: self.centerYAnchor).isActive = true bgImageView.widthAnchor.constraint(equalTo: self.widthAnchor).isActive = true bgImageView.heightAnchor.constraint(equalTo: self.heightAnchor).isActive = true //コメントの設定 addSubview(commentLabel) commentLabel.topAnchor.constraint(equalTo: self.topAnchor, constant: 10).isActive = true commentLabel.centerYAnchor.constraint(equalTo: self.centerYAnchor).isActive = true commentLabel.widthAnchor.constraint(equalTo: self.widthAnchor).isActive = true commentLabel.heightAnchor.constraint(equalTo: self.heightAnchor, multiplier: 0.25).isActive = true //スタックビュー addSubview(stackView) stackView.centerXAnchor.constraint(equalTo: self.centerXAnchor).isActive = true stackView.topAnchor.constraint(equalTo: commentLabel.bottomAnchor, constant: 10).isActive = true stackView.widthAnchor.constraint(equalTo: self.widthAnchor, multiplier: 0.6).isActive = true stackView.heightAnchor.constraint(equalTo: self.heightAnchor, multiplier: 1/3).isActive = true //ボタンの設定 stackView.addArrangedSubview(button) button.widthAnchor.constraint(equalTo: stackView.heightAnchor).isActive = true button.heightAnchor.constraint(equalTo: stackView.heightAnchor).isActive = true //ラベルの設定 stackView.addArrangedSubview(label) label.widthAnchor.constraint(equalTo: stackView.widthAnchor, multiplier: 0.2).isActive = true label.heightAnchor.constraint(equalTo: stackView.heightAnchor).isActive = true } required init?(coder: NSCoder) { fatalError("init(coder:) has not been implemented") } //押下時の挙動 @objc func tap(_ sender: Any) { //ボタンを押下してもプリントされない print("タップ") } }

イメージ説明

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

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