前提・実現したいこと
iOSで、画像を挿入したRTFDファイル(DocumentDirectoryに保存)をUITextViewで表示させたい。
iPhone標準メモやEvernoteのようなメモ帳をイメージしています。
発生している問題・エラーメッセージ
RTFDファイルをDocumentDirectoryから読み込んでUITextViewに表示した際、画像が設定より大きく表示されてしまう(UITextViewを大きくはみ出る)
画像の大きさを設定通りに表示する方法を、ご教授していただけると嬉しいです。
よろしくお願いいたします。
該当のソースコード
Swift
1@IBOutlet weak var text_view: UITextView! 2 3 @objc func addphotoBarButtonItem_pushed(_ sender: UIBarButtonItem) { 4 self.view.endEditing(true) 5 let picker = UIImagePickerController() 6 picker.delegate = self 7 picker.sourceType = .photoLibrary 8 present(picker, animated: true, completion: nil) 9 } 10 11 func imagePickerController(_ picker: UIImagePickerController, didFinishPickingMediaWithInfo info: [UIImagePickerController.InfoKey : Any]) { 12 if let image = info[.originalImage] as? UIImage { 13 14 let fullString = NSMutableAttributedString(attributedString: text_view.attributedText) 15 16 let imageWidth = image.size.width 17 18 let padding: CGFloat = 50 19 20 let scaleFactor = imageWidth / (text_view.frame.size.width - padding) 21 22 let imageAttachment = NSTextAttachment() 23 24 imageAttachment.image = UIImage(cgImage: image.cgImage!, scale: scaleFactor, orientation: .up) 25 26 let imageString = NSAttributedString(attachment: imageAttachment) 27 fullString.append(imageString) 28 29 // TextViewに画像を含んだテキストをセット 30 text_view.attributedText = fullString 31 32 //text_viewをDocumnetsに保存 ・・・・・・・・・・・ 33 //RTFD書込み 34 let paths = NSSearchPathForDirectoriesInDomains(FileManager.SearchPathDirectory.documentDirectory, FileManager.SearchPathDomainMask.userDomainMask, true) 35 let documentsPath = paths[0] as String 36 37 //もしDocuments[0]が存在したら、 38 if FileManager.default.fileExists(atPath: documentsPath) { 39 do { 40 let data = try text_view.attributedText?.fileWrapper(from: NSRange(location: 0, length: (text_view.attributedText?.length)!), documentAttributes: [.documentType: NSAttributedString.DocumentType.rtfd]) 41 42 saveData(data: data!) //保存する 43 44 } catch { 45 print("エラー") 46 } 47 } 48 } 49 dismiss(animated: true, completion: nil) 50 } 51 52 53 func imagePickerControllerDidCancel(_ picker: UIImagePickerController) { 54 dismiss(animated: true, completion: nil) 55 } 56 57 func saveData(data: FileWrapper){ 58 59 let paths = NSSearchPathForDirectoriesInDomains(FileManager.SearchPathDirectory.documentDirectory, FileManager.SearchPathDomainMask.userDomainMask, true) 60 let documentsPath = paths[0] as String 61 let documentsURL = URL(fileURLWithPath: documentsPath) 62 let rtfdURL = documentsURL.appendingPathComponent("0").appendingPathExtension("rtfd") //パスを取得 63 64 do { 65 //保存 66 try data.write(to: rtfdURL, options: .atomic, originalContentsURL: nil) 67 68 } catch { 69 print("保存できませんでした") 70 } 71 } 72 73 override func viewDidLoad() { 74 super.viewDidLoad() 75 76 let paths = NSSearchPathForDirectoriesInDomains(FileManager.SearchPathDirectory.documentDirectory, FileManager.SearchPathDomainMask.userDomainMask, true) 77 let documentsPath = paths[0] as String 78 79 //もしDocuments[0]が存在したら、 80 if FileManager.default.fileExists(atPath: documentsPath) { 81 82 let attributedString: [NSAttributedString.DocumentReadingOptionKey : Any] = [.documentType : NSAttributedString.DocumentType.rtfd] 83 84 let filePath = documentsPath + "/0.rtfd" 85 let documentsURL = URL(fileURLWithPath: filePath) 86 let attributedText = try! NSAttributedString(url: documentsURL, options: attributedString, documentAttributes: nil) 87 88 //text_viewへ読み込み 89 text_view.attributedText = attributedText 90 }
補足情報(FW/ツールのバージョンなど)
Xcode:Version 11.2.1
Swift4
あなたの回答
tips
プレビュー