आईओएस - त्वरित गाइड

सामान्य अवलोकन

iOS, जिसे पहले iPhone OS कहा जाता था, Apple Inc. द्वारा विकसित एक मोबाइल ऑपरेटिंग सिस्टम है। इसकी पहली रिलीज़ 2007 में हुई थी, जिसमें iPhone और iPod Touch शामिल थे। iPad (1st जनरेशन) अप्रैल 2010 में और iPad Mini नवंबर 2012 में रिलीज़ किया गया था।

IOS डिवाइस बहुत बार विकसित होते हैं और अनुभव से, हम पाते हैं कि हर साल कम से कम एक संस्करण iPhone और iPad लॉन्च किया जाता है। अब, हमने iPhone5 लॉन्च किया है जिसमें iPhone, iPhone 3gs, iPhone 4, iPhone 4s से शुरू होने वाले अपने पूर्ववर्तियों हैं। इसी तरह, iPad iPad (1 st Generation) से iPad (4 th Generation) और एक अतिरिक्त iPad Mini संस्करण विकसित हुआ है ।

IOS SDK 1.0 से 6.0 तक विकसित हुआ है। iOS 6.0, नवीनतम SDK Xcode 4.5 और उच्चतर में केवल आधिकारिक रूप से समर्थित संस्करण है। हमारे पास एक समृद्ध Apple दस्तावेज़ है और हम पा सकते हैं कि हमारे परिनियोजन लक्ष्य के आधार पर किन विधियों और पुस्तकालयों का उपयोग किया जा सकता है। Xcode के वर्तमान संस्करण में, हम iOS 4.3, 5.0 और 6.0 के तैनाती लक्ष्य के बीच चयन करने में सक्षम होंगे।

IOS की शक्ति को डिवाइस के एक भाग के रूप में प्रदान की गई कुछ निम्न विशेषताओं के साथ महसूस किया जा सकता है।

  • Maps
  • Siri
  • फेसबुक और ट्विटर
  • Multi-Touch
  • Accelerometer
  • GPS
  • उच्च अंत प्रोसेसर
  • Camera
  • Safari
  • शक्तिशाली एपीआई
  • खेल केंद्र
  • ऐप में खरीदारी
  • Reminders
  • इशारों की एक विस्तृत श्रृंखला

IPhone / iPad का उपयोग करने वाले उपयोगकर्ताओं की संख्या में बहुत अधिक वृद्धि हुई है। यह डेवलपर्स के लिए iPhone और iPad ऐप्पल के ऐप स्टोर के लिए एप्लिकेशन बनाकर पैसा बनाने का अवसर प्रदान करता है।

IOS के लिए कुछ नए लोगों के लिए, Apple ने एक एप्लिकेशन स्टोर डिज़ाइन किया है जहाँ उपयोगकर्ता अपने iOS उपकरणों के लिए विकसित ऐप खरीद सकते हैं। एक डेवलपर ऐप स्टोर में मुफ्त और सशुल्क दोनों ऐप बना सकता है। एप्लिकेशन विकसित करने और स्टोर पर वितरित करने के लिए, डेवलपर को iOS डेवलपर प्रोग्राम के साथ पंजीकरण करना होगा, जिसकी लागत $ 99 प्रति वर्ष और माउंटेन लायन के साथ एक मैक या नवीनतम Xcode के साथ इसके विकास के लिए अधिक है।

Apple डेवलपर के रूप में पंजीकरण

एक Apple ID सबसे आवश्यक है यदि आप कोई Apple डिवाइस रख रहे हैं और एक डेवलपर होने के नाते, आपको निश्चित रूप से इसकी आवश्यकता है। यह मुफ़्त है और इसलिए, एक होने में कोई समस्या नहीं है। Apple खाता होने के लाभ इस प्रकार हैं -

  • विकास के साधनों तक पहुंच।

  • दुनिया भर में डेवलपर्स सम्मेलन (डब्ल्यूडब्ल्यूडीसी) वीडियो।

  • आमंत्रित किए जाने पर iOS डेवलपर प्रोग्राम टीमों में शामिल हो सकते हैं।

Apple खाता पंजीकृत करने के लिए, नीचे दिए गए चरणों का पालन करें -

Step 1 - लिंक पर क्लिक करें https://developer.apple.com/programs/register/ और "Apple ID बनाएं" चुनें

Step 2 - आवश्यक जानकारी प्रदान करें, जो पृष्ठ में दिए गए अनुसार स्वयं व्याख्यात्मक है।

Step 3 - अपने खाते को अपने ईमेल सत्यापन से सत्यापित करें और खाता सक्रिय हो जाए।

Step 4 - अब आप Xcode जैसे डेवलपर टूल डाउनलोड कर पाएंगे, जो iOS सिम्युलेटर और iOS SDK, और अन्य डेवलपर संसाधनों के साथ पैक किया गया है।

Apple iOS डेवलपर प्रोग्राम

एक नए डेवलपर के लिए पहला सवाल यह है कि - मुझे iOS डेवलपर प्रोग्राम के लिए पंजीकरण क्यों करना चाहिए? जवाब बहुत सरल है; Apple हमेशा अपने उपयोगकर्ता को गुणवत्ता अनुप्रयोग प्रदान करने पर ध्यान केंद्रित करता है। यदि कोई पंजीकरण शुल्क नहीं था, तो जंक ऐप्स अपलोड होने की संभावना हो सकती है जो ऐप्पल की ऐप समीक्षा टीम के लिए समस्याएं पैदा कर सकती हैं।

IOS डेवलपर कार्यक्रम में शामिल होने के लाभ इस प्रकार हैं -

  • वास्तविक iOS डिवाइस पर आपके द्वारा विकसित किए गए एप्लिकेशन चलाएं।

  • ऐप्स को ऐप स्टोर में वितरित करें।

  • डेवलपर पूर्वावलोकन के लिए पहुँच प्राप्त करें।

IOS डेवलपर प्रोग्राम में शामिल होने के चरण इस प्रकार हैं -

Step 1- रजिस्टर करने के लिए लिंक पर क्लिक करें - (https://developer.apple.com/programs/ios/)।

Step 2 - जो पेज दिख रहा है उसमें एनरोल नाउ पर क्लिक करें।

Step 3 - आप या तो अपने मौजूदा ऐप्पल खाते में साइन इन कर सकते हैं (यदि आपके पास एक है) या एक नया ऐप्पल आईडी बनाएं।

Step 4- इसके बाद, आपको व्यक्तिगत और कंपनी खातों के बीच चयन करना होगा। यदि आपकी टीम में एक से अधिक डेवलपर होंगे, तो कंपनी खाते का उपयोग करें। व्यक्तिगत खाते में, आप सदस्य नहीं जोड़ सकते।

Step 5 - व्यक्तिगत जानकारी (नए रजिस्टर करने वालों के लिए) दर्ज करने के बाद, आप अपने क्रेडिट कार्ड (केवल भुगतान के स्वीकृत मोड) की सहायता से भुगतान करके कार्यक्रम को खरीद और सक्रिय कर सकते हैं।

Step 6 - अब आपको पेज में मेंबर सेंटर ऑप्शन को सेलेक्ट करके डेवलपर रिसोर्सेज का एक्सेस मिलेगा।

Step 7 - यहाँ आप निम्न कार्य कर सकेंगे -

  • प्रोविजनिंग प्रोफाइल बनाएं।

  • अपनी टीम और उपकरणों का प्रबंधन करें।

  • आईट्यून्स कनेक्ट के माध्यम से ऐप स्टोर में एप्लिकेशन को प्रबंधित करना।

  • मंच और तकनीकी सहायता प्राप्त करें।

iOS - Xcode इंस्टॉलेशन

Step 1 - से Xcode का नवीनतम संस्करण डाउनलोड करें https://developer.apple.com/downloads/

Step 2 - Xcode dmg फाइल पर डबल क्लिक करें।

Step 3 - आपको एक डिवाइस माउंटेड और ओपन मिलेगी।

Step 4 - विंडो में दो आइटम होंगे जो अर्थात् प्रदर्शित होंगे, एक्सकोड एप्लिकेशन और एप्लिकेशन फ़ोल्डर का शॉर्टकट।

Step 5 - Xcode को एप्लिकेशन पर खींचें और यह आपके एप्लिकेशन में कॉपी हो जाएगा।

Step 6 - अब Xcode अन्य एप्लिकेशन के एक भाग के रूप में उपलब्ध होगा, जहाँ से आप चयन और चला सकते हैं।

आपके पास मैक ऐप स्टोर से Xcode डाउनलोड करने का एक और विकल्प है और फिर स्क्रीन पर दी गई चरण-दर-चरण प्रक्रिया का पालन करें।

इंटरफ़ेस बिल्डर

इंटरफ़ेस बिल्डर वह उपकरण है जो UI इंटरफ़ेस के आसान निर्माण को सक्षम बनाता है। आपके पास यूआई तत्वों का एक समृद्ध सेट है जो उपयोग के लिए विकसित किया गया है। आपको बस अपने UI दृश्य में ड्रैग और ड्रॉप करना होगा। हम आगामी पृष्ठों में UI तत्वों को जोड़ने, आउटलेट बनाने और क्रियाओं के बारे में सीखेंगे।

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

आईओएस सिम्युलेटर

एक आईओएस सिम्युलेटर में वास्तव में दो प्रकार के डिवाइस होते हैं, अर्थात् iPhone और iPad अपने विभिन्न संस्करणों के साथ। iPhone संस्करणों में iPhone (सामान्य), iPhone रेटिना, iPhone 5. iPad में iPad और iPad रेटिना शामिल हैं। IPhone सिम्युलेटर का एक स्क्रीनशॉट नीचे प्रदर्शित किया गया है।

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

IOS के विकास में उपयोग की जाने वाली भाषा वस्तुनिष्ठ C. यह एक वस्तु-उन्मुख भाषा है और इसलिए, उन लोगों के लिए यह आसान होगा जिनके पास ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग भाषाओं में कुछ पृष्ठभूमि है।

इंटरफ़ेस और कार्यान्वयन

ऑब्जेक्टिव सी में, वह फाइल जहां क्लास की घोषणा होती है, को कहा जाता है interface file और वह फ़ाइल जहाँ कक्षा को परिभाषित किया गया है, को कहा जाता है implementation file

एक सरल इंटरफ़ेस फ़ाइल MyClass.h निम्नलिखित की तरह दिखेगा -

@interface MyClass:NSObject { 
   // class variable declared here
}

// class properties declared here
// class methods and instance methods declared here
@end

कार्यान्वयन फ़ाइल MyClass.m निम्नानुसार होगा -

@implementation MyClass
   // class methods defined here
@end

वस्तु निर्माण

वस्तु निर्माण निम्नानुसार किया जाता है -

MyClass  *objectName = [[MyClass alloc]init] ;

तरीकों

उद्देश्य C में विधि निम्नानुसार घोषित की गई है -

-(returnType)methodName:(typeName) variable1 :(typeName)variable2;

एक उदाहरण नीचे दिया गया है।

-(void)calculateAreaForRectangleWithLength:(CGfloat)length 
andBreadth:(CGfloat)breadth;

आप सोच रहे होंगे कि क्या andBreadthस्ट्रिंग के लिए है; वास्तव में यह एक वैकल्पिक स्ट्रिंग है, जो हमें आसानी से कॉल करने के समय विधि को आसानी से पढ़ने और समझने में मदद करती है। इस विधि को उसी कक्षा में बुलाने के लिए, हम निम्नलिखित कथन का उपयोग करते हैं -

[self calculateAreaForRectangleWithLength:30 andBreadth:20];

जैसा कि ऊपर कहा गया है, -Breadth का उपयोग हमें यह समझने में मदद करता है कि चौड़ाई 20 है। स्व का उपयोग यह निर्दिष्ट करने के लिए किया जाता है कि यह एक वर्ग विधि है।

कक्षा के तरीके

क्लास के लिए ऑब्जेक्ट्स बनाए बिना क्लास के तरीकों को सीधे एक्सेस किया जा सकता है। उनके पास कोई चर और वस्तुएं नहीं हैं। एक उदाहरण नीचे दिया गया है।

+(void)simpleClassMethod;

इसे वर्ग नाम का उपयोग करके एक्सेस किया जा सकता है (मान लीजिए कि क्लास का नाम MyClass है) निम्नानुसार है -

[MyClass simpleClassMethod];

उदाहरण के तरीके

क्लास के लिए ऑब्जेक्ट बनाने के बाद ही इंस्टेंस के तरीकों को एक्सेस किया जा सकता है। मेमोरी को उदाहरण चर के लिए आवंटित किया गया है। एक उदाहरण उदाहरण विधि नीचे दी गई है।

-(void)simpleInstanceMethod;

इसे कक्षा के लिए एक वस्तु बनाने के बाद एक्सेस किया जा सकता है -

MyClass  *objectName = [[MyClass alloc]init] ;
[objectName simpleInstanceMethod];

उद्देश्य सी में महत्वपूर्ण डेटा प्रकार

अनु क्रमांक। डाटा प्रकार
1

NSString

यह एक स्ट्रिंग का प्रतिनिधित्व करने के लिए उपयोग किया जाता है।

2

CGfloat

इसका उपयोग फ्लोटिंग पॉइंट वैल्यू का प्रतिनिधित्व करने के लिए किया जाता है (सामान्य फ्लोट की भी अनुमति है लेकिन CGfloat का उपयोग करना बेहतर है)।

3

NSInteger

इसका उपयोग पूर्णांक का प्रतिनिधित्व करने के लिए किया जाता है।

4

BOOL

इसका उपयोग बुलियन का प्रतिनिधित्व करने के लिए किया जाता है (YES या NO, BOOL प्रकार की अनुमति है)।

मुद्रण लॉग

NSLog - एक बयान को छापने के लिए उपयोग किया जाता है। इसे क्रमशः रिलीज़ और डीबग मोड में डिवाइस लॉग और डीबग कंसोल में मुद्रित किया जाएगा। उदाहरण के लिए,

NSlog(@"");

नियंत्रण संरचनाएं

अधिकांश नियंत्रण संरचनाएं सी और सी ++ के समान हैं, बयान में कुछ परिवर्धन को छोड़कर।

गुण

बाहरी वर्ग के लिए कक्षा तक पहुंचने के लिए, चर गुणों का उपयोग किया जाता है। उदाहरण के लिए,

@property(nonatomic , strong) NSString *myString;

पहुँच गुण

आप संपत्तियों तक पहुंचने के लिए डॉट ऑपरेटर का उपयोग कर सकते हैं। उपरोक्त संपत्ति तक पहुंचने के लिए, हम निम्नलिखित कार्य करेंगे।

self.myString = @"Test";

आप सेट विधि का उपयोग इस प्रकार कर सकते हैं -

[self setMyString:@"Test"];

श्रेणियाँ

मौजूदा वर्गों में विधियों को जोड़ने के लिए श्रेणियों का उपयोग किया जाता है। इस तरह, हम उन वर्गों के लिए विधि जोड़ सकते हैं जिनके लिए हमारे पास कार्यान्वयन फ़ाइलें भी नहीं हैं जहां वास्तविक वर्ग परिभाषित है। हमारी कक्षा के लिए एक नमूना श्रेणी इस प्रकार है -

@interface MyClass(customAdditions)
- (void)sampleCategoryMethod;
@end

@implementation MyClass(categoryAdditions)

-(void)sampleCategoryMethod {
   NSLog(@"Just a test category");
}

सरणियों

NSMutableArray और NSArray उद्देश्य सी में उपयोग की जाने वाली सरणी कक्षाएं हैं। जैसा कि नाम से पता चलता है, पूर्व उत्परिवर्तनीय है और बाद वाला अपरिवर्तनीय है। एक उदाहरण नीचे दिया गया है।

NSMutableArray *aMutableArray = [[NSMutableArray alloc]init];
[anArray addObject:@"firstobject"];
NSArray *aImmutableArray = [[NSArray alloc]
initWithObjects:@"firstObject",nil];

शब्दकोश

NSMutableDictionary और NSDictionary उद्देश्य सी में प्रयुक्त शब्दकोश कक्षाएं हैं। जैसा कि नाम से पता चलता है, पूर्व उत्परिवर्तनीय है और बाद वाला अपरिवर्तनीय है। एक उदाहरण नीचे दिया गया है।

NSMutableDictionary *aMutableDictionary = [[NSMutableArray alloc]init];
[aMutableDictionary setObject:@"firstobject" forKey:@"aKey"];
NSDictionary*aImmutableDictionary= [[NSDictionary alloc]initWithObjects:[NSArray arrayWithObjects:
@"firstObject",nil] forKeys:[ NSArray arrayWithObjects:@"aKey"]];

पहला ऐप बनाना

अब हम एक सरल सिंगल व्यू एप्लिकेशन (एक खाली ऐप) बनाने जा रहे हैं जो iOS सिम्युलेटर पर चलेगा।

चरण इस प्रकार हैं।

Step 1 - Xcode खोलें और सेलेक्ट करें Create a new Xcode project

Step 2 - चयन करें Single View Application

Step 3 - उत्पाद का नाम, यानी, आवेदन का नाम, संगठन का नाम और फिर कंपनी पहचानकर्ता दर्ज करें।

Step 4 - यह सुनिश्चित करें Use Automatic Reference Countingएक बार स्कोप से बाहर हो जाने पर आवंटित संसाधनों को स्वचालित रूप से जारी करने के लिए चुना जाता है। अगला पर क्लिक करें।

Step 5 - प्रोजेक्ट के लिए डायरेक्टरी चुनें और क्रिएट चुनें।

Step 6 - आपको एक स्क्रीन इस प्रकार दिखाई देगी -

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

Step 7 - अब, रन बटन के पास ड्रॉप डाउन में iPhone सिम्युलेटर का चयन करें और रन का चयन करें।

Step 8- यही है; आपने अपना पहला आवेदन सफलतापूर्वक चला दिया है। आपको निम्नानुसार एक आउटपुट मिलेगा -

अब आइए पृष्ठभूमि रंग बदलते हैं, बस इंटरफ़ेस बिल्डर के साथ एक शुरुआत है। ViewController.xib का चयन करें। दाईं ओर पृष्ठभूमि विकल्प चुनें, रंग बदलें और चलाएं।

उपरोक्त परियोजना में, डिफ़ॉल्ट रूप से, तैनाती लक्ष्य iOS 6.0 पर सेट किया गया होगा और ऑटो-लेआउट सक्षम किया जाएगा। यह सुनिश्चित करने के लिए कि हमारा एप्लिकेशन उन उपकरणों पर चलता है जो iOS 4.3 पर हैं, हमने पहले से ही इस एप्लिकेशन के निर्माण की शुरुआत में तैनाती लक्ष्य को संशोधित कर दिया है, लेकिन हमने ऑटो-लेआउट को अक्षम नहीं किया है।

ऑटो-लेआउट को अक्षम करने के लिए, हमें प्रत्येक निब के फाइल इंस्पेक्टर यानी xib फाइलों में ऑटो-लेआउट चेकबॉक्स को अचयनित करना होगा। Xcode प्रोजेक्ट IDE के विभिन्न खंड निम्नलिखित आकृति में दिए गए हैं (सौजन्य: Apple Xcode 4 उपयोगकर्ता प्रलेखन)।

निरीक्षक चयनकर्ता बार में फ़ाइल इंस्पेक्टर पाया जाता है जैसा कि ऊपर दिखाया गया है और ऑटो लेआउट को अनियंत्रित किया जा सकता है। ऑटो लेआउट का उपयोग तब किया जा सकता है जब आप केवल iOS 6 उपकरणों को लक्षित करना चाहते हैं। इसके अलावा, आप पासबुक जैसी कई नई सुविधाओं का उपयोग करने में सक्षम होंगे यदि आप आईओएस 6 में तैनाती का लक्ष्य बढ़ाते हैं। तो, आइए तैनाती के लक्ष्य के रूप में आईओएस 4.3 से चिपके रहें।

पहले iOS एप्लिकेशन का कोड

आपको पांच अलग-अलग फाइलें मिलेंगी जो आपके एप्लिकेशन के लिए जेनरेट की गई होंगी। वे इस प्रकार सूचीबद्ध हैं -

  • AppDelegate.h
  • AppDelegate.m
  • ViewController.h
  • ViewController.m
  • ViewController.xib

AppDelegate.h

// Header File that provides all UI related items. 
#import <UIKit/UIKit.h> 

// Forward declaration (Used when class will be defined /imported in future)
@class ViewController;  

// Interface for Appdelegate
@interface AppDelegate : UIResponder <UIApplicationDelegate>

// Property window 
@property (strong, nonatomic) UIWindow *window; 

// Property Viewcontroller

@property (strong, nonatomic) ViewController *viewController;
//this marks end of interface 
@end

Important items in code -

  • AppDelegate UIResponder से विरासत में मिला है जो iOS इवेंट्स को हैंडल करता है।

  • UIApplicationDelegate के प्रतिनिधि तरीकों को लागू करता है, जो कि समाप्त होने, लॉन्च करने आदि के बारे में महत्वपूर्ण एप्लिकेशन इवेंट प्रदान करता है।

  • UIWindow iOS डिवाइस स्क्रीन पर विभिन्न विचारों का प्रबंधन और समन्वय करने के लिए ऑब्जेक्ट। यह आधार दृश्य की तरह है जिस पर अन्य सभी दृश्य लोड किए गए हैं। आम तौर पर किसी एप्लिकेशन के लिए केवल एक विंडो होती है।

  • UIViewController स्क्रीन प्रवाह को संभालने के लिए।

AppDelegate.m

// Imports the class Appdelegate's interface
import "AppDelegate.h" 

// Imports the viewcontroller to be loaded
#import "ViewController.h" 

// Class definition starts here
@implementation AppDelegate 


// Method to intimate us that the application launched successfully
- (BOOL)application:(UIApplication *)application 
didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
   self.window = [[UIWindow alloc] initWithFrame:[[UIScreen mainScreen] bounds]];
   
   // Override point for customization after application launch.
   self.viewController = [[ViewController alloc]
   initWithNibName:@"ViewController" bundle:nil];
   self.window.rootViewController = self.viewController;
   [self.window makeKeyAndVisible];
   return YES;
}

- (void)applicationWillResignActive:(UIApplication *)application {
   /* Use this method to release shared resources, save user data,
   invalidate timers, and store enough application state information
   to restore your application to its current state in case it is 
   terminated later. If your application supports background 
   execution, this method is called instead of
   applicationWillTerminate: when the user quits.*/
}

- (void)applicationWillEnterForeground:(UIApplication *)application {
   /* Called as part of the transition from the background to the 
   inactive state. Here you can undo many of the changes made on 
   entering the background.*/
}

- (void)applicationDidBecomeActive:(UIApplication *)application {
   /* Restart any tasks that were paused (or not yet started) while 
   the application was inactive. If the application was previously in 
   the background, optionally refresh the user interface.*/
}

- (void)applicationWillTerminate:(UIApplication *)application {
   /* Called when the application is about to terminate. Save data if 
   appropriate. See also applicationDidEnterBackground:. */
}

- (void)applicationWillTerminate:(UIApplication *)application {
   /* Called when the application is about to terminate. Save data if appropriate.
   See also applicationDidEnterBackground:. */
}
@end

Important items in code -

  • UIApplication प्रतिनिधि यहाँ परिभाषित किए गए हैं। ऊपर बताई गई सभी विधियाँ UI अनुप्रयोग प्रतिनिधि हैं और इनमें कोई उपयोगकर्ता परिभाषित विधियाँ नहीं हैं।

  • UIWindow ऑब्जेक्ट आवंटित एप्लिकेशन को होल्ड करने के लिए आवंटित किया गया है।

  • UIViewController को खिड़की के प्रारंभिक दृश्य नियंत्रक के रूप में आवंटित किया गया है।

  • विंडो को दृश्यमान बनाने के लिए, MakeKeyAndVoice विधि को कहा जाता है।

ViewController.h

#import <UIKit/UIKit.h> 

// Interface for class ViewController
@interface ViewController : UIViewController 

@end

Important items in code -

  • ViewController क्लास UIViewController को विरासत में मिला है, जो iOS एप्लिकेशन के लिए मौलिक व्यू मैनेजमेंट मॉडल प्रदान करता है।

ViewController.m

#import "ViewController.h"

// Category, an extension of ViewController class
@interface ViewController ()

@end

@implementation ViewController  

- (void)viewDidLoad {
   [super viewDidLoad];
   // Do any additional setup after loading the view, typically from a nib.
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}
@end

Important items in code -

  • यहाँ कार्यान्वित दो विधियों को आधार वर्ग UIViewController में परिभाषित किया गया है।

  • ViewDidLoad में प्रारंभिक सेटअप करें, जिसे व्यू लोड के बाद कहा जाता है।

  • मेमोरी चेतावनी के मामले में didReceiveMemoryWarning विधि को कहा जाता है।

IOS में क्रियाओं और आउटलेट को कहा जाता है ibActions तथा ibOutlets क्रमशः, जहां ibइंटरफ़ेस बिल्डर के लिए खड़ा है। ये UI तत्वों से संबंधित हैं और हम उन्हें नेत्रहीन जानने के बाद पता लगाएंगे कि उन्हें कैसे लागू किया जाए।

क्रियाएँ और आउटलेट - शामिल कदम

Step 1 - चलो हमारे पहले iPhone अनुप्रयोग का उपयोग करें।

Step 2 - नाविक अनुभाग में फ़ाइलों से ViewController.xib फ़ाइल का चयन करें।

Step 3 - अब, आप हमारी विंडो के दाईं ओर लाइब्रेरी फलक से UI तत्वों का चयन कर सकते हैं, जो नीचे दिखाया गया है।

Step 4 - आप हमारे इंटरफेस बिल्डर में हमारे विचार के लिए यूआई तत्वों को खींच और छोड़ सकते हैं।

Step 5 - आइए हम अपने विचार में एक लेबल और राउंड रेक्ट बटन जोड़ें।

Step 6 - कार्यक्षेत्र टूलबार में संपादक चयनकर्ता बटन से शीर्ष दाएं कोने पर पाया गया जैसा कि नीचे दिखाया गया है।

सहायक संपादक बटन का चयन करें।

Step 7 - हम केंद्र में हमारे संपादक क्षेत्र में दो विंडो देखेंगे, एक ViewController.xib फ़ाइल है और दूसरा ViewController.h है।

Step 8 - अब, लेबल पर राइट क्लिक करें और नीचे दिखाए गए अनुसार नए रेफ़रिंग आउटलेट को चुनें और दबाए रखें।

Step 9- घुंघराले ब्रेसों के बीच ViewController.h में गिरा। यदि फ़ाइल में कोई घुंघराले ब्रेसिज़ नहीं हैं, तो ऐसा करने से पहले ViewController जोड़ें। जैसा कि नीचे दिखाया गया है, आपको एक पॉप-अप मिलेगा।

Step 10- आउटलेट के लिए लेबल का नाम टाइप करें, यहां हमने लेबल myTitleLabel का उपयोग किया है। कनेक्ट पर क्लिक करें और ibOutlet पूरा हो जाएगा।

Step 11 - इसी तरह, एक क्रिया जोड़ने के लिए, राउंड रेक्ट बटन पर राइट क्लिक करें, अंदर टच अप करें और इसे कर्ली ब्रेसेस के नीचे खींचें।

Step 12 - इसे ड्रॉप करें और इसे setTitleLabel नाम दें।

Step 13 - ViewController.m फ़ाइल का चयन करें, आपको एक विधि मिल जाएगी जैसा कि नीचे दिखाया गया है।

-(IBAction) setTitleLabel:(id)sender {
}

Step 14 - उपरोक्त विधि के अंदर नीचे दिखाया गया विवरण जोड़ें।

[myTitleLabel setText:@"Hello"];

Step 15- अब रन बटन का चयन करके प्रोग्राम को रन करें। आप निम्न आउटपुट देखेंगे।

Step 16 - अब बटन पर क्लिक करें।

Step 17 - हमने जो लेबल बनाया है वह बटन पर कार्रवाई द्वारा बदल दिया गया है।

Step 18- उपरोक्त उदाहरण से, हम यह निष्कर्ष निकाल सकते हैं कि IBOutlet UIElement (यहां UILabel के लिए) का संदर्भ बनाता है। इसी तरह, IBAction UIButton को एक विधि से जोड़ता है, जिसे इवेंट के अंदर टच अप कहा जाता है।

Step 19 - आप कार्रवाई बनाते समय विभिन्न घटनाओं का चयन करके क्रियाओं के साथ खेल सकते हैं।

डेलीगेट के लिए उदाहरण

मान लेते हैं कि एक वस्तु ए को क्रिया करने के लिए एक वस्तु बी कहती है। एक बार कार्रवाई पूरी होने के बाद, ऑब्जेक्ट A को पता होना चाहिए कि B ने कार्य पूरा कर लिया है और आवश्यक कार्रवाई कर रहा है। यह प्रतिनिधियों की मदद से हासिल किया गया है।

उपरोक्त उदाहरण में मुख्य अवधारणाएँ हैं -

  • A, B की एक प्रतिनिधि वस्तु है।

  • B में A का संदर्भ होगा।

  • A, B के प्रतिनिधि तरीकों को लागू करेगा।

  • B प्रतिनिधि प्रतिनिधि के माध्यम से A को सूचित करेगा।

एक प्रतिनिधि बनाने के चरण

Step 1 - सबसे पहले, सिंगल व्यू एप्लिकेशन बनाएं।

Step 2 - इसके बाद फाइल → न्यू → फाइल सेलेक्ट करें ...

Step 3 - इसके बाद ऑब्जेक्टिव सी क्लास चुनें और नेक्स्ट पर क्लिक करें।

Step 4 - क्लास को एक नाम दें, कहें, नीचे दिए गए नमूने के रूप में सबक्लास के साथ सैंपलप्रोटोकॉल।

Step 5 - इसके बाद create को सेलेक्ट करें।

Step 6 - SampleProtocol.h फ़ाइल में एक प्रोटोकॉल जोड़ें और अद्यतन कोड निम्नानुसार है -

#import <Foundation/Foundation.h>

// Protocol definition starts here 
@protocol SampleProtocolDelegate <NSObject>
@required
- (void) processCompleted;
@end

// Protocol Definition ends here
@interface SampleProtocol : NSObject {
   // Delegate to respond back
   id <SampleProtocolDelegate> _delegate; 
}
@property (nonatomic,strong) id delegate;

-(void)startSampleProcess; // Instance method
@end

Step 7 - नीचे दिखाए गए अनुसार नमूनाप्रोटोकॉलेट फ़ाइल को अपडेट करके इंस्टेंस विधि को लागू करें।

#import "SampleProtocol.h"

@implementation SampleProtocol

-(void)startSampleProcess {
   [NSTimer scheduledTimerWithTimeInterval:3.0 target:self.delegate 
	selector:@selector(processCompleted) userInfo:nil repeats:NO];
}
@end

Step 8 - नीचे दी गई जानकारी के अनुसार ऑब्जेक्ट लाइब्रेरी से लेबल को UIView तक खींचकर ViewController.xib में एक UILabel जोड़ें।

Step 9 - लेबल के लिए एक IBOutlet बनाएं और इसे myLabel नाम दें और ViewController.h में SampleProtocolDelegate को अपनाने के लिए कोड को अपडेट करें।

#import <UIKit/UIKit.h>
#import "SampleProtocol.h"

@interface ViewController : UIViewController<SampleProtocolDelegate> {
   IBOutlet UILabel *myLabel;
}
@end

Step 10प्रतिनिधि विधि को लागू करें, नमूनाप्रोटोकॉल के लिए ऑब्जेक्ट बनाएं और स्टार्टप्लसप्रोसेस विधि को कॉल करें। अद्यतन ViewController.m फ़ाइल इस प्रकार है -

#import "ViewController.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   SampleProtocol *sampleProtocol = [[SampleProtocol alloc]init];
   sampleProtocol.delegate = self;
   [myLabel setText:@"Processing..."];
   [sampleProtocol startSampleProcess];
   // Do any additional setup after loading the view, typically from a nib.
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

#pragma mark - Sample protocol delegate
-(void)processCompleted {
   [myLabel setText:@"Process Completed"];
}
@end

Step 11हम निम्नानुसार आउटपुट देखेंगे। प्रारंभ में लेबल "प्रोसेसिंग ..." प्रदर्शित करता है, जो सैंपलप्रोटोकॉल ऑब्जेक्ट द्वारा प्रतिनिधि पद्धति को बुलाए जाने पर अपडेट हो जाता है।

UI तत्व क्या हैं?

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

UI तत्वों को कैसे जोड़ें?

हम यूआई तत्वों को कोड में और इंटरफ़ेस बिल्डर की मदद से जोड़ सकते हैं। आवश्यकता के आधार पर हम उनमें से किसी एक का उपयोग कर सकते हैं।

हमारा विशेष ध्यान

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

हमारा दृष्टिकोण

हम एक सरल iOS एप्लिकेशन बनाएंगे और कुछ UI तत्वों की व्याख्या के लिए इसका उपयोग करेंगे।

Step 1 - जैसा कि हमने अपने पहले iOS एप्लिकेशन में किया था, एक व्यूबेड एप्लिकेशन बनाएं।

Step 2 - हम केवल ViewController.h और ViewController.m फ़ाइलों को अपडेट करेंगे।

Step 3 - तब हम अपने तत्व को यूआई तत्व बनाने के लिए विशिष्ट ViewController.m फ़ाइल में जोड़ते हैं।

Step 4 - हम इस विधि को अपने व्यूडलड विधि में कहेंगे।

Step 5 - कोड की महत्वपूर्ण लाइनों को उन लाइनों के ऊपर एकल लाइन टिप्पणी के साथ कोड में समझाया गया है।

UI तत्वों की सूची

यूआई विशिष्ट तत्वों और उनके संबंधित कार्यात्मकताओं को नीचे समझाया गया है -

अनु क्रमांक। यूआई विशिष्ट तत्व
1 पाठ फ़ील्ड

यह एक यूआई तत्व है जो ऐप को उपयोगकर्ता इनपुट प्राप्त करने में सक्षम बनाता है।

2 इनपुट प्रकार - TextFields

हम उस प्रकार के इनपुट को सेट कर सकते हैं जो उपयोगकर्ता UITextField की कीबोर्ड संपत्ति का उपयोग करके दे सकता है।

3 बटन

इसका उपयोग उपयोगकर्ता कार्यों को संभालने के लिए किया जाता है।

4 लेबल

इसका उपयोग स्थैतिक सामग्री को प्रदर्शित करने के लिए किया जाता है।

5 उपकरण पट्टी

यदि हम अपने वर्तमान दृष्टिकोण के आधार पर किसी चीज़ में हेरफेर करना चाहते हैं तो इसका उपयोग किया जाता है।

6 स्टेटस बार

यह डिवाइस की प्रमुख जानकारी प्रदर्शित करता है।

7 नेविगेशन बार

इसमें नेविगेशन कंट्रोलर के नेविगेशन बटन होते हैं, जो व्यू कंट्रोलर्स का एक स्टैक होता है जिसे पुश और पॉपअप किया जा सकता है।

8 टैब पट्टी

यह आम तौर पर एक ही दृश्य के भीतर विभिन्न उप-प्रकारों, विचारों या मॉडलों के बीच स्विच करने के लिए उपयोग किया जाता है।

9 छवि देखें

यह एक साधारण छवि या छवियों के अनुक्रम को प्रदर्शित करने के लिए उपयोग किया जाता है।

10 स्क्रॉल देखें

इसका उपयोग सामग्री को प्रदर्शित करने के लिए किया जाता है जो स्क्रीन के क्षेत्र से अधिक है।

1 1 टेबल व्यू

इसका उपयोग कई पंक्तियों और अनुभागों में डेटा की स्क्रॉल करने योग्य सूची प्रदर्शित करने के लिए किया जाता है।

12 भाजित दृश्य

इसका उपयोग विस्तार फलक पर जानकारी को नियंत्रित करने वाले मास्टर पैन के साथ दो पैन प्रदर्शित करने के लिए किया जाता है।

13 व्याख्यान दर्शन

इसका उपयोग वैकल्पिक रूप से संपादन योग्य पाठ जानकारी की स्क्रॉल करने योग्य सूची का प्रबंधन करने के लिए किया जाता है।

14 संक्रमण देखें

यह विचारों के बीच विभिन्न दृश्य संक्रमणों की व्याख्या करता है।

15 पिकर्स

यह एक सूची से एक विशिष्ट डेटा का चयन करने के लिए प्रदर्शित करने के लिए उपयोग किया जाता है।

16 स्विच

इसका उपयोग अक्षमता और कार्यों के लिए सक्षम करने के लिए किया जाता है।

17 स्लाइडर्स

इसका उपयोग उपयोगकर्ताओं को अनुमत मानों की एक श्रेणी में मान या प्रक्रिया में समायोजन करने के लिए किया जाता है।

18 अलर्ट

इसका उपयोग उपयोगकर्ताओं को महत्वपूर्ण जानकारी देने के लिए किया जाता है।

19 माउस

यह एक छवि प्रतिनिधित्व है जो किसी कार्रवाई के लिए उपयोग किया जाता है या एप्लिकेशन से संबंधित किसी चीज़ को चित्रित करता है।

एक्सेलेरोमीटर का उपयोग तीन दिशाओं x, y और z में डिवाइस की स्थिति में परिवर्तन का पता लगाने के लिए किया जाता है। हम डिवाइस की वर्तमान स्थिति को जमीन के सापेक्ष जान सकते हैं। इस उदाहरण का परीक्षण करने के लिए, आपको इसे चलाने की आवश्यकता होगीdevice और सिम्युलेटर पर काम नहीं करता है।

एक्सेलेरोमीटर - शामिल कदम

Step 1 - एक सरल बनाएँ View based application

Step 2 - में तीन लेबल जोड़ें ViewController.xib और ibOutlets को xlabel, ylabel, और zlabel के रूप में नाम देना।

Step 3 - अद्यतन ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController<UIAccelerometerDelegate> {
   IBOutlet UILabel *xlabel;
   IBOutlet UILabel *ylabel;
   IBOutlet UILabel *zlabel;
}
@end

Step 4 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   [[UIAccelerometer sharedAccelerometer]setDelegate:self];
   //Do any additional setup after loading the view,typically from a nib
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

- (void)accelerometer:(UIAccelerometer *)accelerometer didAccelerate:
   (UIAcceleration *)acceleration {
   [xlabel setText:[NSString stringWithFormat:@"%f",acceleration.x]];
   [ylabel setText:[NSString stringWithFormat:@"%f",acceleration.y]];
   [zlabel setText:[NSString stringWithFormat:@"%f",acceleration.z]];
}
@end

उत्पादन

जब हम एप्लिकेशन को चलाते हैं iPhone डिवाइस, हम निम्नलिखित उत्पादन प्राप्त करेंगे -

एक सार्वभौमिक अनुप्रयोग एक ऐसा अनुप्रयोग है जो iPhone और iPad दोनों के लिए एकल बाइनरी में डिज़ाइन किया गया है। एक सार्वभौमिक अनुप्रयोग कोड का पुन: उपयोग और तेजी से अद्यतन करने की अनुमति देता है।

यूनिवर्सल एप्लिकेशन - शामिल कदम

Step 1 - एक सरल बनाएँ View based application

Step 2 - फ़ाइल का नाम बदलें ViewController.xib के लिए फ़ाइल ViewController_iPhone.xib जैसा कि नीचे दायें हाथ में फ़ाइल इंस्पेक्टर को दिखाया गया है।

Step 3 - फ़ाइल का चयन करें → नया → फ़ाइल ... तो उपधारा का चयन करें "User Interface" और चुनें View। अगला पर क्लिक करें।

Step 4 - डिवाइस परिवार के रूप में चयन करें iPad और आगे क्लिक करें।

Step 5 - फ़ाइल को इस रूप में सहेजें ViewController_iPad.xib और क्रिएट करें चुनें।

Step 6 - दोनों में स्क्रीन के केंद्र में एक लेबल जोड़ें ViewController_iPhone.xib तथा ViewController_iPad.xib

Step 7 - में ViewController_iPad.xib, को चुनिए identity inspector और के रूप में कस्टम वर्ग सेट करें ViewController

Step 8 - आवेदन को अपडेट करें: DidFinishLaunching: AppDelegate.m में withOptions विधि निम्नानुसार है -

- (BOOL)application:(UIApplication *)application
   didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
   self.window = [[UIWindow alloc] initWithFrame:[[UIScreen 
   mainScreen] bounds]];
   
   // Override point for customization after application launch.
   if (UI_USER_INTERFACE_IDIOM() == UIUserInterfaceIdiomPhone) {
      self.viewController = [[ViewController alloc] 
      initWithNibName:@"ViewController_iPhone" bundle:nil];
   } else {
      self.viewController = [[ViewController alloc] initWithNibName:
      @"ViewController_iPad" bundle:nil];
   }
   self.window.rootViewController = self.viewController;
   [self.window makeKeyAndVisible];
   return YES;
}

Step 9 - प्रोजेक्ट सारांश में उपकरणों को अपडेट करें Universal जैसा कि नीचे दिखाया गया है -

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

जब हम iPad सिम्युलेटर में एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट मिलेंगे -

मोबाइल डिवाइस में कैमरा एक सामान्य विशेषता है। हमारे लिए कैमरे के साथ तस्वीरें लेना और हमारे एप्लिकेशन में इसका उपयोग करना संभव है और यह काफी सरल भी है।

कैमरा प्रबंधन - शामिल कदम

Step 1 - एक सरल बनाएँ View based application

Step 2 - जोड़ें button में ViewController.xib और बटन के लिए आईबीएक्शन बनाएं।

Step 3 - जोड़ें image view और इमेज व्यू के रूप में नामकरण IBOutlet बनाएं।

Step 4 - अपडेट ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController<UIImagePickerControllerDelegate> {
   UIImagePickerController *imagePicker;
   IBOutlet UIImageView *imageView;
}

- (IBAction)showCamera:(id)sender;
@end

Step 5 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

- (IBAction)showCamera:(id)sender {
   imagePicker.allowsEditing = YES;
   
   if ([UIImagePickerController isSourceTypeAvailable:
   UIImagePickerControllerSourceTypeCamera]) {
      imagePicker.sourceType = UIImagePickerControllerSourceTypeCamera;
   } else {
      imagePicker.sourceType = 
      UIImagePickerControllerSourceTypePhotoLibrary;
   }
   [self presentModalViewController:imagePicker animated:YES];
}

-(void)imagePickerController:(UIImagePickerController *)picker 
   didFinishPickingMediaWithInfo:(NSDictionary *)info {
      UIImage *image = [info objectForKey:UIImagePickerControllerEditedImage];
      
      if (image == nil) {
         image = [info objectForKey:UIImagePickerControllerOriginalImage];
      }
   imageView.image = image;
}

-(void)imagePickerControllerDidCancel:(UIImagePickerController *)picker {
   [self dismissModalViewControllerAnimated:YES];
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं और शो कैमरा बटन पर क्लिक करते हैं, तो हमें निम्न आउटपुट मिलेंगे -

एक बार जब हम एक तस्वीर लेते हैं, तो हम चित्र को संपादित कर सकते हैं, अर्थात, नीचे दिखाए अनुसार ले जाएँ और स्केल कर सकते हैं -

हम आसानी से iOS में उपयोगकर्ता के वर्तमान स्थान का पता लगा सकते हैं, बशर्ते उपयोगकर्ता एप्लिकेशन को मुख्य स्थान ढांचे की मदद से जानकारी तक पहुंचने की अनुमति देता है।

स्थान हैंडलिंग - शामिल कदम

Step 1 - एक साधारण दृश्य आधारित एप्लिकेशन बनाएं।

Step 2 - अपनी परियोजना फ़ाइल चुनें, फिर लक्ष्य चुनें और फिर नीचे दिखाए अनुसार CoreLocation.framework जोड़ें -

Step 3 - में दो लेबल जोड़ें ViewController.xib और लेबल के रूप में नामकरण ibOutlets बनाएं latitudeLabel तथा longitudeLabel क्रमशः।

Step 4 - फ़ाइल → नई → फ़ाइल ... → का चयन करके एक नई फ़ाइल बनाएँ Objective C class और आगे क्लिक करें।

Step 5 - कक्षा का नाम बताइए LocationHandler साथ में "sub class of" NSObject के रूप में।

Step 6 - सेलेक्ट क्रिएट करें।

Step 7 - अपडेट LocationHandler.h निम्नानुसार है -

#import <Foundation/Foundation.h>
#import <CoreLocation/CoreLocation.h>

@protocol LocationHandlerDelegate <NSObject>

@required
-(void) didUpdateToLocation:(CLLocation*)newLocation 
   fromLocation:(CLLocation*)oldLocation;
@end

@interface LocationHandler : NSObject<CLLocationManagerDelegate> {
   CLLocationManager *locationManager;
}
@property(nonatomic,strong) id<LocationHandlerDelegate> delegate;

+(id)getSharedInstance;
-(void)startUpdating;
-(void) stopUpdating;

@end

Step 8 - अपडेट LocationHandler.m निम्नानुसार है -

#import "LocationHandler.h"
static LocationHandler *DefaultManager = nil;

@interface LocationHandler()

-(void)initiate;

@end

@implementation LocationHandler

+(id)getSharedInstance{
   if (!DefaultManager) {
      DefaultManager = [[self allocWithZone:NULL]init];
      [DefaultManager initiate];
   }
   return DefaultManager;
}

-(void)initiate {
   locationManager = [[CLLocationManager alloc]init];
   locationManager.delegate = self;
}

-(void)startUpdating{
   [locationManager startUpdatingLocation];
}

-(void) stopUpdating {
   [locationManager stopUpdatingLocation];
}

-(void)locationManager:(CLLocationManager *)manager didUpdateToLocation:
   (CLLocation *)newLocation fromLocation:(CLLocation *)oldLocation {
   if ([self.delegate respondsToSelector:@selector
   (didUpdateToLocation:fromLocation:)]) {
      [self.delegate didUpdateToLocation:oldLocation 
      fromLocation:newLocation];
   }
}
@end

Step 9 - अपडेट ViewController.h निम्नानुसार जहां हमने लागू किया है LocationHandler delegate और दो ibOutlets बनाएं -

#import <UIKit/UIKit.h>
#import "LocationHandler.h"

@interface ViewController : UIViewController<LocationHandlerDelegate> {
   IBOutlet UILabel *latitudeLabel;
   IBOutlet UILabel *longitudeLabel;
}
@end

Step 10 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   [[LocationHandler getSharedInstance]setDelegate:self];
   [[LocationHandler getSharedInstance]startUpdating];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(void)didUpdateToLocation:(CLLocation *)newLocation 
 fromLocation:(CLLocation *)oldLocation {
   [latitudeLabel setText:[NSString stringWithFormat:
   @"Latitude: %f",newLocation.coordinate.latitude]];
   [longitudeLabel setText:[NSString stringWithFormat:
   @"Longitude: %f",newLocation.coordinate.longitude]];
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

डाटा संभालने के लिए iOS में SQLite का इस्तेमाल किया जा सकता है। यह sqlite क्वेरी का उपयोग करता है, जो उन लोगों के लिए आसान बनाता है जो SQL जानते हैं।

कदम शामिल किए गए

Step 1 - एक सरल बनाएँ View based application

Step 2 - अपनी प्रोजेक्ट फ़ाइल चुनें, फिर लक्ष्य चुनें और फिर जोड़ें libsqlite3.dylib पुस्तकालय चुन ढांचे में।

Step 3 - फ़ाइल → नई → फ़ाइल ... → का चयन करके एक नई फ़ाइल बनाएँ Objective C class और आगे क्लिक करें।

Step 4 - कक्षा का नाम बताइए DBManager साथ में "sub class of" NSObject के रूप में।

Step 5 - सेलेक्ट क्रिएट करें।

Step 6 - अपडेट DBManager.h निम्नानुसार है -

#import <Foundation/Foundation.h>
#import <sqlite3.h>

@interface DBManager : NSObject {
   NSString *databasePath;
}

+(DBManager*)getSharedInstance;
-(BOOL)createDB;
-(BOOL) saveData:(NSString*)registerNumber name:(NSString*)name 
   department:(NSString*)department year:(NSString*)year;
-(NSArray*) findByRegisterNumber:(NSString*)registerNumber;

@end

Step 7 - अपडेट DBManager.m निम्नानुसार है -

#import "DBManager.h"
static DBManager *sharedInstance = nil;
static sqlite3 *database = nil;
static sqlite3_stmt *statement = nil;

@implementation DBManager

+(DBManager*)getSharedInstance {
   if (!sharedInstance) {
      sharedInstance = [[super allocWithZone:NULL]init];
      [sharedInstance createDB];
   }
   return sharedInstance;
}

-(BOOL)createDB {
   NSString *docsDir;
   NSArray *dirPaths;
   
   // Get the documents directory
   dirPaths = NSSearchPathForDirectoriesInDomains
   (NSDocumentDirectory, NSUserDomainMask, YES);
   docsDir = dirPaths[0];
   
   // Build the path to the database file
   databasePath = [[NSString alloc] initWithString: 
   [docsDir stringByAppendingPathComponent: @"student.db"]];
   BOOL isSuccess = YES;
   NSFileManager *filemgr = [NSFileManager defaultManager];
   
   if ([filemgr fileExistsAtPath: databasePath ] == NO) {
      const char *dbpath = [databasePath UTF8String];
      if (sqlite3_open(dbpath, &database) == SQLITE_OK) {
         char *errMsg;
         const char *sql_stmt =
         "create table if not exists studentsDetail (regno integer 
         primary key, name text, department text, year text)";
         
         if (sqlite3_exec(database, sql_stmt, NULL, NULL, &errMsg) != SQLITE_OK) {
            isSuccess = NO;
            NSLog(@"Failed to create table");
         }
         sqlite3_close(database);
         return  isSuccess;
      } else {
         isSuccess = NO;
         NSLog(@"Failed to open/create database");
      }
   }    
   return isSuccess;
}

- (BOOL) saveData:(NSString*)registerNumber name:(NSString*)name 
   department:(NSString*)department year:(NSString*)year; {
   const char *dbpath = [databasePath UTF8String];
   
   if (sqlite3_open(dbpath, &database) == SQLITE_OK) {
      NSString *insertSQL = [NSString stringWithFormat:@"insert into
      studentsDetail (regno,name, department, year) values
      (\"%d\",\"%@\", \"%@\", \"%@\")",[registerNumber integerValue],
      name, department, year];        
      const char *insert_stmt = [insertSQL UTF8String];
      sqlite3_prepare_v2(database, insert_stmt,-1, &statement, NULL);
      
      if (sqlite3_step(statement) == SQLITE_DONE) {
         return YES;
      } else {
         return NO;
      }
      sqlite3_reset(statement);
   }
   return NO;
}

- (NSArray*) findByRegisterNumber:(NSString*)registerNumber {
   const char *dbpath = [databasePath UTF8String];
   
   if (sqlite3_open(dbpath, &database) == SQLITE_OK) {
      NSString *querySQL = [NSString stringWithFormat:
      @"select name, department, year from studentsDetail where 
      regno=\"%@\"",registerNumber];
      const char *query_stmt = [querySQL UTF8String];
      NSMutableArray *resultArray = [[NSMutableArray alloc]init];
      
      if (sqlite3_prepare_v2(database, query_stmt, -1, &statement, NULL) == SQLITE_OK) {
         if (sqlite3_step(statement) == SQLITE_ROW) {
            NSString *name = [[NSString alloc] initWithUTF8String:
            (const char *) sqlite3_column_text(statement, 0)];
            [resultArray addObject:name];
            
            NSString *department = [[NSString alloc] initWithUTF8String:
            (const char *) sqlite3_column_text(statement, 1)];
            [resultArray addObject:department];
            
            NSString *year = [[NSString alloc]initWithUTF8String:
            (const char *) sqlite3_column_text(statement, 2)];
            [resultArray addObject:year];
            return resultArray;
         } else {
            NSLog(@"Not found");
            return nil;
         }
         sqlite3_reset(statement);
      }
   }
   return nil;
}

Step 8 - अपडेट ViewController.xib फाइल इस प्रकार है -

Step 9 - उपरोक्त टेक्स्ट फ़ील्ड के लिए IBOutlets बनाएं।

Step 10 - उपरोक्त बटन के लिए आईबीएक्शन बनाएं।

Step 11 - अपडेट ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>
#import "DBManager.h"

@interface ViewController : UIViewController<UITextFieldDelegate> {
   IBOutlet UITextField *regNoTextField;
   IBOutlet UITextField *nameTextField;
   IBOutlet UITextField *departmentTextField;
   IBOutlet UITextField *yearTextField;
   IBOutlet UITextField *findByRegisterNumberTextField;
   IBOutlet UIScrollView *myScrollView;
}

-(IBAction)saveData:(id)sender;
-(IBAction)findData:(id)sender;
@end

Step 12 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (id)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)
   nibBundleOrNil {
   self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil];
   
   if (self) {
      // Custom initialization
   }
   return self;
}

- (void)viewDidLoad {
   [super viewDidLoad];
   // Do any additional setup after loading the view from its nib.
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)saveData:(id)sender {
   BOOL success = NO;
   NSString *alertString = @"Data Insertion failed";
   
   if (regNoTextField.text.length>0 &&nameTextField.text.length>0 &&
      departmentTextField.text.length>0 &&yearTextField.text.length>0 ) {
      success = [[DBManager getSharedInstance]saveData:
      regNoTextField.text name:nameTextField.text department:
      departmentTextField.text year:yearTextField.text];
   } else {
      alertString = @"Enter all fields";
   }     
   
   if (success == NO) {
      UIAlertView *alert = [[UIAlertView alloc]initWithTitle:
      alertString message:nil
      delegate:nil cancelButtonTitle:@"OK" otherButtonTitles:nil];
      [alert show];
   }
}

-(IBAction)findData:(id)sender {
   NSArray *data = [[DBManager getSharedInstance]findByRegisterNumber:
   findByRegisterNumberTextField.text];
   
   if (data == nil) {
      UIAlertView *alert = [[UIAlertView alloc]initWithTitle:
      @"Data not found" message:nil delegate:nil cancelButtonTitle:
      @"OK" otherButtonTitles:nil];
      [alert show];
      regNoTextField.text = @"";
      nameTextField.text =@"";
      departmentTextField.text = @"";
      yearTextField.text =@"";
   } else {
      regNoTextField.text = findByRegisterNumberTextField.text;
      nameTextField.text =[data objectAtIndex:0];
      departmentTextField.text = [data objectAtIndex:1];
      yearTextField.text =[data objectAtIndex:2];
   }
}

#pragma mark - Text field delegate
-(void)textFieldDidBeginEditing:(UITextField *)textField {
   [myScrollView setFrame:CGRectMake(10, 50, 300, 200)];
   [myScrollView setContentSize:CGSizeMake(300, 350)];
}

-(void)textFieldDidEndEditing:(UITextField *)textField {
   [myScrollView setFrame:CGRectMake(10, 50, 300, 350)];

}

-(BOOL) textFieldShouldReturn:(UITextField *)textField {
   [textField resignFirstResponder];
   return YES;
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्नलिखित आउटपुट मिलेंगे जहां हम छात्र विवरण जोड़ सकते हैं और पा सकते हैं -

हम आईओएस डिवाइस के ईमेल एप्लिकेशन का उपयोग करके ईमेल भेज सकते हैं।

कदम शामिल किए गए

Step 1 - एक सरल बनाएँ View based application

Step 2 - अपनी प्रोजेक्ट फ़ाइल चुनें, फिर लक्ष्य चुनें और फिर जोड़ें MessageUI.framework

Step 3 - में एक बटन जोड़ें ViewController.xib और ईमेल भेजने के लिए एक क्रिया बनाएँ।

Step 4 - अपडेट ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>
#import <MessageUI/MessageUI.h>

@interface ViewController : UIViewController<MFMailComposeViewControllerDelegate> {
   MFMailComposeViewController *mailComposer;
}

-(IBAction)sendMail:(id)sender;

@end

Step 5 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(void)sendMail:(id)sender {
   mailComposer = [[MFMailComposeViewController alloc]init];
   mailComposer.mailComposeDelegate = self;
   [mailComposer setSubject:@"Test mail"];
   [mailComposer setMessageBody:@"Testing message 
   for the test mail" isHTML:NO];
   [self presentModalViewController:mailComposer animated:YES];
}

#pragma mark - mail compose delegate
-(void)mailComposeController:(MFMailComposeViewController *)controller 
   didFinishWithResult:(MFMailComposeResult)result error:(NSError *)error{
   
   if (result) {
      NSLog(@"Result : %d",result);
   }
   
   if (error) {
      NSLog(@"Error : %@",error);
   }
   
   [self dismissModalViewControllerAnimated:YES];
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

Send Email पर क्लिक करने पर, हमें निम्न आउटपुट प्राप्त होंगे -

नवीनतम उपकरणों में ऑडियो और वीडियो काफी सामान्य है। की मदद से इसे iOS में सपोर्ट किया गया हैAVFoundation.framework तथा MediaPlayer.framework क्रमशः।

कदम शामिल किए गए

Step 1 - एक सरल बनाएँ View based application

Step 2 - अपनी परियोजना फ़ाइल का चयन करें, लक्ष्य का चयन करें, और फिर हमें जोड़ना चाहिए AVFoundation.framework तथा MediaPlayer.framework

Step 3 - ViewController.xib में दो बटन जोड़ें और क्रमशः ऑडियो और वीडियो चलाने के लिए एक क्रिया बनाएं।

Step 4 - अपडेट ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>
#import <AVFoundation/AVFoundation.h>
#import <MediaPlayer/MediaPlayer.h>

@interface ViewController : UIViewController {
   AVAudioPlayer *audioPlayer;
   MPMoviePlayerViewController *moviePlayer;
}
-(IBAction)playAudio:(id)sender;
-(IBAction)playVideo:(id)sender;
@end

Step 5 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)playAudio:(id)sender {
   NSString *path = [[NSBundle mainBundle]
   pathForResource:@"audioTest" ofType:@"mp3"];
   audioPlayer = [[AVAudioPlayer alloc]initWithContentsOfURL:
   [NSURL fileURLWithPath:path] error:NULL];
   [audioPlayer play];
}

-(IBAction)playVideo:(id)sender {
   NSString *path = [[NSBundle mainBundle]pathForResource:
   @"videoTest" ofType:@"mov"];
   moviePlayer = [[MPMoviePlayerViewController 
   alloc]initWithContentURL:[NSURL fileURLWithPath:path]];
   [self presentModalViewController:moviePlayer animated:NO];
}
@end

ध्यान दें

हमें यह सुनिश्चित करने के लिए ऑडियो और वीडियो फ़ाइलों को जोड़ना होगा कि हमें अपेक्षित आउटपुट मिले।

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

जब हम play वीडियो पर क्लिक करेंगे, तो हमें नीचे दिखाया गया आउटपुट मिलेगा -

जब हम play ऑडियो पर क्लिक करेंगे, तो आप ऑडियो सुनेंगे।

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

फ़ाइल हैंडलिंग में उपयोग किए जाने वाले तरीके

के लिए इस्तेमाल की जाने वाली विधियाँ accessing तथा manipulatingफाइलें नीचे चर्चा की गई हैं। यहां हमें वांछित कार्रवाई पाने के लिए FilePath1, FilePath2 और FilePath तार को हमारे आवश्यक पूर्ण फ़ाइल पथों पर बदलना होगा।

जाँच करें कि क्या कोई फ़ाइल पथ पर मौजूद है

NSFileManager *fileManager = [NSFileManager defaultManager];

//Get documents directory
NSArray *directoryPaths = NSSearchPathForDirectoriesInDomains
(NSDocumentDirectory, NSUserDomainMask, YES);
NSString *documentsDirectoryPath = [directoryPaths objectAtIndex:0];

if ([fileManager fileExistsAtPath:@""]==YES) {
   NSLog(@"File exists");
}

दो फ़ाइल सामग्री की तुलना

if ([fileManager contentsEqualAtPath:@"FilePath1" andPath:@" FilePath2"]) {
   NSLog(@"Same content");
}

जाँच करें कि क्या लिखने योग्य, पठनीय और निष्पादन योग्य है

if ([fileManager isWritableFileAtPath:@"FilePath"]) {
   NSLog(@"isWritable");
}

if ([fileManager isReadableFileAtPath:@"FilePath"]) {
   NSLog(@"isReadable");
}

if ( [fileManager isExecutableFileAtPath:@"FilePath"]) {
   NSLog(@"is Executable");
}

फ़ाइल ले जाएँ

if([fileManager moveItemAtPath:@"FilePath1" 
   toPath:@"FilePath2" error:NULL]) {
   NSLog(@"Moved successfully");
}

प्रतिलिपि फ़ाइल

if ([fileManager copyItemAtPath:@"FilePath1" 
   toPath:@"FilePath2"  error:NULL]) {
   NSLog(@"Copied successfully");
}

फ़ाइल को हटाएं

if ([fileManager removeItemAtPath:@"FilePath" error:NULL]) {
   NSLog(@"Removed successfully");
}

फ़ाइल पढ़ें

NSData *data = [fileManager contentsAtPath:@"Path"];

फ़ाइल लिखें

[fileManager createFileAtPath:@"" contents:data attributes:nil];

मानचित्र हमेशा स्थानों का पता लगाने में हमारे लिए सहायक होते हैं। MapKit फ्रेमवर्क का उपयोग करके मैप्स को iOS में एकीकृत किया गया है।

कदम शामिल किए गए

Step 1 - एक साधारण दृश्य-आधारित एप्लिकेशन बनाएं।

Step 2 - अपनी परियोजना फ़ाइल चुनें, फिर लक्ष्य चुनें और फिर MapKit.framework जोड़ें।

Step 3 - हमें Corelocation.framework भी जोड़ना चाहिए।

Step 4 - ViewController.xib में एक MapView जोड़ें और एक ibOutlet बनाएं और इसे mapView के रूप में नाम दें।

Step 5 - फ़ाइल → नई → फ़ाइल ... का चयन करके एक नई फ़ाइल बनाएं → ऑब्जेक्ट सी क्लास का चयन करें और अगले पर क्लिक करें।

Step 6 - NSAbject के रूप में "उप वर्ग" के साथ MapAnnotation के रूप में वर्ग का नाम।

Step 7 - सेलेक्ट क्रिएट करें।

Step 8 - अद्यतन MapAnnotation.h निम्नानुसार है -

#import <Foundation/Foundation.h>
#import <MapKit/MapKit.h>

@interface MapAnnotation : NSObject<MKAnnotation>
@property (nonatomic, strong) NSString *title;
@property (nonatomic, readwrite) CLLocationCoordinate2D coordinate;

- (id)initWithTitle:(NSString *)title andCoordinate:
   (CLLocationCoordinate2D)coordinate2d;

@end

Step 9 - अपडेट MapAnnotation.m निम्नानुसार है -

#import "MapAnnotation.h"

@implementation MapAnnotation
-(id)initWithTitle:(NSString *)title andCoordinate:
   (CLLocationCoordinate2D)coordinate2d {
  
   self.title = title;
   self.coordinate =coordinate2d;
   return self;
}
@end

Step 10 - अपडेट ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>
#import <MapKit/MapKit.h>
#import <CoreLocation/CoreLocation.h>

@interface ViewController : UIViewController<MKMapViewDelegate> {
   MKMapView *mapView;
}
@end

Step 11 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"
#import "MapAnnotation.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   mapView = [[MKMapView alloc]initWithFrame:
   CGRectMake(10, 100, 300, 300)];
   mapView.delegate = self;
   mapView.centerCoordinate = CLLocationCoordinate2DMake(37.32, -122.03);
   mapView.mapType = MKMapTypeHybrid;
   CLLocationCoordinate2D location;
   location.latitude = (double) 37.332768;
   location.longitude = (double) -122.030039;
   
   // Add the annotation to our map view
   MapAnnotation *newAnnotation = [[MapAnnotation alloc]
   initWithTitle:@"Apple Head quaters" andCoordinate:location];
   [mapView addAnnotation:newAnnotation];
   CLLocationCoordinate2D location2;
   location2.latitude = (double) 37.35239;
   location2.longitude = (double) -122.025919;
   MapAnnotation *newAnnotation2 = [[MapAnnotation alloc] 
   initWithTitle:@"Test annotation" andCoordinate:location2];
   [mapView addAnnotation:newAnnotation2];
   [self.view addSubview:mapView];
}

// When a map annotation point is added, zoom to it (1500 range)
- (void)mapView:(MKMapView *)mv didAddAnnotationViews:(NSArray *)views {
   MKAnnotationView *annotationView = [views objectAtIndex:0];
   id <MKAnnotation> mp = [annotationView annotation];
   MKCoordinateRegion region = MKCoordinateRegionMakeWithDistance
   ([mp coordinate], 1500, 1500);
   [mv setRegion:region animated:YES];
   [mv selectAnnotation:mp animated:YES];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें नीचे दिखाए अनुसार आउटपुट मिलेगा -

जब हम नक्शा ऊपर स्क्रॉल करेंगे, तो हमें नीचे दिखाए अनुसार आउटपुट मिलेगा -

इन-ऐप खरीदारी का उपयोग अतिरिक्त सामग्री खरीदने या किसी एप्लिकेशन के संबंध में सुविधाओं को अपग्रेड करने के लिए किया जाता है।

कदम शामिल किए गए

Step 1 - आईट्यून्स में कनेक्ट, सुनिश्चित करें कि आपके पास ए unique App ID और जब हम के साथ एप्लिकेशन अपडेट बनाते हैं bundle ID और संबंधित प्रावधान प्रोफ़ाइल के साथ Xcode में कोड साइनिंग।

Step 2- एक नया एप्लिकेशन बनाएं और एप्लिकेशन जानकारी अपडेट करें। आप सेब में इसके बारे में अधिक जान सकते हैंAdd new apps प्रलेखन।

Step 3 - में app खरीद के लिए एक नया उत्पाद जोड़ें Manage In-App Purchase आपके आवेदन के पेज पर

Step 4- सुनिश्चित करें कि आप अपने आवेदन के लिए बैंक विवरण सेट करें। इसके लिए सेटअप होना आवश्यक हैIn-App purchaseकाम करने के लिए। इसके अलावा, परीक्षण उपयोगकर्ता खाते का उपयोग करके बनाएंManage Users आईट्यून्स में विकल्प आपके ऐप के पेज को कनेक्ट करता है।

Step 5 - अगले चरण कोड से निपटने और हमारे इन-ऐप खरीदारी के लिए UI बनाने से संबंधित हैं।

Step 6 - एक बनाएँ single view application और बंडल पहचानकर्ता दर्ज करें आईट्यून्स कनेक्ट में निर्दिष्ट पहचानकर्ता है।

Step 7 - अपडेट करें ViewController.xib जैसा कि नीचे दिखाया गया है -

Step 8 - बनाएं IBOutlets तीन लेबल और बटन के लिए उनका नामकरण क्रमशः ProductTitleLabel, ProductDescriptionLabel, ProductPriceLabel और खरीदबटन के रूप में किया जाता है।

Step 9 - अपनी प्रोजेक्ट फ़ाइल चुनें, फिर लक्ष्य चुनें और फिर जोड़ें StoreKit.framework

Step 10 - अपडेट ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>
#import <StoreKit/StoreKit.h>

@interface ViewController : UIViewController<
SKProductsRequestDelegate,SKPaymentTransactionObserver> {
   SKProductsRequest *productsRequest;
   NSArray *validProducts;
   UIActivityIndicatorView *activityIndicatorView;
   IBOutlet UILabel *productTitleLabel;
   IBOutlet UILabel *productDescriptionLabel;
   IBOutlet UILabel *productPriceLabel;
   IBOutlet UIButton *purchaseButton;
}

- (void)fetchAvailableProducts;
- (BOOL)canMakePurchases;
- (void)purchaseMyProduct:(SKProduct*)product;
- (IBAction)purchase:(id)sender;

@end

Step 11 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"
#define kTutorialPointProductID 
@"com.tutorialPoints.testApp.testProduct"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   
   // Adding activity indicator
   activityIndicatorView = [[UIActivityIndicatorView alloc]
   initWithActivityIndicatorStyle:UIActivityIndicatorViewStyleWhiteLarge];
   activityIndicatorView.center = self.view.center;
   [activityIndicatorView hidesWhenStopped];
   [self.view addSubview:activityIndicatorView];
   [activityIndicatorView startAnimating];
   
   //Hide purchase button initially
   purchaseButton.hidden = YES;
   [self fetchAvailableProducts];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(void)fetchAvailableProducts {
   NSSet *productIdentifiers = [NSSet 
   setWithObjects:kTutorialPointProductID,nil];
   productsRequest = [[SKProductsRequest alloc] 
   initWithProductIdentifiers:productIdentifiers];
   productsRequest.delegate = self;
   [productsRequest start];
}

- (BOOL)canMakePurchases {
   return [SKPaymentQueue canMakePayments];
}

- (void)purchaseMyProduct:(SKProduct*)product {
   if ([self canMakePurchases]) {
      SKPayment *payment = [SKPayment paymentWithProduct:product];
      [[SKPaymentQueue defaultQueue] addTransactionObserver:self];
      [[SKPaymentQueue defaultQueue] addPayment:payment];
   } else {
      UIAlertView *alertView = [[UIAlertView alloc]initWithTitle:
      @"Purchases are disabled in your device" message:nil delegate:
      self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
      [alertView show];
   }
}
-(IBAction)purchase:(id)sender {
   [self purchaseMyProduct:[validProducts objectAtIndex:0]];
   purchaseButton.enabled = NO; 
}

#pragma mark StoreKit Delegate

-(void)paymentQueue:(SKPaymentQueue *)queue 
updatedTransactions:(NSArray *)transactions {
   for (SKPaymentTransaction *transaction in transactions) {
      switch (transaction.transactionState) {
         case SKPaymentTransactionStatePurchasing:
            NSLog(@"Purchasing");
         break;
         
         case SKPaymentTransactionStatePurchased:
            if ([transaction.payment.productIdentifier 
            isEqualToString:kTutorialPointProductID]) {
               NSLog(@"Purchased ");
               UIAlertView *alertView = [[UIAlertView alloc]initWithTitle:
               @"Purchase is completed succesfully" message:nil delegate:
               self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
               [alertView show];
            }
            [[SKPaymentQueue defaultQueue] finishTransaction:transaction];
         break;
            
         case SKPaymentTransactionStateRestored:
            NSLog(@"Restored ");
            [[SKPaymentQueue defaultQueue] finishTransaction:transaction];
         break;
            
         case SKPaymentTransactionStateFailed:
            NSLog(@"Purchase failed ");
         break
         default:
         break;
      }
   }
}

-(void)productsRequest:(SKProductsRequest *)request 
didReceiveResponse:(SKProductsResponse *)response {
   SKProduct *validProduct = nil;
   int count = [response.products count];
   
   if (count>0) {
      validProducts = response.products;
      validProduct = [response.products objectAtIndex:0];
      
      if ([validProduct.productIdentifier 
         isEqualToString:kTutorialPointProductID]) {
         [productTitleLabel setText:[NSString stringWithFormat:
            @"Product Title: %@",validProduct.localizedTitle]];
         [productDescriptionLabel setText:[NSString stringWithFormat:
            @"Product Desc: %@",validProduct.localizedDescription]];
         [productPriceLabel setText:[NSString stringWithFormat:
            @"Product Price: %@",validProduct.price]];
      }
   } else {
      UIAlertView *tmp = [[UIAlertView alloc]
         initWithTitle:@"Not Available"
         message:@"No products to purchase"
         delegate:self
         cancelButtonTitle:nil
         otherButtonTitles:@"Ok", nil];
         [tmp show];
   }
   
   [activityIndicatorView stopAnimating];
   purchaseButton.hidden = NO;
}
@end

ध्यान दें

आपको अपने इन-ऐप खरीदारी के लिए बनाए गए उत्पाद को kTutorialPointProductID को अपडेट करना होगा। आप productAdentifiers के NSSet को fetchAvailableProducts में अपडेट करके एक से अधिक उत्पाद जोड़ सकते हैं। Similary, आपके द्वारा जोड़े गए उत्पाद ID के लिए खरीदारी से संबंधित कार्यों को संभालती है।

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

सुनिश्चित करें कि आपने सेटिंग स्क्रीन में अपने खाते से लॉग आउट किया है। पहल खरीद पर क्लिक करें, मौजूदा एप्पल आईडी का उपयोग करें चुनें। अपना मान्य परीक्षण खाता उपयोगकर्ता नाम और पासवर्ड दर्ज करें। आपको कुछ ही सेकंड में निम्नलिखित चेतावनी दिखाई जाएगी।

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

iAd का उपयोग विज्ञापन प्रदर्शित करने के लिए किया जाता है, जो Apple सर्वर द्वारा दिया जाता है। iOS विज्ञापन से आय अर्जित करने में iAd हमारी मदद करता है।

iAd एकीकरण - शामिल कदम

Step 1 - एक साधारण दृश्य-आधारित एप्लिकेशन बनाएं।

Step 2 - अपनी परियोजना फ़ाइल का चयन करें, फिर लक्ष्य का चयन करें और फिर चुनें फ्रेम में iAd.framework जोड़ें।

Step 3 - अद्यतन ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>
#import <iAd/iAd.h>

@interface ViewController : UIViewController<ADBannerViewDelegate> {
   ADBannerView *bannerView;
}
@end

Step 4 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   bannerView = [[ADBannerView alloc]initWithFrame:
   CGRectMake(0, 0, 320, 50)];
   
   // Optional to set background color to clear color
   [bannerView setBackgroundColor:[UIColor clearColor]];
   [self.view addSubview: bannerView];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

#pragma mark - AdViewDelegates

-(void)bannerView:(ADBannerView *)banner 
   didFailToReceiveAdWithError:(NSError *)error {
   NSLog(@"Error loading");
}

-(void)bannerViewDidLoadAd:(ADBannerView *)banner {
   NSLog(@"Ad loaded");
}

-(void)bannerViewWillLoadAd:(ADBannerView *)banner {
   NSLog(@"Ad will load");
}

-(void)bannerViewActionDidFinish:(ADBannerView *)banner {
   NSLog(@"Ad did finish");
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

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

कदम शामिल किए गए

Step 1 - आईट्यून्स में कनेक्ट, सुनिश्चित करें कि आपके पास ए unique App ID और जब हम के साथ एप्लिकेशन अपडेट बनाते हैं bundle ID और संबंधित प्रावधान प्रोफ़ाइल के साथ Xcode में कोड साइनिंग।

Step 2- एक नया एप्लिकेशन बनाएं और एप्लिकेशन जानकारी अपडेट करें। आप इसके बारे में ऐप्पल-ऐड न्यू ऐप्स डॉक्यूमेंटेशन में अधिक जान सकते हैं।

Step 3 - में एक नेता बोर्ड की स्थापना Manage Game Center अपने आवेदन के पृष्ठ पर जहां एक लीडरबोर्ड जोड़ें और दें leaderboard IDऔर स्कोर प्रकार। यहां हम लीडर बोर्ड आईडी को TutorialPoint के रूप में देते हैं।

Step 4 - अगले चरण कोड से निपटने और हमारे आवेदन के लिए UI बनाने से संबंधित हैं।

Step 5 - एक बनाएँ single view application और दर्ज करें bundle identifier में निर्दिष्ट पहचानकर्ता है iTunes connect

Step 6 - नीचे दिखाए अनुसार ViewController.xib अपडेट करें -

Step 7 - अपनी प्रोजेक्ट फ़ाइल चुनें, फिर चुनें targets और फिर जोड़ें GameKit.framework

Step 8 - बनाएं IBActions हमारे द्वारा जोड़े गए बटनों के लिए।

Step 9 - अपडेट करें ViewController.h फाइल इस प्रकार है -

#import <UIKit/UIKit.h>
#import <GameKit/GameKit.h>

@interface ViewController : UIViewController
<GKLeaderboardViewControllerDelegate>

-(IBAction)updateScore:(id)sender;
-(IBAction)showLeaderBoard:(id)sender;

@end

Step 10 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   if([GKLocalPlayer localPlayer].authenticated == NO) {
      [[GKLocalPlayer localPlayer] 
      authenticateWithCompletionHandler:^(NSError *error) {
         NSLog(@"Error%@",error);
      }];
   }    
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

- (void) updateScore: (int64_t) score 
   forLeaderboardID: (NSString*) category {
   GKScore *scoreObj = [[GKScore alloc]
   initWithCategory:category];
   scoreObj.value = score;
   scoreObj.context = 0;
   
   [scoreObj reportScoreWithCompletionHandler:^(NSError *error) {
      // Completion code can be added here
      UIAlertView *alert = [[UIAlertView alloc]
      initWithTitle:nil message:@"Score Updated Succesfully" 
      delegate:self cancelButtonTitle:@"Ok" otherButtonTitles: nil];
      [alert show];
   }];
}

-(IBAction)updateScore:(id)sender {
   [self updateScore:200 forLeaderboardID:@"tutorialsPoint"];
}

-(IBAction)showLeaderBoard:(id)sender {
   GKLeaderboardViewController *leaderboardViewController =
   [[GKLeaderboardViewController alloc] init];
   leaderboardViewController.leaderboardDelegate = self;
   [self presentModalViewController:
   leaderboardViewController animated:YES];
}

#pragma mark - Gamekit delegates
- (void)leaderboardViewControllerDidFinish:
(GKLeaderboardViewController *)viewController {
   [self dismissModalViewControllerAnimated:YES];
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

जब हम "शो लीडर बोर्ड" पर क्लिक करते हैं, तो हमें निम्नलिखित के समान स्क्रीन मिलेगी -

जब हम "अपडेट स्कोर" पर क्लिक करते हैं, तो स्कोर हमारे लीडर बोर्ड को अपडेट किया जाएगा और हमें नीचे दिखाया गया अलर्ट मिलेगा -

स्टोरीबोर्ड आईओएस 5 में पेश किए गए हैं। जब हम स्टोरीबोर्ड का उपयोग करते हैं, तो हमारा परिनियोजन लक्ष्य 5.0 या उच्चतर होना चाहिए। स्टोरीबोर्ड हमें किसी एप्लिकेशन के सभी स्क्रीन बनाने में मदद करता है और स्क्रीन को एक इंटरफ़ेस MainStoryboard.storyboard के अंतर्गत इंटरकनेक्ट करता है। यह व्यू कंट्रोलर्स को पुश / प्रेजेंट करने की कोडिंग को कम करने में भी मदद करता है।

कदम शामिल किए गए

Step 1 - एक बनाएँ single view application और सुनिश्चित करें कि आप का चयन करें storyboard एप्लिकेशन बनाते समय चेकबॉक्स।

Step 2 - चयन करें MainStoryboard.storyboardजहाँ आप एकल दृश्य नियंत्रक पा सकते हैं। एक और दृश्य नियंत्रक जोड़ें और नीचे दिखाए गए अनुसार दृश्य नियंत्रकों को अपडेट करें।

Step 3- अब हम दोनों व्यू कंट्रोलर को कनेक्ट करते हैं। "शो मोडल" बटन पर राइट-क्लिक करें और इसे नीचे दिखाए गए अनुसार बाएं साइड व्यू कंट्रोलर में राइट व्यू कंट्रोलर पर खींचें।

Step 4 - नीचे दिखाए गए तीन विकल्पों में से मोडल का चयन करें।

Step 5 - अपडेट ViewController.h निम्नानुसार है -

#import <UIKit/UIKit.h>

@interface ViewController : UIViewController

-(IBAction)done:(UIStoryboardSegue *)seque;

@end

Step 6 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];	
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)done:(UIStoryboardSegue *)seque {
   [self.navigationController popViewControllerAnimated:YES];
}

@end

Step 7 - मेनस्टोरीबोर्ड।स्टोरीबोर्ड का चयन करें और राइट साइड व्यू कंट्रोलर में एक्जिट बटन पर राइट क्लिक करें, चयन करें और नीचे दिखाए गए बटन के साथ कनेक्ट करें।

उत्पादन

जब हम एप्लिकेशन को ए में चलाते हैं iPhone डिवाइस, हम निम्नलिखित उत्पादन प्राप्त करेंगे -

जब हम "शो मोडल" चुनते हैं, तो हमें निम्नलिखित आउटपुट मिलेंगे -

ऑटो-लेआउट में पेश किए गए थे iOS 6.0.जब हम ऑटो-लेआउट का उपयोग करते हैं, तो हमारा परिनियोजन लक्ष्य 6.0 और उच्चतर होना चाहिए। ऑटो-लेआउट हमें ऐसे इंटरफेस बनाने में मदद करते हैं जिनका उपयोग कई झुकाव और कई उपकरणों के लिए किया जा सकता है।

हमारे उदाहरण का लक्ष्य

हम दो बटन जोड़ेंगे जिन्हें स्क्रीन के केंद्र से एक निश्चित दूरी पर रखा जाएगा। हम एक resizable पाठ फ़ील्ड को जोड़ने का भी प्रयास करेंगे जो कि बटन के ऊपर से एक निश्चित दूरी से रखा जाएगा।

हमारा दृष्टिकोण

हम कोड में एक पाठ क्षेत्र और दो बटन जोड़ेंगे, साथ ही उनकी कमी भी। प्रत्येक UI तत्वों की बाधाओं को बनाया जाएगा और सुपर दृश्य में जोड़ा जाएगा। हमें वांछित परिणाम प्राप्त करने के लिए हमारे द्वारा जोड़े गए प्रत्येक UI तत्वों के लिए ऑटो-आकार को अक्षम करना होगा।

कदम शामिल किए गए

Step 1 - एक साधारण दृश्य-आधारित एप्लिकेशन बनाएं।

Step 2 - हम केवल ViewController.m संपादित करेंगे और यह इस प्रकार है -

#import "ViewController.h"

@interface ViewController ()
@property (nonatomic, strong) UIButton *leftButton;
@property (nonatomic, strong) UIButton *rightButton;
@property (nonatomic, strong) UITextField *textfield;

@end
@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
   UIView *superview = self.view;

   /*1. Create leftButton and add to our view*/
   self.leftButton = [UIButton buttonWithType:UIButtonTypeRoundedRect];
   self.leftButton.translatesAutoresizingMaskIntoConstraints = NO;
   [self.leftButton setTitle:@"LeftButton" forState:UIControlStateNormal];
   [self.view addSubview:self.leftButton];

   /* 2. Constraint to position LeftButton's X*/
   NSLayoutConstraint *leftButtonXConstraint = [NSLayoutConstraint 
   constraintWithItem:self.leftButton attribute:NSLayoutAttributeCenterX 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
   NSLayoutAttributeCenterX multiplier:1.0 constant:-60.0f];

   /* 3. Constraint to position LeftButton's Y*/
   NSLayoutConstraint *leftButtonYConstraint = [NSLayoutConstraint 
   constraintWithItem:self.leftButton attribute:NSLayoutAttributeCenterY 
   relatedBy:NSLayoutRelationEqual toItem:superview attribute:
   NSLayoutAttributeCenterY multiplier:1.0f constant:0.0f];

   /* 4. Add the constraints to button's superview*/
   [superview addConstraints:@[ leftButtonXConstraint,
   leftButtonYConstraint]];

   /*5. Create rightButton and add to our view*/
   self.rightButton = [UIButton buttonWithType:UIButtonTypeRoundedRect];
   self.rightButton.translatesAutoresizingMaskIntoConstraints = NO;
   [self.rightButton setTitle:@"RightButton" forState:UIControlStateNormal];
   [self.view addSubview:self.rightButton];

   /*6. Constraint to position RightButton's X*/
   NSLayoutConstraint *rightButtonXConstraint = [NSLayoutConstraint 
   constraintWithItem:self.rightButton attribute:NSLayoutAttributeCenterX 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
   NSLayoutAttributeCenterX multiplier:1.0 constant:60.0f];

   /*7. Constraint to position RightButton's Y*/
   rightButtonXConstraint.priority = UILayoutPriorityDefaultHigh;
   NSLayoutConstraint *centerYMyConstraint = [NSLayoutConstraint 
   constraintWithItem:self.rightButton attribute:NSLayoutAttributeCenterY 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
   NSLayoutAttributeCenterY multiplier:1.0f constant:0.0f];
   [superview addConstraints:@[centerYMyConstraint,
   rightButtonXConstraint]];

   //8. Add Text field
   self.textfield = [[UITextField alloc]initWithFrame:
   CGRectMake(0, 100, 100, 30)];
   self.textfield.borderStyle = UITextBorderStyleRoundedRect;
   self.textfield.translatesAutoresizingMaskIntoConstraints = NO;
   [self.view addSubview:self.textfield];

   //9. Text field Constraints
   NSLayoutConstraint *textFieldTopConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeTop 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview 
   attribute:NSLayoutAttributeTop multiplier:1.0 constant:60.0f];
   NSLayoutConstraint *textFieldBottomConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeTop 
   relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:self.rightButton 
   attribute:NSLayoutAttributeTop multiplier:0.8 constant:-60.0f];
   NSLayoutConstraint *textFieldLeftConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeLeft 
   relatedBy:NSLayoutRelationEqual toItem:superview attribute:
   NSLayoutAttributeLeft multiplier:1.0 constant:30.0f];
   NSLayoutConstraint *textFieldRightConstraint = [NSLayoutConstraint 
   constraintWithItem:self.textfield attribute:NSLayoutAttributeRight 
   relatedBy:NSLayoutRelationEqual toItem:superview attribute:
   NSLayoutAttributeRight multiplier:1.0 constant:-30.0f];
   [superview addConstraints:@[textFieldBottomConstraint ,
   textFieldLeftConstraint, textFieldRightConstraint, 
   textFieldTopConstraint]];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}
@end

नोट करने के लिए अंक

1, 5, और 8 के चरणों में, हमने क्रमशः दो बटन और एक पाठ क्षेत्र जोड़ा है।

बाकी चरणों में, हमने बाधाओं को बनाया और उन बाधाओं को संबंधित सुपर विचारों में जोड़ा, जो वास्तव में आत्म-विचार हैं। बाएं बटन में से एक की बाधाओं को नीचे दिखाया गया है -

NSLayoutConstraint *leftButtonXConstraint = [NSLayoutConstraint 
constraintWithItem:self.leftButton attribute:NSLayoutAttributeCenterX 
relatedBy:NSLayoutRelationGreaterThanOrEqual toItem:superview attribute:
NSLayoutAttributeCenterX multiplier:1.0 constant:-60.0f];

हमारे पास बाधाएं हैं और यह यह तय करता है कि हम किन यूआई तत्वों के बीच बाधा पैदा कर रहे हैं। विशेषता यह तय करती है कि दोनों तत्व किस आधार पर एक साथ जुड़े हुए हैं। "संबंधितबी" यह तय करता है कि तत्वों के बीच विशेषताओं का कितना प्रभाव है। गुणक गुणन कारक है और गुणक में निरंतर जोड़ा जाएगा।

उपरोक्त उदाहरण में, लेफ्टबॉटन का एक्स सुपर दृश्य के केंद्र के संबंध में -60 पिक्सेल से हमेशा अधिक या बराबर होता है। इसी तरह, अन्य बाधाओं को परिभाषित किया गया है।

उत्पादन

जब हम एप्लिकेशन चलाते हैं, तो हमें iPhone सिम्युलेटर पर निम्न आउटपुट मिलेगा -

जब हम सिम्युलेटर के उन्मुखीकरण को परिदृश्य में बदलते हैं, तो हमें निम्नलिखित आउटपुट मिलेगा -

जब हम iPhone 5 सिम्युलेटर पर एक ही एप्लिकेशन चलाते हैं, तो हमें निम्न आउटपुट प्राप्त होंगे -

जब हम सिम्युलेटर के उन्मुखीकरण को परिदृश्य में बदलते हैं, तो हमें निम्नलिखित आउटपुट मिलेगा -

ट्विटर में एकीकृत किया गया है iOS 5.0 और फेसबुक को एकीकृत किया गया है iOS 6.0। हमारा ट्यूटोरियल Apple द्वारा प्रदान की गई कक्षाओं का उपयोग करने पर ध्यान केंद्रित करता है और ट्विटर और फेसबुक के लिए तैनाती लक्ष्य क्रमशः iOS 5.0 और iOS 6.0 हैं।

कदम शामिल किए गए

Step 1 - एक साधारण दृश्य-आधारित एप्लिकेशन बनाएं।

Step 2 - अपनी प्रोजेक्ट फ़ाइल चुनें, फिर चुनें targets और फिर जोड़ें Social.frameworके और Accounts.framework में choose frameworks

Step 3 - facebookPost और twitterPost नाम के दो बटन जोड़ें और उनके लिए ibActions बनाएं।

Step 4 - अपडेट ViewController.h निम्नानुसार है -

#import <Social/Social.h>
#import <Accounts/Accounts.h>
#import <UIKit/UIKit.h>

@interface ViewController : UIViewController

-(IBAction)twitterPost:(id)sender;
-(IBAction)facebookPost:(id)sender;

@end

Step 5 - अपडेट ViewController.m निम्नानुसार है -

#import "ViewController.h"

@interface ViewController ()
@end

@implementation ViewController

- (void)viewDidLoad {
   [super viewDidLoad];
}

- (void)didReceiveMemoryWarning {
   [super didReceiveMemoryWarning];
   // Dispose of any resources that can be recreated.
}

-(IBAction)facebookPost:(id)sender {
   SLComposeViewController *controller = [SLComposeViewController 
   composeViewControllerForServiceType:SLServiceTypeFacebook];
   SLComposeViewControllerCompletionHandler myBlock = 
      ^(SLComposeViewControllerResult result){
      
      if (result == SLComposeViewControllerResultCancelled) {
         NSLog(@"Cancelled");
      } else {
         NSLog(@"Done");
      }
      [controller dismissViewControllerAnimated:YES completion:nil];
   };
   controller.completionHandler = myBlock;

   //Adding the Text to the facebook post value from iOS
   [controller setInitialText:@"My test post"];

   //Adding the URL to the facebook post value from iOS
   [controller addURL:[NSURL URLWithString:@"http://www.test.com"]];

   //Adding the Text to the facebook post value from iOS
   [self presentViewController:controller animated:YES completion:nil];
}

-(IBAction)twitterPost:(id)sender {
   SLComposeViewController *tweetSheet = [SLComposeViewController 
   composeViewControllerForServiceType:SLServiceTypeTwitter];
   [tweetSheet setInitialText:@"My test tweet"];
   [self presentModalViewController:tweetSheet animated:YES];
}
@end

उत्पादन

जब हम एप्लिकेशन चलाते हैं और facebookPost पर क्लिक करते हैं, तो हमें निम्न आउटपुट मिलेंगे -

जब हम twitterPost पर क्लिक करेंगे, तो हमें निम्न आउटपुट मिलेंगे -

IOS में मेमोरी प्रबंधन शुरू में नॉन-एआरसी (ऑटोमैटिक रेफरेंस काउंटिंग) था, जहां हमें वस्तुओं को बनाए रखना और जारी करना होता है। अब, यह एआरसी का समर्थन करता है और हमें वस्तुओं को बनाए रखने और जारी करने की आवश्यकता नहीं है। Xcode संकलन समय में स्वचालित रूप से नौकरी का ख्याल रखता है।

मेमोरी प्रबंधन के मुद्दे

Apple प्रलेखन के अनुसार, स्मृति प्रबंधन में दो प्रमुख मुद्दे हैं -

  • नि: शुल्क या अधिलेखित डेटा जो अभी भी उपयोग में है। यह स्मृति भ्रष्टाचार का कारण बनता है और आमतौर पर आपके आवेदन के दुर्घटनाग्रस्त होने, या बदतर, दूषित उपयोगकर्ता डेटा के परिणामस्वरूप होता है।

  • डेटा को मुक्त नहीं करना जो अब उपयोग में नहीं है, मेमोरी लीक का कारण बनता है। जब आवंटित मेमोरी को मुक्त नहीं किया जाता है, भले ही इसे फिर से उपयोग नहीं किया जाए, तो इसे मेमोरी लीक के रूप में जाना जाता है। लीक्स से आपके एप्लिकेशन को कभी-कभी बढ़ती हुई मेमोरी का उपयोग करने का कारण बनता है, जिसके परिणामस्वरूप खराब सिस्टम प्रदर्शन हो सकता है या (आईओएस में) आपके आवेदन को समाप्त कर दिया जाता है।

स्मृति प्रबंधन नियम

  • हम अपने द्वारा बनाई गई वस्तुओं के मालिक हैं, और हमें बाद में उन्हें रिलीज़ करना होगा जब उन्हें ज़रूरत नहीं होगी।

  • किसी ऐसी वस्तु का स्वामित्व प्राप्त करने के लिए, जिसे आपने नहीं बनाया है, का लाभ लेने के लिए Retain का उपयोग करें आपको इन वस्तुओं को तब भी जारी करना होगा जब उनकी आवश्यकता न हो।

  • उन वस्तुओं को जारी न करें, जो आपके पास नहीं हैं।

एआरसी में मेमोरी को संभालना

आपको ARC में रिलीज़ और रिटेन का उपयोग करने की आवश्यकता नहीं है। इसलिए, जब व्यू कंट्रोलर को हटा दिया जाता है, तो सभी व्यू कंट्रोलर की ऑब्जेक्ट को छोड़ दिया जाएगा। इसी प्रकार, किसी भी वस्तु की उप-वस्तुएँ तब रिलीज़ की जाएंगी जब उन्हें छोड़ा जाएगा। ध्यान दें कि यदि अन्य वर्गों के पास किसी कक्षा के ऑब्जेक्ट का एक मजबूत संदर्भ है, तो पूरी कक्षा को जारी नहीं किया जाएगा। तो, प्रतिनिधियों के लिए कमजोर गुणों का उपयोग करने की सिफारिश की जाती है।

मेमोरी प्रबंधन उपकरण

हम Xcode टूल इंस्ट्रूमेंट्स की मदद से मेमोरी के उपयोग का विश्लेषण कर सकते हैं। इसमें एक्टिविटी मॉनीटर, एलोकेशन, लीक्स, लाश इत्यादि जैसे टूल शामिल हैं।

मेमोरी आवंटन का विश्लेषण करने के लिए कदम

Step 1 - एक मौजूदा एप्लिकेशन खोलें।

Step 2 - नीचे दिखाए गए अनुसार उत्पाद और फिर प्रोफ़ाइल का चयन करें।

Step 3 - नीचे दिखाए गए अगली स्क्रीन में आवंटन का चयन करें और प्रोफ़ाइल का चयन करें।

Step 4 - हम नीचे दिखाए गए अनुसार विभिन्न वस्तुओं के लिए मेमोरी का आवंटन देखेंगे।

Step 5 - आप दृश्य नियंत्रकों के बीच स्विच कर सकते हैं और जांच सकते हैं कि मेमोरी ठीक से जारी की गई है या नहीं।

Step 6 - इसी तरह, आवंटन के बजाय, हम एप्लिकेशन के लिए आवंटित समग्र मेमोरी को देखने के लिए गतिविधि मॉनिटर का उपयोग कर सकते हैं।

Step 7 - ये उपकरण हमें अपनी मेमोरी खपत तक पहुंचने में मदद करते हैं और उन जगहों का पता लगाते हैं जहां संभव लीक हुए हैं।

हम एक एप्लिकेशन विकसित करते समय गलतियां कर सकते हैं, जिससे विभिन्न प्रकार की त्रुटियां हो सकती हैं। इन त्रुटियों या बग्स को ठीक करने के लिए, हमें एप्लिकेशन को डीबग करना होगा।

डिबगर का चयन करना

Xcode के दो डिबगर हैं, GDB और LLDB डिबगर। GDB डिफ़ॉल्ट रूप से चयनित है। एलएलडीबी एक डिबगर है जो एलएलवीएम ओपन-सोर्स कंपाइलर प्रोजेक्ट का एक हिस्सा है। आप "सक्रिय योजनाओं को संपादित करें" विकल्प द्वारा डिबगर को बदल सकते हैं।

कोडिंग त्रुटियों को कैसे खोजें?

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

आप किसी अनुप्रयोग में संभावित समस्याओं का पता लगाने के लिए उत्पाद और फिर विश्लेषण पर क्लिक कर सकते हैं।

ब्रेकप्वाइंट सेट करें

ब्रेकप्वाइंट हमें अपने एप्लिकेशन ऑब्जेक्ट्स के विभिन्न राज्यों को जानने में मदद करते हैं, जो हमें तार्किक मुद्दों सहित कई खामियों की पहचान करने में मदद करते हैं। हमें बस एक ब्रेकपॉइंट बनाने के लिए लाइन नंबर पर क्लिक करने की आवश्यकता है। एक ब्रेकपॉइंट निकालने के लिए, बस क्लिक करें और इसे बाहर खींचें। निम्न स्क्रीनशॉट दिखाता है कि ब्रेकपॉइंट कैसे सेट किया जाए -

जब हम एप्लिकेशन चलाते हैं और playVideo बटन का चयन करते हैं, तो एप्लिकेशन उस लाइन नंबर पर विराम देगा जहां हमने ब्रेकपॉइंट सेट किया था। यह हमें आवेदन की स्थिति का विश्लेषण करने का समय देता है। जब ब्रेकपाइंट को ट्रिगर किया जाता है, तो हमें नीचे दिखाए अनुसार आउटपुट मिलेगा।

आप आसानी से पहचान सकते हैं कि किस थ्रेड ने ब्रेकपॉइंट को ट्रिगर किया है। नीचे, आप स्वयं, प्रेषक और इसी तरह की वस्तुओं को देख सकते हैं, जो संबंधित वस्तुओं के मूल्यों को पकड़ते हैं और हम इनमें से कुछ वस्तुओं का विस्तार कर सकते हैं, और देख सकते हैं कि इनमें से प्रत्येक वस्तु की स्थिति क्या है।

एप्लिकेशन को जारी रखने के लिए हम नीचे दिखाए गए डिबग क्षेत्र में जारी बटन (सबसे बाएं बटन) का चयन करेंगे। अन्य विकल्पों में कदम, बाहर कदम और कदम खत्म शामिल हैं।

अपवाद ब्रेकअप

हमारे पास अपवाद ब्रेकप्वाइंट भी हैं जो एक एप्लिकेशन को उस स्थान पर रोकने के लिए ट्रिगर करते हैं जहां अपवाद होता है। हम डिबग नाविक का चयन करने के बाद + बटन का चयन करके अपवाद ब्रेकप्वाइंट डाल सकते हैं। आपको निम्न विंडो मिलेगी।

फिर हमें Add Exception Breakpoint का चयन करना होगा, जो निम्न विंडो प्रदर्शित करेगा।

आप डिबगिंग और अन्य Xcode सुविधाओं पर Xcode 4 उपयोगकर्ता गाइड से अधिक जानकारी एकत्र कर सकते हैं ।