この記事は2018年07月30日に投稿しました。 この記事は2018年07月31日に更新しました。
目次
詳細! Swift 4 iPhoneアプリ開発 入門ノート Swift 4 + Xcode 9対応
- 作者: 大重美幸
- 出版社/メーカー: ソーテック社
- 発売日: 2017/11/03
- メディア: 単行本
- この商品を含むブログを見る
1. はじめに
こんにちは、iOSのエディタアプリPWEditorの開発者の二俣です。
今回はSwiftのGoogleDrive APIでファイルをコピーしてみます。
PWEditorでは、SwiftのGoogleDrive APIを操作するため、
を使用しています。
2. 前提
下記の記事を参考にGoogleDrive APIを使用できる状態にしておいてください。
SwiftでGoogleDrive APIを使用する準備を行う。 - プログラムを書こう!
SwiftのGoogleDrive APIで初期化処理を行う。 - プログラムを書こう!
SwiftのGoogleDrive APIでサインインを行う。 - プログラムを書こう!
3. ファイルコピー処理
SwiftのGoogleDrive APIでファイルをコピーするには、Google APIs Client Library for Objective-C For RESTライブラリのGTLRService#executeQueryメソッドを使用します。
このメソッドで、ディレクトリもファイルもコピーできます。
ディレクトリをコピーする場合、配下のディレクトリやファイルもコピーされます。
コピー先に同名のディレクトリやファイルが存在する場合、エラーになります。
以下に手順を示します。
- 引数のコピー元ファイル名とコピー先ディレクトリIDを指定して、ファイル(GTLRDrive_File)オブジェクトを作成します。
- 1で作成したファイル(GTLRDrive_File)オブジェクトと引数のコピー元ファイルIDを指定して、クエリオブジェクトを取得します。
- 2で作成したクエリオブジェクトを指定して、GTLRService#executeQueryメソッドを実行し、ファイルをコピーします。
PWEditorでGTLRServiceオブジェクトは、AppDelegateでgoogleDriveServiceDriveとして保持しています。
GTLRService#executeQueryメソッドの実行は、ネットワークにアクセスするため時間がかかかります。
そのためPWEditorでは、通信中は処理中ダイアログを表示しています。 - GTLRService#execcuteQueryメソッドを実行した結果は、クロージャで返却されます。
エラーの場合はerrorオブジェクトが設定されます。
AppDelegate.swift
@UIApplicationMain class AppDelegate: UIResponder, UIApplicationDelegate { ... /// GoogleDriveサービスドライブ let googleDriveServiceDrive = GTLRDriveService() .... }
ViewController.swift
import GoogleAPIClientForREST /** GoogleDriveでファイルをコピーします。 - Parameter dirId: コピー先ディレクトリID - Parameter fileId: コピー元ファイルID - Parameter fileName: コピー元ファイル名 */ func copyFile(_ dirId: String, fileId: String, fileName: String) { // 1. 引数のコピー元ファイル名とコピー先ディレクトリIDを指定して、ファイル(GTLRDrive_File)オブジェクトを作成します。 let copyFile = GTLRDrive_File() copyFile.name = fileName copyFile.parents = [dirId] // 2. 1で作成したファイル(GTLRDrive_File)オブジェクトと引数のコピー元ファイルIDを指定して、クエリオブジェクトを取得します。 let query = GTLRDriveQuery_FilesCopy.query(withObject: copyFile, fileId: fileId) // 3. 2で作成したクエリオブジェクトを指定して、GTLRService#executeQueryメソッドを実行し、ファイルをコピーします。 let appDelegate = EnvUtils.getAppDelegate() let serviceDrive = appDelegate.googleDriveServiceDrive serviceDrive.executeQuery(query, completionHandler: { (ticket: GTLRServiceTicket?, updatedFile: Any?, error: Error?) -> Void in if let error = error { // 5. エラーの場合、処理を終了します。 // 必要に応じてエラー処理を行ってください。 return } // 正常終了の場合の処理を記述してください。 }) }
4. おわりに
PWEditorでファイルコピー処理を実装した時に参考にしたドキュメントが、以前はGoogleのサイトにあったと思うのですが、今は見つけられませんでした。
代わりに、以下がGoogleDrive APIのファイルコピーに関するRESTのリファレンスになります。
File:copy
- 作者: 荻原剛志
- 出版社/メーカー: SBクリエイティブ
- 発売日: 2017/12/26
- メディア: 単行本
- この商品を含むブログ (1件) を見る
紹介している一部の記事のコードはGitlabで公開しています。
興味のある方は覗いてみてください。
私が勤務しているニューラルでは、主に組み込み系ソフトの開発を行っております。
弊社製品のハイブリッドOS Bi-OSは高い技術力を評価されており、特に制御系や通信系を得意としています。
私自身はiOSモバイルアプリやウィンドウズアプリを得意としております。
ソフトウェア開発に関して相談などございましたら、お気軽にご連絡ください。
また一緒に働きたい技術者の方も随時募集中です。
興味がありましたらご連絡ください。
EMAIL : info-nr@newral.co.jp / m-futamata@newral.co.jp
TEL : 042-523-3663
FAX : 042-540-1688