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

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

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

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

Q&A

解決済

1回答

677閲覧

tableViewCellのDeleteがうまく表示されない。

atk_721

総合スコア62

Swift

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

0グッド

2クリップ

投稿2020/04/08 05:41

前提・実現したいこと

画像、1
イメージ説明
画像、2
イメージ説明

画像,1の様にtableViewCellをDeleteする際、なぜかDeleteボタンが見切れて表示されてしまいます。
画像、2の様にDeleteボタン全体を表示したいです。

初歩的な質問かと思いますが、回答よろしくお願いします。

該当のソースコード

// // ViewController.swift // RealmSwift5 // // Created by username on 2020/04/03. // Copyright © 2020 username. All rights reserved. // import UIKit import RealmSwift class ViewController: UIViewController, UITextFieldDelegate{ @IBOutlet weak var createLabel: UILabel! @IBOutlet weak var doneLabel: UILabel! @IBOutlet weak var searchTextField: UITextField! @IBOutlet weak var tableView: UITableView! var toDoList: Results<ToDo>! override func viewDidLoad() { super.viewDidLoad() searchTextField.delegate = self self.tableView.delegate = self self.tableView.dataSource = self tableView.register(UINib(nibName: "CustomTableViewCell", bundle: nil), forCellReuseIdentifier: "cell") tableView.rowHeight = UITableView.automaticDimension tableView.estimatedRowHeight = 100 tableView.separatorStyle = .none } func textFieldShouldReturn(_ textField: UITextField) -> Bool { textField.resignFirstResponder() return true } override func touchesBegan(_ touches: Set<UITouch>, with event: UIEvent?) { self.view.endEditing(true) } override func viewWillAppear(_ animated: Bool) { super.viewWillAppear(animated) self.navigationController?.navigationBar.setBackgroundImage(UIImage(), for: .default) self.navigationController?.navigationBar.shadowImage = UIImage() tableView.isEditing = false getToDoData() } @IBAction func doneAction(_ sender: Any) { if searchTextField.text == "" { return } do{ let realm = try! Realm() guard realm.objects(ToDo.self).filter("ToDo == %@",searchTextField.text!).first != nil else { doneLabel.text = "一致するデータがありません。" return } let results = realm.objects(ToDo.self).filter("ToDo == %@",searchTextField.text!).first! doneLabel.text = results.ToDo createLabel.text = results.createdAt }catch let error { print(error.localizedDescription) } } @IBAction func editButtonTaped(_ sender: Any) { if tableView.isEditing == false { tableView.isEditing = true }else if tableView.isEditing == true { tableView.isEditing = false } } @IBAction func addButtonTaped(_ sender: Any) { showAlert() } func showAlert(){ let alertVC = UIAlertController(title: "ToDoList", message: nil, preferredStyle: .alert) alertVC.addTextField { (textField) in textField.placeholder = "ToDoList" } let action = UIAlertAction(title: "OK", style: .default) { (alertAction) in if let textField = alertVC.textFields?.first { guard let text = textField.text else{ return } let ToDoText = ToDo() ToDoText.createdAt = self.getNowDate() ToDoText.ToDo = text do{ let realm = try! Realm() try! realm.write{ realm.add(ToDoText) self.tableView.reloadData() } }catch let error{ print(error.localizedDescription) } } //MARK: Test do{ let realm = try! Realm() let todo: Results<ToDo> = realm.objects(ToDo.self) print(type(of: todo)) }catch let error { print(error.localizedDescription) } } let cancal = UIAlertAction(title: "cancel", style: .cancel, handler: nil) alertVC.addAction(action) alertVC.addAction(cancal) self.present(alertVC, animated: true, completion: nil) } fileprivate func getNowDate() -> String{ let date = Date() let formatter = DateFormatter() formatter.timeStyle = .medium formatter.dateStyle = .medium formatter.locale = Locale(identifier: "ja_JP") let currentDate = formatter.string(from: date) return currentDate } fileprivate func getToDoData(){ do{ let realm = try! Realm() toDoList = realm.objects(ToDo.self).sorted(byKeyPath: "createdAt", ascending: true) }catch let error{ print(error.localizedDescription) } } } extension ViewController: UITableViewDelegate,UITableViewDataSource { func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return toDoList.count } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let item = toDoList[indexPath.row] let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! CustomTableViewCell cell.createdLabel.text = item.createdAt cell.todoLabel.text = item.ToDo cell.todoLabel.numberOfLines = 0 cell.todoLabel.adjustsFontSizeToFitWidth = true cell.selectionStyle = .none return cell } func numberOfSections(in tableView: UITableView) -> Int { return 1 } func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { return self.view.frame.height/6 } func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool { //3番目は削除させない。 // if indexPath.row == 3{ // return false // } return true } func tableView(_ tableView: UITableView, editingStyleForRowAt indexPath: IndexPath) -> UITableViewCell.EditingStyle { return UITableViewCell.EditingStyle.delete } func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) { if (editingStyle == .delete){ do{ let realm = try! Realm() try! realm.write{ realm.delete(toDoList[indexPath.row]) } tableView.deleteRows(at: [indexPath], with: UITableView.RowAnimation.right) }catch let error { print(error.localizedDescription) } } } }

swift5
Xcode Version 11.4 (11E146)

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

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

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

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

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

hoshi-takanori

2020/04/08 06:09

たぶん、Storyboard 上では tableView の幅が 414 ピクセル (iPhone 11 Pro Max サイズ) で作られていて、iPhone 11 Pro などの画面の横幅 375 ピクセルにリサイズされずにはみ出しているのでは。
atk_721

2020/04/09 09:28

解決することができました。原因はご指摘の通りiphone 11 pro と iphone 11 pro Max の違いによってDeleteButtonが見切れていました。ありがとうございました。
guest

回答1

0

ベストアンサー

hoshi-takanoriさんのおっしゃるとおりだと思いますので、UITableViewに制約をつけてサイズを画面幅内に収まるようにしてみてください。

なんなら、ViewControllerに↓これ貼り付けて、各々の幅を確認してみて。

swift

1override func viewDidAppear(_ animated: Bool) { 2 super.viewDidAppear(animated) 3 4 print("画面の幅: (self.view.frame.width)") 5 print("tableViewの幅: (tableView.frame.width)") 6 7}

投稿2020/04/08 09:46

退会済みユーザー

退会済みユーザー

総合スコア0

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

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

atk_721

2020/04/09 09:29

初歩的な質問でしたが、回答ありがとうがとうございました。無事解決できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問