এই নির্দেশিকাটি বর্ণনা করে কিভাবে অবাস্তব ইঞ্জিন ব্যবহার করে আপনার অ্যাপে ইন-অ্যাপ আপডেট সমর্থন করতে হয়। যে ক্ষেত্রে আপনার বাস্তবায়ন কোটলিন প্রোগ্রামিং ভাষা বা জাভা প্রোগ্রামিং ভাষা ব্যবহার করে, এবং যেখানে আপনার বাস্তবায়ন নেটিভ কোড (C/C++) বা ইউনিটি ব্যবহার করে তার জন্য আলাদা নির্দেশিকা রয়েছে।
অবাস্তব ইঞ্জিন SDK ওভারভিউ
প্লে ইন-অ্যাপ আপডেট API হল Play Core SDK পরিবারের অংশ। অবাস্তব ইঞ্জিনের জন্য API আপনার অ্যাপ এবং প্লে API-এর মধ্যে যোগাযোগ পরিচালনা করতে একটি UInAppUpdatesManager
ক্লাস অফার করে। একটি অনুরোধ করার পরে, আপনার অ্যাপটি EAppUpdateErrorCode
ব্যবহার করে অনুরোধের স্থিতি পরীক্ষা করতে পারে।
অবাস্তব ইঞ্জিন সংস্করণ সমর্থিত
প্লাগইনটি অবাস্তব ইঞ্জিন 5.0 এবং পরবর্তী সমস্ত সংস্করণ সমর্থন করে।
আপনার উন্নয়ন পরিবেশ সেট আপ করুন
সেটআপ
GitHub সংগ্রহস্থল থেকে Play Unreal Engine Plugin ডাউনলোড করুন।
আপনার অবাস্তব ইঞ্জিন প্রকল্পে আপনার
Plugins
ফোল্ডারের মধ্যেGooglePlay
ফোল্ডারটি অনুলিপি করুন।আপনার অবাস্তব ইঞ্জিন প্রকল্প খুলুন এবং সম্পাদনা → প্লাগইন ক্লিক করুন।
Google Play-এর জন্য অনুসন্ধান করুন এবং সক্রিয় চেকবক্সটি চেক করুন।
গেম প্রজেক্ট রিস্টার্ট করুন এবং একটি বিল্ড ট্রিগার করুন।
আপনার প্রকল্পের
Build.cs
ফাইল খুলুন এবংPublicDependencyModuleNames
এPlayInAppUpdates
মডিউল যোগ করুন:using UnrealBuildTool; public class MyGame : ModuleRules { public MyGame(ReadOnlyTargetRules Target) : base(Target) { // ... PublicDependencyModuleNames.Add("PlayInAppUpdates"); // ... } }
আপডেট প্রাপ্যতা জন্য চেক করুন
আপনি একটি আপডেটের অনুরোধ করার আগে, আপনার অ্যাপের জন্য একটি আপডেট উপলব্ধ আছে কিনা তা পরীক্ষা করুন। একটি আপডেট পরীক্ষা করতে UInAppUpdatesManager::RequestInfo
ব্যবহার করুন:
void MyClass::OnRequestInfoOperationCompleted(
EAppUpdateErrorCode ErrorCode,
UAppUpdateInfo* UpdateInfo)
{
// Check the resulting error code.
if (ErrorCode == EAppUpdateErrorCode::AppUpdate_NO_ERROR)
{
// Check AppUpdateInfo's UpdateAvailability, UpdatePriority,
// IsUpdateTypeAllowed(), ... and decide whether to ask the user
// to start an in-app update.
}
}
void MyClass::CheckForUpdateAvailability()
{
// Create a delegate to bind the callback function.
FRequestInfoOperationCompletedDelegate Delegate;
// Bind the completion handler (OnRequestInfoOperationCompleted) to the delegate.
Delegate.BindDynamic(this, &MyClass::OnRequestInfoOperationCompleted);
// Initiate the request info operation, passing the delegate to handle the result.
GetGameInstance()
->GetSubsystem<UInAppUpdatesManager>()
->RequestInfo(Delegate);
}
ফিরে আসা UAppUpdateInfo
উদাহরণে আপডেট উপলব্ধতার স্থিতি রয়েছে। যদি একটি ইন-অ্যাপ আপডেট ইতিমধ্যেই প্রগতিতে থাকে, তাহলে ইনস্ট্যান্সটি ইন-প্রোগ্রেস আপডেটের অবস্থাও রিপোর্ট করে।
আপডেট অচলতা পরীক্ষা করুন
একটি আপডেট উপলব্ধ কিনা তা পরীক্ষা করার পাশাপাশি, আপনি প্লে স্টোরের মাধ্যমে ব্যবহারকারীকে সর্বশেষ আপডেটের বিষয়ে জানানোর পর থেকে কত সময় অতিবাহিত হয়েছে তাও পরীক্ষা করতে চাইতে পারেন। এটি আপনাকে সিদ্ধান্ত নিতে সাহায্য করতে পারে যে আপনি একটি নমনীয় আপডেট বা অবিলম্বে আপডেট শুরু করবেন কিনা। উদাহরণস্বরূপ, আপনি একটি নমনীয় আপডেটের সাথে ব্যবহারকারীকে অবহিত করার আগে কয়েক দিন অপেক্ষা করতে পারেন, এবং তার কয়েকদিন পরে একটি তাত্ক্ষণিক আপডেটের প্রয়োজন হওয়ার আগে।
প্লে স্টোরের মাধ্যমে আপডেটটি উপলব্ধ হওয়ার পর থেকে কত দিনের সংখ্যা পরীক্ষা করতে UAppUpdateInfo:GetClientVersionStalenessDays
ব্যবহার করুন:
int32 ClientVersionStalenessDays = UpdateInfo->GetClientVersionStalenessDays();
আপডেট অগ্রাধিকার চেক করুন
Google Play Developer API আপনাকে প্রতিটি আপডেটের অগ্রাধিকার সেট করতে দেয়। এটি আপনার অ্যাপটিকে কতটা দৃঢ়ভাবে ব্যবহারকারীকে একটি আপডেটের সুপারিশ করতে হবে তা সিদ্ধান্ত নিতে দেয়৷ উদাহরণস্বরূপ, আপডেট অগ্রাধিকার সেট করার জন্য নিম্নলিখিত কৌশল বিবেচনা করুন:
- ক্ষুদ্র UI উন্নতি: নিম্ন-অগ্রাধিকার আপডেট; একটি নমনীয় আপডেট বা একটি অবিলম্বে আপডেট না অনুরোধ.
- কর্মক্ষমতা উন্নতি: মাঝারি অগ্রাধিকার আপডেট; একটি নমনীয় আপডেটের জন্য অনুরোধ করুন।
- গুরুতর নিরাপত্তা আপডেট: উচ্চ অগ্রাধিকার আপডেট; একটি অবিলম্বে আপডেট অনুরোধ.
অগ্রাধিকার নির্ধারণ করতে, Google Play 0 এবং 5-এর মধ্যে একটি পূর্ণসংখ্যা মান ব্যবহার করে, যার মধ্যে 0 ডিফল্ট এবং 5 সর্বোচ্চ অগ্রাধিকার। একটি আপডেটের জন্য অগ্রাধিকার সেট করতে, Google Play Developer API-এ Edits.tracks.releases
অধীনে inAppUpdatePriority
ক্ষেত্রটি ব্যবহার করুন৷ রিলিজে সব নতুন-সংযোজিত সংস্করণকে রিলিজের মতোই অগ্রাধিকার হিসেবে বিবেচনা করা হয়। অগ্রাধিকার শুধুমাত্র একটি নতুন রিলিজ রোল আউট করার সময় সেট করা যেতে পারে এবং পরে পরিবর্তন করা যাবে না।
Play Developer API ডকুমেন্টেশনে বর্ণিত Google Play Developer API ব্যবহার করে অগ্রাধিকার সেট করুন। অ্যাপ-মধ্যস্থ আপডেট অগ্রাধিকার Edit.tracks: update
পদ্ধতিতে পাস করা Edit.tracks
সম্পদে উল্লেখ করা উচিত। নিম্নলিখিত উদাহরণটি সংস্করণ কোড 88 এবং inAppUpdatePriority
5 সহ একটি অ্যাপ প্রকাশ করে:
{ "releases": [{ "versionCodes": ["88"], "inAppUpdatePriority": 5, "status": "completed" }] }
আপনার অ্যাপের কোডে, আপনি UAppUpdateInfo::UpdatePriority
ব্যবহার করে প্রদত্ত আপডেটের জন্য অগ্রাধিকার স্তর পরীক্ষা করতে পারেন।
int32 Priority = UpdateInfo->GetPriority();
একটি আপডেট শুরু করুন
আপনি একটি আপডেট উপলব্ধ আছে তা নিশ্চিত করার পরে, আপনি UInAppUpdatesManager::StartUpdate
ব্যবহার করে একটি আপডেটের অনুরোধ করতে পারেন। আপনি একটি আপডেটের অনুরোধ করার আগে, নিশ্চিত করুন যে আপনার কাছে একটি আপ-টু-ডেট UAppUpdateInfo
অবজেক্ট আছে। আপডেট ফ্লো কনফিগার করতে আপনাকে অবশ্যই একটি UAppUpdateOptions
অবজেক্ট তৈরি করতে হবে।
নিম্নলিখিত উদাহরণটি একটি তাত্ক্ষণিক আপডেট প্রবাহের জন্য একটি UAppUpdateOptions
অবজেক্ট তৈরি করে:
// Creates an UAppUpdateOptions defining an immediate in-app
// update flow and its parameters.
UAppUpdateOptions* Options = NewObject<UAppUpdateOptions>();
Options->CreateOptions(EAppUpdateType::AppUpdate_TYPE_IMMEDIATE);
নিম্নলিখিত উদাহরণটি একটি নমনীয় আপডেট প্রবাহের জন্য একটি UAppUpdateOptions
অবজেক্ট তৈরি করে:
// Creates an UAppUpdateOptions defining a flexible in-app
// update flow and its parameters.
UAppUpdateOptions* Options = NewObject<UAppUpdateOptions>();
Options->CreateOptions(EAppUpdateType::AppUpdate_TYPE_FLEXIBLE);
UAppUpdateOptions
অবজেক্টে একটি IsAssetPackDeletionAllowed
ফাংশনও রয়েছে যা সীমিত ডিভাইস স্টোরেজের ক্ষেত্রে অ্যাসেট প্যাকগুলি সাফ করার জন্য আপডেটটি অনুমোদিত কিনা তা প্রদান করে। এই ক্ষেত্রটি ডিফল্টরূপে false
সেট করা আছে, তবে আপনি UAppUpdateOptions::SetAssetPackDeletionAllowed
পরিবর্তে এটিকে true
সেট করার অনুমতি দিয়ে ক্ষেত্র সেট করতে পারেন:
// Sets the AssetPackDeletionAllowed field to true.
Options->SetAssetPackDeletionAllowed(true);
পরবর্তী পদক্ষেপগুলি আপনি একটি নমনীয় আপডেট বা একটি তাত্ক্ষণিক আপডেটের অনুরোধ করছেন কিনা তার উপর নির্ভর করে৷
একটি নমনীয় আপডেট পরিচালনা করুন
আপনার কাছে একটি আপ-টু-ডেট UAppUpdateInfo
অবজেক্ট এবং একটি সঠিকভাবে কনফিগার করা UAppUpdateOptions
অবজেক্ট থাকার পরে, আপনি একটি আপডেট প্রবাহের অনুরোধ করতে UInAppUpdatesManager::StartUpdate
কল করতে পারেন।
void MyClass::OnStartUpdateOperationCompleted(EAppUpdateErrorCode ErrorCode)
{
// ...
}
// .cpp
void MyClass::StartUpdate()
{
// Create a delegate to bind the callback function.
FUpdateOperationCompletedDelegate Delegate;
// Bind the completion handler (OnStartUpdateOperationCompleted) to the delegate.
Delegate.BindDynamic(this, &MyClass::OnStartUpdateOperationCompleted);
// Initiate the start update operation, passing the delegate to handle the result.
GetGameInstance()
->GetSubsystem<UInAppUpdatesManager>()
->StartUpdate(UpdateInfo, UpdateOptions, Delegate);
}
একটি নমনীয় আপডেট প্রবাহের জন্য, ডাউনলোড সফলভাবে শেষ হওয়ার পরে আপনাকে অবশ্যই অ্যাপ আপডেটের ইনস্টলেশন ট্রিগার করতে হবে। এটি করার জন্য, InAppUpdatesManager::CompleteUpdate
কল করুন, নিম্নলিখিত উদাহরণে দেখানো হয়েছে:
void MyClass::OnCompleteUpdateOperationCompleted(EAppUpdateErrorCode ErrorCode)
{
// ...
}
void MyClass::CompleteFlexibleUpdate()
{
// Create a delegate to bind the callback function.
FUpdateOperationCompletedDelegate Delegate;
// Bind the completion handler (OnCompleteUpdateOperationCompleted) to the delegate.
Delegate.BindDynamic(this, &MyClass::OnCompleteUpdateOperationCompleted);
// Initiate the complete update operation, passing the delegate to handle the result.
GetGameInstance()
->GetSubsystem<UInAppUpdatesManager>()
->CompleteUpdate(UpdateInfo, UpdateOptions, Delegate);
}
একটি অবিলম্বে আপডেট হ্যান্ডেল
আপনার কাছে একটি আপ-টু-ডেট UAppUpdateInfo
অবজেক্ট এবং একটি সঠিকভাবে কনফিগার করা UAppUpdateOptions
অবজেক্ট থাকার পরে, আপনি একটি আপডেট প্রবাহের অনুরোধ করতে InAppUpdatesManager::StartUpdate
কল করতে পারেন।
void MyClass::OnStartUpdateOperationCompleted(EAppUpdateErrorCode ErrorCode)
{
// ...
}
void MyClass::StartUpdate()
{
// Create a delegate to bind the callback function.
FUpdateOperationCompletedDelegate Delegate;
// Bind the completion handler (OnStartUpdateOperationCompleted) to the delegate.
Delegate.BindDynamic(this, &MyClass::OnStartUpdateOperationCompleted);
// Initiate the start update operation, passing the delegate to handle the result.
GetGameInstance()
->GetSubsystem<UInAppUpdatesManager>()
->StartUpdate(UpdateInfo, UpdateOptions, Delegate);
}
একটি অবিলম্বে আপডেট প্রবাহের জন্য, Google Play একটি ব্যবহারকারী নিশ্চিতকরণ ডায়ালগ প্রদর্শন করে৷ ব্যবহারকারী অনুরোধটি গ্রহণ করলে, Google Play স্বয়ংক্রিয়ভাবে আপডেটটি ডাউনলোড করে এবং ইনস্টল করে, তারপর ইনস্টলেশন সফল হলে অ্যাপটিকে আপডেট করা সংস্করণে পুনরায় চালু করে।
ত্রুটি হ্যান্ডলিং
এই বিভাগটি সাধারণ ত্রুটির সমাধান বর্ণনা করে।
- যদি
UInAppUpdatesManager::StartUpdate
একটিAppUpdate_INVALID_REQUEST
ত্রুটি প্রদান করে, তাহলে এর মানে হলUAppUpdateInfo
অবৈধ৷ নিশ্চিত করুন যেUAppUpdateInfo
অবজেক্টটিUInAppUpdatesManager::RequestInfo
আপডেট প্রবাহ শুরু করার আগে শূন্য নয়। - যদি
UInAppUpdatesManager::StartUpdate
AppUpdate_NOT_ALLOWED
ত্রুটি প্রদান করে, তাহলে এর মানে হল যেUAppUpdateOptions
অবজেক্ট একটি আপডেটের ধরন নির্দেশ করে যা উপলব্ধ আপডেটের জন্য অনুমোদিত নয়। আপডেট প্রবাহ শুরু করার আগেUAppUpdateInfo
অবজেক্টটি নির্দেশ করে যে নির্বাচিত আপডেট প্রকারটি অনুমোদিত কিনা তা পরীক্ষা করুন।
পরবর্তী পদক্ষেপ
আপনার ইন্টিগ্রেশন সঠিকভাবে কাজ করছে কিনা তা যাচাই করতে আপনার অ্যাপের ইন-অ্যাপ আপডেট পরীক্ষা করুন ।