कोरोना एसडीके में गेम डेटा कैसे लोड करें और सहेजें

गेम डेटा और सेटिंग्स स्टोर करने के लिए SQLite का उपयोग कैसे करें

एक बात लगभग हर ऐप और गेम में आम है, डेटा को स्टोर और पुनर्प्राप्त करने की आवश्यकता है। यहां तक ​​कि सबसे सरल गेम ऐप संस्करण संख्या को सहेजने के लिए SQLite का उपयोग कर सकता है, जिसका उपयोग अपग्रेड करने पर संगतता सुनिश्चित करने के लिए किया जा सकता है, या गेम की ध्वनि को चालू या बंद करने जैसी सरल सेटिंग्स।

यदि आपने कभी डेटाबेस के साथ अधिक काम नहीं किया है या कोरोना एसडीके में डेटाबेस सुविधाओं का उपयोग नहीं किया है, तो चिंता न करें। यह वास्तव में एक अपेक्षाकृत सीधी प्रक्रिया है जो लूए की शक्ति और कोरोना एसडीके में उपयोग किए गए SQLite डेटाबेस इंजन के लिए धन्यवाद। यह ट्यूटोरियल एक सेटिंग टेबल बनाने और दोनों से जानकारी संग्रहीत करने और पुनर्प्राप्त करने की प्रक्रिया के माध्यम से चलता है। आईपैड ऐप्स कैसे विकसित करें।

यह भी ध्यान रखें कि यह तकनीक उपयोगकर्ता-आधारित सेटिंग्स को संग्रहीत करने से परे जा सकती है। उदाहरण के लिए, यदि आपके पास ऐसा गेम है जिसे "गेम" मोड और "आर्केड" मोड जैसे विभिन्न गेम मोड का उपयोग करके खेला जा सकता है। वर्तमान सेटिंग्स को स्टोर करने के लिए इस सेटिंग्स तालिका का उपयोग किया जा सकता है। या डेटा का कोई भी अन्य टुकड़ा जिसे आप लगातार बने रहना चाहते हैं भले ही उपयोगकर्ता गेम से बाहर निकल जाए और उसे फिर से चालू कर दे।

चरण एक: डेटाबेस आरंभ करना और सेटिंग्स तालिका बनाना

पहली चीज़ जो हमें करने की ज़रूरत है वह SQLite लाइब्रेरी घोषित करें और हमारे ऐप को बताएं कि डेटाबेस फ़ाइल कहां खोजें। इस कोड को रखने के लिए सबसे अच्छी जगह मुख्य.लुआ फ़ाइल के शीर्ष पर अन्य आवश्यक बयानों के साथ सही है। यदि कोई भी नहीं मिला है तो डेटाबेस फ़ाइल बनाई जाएगी, और हम इसे दस्तावेज़ फ़ोल्डर में संग्रहीत करेंगे ताकि हम इसे पढ़ सकें और इसे लिख सकें।

"sqlite3" की आवश्यकता है
स्थानीय data_path = system.pathForFile ("data.db", system.DocumentsDirectory);
db = sqlite3.open (data_path);

ध्यान दें कि कैसे "डीबी" चर स्थानीयकरण नहीं किया जाता है। हमने यह सुनिश्चित करने के लिए यह किया है कि हम अपने पूरे प्रोजेक्ट में डेटाबेस तक पहुंच सकते हैं। आप सभी डेटाबेस फ़ंक्शंस के लिए एक विशिष्ट .lua फ़ाइल भी बना सकते हैं और डेटाबेस को उस फ़ाइल में स्थानांतरित कर सकते हैं।

इसके बाद, हमें डेटाबेस तालिका बनाने की आवश्यकता है जो हमारी सेटिंग्स को स्टोर करेगा:

स्थानीय sql = "तालिका बनाएं यदि सेटिंग्स को सेट नहीं किया गया है (नाम, मान);"
db: कार्यकारी (एसक्यूएल);

यह कथन हमारी सेटिंग्स तालिका बनाता है। ऐप लोड होने पर हर बार इसे चलाने के लिए ठीक है क्योंकि यदि तालिका पहले से मौजूद है, तो यह कथन कुछ भी नहीं करेगा। आप इस कथन को सही तरीके से नीचे डाल सकते हैं जहां हमने डेटाबेस घोषित किया है या उस फ़ंक्शन में जो आपके ऐप को चलाने के लिए सेट करता है। मुख्य आवश्यकता है (1) ऐप लॉन्च होने पर हर वक्त उन बयानों को निष्पादित करने के लिए और (2) सेटिंग्स को लोड या सहेजने के लिए किसी भी कॉल से पहले इसे निष्पादित करें।

चरण दो: डेटाबेस में सेटिंग्स को सहेजना

फ़ंक्शन सेट सेटिंग (नाम, मान)
sql = "सेटिंग्स से हटाएं जहां नाम = '" .. नाम .. "'";
डीबी: निष्पादन (एसक्यूएल)

sql = "सेटिंग्स में प्रवेश करें (नाम, मूल्य) मूल्य ('" ..नाम .. "'," .. मूल्य .. ");";
डीबी: निष्पादन (एसक्यूएल)
समाप्त

फ़ंक्शन सेटसेटिंगस्ट्रिंग (नाम, मान)
setSetting (नाम, " '" .. मूल्य .. "'");
समाप्त

सेटसेटिंग फ़ंक्शन तालिका में सहेजी गई पिछली सेटिंग्स को हटा देता है और हमारे नए मान को सम्मिलित करता है। यह दोनों पूर्णांक और तारों के साथ काम करेगा, लेकिन स्ट्रिंग को सहेजने के लिए मूल्य के चारों ओर सिंगल कोट्स की आवश्यकता होती है, इसलिए हमने सेटसेटिंग स्ट्रिंग फ़ंक्शन का उपयोग हमारे लिए अतिरिक्त काम करने के लिए किया है।

चरण तीन: डेटाबेस से सेटिंग्स लोड हो रहा है

फ़ंक्शन मिलते हैं (नाम)

स्थानीय एसक्यूएल = "चयन * सेटिंग्स से कहां नाम = '" .. नाम .. "' ';
स्थानीय मूल्य = -1;

डीबी में पंक्ति के लिए: nrows (sql) करते हैं
मूल्य = row.value;
समाप्त

प्रतिलाभ की मात्रा;
समाप्त

फ़ंक्शन getSettingString (नाम)
स्थानीय एसक्यूएल = "चयन * सेटिंग्स से कहां नाम = '" .. नाम .. "' ';
स्थानीय मूल्य = '';

डीबी में पंक्ति के लिए: nrows (sql) करते हैं
मूल्य = row.value;
समाप्त

प्रतिलाभ की मात्रा;
समाप्त

उपर्युक्त के रूप में, हमने कार्यों को दो संस्करणों में तोड़ दिया है: एक पूर्णांक के लिए और एक तार के लिए। हमने ऐसा करने का मुख्य कारण यह है कि यदि डेटाबेस में कोई सेटिंग मौजूद नहीं है तो हम उन्हें विशिष्ट मानों के साथ प्रारंभ कर सकते हैं। GetSetting फ़ंक्शन एक -1 लौटाएगा, जो हमें बताएगा कि सेटिंग सहेजी नहीं गई है। GetSettingString एक खाली स्ट्रिंग वापस कर देगा।

GetSettingString फ़ंक्शन पूरी तरह से वैकल्पिक है। इसके बीच एकमात्र अंतर और सामान्य getSetting फ़ंक्शन डेटाबेस में कुछ भी नहीं मिलने पर वापस किया जाता है।

चरण चार: हमारी सेटिंग्स तालिका का उपयोग करना

अब जब हमारे पास कड़ी मेहनत की गई है, तो हम आसानी से स्थानीय डेटाबेस में सेटिंग लोड और सहेज सकते हैं। उदाहरण के लिए, हम निम्नलिखित कथन के साथ ध्वनि म्यूट कर सकते हैं:

setSetting ( 'ध्वनि', झूठी);

और हम आवाज़ बजाने के लिए वैश्विक फ़ंक्शन में सेटिंग का उपयोग कर सकते हैं:

फ़ंक्शन प्लेसाउंड (साउंडआईडी)
अगर (getSetting ('sound')) तो
ऑडियो.प्ले (साउंडआईडी)
समाप्त
समाप्त

ध्वनि को वापस चालू करने के लिए, हम बस ध्वनि सेटिंग को सत्य पर सेट करते हैं:

setSetting ( 'ध्वनि', true);

इन कार्यों के बारे में अच्छा हिस्सा यह है कि आप सेटिंग्स तालिका में तार या पूर्णांक सहेज सकते हैं और उन्हें आसानी से पुनर्प्राप्त कर सकते हैं। यह आपको अपने उच्च स्कोर को बचाने के लिए किसी खिलाड़ी के नाम को सहेजने से कुछ भी करने की अनुमति देता है।

कोरोना एसडीके: कैसे ग्राफिक्स लेयर, ग्राफिक्स ले जाएँ और ग्राफिक्स को सामने लाएं