19
21

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Swiftでデータベースを使おう!③(ランキングを作る・アクセス権限)

Last updated at Posted at 2016-02-17

【お知らせ】Swift3に対応しました!(2017/02/23更新)

【Swift×mBaaS】シリーズ概要

事前準備のお願い

Swiftでデータベースを使おう!

ランキングを作る

iOSアプリでランキングを実装する場合の使い方について解説します。

スコアの保存

  • 通常のオブジェクトの保存方法と同じようにプレイヤー名とスコアを設定してデータストアのHighScoreクラスに保存します。
Swift3
// HighScoreクラスのインスタンスを作成
let score = NCMBObject(className:"HighScore")
// 名前とスコアをセット
score?.setObject("name", forKey:"Name")
score?.setObject(0, forKey:"Score")
// データストアに保存
score?.saveInBackground({(error) in
    if error != nil {
        // 保存に失敗した場合の処理
    }else{
        // 保存に成功した場合の処理
    }
})
Swift2
// HighScoreクラスのインスタンスを作成
let score = NCMBObject(className:"HighScore")
// 名前とスコアをセット
score.setObject("name", forKey:"Name")
score.setObject(0, forKey:"Score")
// データストアに保存
score.saveInBackgroundWithBlock({(error: NSError!) in
    if error != nil {
        // 保存に失敗した場合の処理
    }else{
        // 保存に成功した場合の処理
    }
})

ランキングの取得

  • 各プレイヤーのスコアが保存されるHighScoreクラスから、スコアの降順データを検索することで、簡単にランキングを取得できます。
Swift3
// HighScoreクラスを検索するNCMBQueryを作成
let query = NCMBQuery(className:"HighScore")
// Scoreの降順でデータを取得するように設定
query?.addDescendingOrder("Score")
// 検索件数を5件に設定
query?.limit = 5
// データストアでの検索を行う
query?.findObjectsInBackground({(objects, error) in
    if error != nil {
        // 検索に失敗した場合の処理
    }else{
        // 検索に成功した場合の処理
        print(objects as! [NCMBObject]) // 例)取得結果を表示
    }
})
Swift2
// HighScoreクラスを検索するNCMBQueryを作成
let query = NCMBQuery(className:"HighScore")
// Scoreの降順でデータを取得するように設定
query.addDescendingOrder("Score")
// 検索件数を5件に設定
query.limit = 5
// データストアでの検索を行う
query.findObjectsInBackgroundWithBlock({(objects: [NSArray]!, error: NSError!) -> void in
    if error != nil {
        // 検索に失敗した場合の処理
    }else{
        // 検索に成功した場合の処理
        print(objects) // 例)取得結果を表示
    }
})
  • ゲームのにオンラインランキングはこんなに簡単に実装できてしまうんですね!!^^*

アクセス権限設定

データストアのACL機能を利用して各データのアクセス権限を会員、ロールごとに設定する方法を説明します。

  • ACLを設定する場合は、NCMBACLクラスを利用します。
Swift3
//ACLオブジェクトを作成
let acl = NCMBACL()
//読み込み(検索)・書き込みを全開放を設定
acl.setPublicReadAccess(true)
acl.setPublicWriteAccess(true)

let obj = NCMBObject(className:"test")
//オブジェクトにACLを設定
obj?.acl = acl
obj?.save(nil)
Swift2
//ACLオブジェクトを作成
let acl = NCMBACL()
//読み込み(検索)・書き込みを全開放を設定
acl.setPublicReadAccess(true)
acl.setPublicWriteAccess(true)
        
let obj = NCMBObject(className:"test")
//オブジェクトにACLを設定
obj.ACL = acl
obj.save(nil)
  • 会員やロールを対象にACLを設定することも可能です。このとき、会員やロールは登録が済んでおりobjectIdを持っている必要があります。
  • 一部会員管理クラス(userクラス)の知識が必要です。
  • 会員管理のドキュメントには<会員管理編>をご覧ください。
Swift3
let sharedNote = NCMBObject(className:"Note")
sharedNote?.setObject("This note is shared!", forKey:"content")
// NCMBACLのインスタンスを作成
let groupACL = NCMBACL()
let user = NCMBUser()
user?.userName = "user"
user?.password = "password"
//上記ユーザー名とパスワードで新規登録ログインを実施
user?.signUp(nil)
// 引数で渡された会員userへの読み込み権限を設定する
groupACL.setReadAccess(true, for:user)
// 引数で渡された会員userへの書き込み権限を設定する
groupACL.setWriteAccess(true, for:user)
//ACLをオブジェクトに設定する
sharedNote?.acl = groupACL
sharedNote?.save(nil)
Swift2
let sharedNote = NCMBObject(className:"Note")
sharedNote.setObject("This note is shared!", forKey:"content")
// NCMBACLのインスタンスを作成
let groupACL = NCMBACL()
let user = NCMBUser()
user.userName = "user"
user.password = "password"
//上記ユーザー名とパスワードで新規登録ログインを実施
user.signUp(nil)
// 引数で渡された会員userへの読み込み権限を設定する
groupACL.setReadAccess(true, forUser:user)
// 引数で渡された会員userへの書き込み権限を設定する
groupACL.setWriteAccess(true, forUser:user)
//ACLをオブジェクトに設定する
sharedNote.ACL = groupACL
sharedNote.save(nil)

参考

19
21
3

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
19
21

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?