お世話になっております。
前回質問させていただいた続きになってしまうのですが...
やりたいこと
アプリ側でiphoneの端末内画像をアプリで取得しその情報を保持したい。
Lineのトーク画面の背景画像を目指しています。
やったこと
アプリから端末内の写真を取得しそれを背景に設定するところまではなんとかできました。
しかし当たり前ですが、アプリをタスクキルしてしまうとなかったことになってしまいました。
以下がそのソースです
//ViewController import UIKit class ViewController: UIViewController , UITableViewDataSource, UITableViewDelegate,UINavigationControllerDelegate, UIImagePickerControllerDelegate{ @IBOutlet weak var toDoListTable: UITableView! var myImagePicker: UIImagePickerController! var myImageView: UIImageView! var imageview: UIImageView! let user = UserDefaults.standard // 2. StoryBoardとつなぐ @IBOutlet weak var tableView: UITableView! override func viewDidLoad() { super.viewDidLoad() if user.object(forKey: "todoList") != nil { toDoItem = user.object(forKey: "todoList") as! [String] } //背景Viewの大きさ設定 imageview = UIImageView(frame: CGRectMake( 0 ,0,self.tableView.frame.width,self.tableView.frame.height)) //画像の設定 let image = UIImage(named: "aaaa") imageview.image = image imageview.alpha = 0.5 self.tableView.backgroundView = imageview myImageView = UIImageView(frame: self.view.bounds) // インスタンス生成 myImagePicker = UIImagePickerController() // デリゲート設定 myImagePicker.delegate = self // 画像の取得先はフォトライブラリ myImagePicker.sourceType = UIImagePickerControllerSourceType.photoLibrary // 画像取得後の編集を不可に myImagePicker.allowsEditing = false tableView.delegate = self tableView.dataSource = self } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } override func viewDidAppear(_ animated: Bool) { toDoListTable.reloadData() } //以下テーブルビュー設定 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return toDoItem.count } func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cellValue = UITableViewCell(style: UITableViewCellStyle.default, reuseIdentifier: "cell") cellValue.textLabel?.text = toDoItem[indexPath.row] //cellの背景設定 cellValue.backgroundColor = UIColor.clear cellValue.contentView.backgroundColor = UIColor.clear return cellValue } func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCellEditingStyle, forRowAt indexPath: IndexPath) { if editingStyle == UITableViewCellEditingStyle.delete{ toDoItem.remove(at: indexPath.row) user.set(toDoItem, forKey: "todoList") toDoListTable.reloadData() } } func tableView(_ table: UITableView, didSelectRowAt indexPath:IndexPath) {} //背景変更ボタン @IBAction func back(_ sender: AnyObject) { self.present(myImagePicker, animated: true, completion: nil) } //背景Viewを作るためのCGRectWrapメソッド func CGRectMake(_ x: CGFloat, _ y: CGFloat, _ width: CGFloat, _ height: CGFloat) -> CGRect { return CGRect (x: x, y: y, width: width,height: height) } /** 画像が選択された時に呼ばれる. */ func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [String : AnyObject]) { //選択された画像を取得. let myImage: AnyObject? = info[UIImagePickerControllerOriginalImage] imageview.image = myImage as! UIImage self.dismiss(animated: true, completion: nil) } /** 画像選択がキャンセルされた時に呼ばれる. */ func imagePickerControllerDidCancel(_ picker: UIImagePickerController) { // モーダルビューを閉じる self.dismiss(animated: true, completion: nil) } }
一画面でやってしまっているのでごちゃごちゃしています。申し訳ないです。
UserDefaulとかでいけるのでしょうか?
それともアプリ内にその画像を保存しておかないといけないのでしょうか?
どなたかご教授願えれば幸いです。
回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2016/12/12 07:51
2016/12/12 08:53