इस दस्तावेज़ में, Play की मैनेज की गई इंस्टॉलेशन सुविधा का इस्तेमाल करके, Google Play Games on PC पर गेम पब्लिश करने का तरीका बताया गया है.
Play की मैनेज की गई इंस्टॉलेशन सुविधा की मदद से, Google Play गेम को इंस्टॉल करने, अपडेट करने, और अनइंस्टॉल करने की प्रोसेस को मैनेज करता है. इसके लिए, वह गेम फ़ाइलों और मेटाडेटा का इस्तेमाल करता है. यह मेटाडेटा, Windows ऐप्लिकेशन बंडल (WAB) फ़ाइल में मौजूद होता है.
शुरू करने से पहले
अपने गेम में Google Play Games SDK को इंटिग्रेट करें.
अपने गेम को WAB फ़ाइल के तौर पर पैकेज करना
Play की ओर से मैनेज किए जाने वाले इंस्टॉलेशन की WAB फ़ाइल बनाने के लिए, यह तरीका अपनाएं:
Play पब्लिशिंग टूल डाउनलोड करें. इस टूल को Windows कमांड लाइन या Powershell पर चलाया जा सकता है.
Play पर पब्लिश करने के लिए कॉन्फ़िगरेशन फ़ाइल बनाएं. इसका कोई भी नाम रखा जा सकता है. उदाहरण के लिए,
play_publishing_config.xmlइस फ़ॉर्मैट में:<?xml version="1.0" encoding="UTF-8"?> <play-publishing-config version="1.0"> <!-- Application metadata: This section contains basic information about your game. --> <application> <package-name>PACKAGE_NAME</package-name> <version-name>VERSION_NAME</version-name> </application> <!-- Game files: This section specifies which game files to include in the bundle and how to treat them. --> <game-files> <file-set> <root-folder-path>PATH_TO_ROOT_FOLDER</root-folder-path> <!-- absolute or relative to the parent directory of the config xml --> <!-- Exclusions: A list of files or folders to exclude from the bundle. This is useful for removing development files, temporary data, or redundant assets. --> <exclusions> <file-path>REGEX_PATTERN_OF_EXCLUDED_FILES</file-path> <file-path>PATH_TO_BE_EXCLUDED</file-path> </exclusions> <!-- File attributes: Define special handling for certain files during installation and updates. --> <file-attribute value=FILE_ATTRIBUTE_VALUE> <file-path>PATH_TO_FILE</file-path> <file-path>REGEX_PATTERN_OF_FILE_ATTRIBUTE_FILES</file-path> </file-attribute> </file-set> </game-files> <!-- This file represents the startup process for this game. Google Play Games for PC should start this process when user clicks on "Play" on this game. --> <launch-command> <path>PATH_TO_LAUNCH_FILE</path> <arguments>ARGUMENTS</arguments> </launch-command> <!-- Lifecycle operations: Custom actions to be performed during the game's installation and uninstallation. --> <lifecycle-operations> <!-- Install operations: These actions run when the game is installed. 'requiresElevation="true"' will trigger a UAC prompt for administrator rights. There are three types of install operations that can be specified. An instance of each is listed below. --> <install-operation requiresElevation=INSTALL_OPERATION_REQUIRES_ELEVATION> <operation-identifier>OPERATION_IDENTIFIER_STRING</operation-identifier> <execute-file> <path>PATH_TO_INSTALL_EXECUTE_FILE</path> <arguments>ARGUMENTS</arguments> </execute-file> </install-operation> <install-operation requiresElevation=INSTALL_OPERATION_REQUIRES_ELEVATION> <operation-identifier>OPERATION_IDENTIFIER_STRING</operation-identifier> <update-registry baseKey=BASE_KEY> <sub-key>SUB_KEY_PATH</sub-key> <value-name>VALUE_NAME</value-name> <value type=REGISTRY_VALUE_TYPE>VALUE_TEXT</value> </update-registry> </install-operation> <!-- Uninstall operations: These actions run before the game is uninstalled. --> <uninstall-operation requiresElevation=UNINSTALL_OPERATION_REQUIRES_ELEVATION> <execute-file> <path>PATH_TO_UNINSTALL_EXECUTE_FILE</path> <arguments>ARGUMENTS</arguments> </execute-file> </uninstall-operation> </lifecycle-operations> </play-publishing-config>
इनकी जगह ये डालें:
PACKAGE_NAME: आपके गेम के पैकेज का नाम. यह यूनीक आइडेंटिफ़ायर, Google Play पर आपके गेम से जुड़ा होगा. उदाहरण के लिए,com.yourcompany.yourgame. पैकेज का नाम, इन नियमों के मुताबिक होना चाहिए:- इसमें कम से कम दो सेगमेंट (एक या उससे ज़्यादा बिंदु) होने चाहिए.
- हर सेगमेंट की शुरुआत किसी अक्षर से होनी चाहिए.
- सभी वर्ण, अक्षर और अंक या अंडरस्कोर (
[a-zA-Z0-9_]) होने चाहिए.
VERSION_NAME: गेम के वर्शन की स्ट्रिंग. यह कोई भी स्ट्रिंग हो सकती है. हालांकि, यह आपके गेम के लिए अपलोड किए गए सभी WAB में यूनीक होनी चाहिए. उदाहरण के लिए:1.0,1.0.1-beta,2025.11.24,v1.rc1.PATH_TO_ROOT_FOLDER: गेम की फ़ाइलें रखने वाले रूट फ़ोल्डर का पाथ. इस फ़ोल्डर में मौजूद सभी फ़ाइलों को बंडल में जोड़ा जाता है. हालांकि, इसमें वे फ़ाइलें शामिल नहीं होती हैं जिन्हें बाहर रखा गया है. यह पाथ,play_publishing_config.xmlफ़ाइल वाली डायरेक्ट्री के हिसाब से ऐब्सलूट या रिलेटिव हो सकता है.exclusions: (ज़रूरी नहीं)PATH_TO_ROOT_FOLDERमें मौजूद फ़ाइलों के लिए फ़ाइल पाथ या पैटर्न तय करता है, ताकि उन्हें बंडल से हटाया जा सके.exclusionsएलिमेंट में एक से ज़्यादाfile-pathएलिमेंट शामिल किए जा सकते हैं. पाथ को इन दो तरीकों में से किसी एक तरीके से दिखाया जा सकता है:- फ़ाइल पाथ के तौर पर: वह फ़ाइल पाथ जिसे स्कैन से बाहर रखना है.
- रेगुलर एक्सप्रेशन स्ट्रिंग के तौर पर: रेगुलर एक्सप्रेशन स्ट्रिंग से मैच करने वाली सभी फ़ाइलों को बंडल से बाहर रखा जाता है. RE2 सिंटैक्स का इस्तेमाल करें.
file-attribute: (ज़रूरी नहीं) यह किसी खास फ़ाइल या रेगुलर एक्सप्रेशन पैटर्न से मेल खाने वाली फ़ाइलों के लिए एट्रिब्यूट तय करता है.FILE_ATTRIBUTE_VALUE: इनमें से कोई एक स्थिति हो सकती है:SKIP_UPDATE: अपडेट के दौरान, यह एट्रिब्यूट सिस्टम को बताता है कि फ़ाइल को सिर्फ़ तब कॉपी किया जाए, जब वह पहले से मौजूद न हो. इससे मौजूदा फ़ाइल में किए गए बदलाव सुरक्षित रहते हैं.MODIFIED_ON_DEVICE: इसका इस्तेमाल उन फ़ाइलों के लिए करें जिन्हें अपडेट करना ज़रूरी है. हालांकि, इंस्टॉल करने के बाद डिवाइस पर उनमें बदलाव किया जा सकता है. अपडेट के दौरान, सिस्टम पूरी नई फ़ाइल डाउनलोड करता है और इंस्टॉल किए गए वर्शन को बदल देता है. अगर इंस्टॉलेशन की इंटिग्रिटी की जांच के दौरान, यह फ़ाइल इंस्टॉल किए गए वर्शन से अलग होती है, तो इंस्टॉलेशन को खराब नहीं माना जाता.
file-path: इस एट्रिब्यूट के लिए फ़ाइलों की पहचान करता है. हरfile-attributeएलिमेंट में एक से ज़्यादाfile-pathएलिमेंट शामिल किए जा सकते हैं. हर पाथ को इन दो तरीकों में से किसी एक तरीके से दिखाया जा सकता है:- फ़ाइल पाथ के तौर पर: इस एट्रिब्यूट को जिस फ़ाइल से जोड़ना है उसका पाथ.
- रेगुलर एक्सप्रेशन स्ट्रिंग के तौर पर: रेगुलर एक्सप्रेशन स्ट्रिंग से मेल खाने वाली सभी फ़ाइलें, एट्रिब्यूट वैल्यू से जुड़ी होती हैं. RE2 सिंटैक्स का इस्तेमाल करें.
PATH_TO_LAUNCH_FILE: गेम लॉन्च करने के लिए इस्तेमाल की जाने वाली एक्ज़ीक्यूटेबल फ़ाइल का पाथ.ARGUMENTS: (ज़रूरी नहीं) कमांड-लाइन आर्ग्युमेंट.<arguments>एलिमेंट का इस्तेमाल,<launch-command>,<install-operation>या<uninstall-operation>में बताई गई एक्ज़ीक्यूटेबल फ़ाइल को आर्ग्युमेंट पास करने के लिए किया जाता है.<arguments>एलिमेंट का हर इस्तेमाल, सिर्फ़ उस एक्ज़ीक्यूटेबल पर लागू होता है जिसके साथ इसे तय किया गया है. इससे, अलग-अलग एक्ज़ीक्यूटेबल के लिए अलग-अलग आर्ग्युमेंट तय किए जा सकते हैं.- अगर किसी एक्ज़ीक्यूटेबल में एक से ज़्यादा आर्ग्युमेंट हैं, तो उन्हें स्पेस से अलग करें.
- अगर एक्ज़ीक्यूटेबल के लिए इसकी ज़रूरत है, तो आर्ग्युमेंट से पहले
--या-जोड़ें. उदाहरण:<arguments>--package_name --version_name</arguments>
lifecycle-operations: (ज़रूरी नहीं) गेम इंस्टॉल या अनइंस्टॉल करने के दौरान की जाने वाली कस्टम कार्रवाइयां.install-operation: गेम इंस्टॉल होने पर चलाने के लिए कोई कार्रवाई. दो तरह के इंस्टॉलेशन ऑपरेशन तय किए जा सकते हैं:execute-fileऔरupdate-registry.uninstall-operation: गेम को अनइंस्टॉल करने से पहले की जाने वाली कार्रवाई. अनइंस्टॉल करने के दौरान,update-registryकार्रवाइयां अपने-आप पहले जैसी हो जाती हैं.INSTALL_OPERATION_REQUIRES_ELEVATION: इससे पता चलता है कि इंस्टॉल करने की प्रोसेस को एडमिन के अधिकारों के साथ चलाना है या नहीं.- "true": एडमिन के तौर पर चलाएं.
- "false": इसे मौजूदा उपयोगकर्ता के तौर पर चलाएं. अगर इस विकल्प को नहीं चुना जाता है, तो यह डिफ़ॉल्ट रूप से लागू होता है.
UNINSTALL_OPERATION_REQUIRES_ELEVATION: इससे पता चलता है कि अनइंस्टॉल करने की प्रोसेस को एडमिन के अधिकारों के साथ चलाना है या नहीं.- "true": एडमिन के तौर पर चलाएं.
- "false": इसे मौजूदा उपयोगकर्ता के तौर पर चलाएं. अगर इस विकल्प को नहीं चुना जाता है, तो यह डिफ़ॉल्ट रूप से लागू होता है.
operation-identifier:install-operationकी पहचान करने के लिए यूनीक स्ट्रिंग.execute-file: इस फ़ंक्शन का इस्तेमाल, फ़ाइल रन करने के लिए निर्देश देने वाली फ़ाइल को चलाने के लिए किया जाता है.PATH_TO_INSTALL_EXECUTE_FILE: इंस्टॉलेशन के दौरान चलाने के लिए, एक्ज़ीक्यूटेबल का पाथ.PATH_TO_UNINSTALL_EXECUTE_FILE: अनइंस्टॉल करने से पहले चलाने के लिए, एक्ज़ीक्यूटेबल का पाथ.
update-registry: यह Windows रजिस्ट्री एंट्री बनाता है या उसे अपडेट करता है.BASE_KEY: Windows रजिस्ट्री में इस्तेमाल की जाने वाली रूट कुंजी के बारे में बताता है. स्वीकार की गई वैल्यू:HKEY_CLASSES_ROOT,HKEY_CURRENT_CONFIG,HKEY_CURRENT_USER,HKEY_LOCAL_MACHINE,HKEY_PERFORMANCE_DATA, औरHKEY_USERS.update-registryऑपरेशन करते समय, इस्तेमाल किए गएbaseKeyके आधार पर, पैरंटinstall-operationपरrequiresElevation="true"सेट करें:HKEY_LOCAL_MACHINEयाHKEY_CURRENT_CONFIG:requiresElevation="true"को सेट करें.HKEY_CURRENT_USER:requiresElevation="true"की ज़रूरत नहीं है.HKEY_CLASSES_ROOT:requiresElevation="true"को सिर्फ़ तब सेट करें, जब मशीन-वाइड सेक्शन में लिखा जा रहा हो. उपयोगकर्ता के हिसाब से सेक्शन के लिए इसकी ज़रूरत नहीं होती.HKEY_USERS: इसमें सभी उपयोगकर्ताओं की प्रोफ़ाइलें होती हैं. मौजूदा उपयोगकर्ता के अलावा, अन्य उपयोगकर्ताओं की प्रोफ़ाइलों में बदलाव करते समयrequiresElevation="true"सेट करें (जैसे, अन्य उपयोगकर्ता या.DEFAULT).
SUB_KEY_PATH: यह Windows Registry में मौजूद किसी खास कुंजी का पाथ दिखाता है. यह मुख्यbaseKeyके तहत नेस्ट की गई होती है.VALUE_NAME: इससे उस डेटा एंट्री का नाम पता चलता है जिसमें आपको तय की गई सब-की के अंदर बदलाव करना है.REGISTRY_VALUE_TYPE: यह एट्रिब्यूट, रजिस्ट्री में लिखी जा रही वैल्यू के डेटा टाइप के बारे में बताता है.STRINGको स्ट्रिंग के लिए याDWORDको 32-बिट नंबर के लिए वैल्यू के तौर पर इस्तेमाल किया जा सकता है.VALUE_TEXT: रजिस्ट्री की में सेव किया जाने वाला डेटा.
रेगुलर एक्सप्रेशन इस्तेमाल करने का तरीका
फ़ाइलों के किसी ग्रुप पर, फ़ाइल एट्रिब्यूट लागू करने या उन्हें बाहर रखने के लिए,
file-pathटैग में RE2 सिंटैक्स रेगुलर एक्सप्रेशन का इस्तेमाल किया जा सकता है. ध्यान रखें कि डायरेक्ट्री सेपरेटर के लिए, फ़ॉरवर्ड स्लैश/का इस्तेमाल करें. साथ ही, रेगुलर एक्सप्रेशन के खास वर्णों को एस्केप करने के लिए, बैकस्लैश\का इस्तेमाल करें. उदाहरण के लिए, लिटरल डॉट.से मैच करने के लिए\.का इस्तेमाल करें या किसी अंक से मैच करने के लिए\dका इस्तेमाल करें.यहां कुछ सामान्य उदाहरण दिए गए हैं:
- किसी भी डायरेक्ट्री में, किसी खास एक्सटेंशन (उदाहरण के लिए, .log) वाली सभी फ़ाइलों से मेल खाना
.*\.logका इस्तेमाल करके,.logपर खत्म होने वाले किसी भी पाथ से मेल खाएं. जैसे,game.logयाlogs/errors.log.<file-path>.*\.log</file-path>
- किसी फ़ोल्डर (उदाहरण के लिए, 'temp') में मौजूद सभी फ़ाइलों और सबडायरेक्ट्री से मेल खाना
temp/.*का इस्तेमाल करके,temp/से शुरू होने वाले सभी पाथ से मैच करें. जैसे,temp/data.txtयाtemp/saves/file.sav.<file-path>temp/.*</file-path>
- किसी फ़ोल्डर में मौजूद, पैटर्न से मेल खाने वाली फ़ाइलों का पता लगाना
assets/level1.datऔरassets/level2.datसे मेल खाने के लिएassets/level\d\.datका इस्तेमाल करें, लेकिनassets/other.datसे मेल खाने के लिए नहीं.<file-path>assets/level\d\.dat</file-path>
- पाथ में कहीं भी दिखने वाले फ़ोल्डर के नाम से मेल खाना
.*/cache/.*का इस्तेमाल करके,cacheनाम वाली किसी भी डायरेक्ट्री में मौजूद फ़ाइलों से मैच किया जा सकता है. जैसे,game/cache/file.txtयाtemp/cache/other.log.<file-path>.*/cache/.*</file-path>
- कई एक्सटेंशन वाली फ़ाइलों का मिलान करना (उदाहरण के लिए, .ini, .cfg, .sav)
.ini,.cfgया.savसे खत्म होने वाली किसी भी फ़ाइल से मैच करने के लिए,.*\.(ini|cfg|sav)का इस्तेमाल करें. जैसे,settings.ini,config.cfgयाsaves/slot1.sav.<file-path>.*\.(ini|cfg|sav)</file-path>
- किसी खास डायरेक्ट्री में, किसी खास एक्सटेंशन वाली फ़ाइलों से मेल खाना (उदाहरण के लिए, music/ या sfx/ में .ogg)
(music|sfx)/.*\.oggका इस्तेमाल करके,.oggफ़ाइलों से मिलान करें. ये फ़ाइलें,music/याsfx/डायरेक्ट्री में मौजूद होनी चाहिए, लेकिन किसी दूसरी डायरेक्ट्री में नहीं.music/level1.oggयाsfx/explosion.oggसे मेल खाता है, लेकिनvoice/intro.oggसे नहीं.<file-path>(music|sfx)/.*\.ogg</file-path>
Play पर पब्लिश करने की कॉन्फ़िगरेशन फ़ाइल का उदाहरण
यहां
TestGameनाम के गेम के लिएplay_publishing_config.xmlका एक उदाहरण दिया गया है:<?xml version="1.0" encoding="UTF-8"?> <play-publishing-config version="1.0"> <application> <package-name>com.test.package</package-name> <version-name>1.0</version-name> </application> <game-files> <file-set> <root-folder-path>C:\Users\Username\game-files</root-folder-path> <exclusions> <file-path>mock_game\d\.exe</file-path> <!-- exclude files using a regex --> <file-path>deprecated_graphics</file-path> <!-- exclude a folder --> <file-path>.*\.log</file-path> <!-- recursively exclude all files with .log extension --> </exclusions> <file-attribute value="SKIP_UPDATE"> <file-path>settings.ini</file-path> </file-attribute> <file-attribute value="MODIFIED_ON_DEVICE"> <file-path>game_assets\d\.zip</file-path> <!-- define the path using regex --> </file-attribute> </file-set> </game-files> <launch-command> <path>launcher_test_game.exe</path> <arguments>--launch-arg</arguments> <!-- optional --> </launch-command> <lifecycle-operations> <install-operation requiresElevation="true"> <operation-identifier>elevated-execute-file</operation-identifier> <execute-file> <path>install_file.exe</path> <arguments>--arg</arguments> <!-- optional --> </execute-file> </install-operation> <install-operation requiresElevation="true"> <operation-identifier>elevated-update-registry</operation-identifier> <update-registry baseKey="HKEY_LOCAL_MACHINE"> <sub-key>SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\TestGame</sub-key> <value-name>InstallLocation</value-name> <value type="STRING">C:\Program Files\TestGame</value> </update-registry> </install-operation> <uninstall-operation requiresElevation="true"> <execute-file> <path>uninstall.exe</path> <arguments>--test-arg</arguments> <!-- optional --> </execute-file> </uninstall-operation> </lifecycle-operations> </play-publishing-config>
Windows कमांड लाइन या Powershell पर, Play पब्लिशिंग टूल को
build-bundleकमांड का इस्तेमाल करके चलाएं:playpublishingtool.exe build-bundle --input=PLAY_PUBLISHING_CONFIG_PATH --output=WAB_OUTPUT_PATH
अगर आपको एक ही नाम वाली किसी मौजूदा WAB फ़ाइल को बदलना है, तो
--forceआर्ग्युमेंट का इस्तेमाल करें.playpublishingtool.exe build-bundle --input=PLAY_PUBLISHING_CONFIG_PATH --output=WAB_OUTPUT_PATH --force
इनकी जगह ये डालें:
PLAY_PUBLISHING_CONFIG_PATH: Play में पब्लिश करने के कॉन्फ़िगरेशन का पाथ. उदाहरण के लिए,path\to\play_publishing_config.xml.WAB_OUTPUT_PATH: WAB फ़ाइल का पाथ. उदाहरण के लिए,path\to\output_bundle.wab.
Play पब्लिशिंग टूल इस्तेमाल करने का तरीका
अगर आपके पास
playpublishingtool.exe,play_publishing_config.xml, और मौजूदा वर्किंग डायरेक्ट्री मेंgame_files/में मौजूद गेम फ़ाइलें हैं, तो:.\ ├── game_files/ ├── play_publishing_config.xml ├── playpublishingtool.exe
उसी डायरेक्ट्री में
pmi_bundle.wabबनाने के लिए, यह कमांड चलाएं:playpublishingtool.exe build-bundle --input=play_publishing_config.xml --output=pmi_bundle.wab
टूल के बंडल बनाने के दौरान, आपको टर्मिनल पर एक प्रोग्रेस बार दिखेगा:
Building bundle: [==== ] 40%
सफल होने पर, आपको इससे मिलता-जुलता आउटपुट दिखेगा:
Building bundle: [===========] 100% Successfully built the managed install bundle at pmi_bundle.wab
WAB फ़ाइल को इस फ़ोल्डर में ढूंढें:
.\ ├── game_files/ ├── pmi_bundle.wab ├── play_publishing_config.xml ├── playpublishingtool.exe