GS2-Buff SDK for Game Engine API リファレンス

ゲームエンジン向け GS2-Buff SDK の モデルの仕様 と API のリファレンス

モデル

EzBuffEntryModel

バフエントリーモデル

バフの適用量はバフエントリーモデルで管理し、特定のエントリーに対して複数のバフエントリーモデルを関連づけることが可能です。
バフエントリーモデルの適用順番はバフエントリーモデルの priority で管理し、priority の値が小さいほど優先度が高くなります。

バフの適用方式は3種類存在し「Rate Add」、「Mul」と「Value Add」があります。
Rate Add はバフの適用レートに加算する命令、Mul はバフの適用レートに乗算する命令です。
Value Add はバフの補正計算後の値に加算を行う命令です。
たとえば、デフォルトのレートが 1.0 で、Add 0.2 と設定するとバフの適用レートは 1.2 になります。
Mul 0.5 と設定するとバフの適用レートは 0.5 倍になります。

バフエントリーモデルには GS2-Schedule のイベントを関連づけることができ、イベントの開催期間中のみバフを適用するような設定も可能です。

有効化条件必須デフォルト値の制限説明
namestring
~ 128文字バフエントリーモデル名
バフエントリーモデル固有の名前。英数字および -(ハイフン) _(アンダースコア) .(ピリオド)で指定します。
metadatastring~ 2048文字メタデータ
メタデータには任意の値を設定できます。
これらの値は GS2 の動作には影響しないため、ゲーム内で利用する情報の保存先として使用できます。
targetType文字列列挙型
enum {
  “model”,
  “action”
}
バフを適用する対象の種類
バフをモデルのフィールド値に適用するか、アクションのパラメータに適用するかを指定します。「Model」は GS2 リソースモデルのフィールドを対象とし、「Action」は GS2 アクション(例:入手量や消費量)のパラメータを対象とします。
定義説明
“model”モデル
“action”アクション
targetModelEzBuffTargetModel{targetType} == “model”
✓※
バフを適用する対象のモデル
バフを適用する GS2 リソースモデルとフィールドを指定します。モデル名、フィールド名、対象リソースを特定する条件GRN、およびレート値が含まれます。

※ targetType が “model” であれば 必須
targetActionEzBuffTargetAction{targetType} == “action”
✓※
バフを適用する対象のアクション
バフを適用する GS2 アクションとパラメータを指定します。アクション名、フィールド名、対象リソースを特定する条件GRN、およびレート値が含まれます。

※ targetType が “action” であれば 必須
expression文字列列挙型
enum {
  “rate_add”,
  “mul”,
  “value_add”
}
バフの適用タイプ
バフ値を対象にどのように適用するかを指定します。「Rate Add」は補正レートに加算(例: 1.0 + 0.2 = 1.2)、「Mul」は補正レートに乗算(例: レート * 0.5)、「Value Add」はレートベースの補正計算後の値に直接加算します。
定義説明
“rate_add”補正レートに加算
“mul”補正レートに乗算
“value_add”値を直接加算(モデルやアクションの数値のみ)
applyPeriodScheduleEventIdstring~ 1024文字バフを適用するイベントの開催期間 GRN
このバフの有効期間を制御する GS2-Schedule イベントの GRN です。指定した場合、イベントの開催期間中のみバフが適用されます。未指定の場合、バフは常に有効です。

EzBuffTargetModel

バフを適用する対象のモデル

バフ適用の対象となる GS2 リソースモデルとフィールドを定義します。どのモデルのどのフィールド値をバフで変更するかを指定し、対象リソースインスタンスを特定する条件GRNと適用するレート値を含みます。

有効化条件必須デフォルト値の制限説明
targetModelName文字列列挙型
enum {
"Gs2Exchange:RateModel",
"Gs2Exchange:IncrementalRateModel",
"Gs2Experience:Status",
"Gs2Formation:Mold",
"Gs2Idle:Status",
"Gs2Idle:CategoryModel",
"Gs2Inventory:Inventory",
"Gs2LoginReward:BonusModel",
"Gs2Mission:MissionTaskModel",
"Gs2Quest:QuestModel",
"Gs2Showcase:DisplayItem",
"Gs2Showcase:RandomDisplayItemModel",
"Gs2SkillTree:NodeModel",
"Gs2Stamina:Stamina",
}
バフを適用するモデルの種類
targetFieldNamestring
~ 64文字バフの適用対象フィールド名
バフによって値が変更される対象モデル上の数値フィールド名です。例えば、経験値や攻撃力などの数値属性を表すフィールドが対象となります。
conditionGrnsList<EzBuffTargetGrn>
1 ~ 10 itemsバフの適用条件GRNのリスト
バフ適用の対象リソースインスタンスを特定する GRN パターンのリストです。複数の GRN を組み合わせて、リソースを正確に特定する複合条件を形成します。
ratefloat
0 ~ 1000000補正レート
適用されるバフ値です。適用タイプにより意味が異なります。「Rate Add」の場合は基本レートに加算、「Mul」の場合は現在のレートに乗算、「Value Add」の場合はレート計算後のフィールド値に直接加算されます。

EzBuffTargetAction

バフを適用する対象のアクション

バフ適用の対象となる GS2 アクションとパラメータを定義します。どのアクションのどのパラメータをバフで変更するかを指定し、対象リソースインスタンスを特定する条件GRNと適用するレート値を含みます。

有効化条件必須デフォルト値の制限説明
targetActionName文字列列挙型
enum {
"Gs2Experience:AddExperienceByUserId",
"Gs2Experience:SubExperience",
"Gs2Experience:SubExperienceByUserId",
"Gs2Inventory:AcquireItemSetByUserId",
"Gs2Inventory:ConsumeItemSet",
"Gs2Inventory:ConsumeItemSetByUserId",
"Gs2Inventory:AcquireSimpleItemsByUserId",
"Gs2Inventory:ConsumeSimpleItems",
"Gs2Inventory:ConsumeSimpleItemsByUserId",
"Gs2Inventory:AcquireBigItemByUserId",
"Gs2Inventory:ConsumeBigItem",
"Gs2Inventory:ConsumeBigItemByUserId",
"Gs2Limit:CountUp",
"Gs2Limit:CountUpByUserId",
"Gs2Money:DepositByUserId",
"Gs2Money:Withdraw",
"Gs2Money:WithdrawByUserId",
"Gs2Money2:DepositByUserId",
"Gs2Money2:Withdraw",
"Gs2Money2:WithdrawByUserId",
"Gs2Stamina:ConsumeStamina",
"Gs2Stamina:ConsumeStaminaByUserId",
"Gs2Stamina:RecoverStaminaByUserId",
}
バフを適用するアクションの種類
targetFieldNamestring
~ 64文字バフの適用対象フィールド名
バフによって値が変更される対象アクション上の数値パラメータ名です。例えば、入手数、消費量、報酬数量などを表すパラメータが対象となります。
conditionGrnsList<EzBuffTargetGrn>
1 ~ 10 itemsバフの適用条件GRNのリスト
バフ適用の対象リソースインスタンスを特定する GRN パターンのリストです。複数の GRN を組み合わせて、リソースを正確に特定する複合条件を形成します。
ratefloat
0 ~ 1000000レート
適用されるバフ値です。適用タイプにより意味が異なります。「Rate Add」の場合は基本レートに加算、「Mul」の場合は現在のレートに乗算、「Value Add」の場合はレート計算後のパラメータ値に直接加算されます。

EzBuffTargetGrn

バフを適用するリソースのGRNパターン

バフを適用する対象のリソースインスタンスを特定するための、プレースホルダーを含む GRN テンプレートです。モデル名で GS2 サービスモデルを特定し、GRN パターンにはランタイムで解決されるコンテキスト変数(例:region、ownerId、namespaceName)が含まれます。

有効化条件必須デフォルト値の制限説明
targetModelNamestring
~ 64文字バフの適用条件のモデル名
条件GRNを解決するために使用される GS2 サービスモデルの名前です。GRN パターンがどのサービスのリソースモデルを参照するかを特定します。
targetGrnstring
~ 1024文字バフの適用条件GRN
ランタイムで解決されるコンテキストプレースホルダー(例:{region}、{ownerId})を含む GRN テンプレートです。バフの対象となる特定のリソースインスタンスを特定するために使用されます。

メソッド

getBuffEntryModel

名前を指定してバフ定義を取得する

名前を指定して、バフエントリーモデルを1件取得します。
取得できる情報には、適用方法(Rate Add / Mul / Value Add)、バフの対象、
優先度、および設定されている場合はバフが有効になるイベント期間が含まれます。

特定のバフの効果内容や有効期間などの詳細を表示する際に使います。

Request

有効化条件必須デフォルト値の制限説明
namespaceNamestring
~ 128文字ネームスペース名
ネームスペース固有の名前。英数字および -(ハイフン) _(アンダースコア) .(ピリオド)で指定します。
buffEntryNamestring
~ 128文字バフエントリーモデル名
バフエントリーモデル固有の名前。英数字および -(ハイフン) _(アンダースコア) .(ピリオド)で指定します。

Result

説明
itemEzBuffEntryModelバフエントリーモデル

実装例

    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    ).BuffEntryModel(
        buffEntryName: "character-level"
    );
    var item = await domain.ModelAsync();
    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    ).BuffEntryModel(
        buffEntryName: "character-level"
    );
    var future = domain.ModelFuture();
    yield return future;
    var item = future.Result;
    const auto Domain = Gs2->Buff->Namespace(
        "namespace-0001" // namespaceName
    )->BuffEntryModel(
        "character-level" // buffEntryName
    );
    const auto Future = Domain->Model();
    Future->StartSynchronousTask();
    if (Future->GetTask().IsError())
    {
        return false;
    }
値の変更イベントハンドリング
    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    ).BuffEntryModel(
        buffEntryName: "character-level"
    );
    
    // イベントハンドリングを開始
    var callbackId = domain.Subscribe(
        value => {
            // 値が変化した時に呼び出される
            // value には変更後の値が渡ってくる
        }
    );

    // イベントハンドリングを停止
    domain.Unsubscribe(callbackId);
    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    ).BuffEntryModel(
        buffEntryName: "character-level"
    );
    
    // イベントハンドリングを開始
    var callbackId = domain.Subscribe(
        value => {
            // 値が変化した時に呼び出される
            // value には変更後の値が渡ってくる
        }
    );

    // イベントハンドリングを停止
    domain.Unsubscribe(callbackId);
    const auto Domain = Gs2->Buff->Namespace(
        "namespace-0001" // namespaceName
    )->BuffEntryModel(
        "character-level" // buffEntryName
    );
    
    // イベントハンドリングを開始
    const auto CallbackId = Domain->Subscribe(
        [](TSharedPtr<Gs2::Buff::Model::FBuffEntryModel> value) {
            // 値が変化した時に呼び出される
            // value には変更後の値が渡ってくる
        }
    );

    // イベントハンドリングを停止
    Domain->Unsubscribe(CallbackId);

listBuffEntryModels

バフ定義の一覧を取得する

このネームスペースに登録されているすべてのバフエントリーモデルを取得します。
各バフエントリーモデルは、1つのバフ効果を定義しています。
対象(モデルのステータスやアクションのパラメータ)、適用方法(Rate Add / Mul / Value Add)、優先度、
そしてオプションでバフが有効になるイベント期間が含まれます。

ゲームUIでバフの一覧を表示したり、現在設定されているバフを確認する際に使います。

Request

有効化条件必須デフォルト値の制限説明
namespaceNamestring
~ 128文字ネームスペース名
ネームスペース固有の名前。英数字および -(ハイフン) _(アンダースコア) .(ピリオド)で指定します。

Result

説明
itemsList<EzBuffEntryModel>バフエントリーモデルのリスト

実装例

    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    );
    var items = await domain.BuffEntryModelsAsync(
    ).ToListAsync();
    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    );
    var it = domain.BuffEntryModels(
    );
    List<EzBuffEntryModel> items = new List<EzBuffEntryModel>();
    while (it.HasNext())
    {
        yield return it.Next();
        if (it.Error != null)
        {
            onError.Invoke(it.Error, null);
            break;
        }
        if (it.Current != null)
        {
            items.Add(it.Current);
        }
        else
        {
            break;
        }
    }
    const auto Domain = Gs2->Buff->Namespace(
        "namespace-0001" // namespaceName
    );
    const auto It = Domain->BuffEntryModels(
    );
    TArray<Gs2::UE5::Buff::Model::FEzBuffEntryModelPtr> Result;
    for (auto Item : *It)
    {
        if (Item.IsError())
        {
            return false;
        }
        Result.Add(Item.Current());
    }
値の変更イベントハンドリング
    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    );
    
    // イベントハンドリングを開始
    var callbackId = domain.SubscribeBuffEntryModels(
        () => {
            // リストの要素が変化した時に呼び出される
        }
    );

    // イベントハンドリングを停止
    domain.UnsubscribeBuffEntryModels(callbackId);
    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    );
    
    // イベントハンドリングを開始
    var callbackId = domain.SubscribeBuffEntryModels(
        () => {
            // リストの要素が変化した時に呼び出される
        }
    );

    // イベントハンドリングを停止
    domain.UnsubscribeBuffEntryModels(callbackId);
    const auto Domain = Gs2->Buff->Namespace(
        "namespace-0001" // namespaceName
    );
    
    // イベントハンドリングを開始
    const auto CallbackId = Domain->SubscribeBuffEntryModels(
        []() {
            // リストの要素が変化した時に呼び出される
        }
    );

    // イベントハンドリングを停止
    Domain->UnsubscribeBuffEntryModels(CallbackId);

applyBuff

プレイヤーにバフを適用する

このネームスペースに登録されたすべてのバフ設定を評価し、条件に合うものをプレイヤーに適用します。
たとえば「イベント中は経験値2倍」「特定アイテム所持時にゴールドドロップ率+10%」といったバフを設定できます。

バフの適用方法は3種類あります:

  • Rate Add: 倍率に加算する(例: 基本 1.0 + 0.2 = 1.2倍)
  • Mul: 現在の倍率に乗算する(例: 倍率 × 0.5)
  • Value Add: 倍率計算後の値に固定値を加算する

GS2-Schedule のイベントに紐づけたバフは、そのイベント開催中のみ有効になります。
複数のバフは優先度順に適用されます(値が小さいほど優先)。

Request

有効化条件必須デフォルト値の制限説明
namespaceNamestring
~ 128文字ネームスペース名
ネームスペース固有の名前。英数字および -(ハイフン) _(アンダースコア) .(ピリオド)で指定します。
gameSessionGameSession
GameSession

Result

説明
itemsList<EzBuffEntryModel>適用したバフのリスト
newContextStackstringバフの適用状況を記録したコンテキスト

実装例

    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    ).Me(
        gameSession: GameSession
    ).Buff(
    );
    var result = await domain.ApplyBuffAsync(
    );
    var item = await result.ModelAsync();
    var domain = gs2.Buff.Namespace(
        namespaceName: "namespace-0001"
    ).Me(
        gameSession: GameSession
    ).Buff(
    );
    var future = domain.ApplyBuffFuture(
    );
    yield return future;
    if (future.Error != null)
    {
        onError.Invoke(future.Error, null);
        yield break;
    }
    var future2 = future.Result.ModelFuture();
    yield return future2;
    if (future2.Error != null)
    {
        onError.Invoke(future2.Error, null);
        yield break;
    }
    var result = future2.Result;
    const auto Domain = Gs2->Buff->Namespace(
        "namespace-0001" // namespaceName
    )->Me(
        GameSession
    )->Buff(
    );
    const auto Future = Domain->ApplyBuff(
    );
    Future->StartSynchronousTask();
    if (Future->GetTask().IsError())
    {
        return false;
    }

    // obtain changed values / result values
    const auto Future2 = Future->GetTask().Result()->Model();
    Future2->StartSynchronousTask();
    if (Future2->GetTask().IsError())
    {
        return Future2->GetTask().Error();
    }
    const auto Result = Future2->GetTask().Result();