एमएफसी - त्वरित गाइड

Microsoft फ़ाउंडेशन क्लास (MFC) लाइब्रेरी Microsoft Windows ऑपरेटिंग सिस्टम के लिए एप्लिकेशन बनाने के लिए कार्यों को बनाने, स्थिरांक, डेटा प्रकार और कक्षाएं प्रदान करता है। इस ट्यूटोरियल में, आप एमएफसी का उपयोग करके विंडोज़ आधारित एप्लिकेशन शुरू करने और बनाने के तरीके के बारे में सीखेंगे।

आवश्यक शर्तें

हमने मान लिया है कि आप निम्नलिखित जानते हैं -

  • विंडोज के लिए प्रोग्रामिंग के बारे में थोड़ा सा।
  • C ++ में प्रोग्रामिंग की मूल बातें।
  • ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग के मूल सिद्धांतों को समझें।

MFC क्या है?

माइक्रोसॉफ्ट फाउंडेशन क्लास लाइब्रेरी (MFC) Microsoft विंडोज में प्रोग्रामिंग के लिए एक "एप्लीकेशन फ्रेमवर्क" है। MFC बहुत कोड प्रदान करता है, जो निम्नलिखित के लिए आवश्यक हैं -

  • विंडोज का प्रबंधन।
  • मेनू और संवाद बॉक्स।
  • मूल इनपुट / आउटपुट प्रदर्शन करना।
  • डेटा ऑब्जेक्ट्स का संग्रह संग्रहीत करना, आदि।

आप MFC फ्रेमवर्क में अपने एप्लिकेशन-विशिष्ट कोड को जोड़कर C ++ अनुप्रयोगों में मूल कार्यक्षमता MFC फ्रेमवर्क को आसानी से विस्तारित या ओवरराइड कर सकते हैं।

MFC फ्रेमवर्क

  • MFC फ्रेमवर्क विंडोज प्रोग्रामिंग को आसान बनाने के लिए डिज़ाइन किए गए पुन: प्रयोज्य वर्गों का एक सेट प्रदान करता है।

  • MFC कई बुनियादी वस्तुओं के लिए कक्षाएं प्रदान करता है, जैसे कि तार, फाइलें और संग्रह जो रोजमर्रा की प्रोग्रामिंग में उपयोग किए जाते हैं।

  • यह सामान्य विंडोज एपीआई और डेटा संरचनाओं के लिए कक्षाएं भी प्रदान करता है, जैसे कि विंडोज़, नियंत्रण और डिवाइस संदर्भ।

  • फ़्रेमवर्क अधिक उन्नत सुविधाओं के लिए एक ठोस आधार भी प्रदान करता है, जैसे कि ActiveX और दस्तावेज़ दृश्य प्रसंस्करण।

  • इसके अलावा, MFC एक एप्लिकेशन फ्रेमवर्क प्रदान करता है, जिसमें उन वर्गों को शामिल किया जाता है जो एप्लिकेशन आर्किटेक्चर पदानुक्रम बनाते हैं।

क्यों MFC?

MFC फ्रेमवर्क एक शक्तिशाली दृष्टिकोण है जो आपको विंडोज के लिए विशेषज्ञ प्रोग्रामर के काम पर निर्माण करने देता है। एमएफसी फ्रेमवर्क के निम्नलिखित फायदे हैं।

  • यह विकास के समय को छोटा करता है।

  • यह कोड को अधिक पोर्टेबल बनाता है।

  • यह प्रोग्रामिंग स्वतंत्रता और लचीलेपन को कम किए बिना भी जबरदस्त समर्थन प्रदान करता है।

  • यह उपयोगकर्ता-इंटरफ़ेस तत्वों और प्रौद्योगिकियों के लिए "हार्ड टू प्रोग्राम" की आसान पहुंच देता है।

  • MFC डेटाबेस प्रोग्रामिंग को डेटा एक्सेस ऑब्जेक्ट्स (DAO) और ओपन डेटाबेस कनेक्टिविटी (ODBC), और विंडोज सॉकेट्स के माध्यम से नेटवर्क प्रोग्रामिंग के माध्यम से सरल करता है।

Microsoft Visual C ++ एक प्रोग्रामिंग वातावरण है जिसका उपयोग Microsoft Windows ऑपरेटिंग सिस्टम के लिए एप्लिकेशन बनाने के लिए किया जाता है। अपने C ++ एप्लिकेशन में MFC फ्रेमवर्क का उपयोग करने के लिए, आपने Microsoft Visual C ++ या Microsoft Visual Studio स्थापित किया होगा। Microsoft Visual Studio में Microsoft Visual C ++ वातावरण भी होता है।

Microsoft दृश्य स्टूडियो का एक निःशुल्क संस्करण प्रदान करता है जिसमें SQL सर्वर भी होता है और इसे डाउनलोड किया जा सकता है https://www.visualstudio.com/en-us/downloads/downloadvisual- studio-vs.aspx।

स्थापना के चरण निम्नलिखित हैं।

Step 1- विजुअल स्टूडियो डाउनलोड हो जाने के बाद, इंस्टॉलर चलाएं। निम्नलिखित संवाद बॉक्स प्रदर्शित किया जाएगा।

Step 2 - इंस्टॉलेशन प्रक्रिया शुरू करने के लिए इंस्टॉल पर क्लिक करें।

Step 3 - एक बार विजुअल स्टूडियो सफलतापूर्वक इंस्टॉल हो जाने के बाद, आपको निम्नलिखित डायलॉग बॉक्स दिखाई देगा।

Step 4 - इस संवाद बॉक्स को बंद करें और यदि आवश्यक हो तो अपने कंप्यूटर को पुनरारंभ करें।

Step 5- स्टार्ट मेनू से विजुअल स्टूडियो खोलें, जो निम्न डायलॉग बॉक्स खोलेगा। पहली बार शुरू करते समय, तैयारी के लिए कुछ समय लगेगा।

Step 6 - इसके बाद, आप विजुअल स्टूडियो की मुख्य विंडो देखेंगे।

Step 7 - अब आप अपना आवेदन शुरू करने के लिए तैयार हैं।

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

  • यह इनमें से कई प्रोजेक्ट टेम्प्लेट के लिए विजार्ड प्रदान करता है और जैसे ही आप इन्हें बनाते हैं, आप अपनी परियोजनाओं को अनुकूलित करने में मदद करते हैं।

  • प्रोजेक्ट बन जाने के बाद, आप एप्लिकेशन बना और चला सकते हैं।

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

  • प्रदान की गई परियोजना फ़ाइलों और संरचना को संशोधित करना आसान है, क्योंकि उन्हें खरोंच से बनाना है।

MFC में, आप निम्न प्रोजेक्ट टेम्प्लेट का उपयोग कर सकते हैं।

अनु क्रमांक। प्रोजेक्ट टेम्प्लेट और विवरण
1

MFC Application

MFC अनुप्रयोग Windows के लिए एक निष्पादन योग्य अनुप्रयोग है जो Microsoft Foundation Class (MFC) लाइब्रेरी पर आधारित है। MFC एप्लिकेशन बनाने का सबसे आसान तरीका MFC एप्लिकेशन विज़ार्ड का उपयोग करना है।

2

MFC ActiveX Control

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

3

MFC DLL

MFC DLL एक बाइनरी फ़ाइल है जो एक साझा लाइब्रेरी के रूप में कार्य करती है जिसे एक साथ कई अनुप्रयोगों द्वारा उपयोग किया जा सकता है। MFC DLL प्रोजेक्ट बनाने का सबसे आसान तरीका MFC DLL विज़ार्ड का उपयोग करना है।

कुछ सामान्य टेम्पलेट निम्नलिखित हैं जिनका उपयोग MFC एप्लिकेशन बनाने के लिए किया जा सकता है -

अनु क्रमांक। प्रोजेक्ट टेम्प्लेट और विवरण
1

Empty Project

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

2

Custom Wizard

जब आप एक नया कस्टम विज़ार्ड बनाने की आवश्यकता होती है, तो विजुअल C ++ कस्टम विजार्ड का उपयोग करने का उपकरण होता है। कस्टम विज़ार्ड बनाने का सबसे आसान तरीका कस्टम विज़ार्ड का उपयोग करना है।

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

प्रोजेक्ट टेम्प्लेट का उपयोग करके प्रोजेक्ट बनाएं

विज़ुअल स्टूडियो में उपलब्ध प्रोजेक्ट टेम्प्लेट का उपयोग करके प्रोजेक्ट बनाने के लिए निम्नलिखित चरण हैं।

Step 1 - विज़ुअल स्टूडियो खोलें और फ़ाइल → नई → प्रोजेक्ट मेनू विकल्प पर क्लिक करें।

Step 2 - अब आप देख सकते हैं कि नया प्रोजेक्ट डायलॉग बॉक्स खुला है।

Step 3 - बाएं फलक से, टेम्पलेट → विज़ुअल C ++ → MFC चुनें

Step 4 - मध्य फलक में, MFC एप्लिकेशन चुनें।

Step 5- नाम फ़ील्ड में प्रोजेक्ट का नाम 'एमएफसीडीमो' दर्ज करें और जारी रखने के लिए ठीक पर क्लिक करें। आप निम्नलिखित संवाद देखेंगे।

Step 6 - अगला।

Step 7 - ऊपर दिए गए डायलॉग बॉक्स में दिखाए गए विकल्पों का चयन करें और नेक्स्ट पर क्लिक करें।

Step 8 - सभी विकल्पों को अनचेक करें और फिनिश बटन पर क्लिक करें।

अब आप देख सकते हैं कि MFC विज़ार्ड इस डायलॉग बॉक्स और डिफ़ॉल्ट रूप से प्रोजेक्ट फ़ाइलों को बनाता है।

Step 9 - इस एप्लिकेशन को चलाएं, आपको निम्न आउटपुट दिखाई देगा।

स्क्रैच से प्रोजेक्ट बनाएं

आप स्क्रैच से एमएफसी एप्लिकेशन भी बना सकते हैं। MFC एप्लिकेशन बनाने के लिए, आपको निम्न चरणों का पालन करना होगा।

Step 1 - विज़ुअल स्टूडियो खोलें और फ़ाइल → नई → प्रोजेक्ट मेनू विकल्प पर क्लिक करें।

Step 2 - अब आप न्यू प्रोजेक्ट डायलॉग बॉक्स देख सकते हैं।

Step 3 - बाएं फलक से, टेम्पलेट → विज़ुअल C ++ → जनरल चुनें।

Step 4 - मध्य फलक में, खाली का चयन करें

Step 5- नाम फ़ील्ड में प्रोजेक्ट का नाम 'MFCDemoFromScratch' दर्ज करें और जारी रखने के लिए ठीक क्लिक करें। आप देखेंगे कि एक खाली प्रोजेक्ट बनाया गया है।

Step 6 - इसे MFC प्रोजेक्ट बनाने के लिए, प्रोजेक्ट पर राइट-क्लिक करें और Properties को चुनें।

Step 7 - बाएं अनुभाग में, कॉन्फ़िगरेशन गुण → सामान्य पर क्लिक करें।

Step 8 - प्रोजेक्ट डिफॉल्ट सेक्शन में शेयर्ड डीएलएल ऑप्शन में यूज एमएफसी का चयन करें और ओके पर क्लिक करें।

Step 9- चूंकि यह अब एक खाली परियोजना है; हमें C ++ फ़ाइल जोड़ने की आवश्यकता है। इसलिए, प्रोजेक्ट पर राइट-क्लिक करें और Add → New Item… चुनें

Step 10 - चयन करें C++ File (.cpp) मध्य फलक में और नाम फ़ील्ड में फ़ाइल नाम दर्ज करें और बटन जोड़ें पर क्लिक करें।

Step 11 - अब आप देख सकते हैं main.cpp स्रोत फ़ाइल फ़ोल्डर के अंतर्गत फ़ाइल जोड़ी गई।

Step 12 - इस फाइल में निम्नलिखित कोड जोड़ते हैं।

#include <iostream> 
using namespace std;  

void main() { 
   cout << "***************************************\n"; 
   cout << "MFC Application Tutorial"; 
   cout << "\n***************************************"; 
   getchar(); 
}

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

*************************************** 
MFC Application Tutorial 
***************************************

इस अध्याय में, हम विंडोज के फंडामेंटल को कवर करेंगे। एक प्रोग्राम बनाने के लिए, जिसे एक एप्लिकेशन भी कहा जाता है, आप MFC के CWinApp से एक क्लास प्राप्त करते हैं।CWinApp के लिए खड़ा है Class for a Windows Application.

हमें एक नया Win32 प्रोजेक्ट बनाकर एक साधारण उदाहरण में देखें।

Step 1 - विज़ुअल स्टूडियो खोलें और फ़ाइल → नई → प्रोजेक्ट मेनू विकल्प पर क्लिक करें।

Step 2 - अब आप न्यू प्रोजेक्ट डायलॉग बॉक्स देख सकते हैं।

Step 3 - बाएं फलक से, टेम्पलेट → विज़ुअल C ++ → Win32 चुनें।

Step 4 - मध्य फलक में, Win32 प्रोजेक्ट चुनें।

Step 5- नाम फ़ील्ड में प्रोजेक्ट नाम 'MFCWindowDemo' दर्ज करें और जारी रखने के लिए ठीक क्लिक करें। आपको निम्नलिखित डायलॉग बॉक्स दिखाई देगा।

Step 6 - अगला।

Step 7 - ऊपर दिए गए डायलॉग बॉक्स में दिखाए गए विकल्पों का चयन करें और समाप्त पर क्लिक करें।

Step 8 - एक खाली प्रोजेक्ट बनाया जाता है।

Step 9 - इसे MFC प्रोजेक्ट बनाने के लिए, प्रोजेक्ट पर राइट-क्लिक करें और Properties को चुनें।

Step 10 - बाएं अनुभाग में, कॉन्फ़िगरेशन गुण → सामान्य पर क्लिक करें।

Step 11 - प्रोजेक्ट डिफॉल्ट सेक्शन में शेयर्ड डीएलएल ऑप्शन में यूज एमएफसी का चयन करें और ओके पर क्लिक करें।

Step 12 - एक नया स्रोत फ़ाइल जोड़ें।

Step 13 - अपने प्रोजेक्ट पर राइट-क्लिक करें और Add → New Item चुनें ...

Step 14 - टेम्प्लेट अनुभाग में, C ++ फ़ाइल (.cpp) पर क्लिक करें।

Step 15 - उदाहरण के रूप में नाम सेट करें और जोड़ें पर क्लिक करें।

खिड़की निर्माण

किसी भी एप्लिकेशन के दो मुख्य भाग हैं -

  • Class
  • फ्रेम या खिड़की

आइए हम निम्नलिखित चरणों का उपयोग करके एक विंडो बनाते हैं -

Step 1 - एक आवेदन पत्र बनाने के लिए, हमें MFC के CWinApp से एक वर्ग प्राप्त करना होगा।

#include
class CExample : public CWinApp {
   BOOL InitInstance() {
      return TRUE;
   }
};

Step 2 - हमें अपने एप्लिकेशन की सामग्री दिखाने के लिए एक फ़्रेम / विंडो की भी आवश्यकता है।

Step 3 - इसके लिए, हमें एक और वर्ग जोड़ने और इसे MFC से प्राप्त करने की आवश्यकता है CFrameWnd क्लास और इसके कंस्ट्रक्टर को लागू करें और कॉल () विधि बनाएँ, जो निम्नलिखित कोड में दिखाए गए अनुसार एक फ्रेम / विंडो बनाएगा।

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"));
      }
};

Step 4 - जैसा कि आप देख सकते हैं कि Create () मेथड को दो पैरामीटर्स की जरूरत है, क्लास का नाम, जिसे NULL के रूप में पास किया जाना चाहिए, और विंडो का नाम, जो कि स्ट्रिंग है जिसे टाइटल बार पर दिखाया जाएगा।

मुख्य खिड़की

एक विंडो बनाने के बाद, एप्लिकेशन को इसका उपयोग करने देने के लिए, आप विंडो बनाने के लिए उपयोग किए गए वर्ग को दिखाने के लिए एक पॉइंटर का उपयोग कर सकते हैं। इस मामले में, सूचक CFrameWnd होगा। फ़्रेम विंडो का उपयोग करने के लिए, इसके पॉइन्टर को CWinThread :: m_pMainWnd सदस्य चर पर असाइन करें। यह आपके आवेदन के InitInstance () कार्यान्वयन में किया जाता है।

Step 1 - यहाँ CExample वर्ग में InitInstance () का कार्यान्वयन है।

class CExample : public CWinApp {
   BOOL InitInstance() {
      CMyFrame *Frame = new CMyFrame();  m_pMainWnd = Frame;
      
      Frame->ShowWindow(SW_NORMAL);
      Frame->UpdateWindow();
      
      return TRUE;
   }
};

Step 2 - इसके बाद Example.cpp फ़ाइल का पूर्ण कार्यान्वयन है।

#include <afxwin.h>

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"));
      }
};

class CExample : public CWinApp {
   BOOL InitInstance() {
      CMyFrame *Frame = new CMyFrame();
      m_pMainWnd = Frame;
      
      Frame->ShowWindow(SW_NORMAL);
      Frame->UpdateWindow();
      
      return TRUE;
   }
};

CExample theApp;

Step 3 - जब हम उपरोक्त एप्लिकेशन चलाते हैं, तो निम्न विंडो बनाई जाती है।

विंडोज स्टाइल्स

विंडोज शैलियाँ ऐसी विशेषताएँ हैं जो विंडो उपस्थिति, सीमाओं, न्यूनतम या अधिकतम स्थिति, या अन्य आकार बदलने वाले राज्यों, आदि जैसी सुविधाओं को नियंत्रित करती हैं।

अनु क्रमांक। शैली और विवरण
1

WS_BORDER

एक खिड़की बनाता है जिसमें एक सीमा होती है।

2

WS_CAPTION

एक विंडो बनाता है जिसका शीर्षक बार होता है (जिसका अर्थ है WS_BORDER शैली)। WS_DLGFRAME शैली के साथ उपयोग नहीं किया जा सकता है।

3

WS_CHILD

एक बाल खिड़की बनाता है। WS_POPUP शैली के साथ उपयोग नहीं किया जा सकता।

4

WS_CHILDWINDOW

WS_CHILD शैली के समान।

5

WS_CLIPCHILDREN

जब आप मूल विंडो के भीतर ड्रा करते हैं, तो चाइल्ड विंडो द्वारा अधिग्रहित क्षेत्र को छोड़ देता है। जब आप पेरेंट विंडो बनाते हैं तो उपयोग किया जाता है।

6

WS_CLIPSIBLINGS

एक दूसरे के सापेक्ष बाल खिड़कियां; वह है, जब एक विशेष चाइल्ड विंडो को एक पेंट संदेश प्राप्त होता है, तो WS_CLIPSIBLINGS स्टाइल क्लिप अपडेट की जाने वाली चाइल्ड विंडो के क्षेत्र से बाहर अन्य सभी ओवरलैप किए गए चाइल्ड विंडो को क्लिप करती है। (यदि WS_CLIPSIBLINGS नहीं दिए गए हैं और चाइल्ड विंडो ओवरलैप हैं, जब आप चाइल्ड विंडो के क्लाइंट एरिया के भीतर आते हैं, तो पड़ोसी बच्चे की विंडो के क्लाइंट एरिया में ड्रॉ करना संभव है।) केवल WS_CHILD के साथ उपयोग के लिए।

7

WS_DISABLED

एक विंडो बनाता है जो शुरू में अक्षम है।

8

WS_DLGFRAME

एक दोहरी सीमा के साथ एक खिड़की बनाता है लेकिन कोई शीर्षक नहीं।

9

WS_GROUP

नियंत्रण के एक समूह के पहले नियंत्रण को निर्दिष्ट करता है जिसमें उपयोगकर्ता तीर कुंजी के साथ एक नियंत्रण से अगले तक जा सकता है। पहले नियंत्रण के बाद WS_GROUP शैली FALSE के साथ परिभाषित सभी नियंत्रण एक ही समूह के हैं। WS_GROUP शैली के साथ अगला नियंत्रण अगला समूह शुरू होता है (यानी, एक समूह समाप्त होता है जहां अगला शुरू होता है)।

10

WS_HSCROLL

एक विंडो बनाता है जिसमें एक क्षैतिज स्क्रॉल पट्टी होती है।

1 1

WS_ICONIC

एक विंडो बनाता है जिसे शुरू में छोटा किया जाता है। WS_MINIMIZE शैली के समान।

12

WS_MAXIMIZE

अधिकतम आकार की एक विंडो बनाता है।

13

WS_MAXIMIZEBOX

एक विंडो बनाता है जिसमें एक मैक्सिमाइज़ बटन होता है।

14

WS_MINIMIZE

एक विंडो बनाता है जिसे शुरू में छोटा किया जाता है। केवल WS_OVERLAPPED शैली के साथ उपयोग के लिए।

15

WS_MINIMIZEBOX

एक विंडो बनाता है जिसमें एक छोटा बटन होता है।

16

WS_OVERLAPPED

एक ओवरलैप्ड विंडो बनाता है। ओवरलैप्ड विंडो में आमतौर पर एक कैप्शन और एक सीमा होती है।

17

WS_OVERLAPPED WINDOW

WS_OVERLAPPED, WS_CAPTION, WS_SYSMENU, WS_THICKFRAME, WS_MINIMIZEBOX और WS_MAXIMIZIOBOX शैलियों के साथ एक ओवरलैप्ड विंडो बनाता है।

18

WS_POPUP

एक पॉप-अप विंडो बनाता है। WS_CHILD शैली के साथ उपयोग नहीं किया जा सकता।

19

WS_POPUPWINDOW

WS_BORDER, WS_POPUP और WS_SYSMENU शैलियों के साथ एक पॉप-अप विंडो बनाता है। नियंत्रण मेनू को दृश्यमान बनाने के लिए WS_CAPTION शैली को WS_POPUPWINDOW शैली के साथ जोड़ा जाना चाहिए।

20

WS_SIZEBOX

एक विंडो बनाता है जिसमें एक साइज़िंग बॉर्डर होता है। WS_THICKFRAME शैली के समान।

21

WS_SYSMENU

एक विंडो बनाता है जिसमें इसके शीर्षक बार में एक नियंत्रण-मेनू बॉक्स होता है। केवल शीर्षक पट्टियों वाली खिड़कियों के लिए उपयोग किया जाता है।

22

WS_TABSTOP

किसी भी संख्या में नियंत्रणों में से एक निर्दिष्ट करता है जिसके माध्यम से उपयोगकर्ता TAB कुंजी का उपयोग करके स्थानांतरित कर सकता है। TAB कुंजी उपयोगकर्ता को WS_TABSTOP शैली द्वारा निर्दिष्ट अगले नियंत्रण पर ले जाती है।

23

WS_THICKFRAME

एक मोटे फ्रेम के साथ एक खिड़की बनाता है जिसका उपयोग खिड़की को आकार देने के लिए किया जा सकता है।

24

WS_TILED

एक ओवरलैप्ड विंडो बनाता है। ओवरलैप्ड विंडो में टाइटल बार और बॉर्डर होता है। WS_OVERLAPPED शैली के समान।

25

WS_TILEDWINDOW

WS_OVERLAPPED, WS_CAPTION, WS_SYSMENU, WS_THICKFRAME, WS_MINIMIZEBOX और WS_MAXIMIZIOBOX शैलियों के साथ एक ओवरलैप्ड विंडो बनाता है। WS_OVERLAPPEDWINDOW शैली के समान।

26

WS_VISIBLE

एक खिड़की बनाता है जो शुरू में दिखाई देती है।

27

WS_VSCROLL

एक विंडो बनाता है जिसमें वर्टिकल स्क्रॉल बार होता है।

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

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"), WS_VISIBLE | WS_OVERLAPPED);
      }
};

Step 2 - जब आप इस एप्लिकेशन को चलाते हैं, तो निम्न विंडो बनाई जाती है।

अब आप देख सकते हैं कि न्यूनतम, अधिकतम और करीबी विकल्प अब दिखाई नहीं देते हैं।

विंडोज लोकेशन

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

Win32 library POINT नामक एक संरचना प्रदान करता है जो निम्नानुसार है -

typedef struct tagPOINT {
   LONG x;
   LONG y;
} POINT;
  • 'X' सदस्य चर स्क्रीन के बाईं सीमा से बिंदु तक की दूरी है।

  • 'Y' वेरिएबल स्क्रीन के टॉप बॉर्डर से पॉइंट तक की दूरी को दर्शाता है।

  • Win32 की POINT संरचना के अलावा, Microsoft Foundation Class (MFC) लाइब्रेरी CPoint वर्ग प्रदान करता है।

  • यह POINT संरचना के समान कार्यक्षमता प्रदान करता है। C ++ वर्ग के रूप में, यह एक बिंदु का पता लगाने के लिए आवश्यक अधिक कार्यक्षमता जोड़ता है। यह दो कंस्ट्रक्टर प्रदान करता है।

CPoint();
CPoint(int X, int Y);

विंडोज का आकार

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

  • किसी वस्तु की चौड़ाई।
  • किसी वस्तु की ऊँचाई।

Win32 पुस्तकालय SIZE संरचना का उपयोग करता है जो निम्नानुसार परिभाषित है -

typedef struct tagSIZE {
   int cx;
   int cy;
} SIZE;

Win32 की SIZE संरचना के अलावा, MFC CSize वर्ग प्रदान करता है। इस वर्ग की SIZE जैसी ही कार्यक्षमता है लेकिन C ++ वर्ग की विशेषताएं जोड़ता है। यह पांच कंस्ट्रक्टर प्रदान करता है जो आपको अपनी पसंद के किसी भी तरह से एक आकार चर बनाने की अनुमति देता है।

CSize();
CSize(int initCX, int initCY);
CSize(SIZE initSize);
CSize(POINT initPt);
CSize(DWORD dwSize);

विंडोज आयाम

जब एक विंडो प्रदर्शित होती है, तो इसे मॉनिटर की सीमाओं के संबंध में स्क्रीन पर उसके स्थान से पहचाना जा सकता है। एक विंडो को उसकी चौड़ाई और ऊंचाई से भी पहचाना जा सकता है। इन विशेषताओं निर्दिष्ट या द्वारा नियंत्रित कर रहे रेक्ट के तर्कCreate()तरीका। यह तर्क एक आयत है जिसे Win32 RECT संरचना के माध्यम से बनाया जा सकता है।

typedef struct _RECT {
   LONG left;
   LONG top;
   LONG right;
   LONG bottom;
} RECT, *PRECT;

Win32 के अलावा RECT संरचना, MFC को CRect वर्ग प्रदान करता है जिसमें निम्नलिखित निर्माता हैं -

CRect();
CRect(int l, int t, int r, int b);
CRect(const RECT& srcRect);
CRect(LPCRECT lpSrcRect);
CRect(POINT point, SIZE size);
CRect(POINT topLeft, POINT bottomRight);

आइए एक सरल उदाहरण देखें, जिसमें हम विंडो के स्थान और आकार को निर्दिष्ट करेंगे

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"), WS_SYSMENU, CRect(90, 120, 
            550, 480));
      }
};

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

विंडोज माता-पिता

वास्तविक दुनिया में, कई एप्लिकेशन अलग-अलग विंडोज से बने होते हैं। जब कोई एप्लिकेशन विभिन्न विंडोज का उपयोग करता है, तो अधिकांश ऑब्जेक्ट एक विशेष पर निर्भर करते हैं। यह पहली विंडो हो सकती है जिसे बनाया गया था या दूसरी विंडो जिसे आपने निर्दिष्ट किया था। इस तरह के एक विंडो के रूप में जाना जाता हैParent Window। अन्य सभी खिड़कियां प्रत्यक्ष या अप्रत्यक्ष रूप से इस पर निर्भर करती हैं।

  • यदि आप जो विंडो बना रहे हैं, वह दूसरे पर निर्भर है, तो आप यह निर्दिष्ट कर सकते हैं कि उसका कोई अभिभावक है।

  • यह CFPameWnd :: Create () विधि के pParentWnd तर्क के साथ किया जाता है।

  • यदि विंडो में पैरेंट नहीं है, तो NULL मान के साथ तर्क पास करें।

आइए एक उदाहरण देखें, जिसमें केवल एक विंडो है, और कोई अभिभावक विंडो उपलब्ध नहीं है, इसलिए हम NULL मान के साथ तर्क पास करेंगे जैसा कि निम्नलिखित कोड में दिखाया गया है -

class CMyFrame : public CFrameWnd {
   public:
      CMyFrame() {
         Create(NULL, _T("MFC Application Tutorial"), WS_SYSMENU, 
            CRect(90, 120, 550, 480), NULL);
      }
};

जब आप उपरोक्त एप्लिकेशन चलाते हैं, तो आपको वही आउटपुट दिखाई देता है।

इस अध्याय में, हम डायलॉग बॉक्स को कवर करेंगे। विंडोज के लिए एप्लिकेशन उपयोगकर्ता के साथ संवाद बॉक्स के माध्यम से अक्सर संवाद करते हैं।CDialog classसंवाद बॉक्स के प्रबंधन के लिए एक इंटरफ़ेस प्रदान करता है। विजुअल C ++ डायलॉग एडिटर डायलॉग बॉक्स को डिज़ाइन करना और उनके डायलॉग-टेम्पलेट संसाधन बनाना आसान बनाता है।

  • एक डायलॉग ऑब्जेक्ट बनाना दो चरण का ऑपरेशन है -

    • संवाद वस्तु का निर्माण।

    • संवाद विंडो बनाएँ।

हमें एक नया Win32 प्रोजेक्ट बनाकर एक साधारण उदाहरण में देखें।

Step 1 - विज़ुअल स्टूडियो खोलें और फ़ाइल → नई → प्रोजेक्ट मेनू विकल्प पर क्लिक करें।

Step 2 - अब आप न्यू प्रोजेक्ट डायलॉग बॉक्स देख सकते हैं।

Step 3 - बाएं फलक से, टेम्पलेट → विज़ुअल C ++ → Win32 चुनें।

Step 4 - मध्य फलक में, Win32 प्रोजेक्ट चुनें।

Step 5- नाम फ़ील्ड में प्रोजेक्ट का नाम 'MFCDialogDemo' दर्ज करें और जारी रखने के लिए ठीक पर क्लिक करें। आप निम्नलिखित संवाद देखेंगे।

Step 6 - अगला।

Step 7 - ऊपर दिए गए डायलॉग बॉक्स में दिखाए गए विकल्पों का चयन करें और समाप्त पर क्लिक करें।

Step 8 - एक खाली प्रोजेक्ट बनाया जाता है।

Step 9 - इसे MFC प्रोजेक्ट बनाने के लिए, प्रोजेक्ट पर राइट-क्लिक करें और Properties को चुनें।

Step 10 - बाएं अनुभाग में, कॉन्फ़िगरेशन गुण → सामान्य पर क्लिक करें।

Step 11 - प्रोजेक्ट डिफॉल्ट सेक्शन में शेयर्ड डीएलएल ऑप्शन में यूज एमएफसी का चयन करें और ओके पर क्लिक करें।

Step 12 - एक नया स्रोत फ़ाइल जोड़ें।

Step 13 - अपने प्रोजेक्ट पर राइट-क्लिक करें और Add → New Item चुनें।

Step 14 - टेम्प्लेट अनुभाग में, C ++ फ़ाइल (.cpp) पर क्लिक करें

Step 15 - उदाहरण के रूप में नाम सेट करें और जोड़ें पर क्लिक करें।

Step 16 - एक आवेदन पत्र बनाने के लिए, हमें एक वर्ग जोड़ना होगा और इसे MFC के CWinApp से प्राप्त करना होगा।

#include <afxwin.h>

class CExample : public CWinApp {
   public:
      BOOL InitInstance();
};

डायलॉग बॉक्स क्रिएशन

Step 1 - डायलॉग बॉक्स बनाने के लिए, सॉल्यूशन एक्सप्लोरर में रिसोर्स फाइल्स फोल्डर पर राइट-क्लिक करें और Add → Resource चुनें।

Step 2 - संसाधन जोड़ें संवाद बॉक्स में, संवाद चुनें और नया पर क्लिक करें।

Step 3 - एक संवाद बॉक्स को वास्तव में प्रोग्राम बनाने से पहले कुछ तैयारी की आवश्यकता होती है।

Step 4 - एक संवाद बॉक्स पहले एक पाठ फ़ाइल (एक संसाधन फ़ाइल में) के रूप में मैन्युअल रूप से बनाया जा सकता है।

Step 5 - अब आप संसाधन फ़ाइलों के तहत बनाई गई MFCDialogDemo.rc फ़ाइल देख सकते हैं।

Step 6- डिजाइनर में रिसोर्स फाइल ओपन है। उसी को टेक्स्ट फाइल के रूप में खोला जा सकता है। संसाधन फ़ाइल पर राइट-क्लिक करें और ओपन विथ का चयन करें।

Step 7 - सोर्स कोड (टेक्स्ट) एडिटर चुनें और ऐड बटन पर क्लिक करें।

Step 8 - डिजाइनर पर वापस जाएं और डायलॉग पर राइट-क्लिक करें और प्रॉपर्टीज चुनें।

Step 9 - आपको कई विकल्पों में से चुनने की जरूरत है।

Step 10- अधिकांश अन्य नियंत्रणों की तरह, एक संवाद बॉक्स की पहचान की जानी चाहिए। एक संवाद बॉक्स का पहचानकर्ता (आईडी) आमतौर पर IDD_ से शुरू होता है, आइडी को IDD_EXAMPLE__LL से बदलें।

संवाद स्थान

एक संवाद बॉक्स "शारीरिक रूप से" एक आवेदन पर स्थित होना चाहिए। क्योंकि एक संवाद बॉक्स आमतौर पर अन्य नियंत्रणों के लिए एक माता-पिता के रूप में बनाया जाता है, इसका स्थान इसकी मूल खिड़की या डेस्कटॉप के साथ अपने संबंधों पर निर्भर करता है।

यदि आप देखते हैं और गुण विंडो, आप दो फ़ील्ड, X Pos और Y Pos देखते हैं।

  • X मॉनीटर की बाईं बॉर्डर से डायलॉग बॉक्स के लेफ्ट बॉर्डर की दूरी है।

  • Y, मॉनिटर के शीर्ष बॉर्डर से संवाद बॉक्स के शीर्ष बॉर्डर तक की दूरी है।

डिफ़ॉल्ट रूप से, ये फ़ील्ड शून्य पर सेट हैं। आप ऊपर दिखाए अनुसार बदल भी सकते हैं।

यदि आप इन दोनों आयामों को 0 के रूप में निर्दिष्ट करते हैं, तो संवाद बॉक्स की बाईं और ऊपरी सीमाएं सेट की जाएंगी ताकि स्क्रीन के मध्य-मध्य में ऑब्जेक्ट दिखाई दे।

डायलॉग बॉक्स आयाम

एक संवाद बॉक्स के आयाम इसकी चौड़ाई और इसकी ऊंचाई को संदर्भित करते हैं। आप डिज़ाइनर विंडो में माउस की मदद से चौड़ाई और ऊँचाई का आकार बदल सकते हैं।

आप स्थिति पट्टी पर चौड़ाई और ऊँचाई में परिवर्तन देख सकते हैं।

डायलॉग बॉक्स मेथड्स

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

CDialog();
CDialog(UINT nIDTemplate, CWnd* pParentWnd = NULL);
CDialog(LPCTSTR lpszTemplateName, CWnd* pParentWnd = NULL);

आइए हम एक और वर्ग CExampleDlg बनाएं और इसे CDialog से प्राप्त करें। हम इसके डिफॉल्ट कंस्ट्रक्टर विध्वंसक को लागू करेंगे जैसा कि निम्नलिखित कोड में दिखाया गया है।

class CExampleDlg : public CDialog {
   public:
      enum { IDD = IDD_EXAMPLE_DLG };
   
      CExampleDlg();
      ~CExampleDlg();
};

CExampleDlg::CExampleDlg():CDialog(CExampleDlg::IDD) {

}

CExampleDlg::~CExampleDlg() {

}

हमें निम्नलिखित कोड में दिखाए गए CExample :: InitInstance () पद्धति पर इस डायलॉग को तुरंत लिखना होगा।

BOOL CExample::InitInstance() {
   CExampleDlg myDlg;
   m_pMainWnd = &myDlg;
   
   return TRUE;
}

मोडल डायलॉग बॉक्स

संवाद बॉक्स दो प्रकार के होते हैं - modeless तथा modal। मोडल और मॉडललेस डायलॉग बॉक्स उन्हें बनाने और प्रदर्शित करने के लिए उपयोग की जाने वाली प्रक्रिया से भिन्न होते हैं।

मॉडल डायलॉग बॉक्स

  • एक मॉडल संवाद बॉक्स के लिए, आपको अपने स्वयं के सार्वजनिक निर्माता को अपने संवाद वर्ग में प्रदान करना होगा।

  • एक मॉडल संवाद बॉक्स बनाने के लिए, अपने सार्वजनिक निर्माणकर्ता को कॉल करें और फिर संवाद संसाधन को लोड करने के लिए डायल ऑब्जेक्ट ऑब्जेक्ट बनाएँ फ़ंक्शन को कॉल करें।

  • आप कंस्ट्रक्टर कॉल के दौरान या बाद में Create को कॉल कर सकते हैं। यदि संवाद संसाधन में WS_VISIBLE गुण है, तो संवाद बॉक्स तुरंत प्रकट होता है।

  • यदि नहीं, तो आपको इसके ShowWindow सदस्य फ़ंक्शन को कॉल करना होगा।

मोडल डायलॉग

  • मोडल डायलॉग बॉक्स बनाने के लिए, CDialog में घोषित दो सार्वजनिक निर्माणकर्ताओं में से किसी एक को कॉल करें।

  • इसके बाद, डायलॉग ऑब्जेक्ट को कॉल करें DoModal सदस्य फ़ंक्शन डायलॉग बॉक्स प्रदर्शित करने और उपयोगकर्ता के ठीक होने या रद्द होने तक उसके साथ सहभागिता प्रबंधित करने के लिए।

  • DoModal द्वारा यह प्रबंधन वह है जो संवाद बॉक्स को मोडल बनाता है। मोडल डायलॉग बॉक्स के लिए, DoModal डायलॉग संसाधन को लोड करता है।

Step 1 - संवाद बॉक्स को मोडल के रूप में प्रदर्शित करने के लिए, CExample :: InitInstance () ईवेंट को अपने संवाद चर का उपयोग करते हुए DoModal () विधि को कॉल करें -

BOOL CExample::InitInstance() {
   CExampleDlg myDlg;
   m_pMainWnd = &myDlg;
   myDlg.DoModal();
   return TRUE;
}

Step 2 - यहां Example.cpp फ़ाइल का पूर्ण कार्यान्वयन है।

#include <afxwin.h>
#include "resource.h"

class CExample : public CWinApp {
   public:
      BOOL InitInstance();
};
   
class CExampleDlg : public CDialog {
   public:
      enum { IDD = IDD_EXAMPLE_DLG };
   
      CExampleDlg();
     ~CExampleDlg();
};

CExampleDlg::CExampleDlg():CDialog(CExampleDlg::IDD) {

}

CExampleDlg::~CExampleDlg() {

}

BOOL CExample::InitInstance() {
   CExampleDlg myDlg;
   m_pMainWnd = &myDlg;
   myDlg.DoModal();
   return TRUE;
}
CExample MyApp;

Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्नलिखित संवाद बॉक्स दिखाई देगा।

संवाद-आधारित अनुप्रयोग

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

Step 1- विज़ुअल स्टूडियो खोलें और फ़ाइल → नई → प्रोजेक्ट मेनू विकल्प पर क्लिक करें। आप न्यू प्रोजेक्ट डायलॉग बॉक्स देख सकते हैं।

Step 2 - बाएं फलक से, टेम्पलेट → विज़ुअल C ++ → MFC चुनें।

Step 3 - मध्य फलक में, MFC एप्लिकेशन चुनें।

Step 4- नाम फ़ील्ड में प्रोजेक्ट नाम 'MFCModalDemo' दर्ज करें और जारी रखने के लिए ठीक क्लिक करें। आपको निम्नलिखित डायलॉग बॉक्स दिखाई देगा।

Step 5 - अगला।

Step 6 - उपरोक्त संवाद बॉक्स में दिखाए गए विकल्पों का चयन करें और अगला क्लिक करें।

Step 7 - आपके द्वारा चुने गए सभी विकल्पों को अपने डायलॉग बॉक्स पर चेक करें जैसे कि Maximize और Minimize बॉक्स।

Step 8 - अगला।

Step 9- यह इन दो वर्गों को उत्पन्न करेगा। आप कक्षाओं का नाम बदल सकते हैं और समाप्त पर क्लिक कर सकते हैं।

Step 10 - अब आप देख सकते हैं कि MFC विज़ार्ड इस डायलॉग बॉक्स और डिफ़ॉल्ट रूप से प्रोजेक्ट फ़ाइलों को बनाता है।

Step 11 - जब आप इस एप्लिकेशन को चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

resourceएक टेक्स्ट फ़ाइल है जो कंपाइलर को ऑब्जेक्ट्स जैसे पिक्चर, साउंड, माउस कर्सर, डायलॉग बॉक्स इत्यादि को मैनेज करने की अनुमति देती है। Microsoft Visual Studio प्रोग्राम के लिए इस्तेमाल होने वाले समान वातावरण में आवश्यक उपकरण प्रदान करके एक संसाधन फ़ाइल को विशेष रूप से आसान बनाता है। इसका मतलब है, आमतौर पर आपको संसाधन फ़ाइल बनाने या कॉन्फ़िगर करने के लिए किसी बाहरी एप्लिकेशन का उपयोग नहीं करना पड़ता है। संसाधनों से संबंधित कुछ महत्वपूर्ण विशेषताएं निम्नलिखित हैं।

  • संसाधन इंटरफ़ेस तत्व हैं जो उपयोगकर्ता को जानकारी प्रदान करते हैं।

  • बिटमैप, आइकन, टूलबार और कर्सर सभी संसाधन हैं।

  • किसी क्रिया को करने के लिए कुछ संसाधनों में हेरफेर किया जा सकता है जैसे कि मेनू से चयन करना या संवाद बॉक्स में डेटा दर्ज करना।

  • एक अनुप्रयोग विभिन्न संसाधनों का उपयोग कर सकता है जो एक दूसरे से स्वतंत्र रूप से व्यवहार करते हैं, इन संसाधनों को एक टेक्स्ट फ़ाइल में वर्गीकृत किया जाता है जिसमें * .rc एक्सटेंशन होता है।

  • अधिकांश संसाधन संसाधन जोड़ें संवाद बॉक्स से वांछित का चयन करके बनाए जाते हैं।

  • संसाधन जोड़ें संवाद बॉक्स संसाधनों की एक विस्तृत सूची प्रदान करता है, जिसका उपयोग आवश्यकताओं के अनुसार किया जा सकता है, लेकिन यदि आपको किसी ऐसी चीज़ की आवश्यकता है जो उपलब्ध नहीं है, तो आप प्रोग्राम को निष्पादित करने से पहले इसे * .rc फ़ाइल में मैन्युअल रूप से जोड़ सकते हैं।

पहचानकर्ता

एक identifierएक प्रतीक है जो एक स्थिर पूर्णांक है जिसका नाम आमतौर पर आईडी से शुरू होता है। इसमें दो भाग होते हैं - एक पाठ स्ट्रिंग (प्रतीक नाम) एक पूर्णांक मान (प्रतीक मान) पर मैप किया जाता है।

  • प्रतीक आपके स्रोत कोड में और जब आप संसाधन संपादकों में उनके साथ काम कर रहे हैं, तो संसाधनों और उपयोगकर्ता-इंटरफ़ेस ऑब्जेक्ट्स का संदर्भ देने का एक वर्णनात्मक तरीका प्रदान करते हैं।

  • जब आप एक नया संसाधन या संसाधन ऑब्जेक्ट बनाते हैं, तो resource editors संसाधन के लिए एक डिफ़ॉल्ट नाम प्रदान करें, उदाहरण के लिए, IDC_DIALOG1, और इसके लिए एक मान निर्दिष्ट करें।

  • Name-plus-value परिभाषा रिसोर्स.ह फ़ाइल में संग्रहीत है।

Step 1 - हमें अपने में देखो CMFCDialogDemo पिछले अध्याय से उदाहरण जिसमें हमने एक संवाद बॉक्स बनाया है और इसकी आईडी है IDD_EXAMPLE_DLG

Step 2- सॉल्यूशन एक्सप्लोरर में जाएं, आपको हैडर फाइल्स के नीचे रिसोर्स.ह फाइल दिखाई देगी। इस फ़ाइल को संपादक में खोलकर जारी रखें और आप संवाद बॉक्स पहचानकर्ता और इसके पूर्णांक मान को भी देखेंगे।

माउस

एक iconएक खिड़की पर उपयोग किया जाने वाला एक छोटा चित्र है जो एक अनुप्रयोग का प्रतिनिधित्व करता है। इसका उपयोग दो मुख्य परिदृश्यों में किया जाता है।

  • विंडो के फ्रेम पर, यह शीर्षक पट्टी पर विंडो नाम के बाईं ओर प्रदर्शित होता है।

  • विंडोज एक्सप्लोरर में, डेस्कटॉप पर, माय कंप्यूटर में, या कंट्रोल पैनल विंडो में।

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

आप नीचे दिए गए चरणों का पालन करके अपना खुद का आइकन बना सकते हैं -

Step 1 - अपने प्रोजेक्ट पर राइट-क्लिक करें और Add → Resources चुनें, आपको Add Resources डायलॉग बॉक्स दिखाई देगा।

Step 2 - आइकन चुनें और न्यू बटन पर क्लिक करें और आपको निम्नलिखित आइकन दिखाई देगा।

Step 3- सॉल्यूशन एक्सप्लोरर में, रिसोर्स व्यू पर जाएं और MFCModalDemo> आइकन का विस्तार करें। आपको दो आइकन दिखाई देंगे। IDR_MAINFRAME डिफ़ॉल्ट एक है और IDI_ICON1 नव निर्मित आइकन है।

Step 4 - नए बनाए गए आइकन पर राइट-क्लिक करें और गुण चुनें।

Step 5 - IDI_ICON1 इस आइकन की आईडी है, अब इस ID को IDR_MYICON में बदल दें।

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

Step 7 - इस आइकन को सेव करें।

Step 8 - CMFCModalDemoDlg कंस्ट्रक्टर CMFCModalDemoDlg.cpp फाइल पर जाएं जो निम्न कोड की तरह दिखेगा।

CMFCModalDemoDlg::CMFCModalDemoDlg(CWnd* pParent /* = NULL*/)
   : CDialogEx(IDD_MFCMODALDEMO_DIALOG, pParent) {
   m_hIcon = AfxGetApp() -> LoadIcon(IDR_MAINFRAME);
}

Step 9- अब आप देख सकते हैं कि डिफॉल्ट आइकन कंस्ट्रक्टर में लोड है। निम्नलिखित कोड में दिखाए गए अनुसार हमें IDR_ MYICON में बदल दें।

CMFCModalDemoDlg::CMFCModalDemoDlg(CWnd* pParent /* = NULL*/)
   : CDialogEx(IDD_MFCMODALDEMO_DIALOG, pParent) {
   m_hIcon = AfxGetApp() -> LoadIcon(IDR_ MYICON);
}

Step 10 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप देखेंगे कि नया आइकन संवाद बॉक्स पर प्रदर्शित होगा।

मेनू

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

Step 1- अपने प्रोजेक्ट पर राइट-क्लिक करें और Add → Resources चुनें। आपको संसाधन जोड़ें संवाद बॉक्स दिखाई देगा।

Step 2- मेनू का चयन करें और नया पर क्लिक करें। आपको आयत दिखाई देगा जिसमें मेनू बार पर "टाइप हियर" है।

Step 3 - निम्न स्नैपशॉट में दिखाए गए अनुसार कुछ मेनू विकल्प जैसे फ़ाइल, संपादन, आदि लिखें।

Step 4- यदि आप संसाधन दृश्य में मेनू फ़ोल्डर का विस्तार करते हैं, तो आपको मेनू पहचानकर्ता IDR_MENU1 दिखाई देगा। इस पहचानकर्ता पर राइट-क्लिक करें और इसे IDM_MAINMENU में बदलें।

Step 5 - सभी परिवर्तनों को सहेजें।

Step 6- हमें इस मेनू को अपने संवाद बॉक्स में संलग्न करना होगा। समाधान एक्सप्लोरर में अपने डायलॉग फ़ोल्डर का विस्तार करें और डायलॉग बॉक्स पहचानकर्ता पर डबल क्लिक करें।

Step 7- आप गुण में मेनू फ़ील्ड देखेंगे। ऊपर दिखाए गए अनुसार ड्रॉपडाउन से मेनू पहचानकर्ता का चयन करें।

Step 8 - इस एप्लिकेशन को चलाएं और आपको निम्नलिखित संवाद बॉक्स दिखाई देगा जिसमें मेनू विकल्प भी हैं।

उपकरण पट्टियाँ

toolbar एक विंडोज नियंत्रण है जो उपयोगकर्ता को मेनू का उपयोग करने के बजाय एक बटन पर क्लिक करके फ़ॉर्म पर कुछ क्रियाएं करने की अनुमति देता है।

  • एक टूलबार बटन का एक सुविधाजनक समूह प्रदान करता है जो बटन के रूप में सबसे सुलभ कार्यों को लाकर उपयोगकर्ता की नौकरी को सरल करता है।

  • एक टूलबार ऐसी सामान्य क्रियाओं को उपयोगकर्ता के करीब ला सकता है।

  • टूलबार आमतौर पर मुख्य मेनू के तहत प्रदर्शित होते हैं।

  • वे बटन से लैस हो सकते हैं लेकिन कभी-कभी उनके बटन या उनके कुछ बटन कैप्शन में होते हैं।

  • टूलबार अन्य प्रकार के नियंत्रणों से भी लैस हो सकते हैं।

टूलबार बनाने के लिए, निम्न चरण हैं।

Step 1- अपने प्रोजेक्ट पर राइट-क्लिक करें और Add → Resources चुनें। आपको संसाधन जोड़ें संवाद बॉक्स दिखाई देगा।

Step 2- टूलबार का चयन करें और नया पर क्लिक करें। आपको निम्न स्क्रीन दिखाई देगी।

Step 3 - डिज़ाइनर में अपने टूलबार को डिज़ाइन करें जैसा कि निम्नलिखित स्क्रीनशॉट में दिखाया गया है और आईडी भी निर्दिष्ट करें।

Step 4 - इन दो चर को CMFCModalDemoDlg वर्ग में जोड़ें।

CToolBar m_wndToolBar;
   BOOL butD;

Step 5 - CMFCModalDemoDlg का पूरा कार्यान्वयन CMFCModalDemoDlg.h फ़ाइल में निम्नलिखित है -

class CMFCModalDemoDlg : public CDialogEx {
   // Construction
   public:
      CMFCModalDemoDlg(CWnd* pParent = NULL); // standard constructor
   // Dialog Data
   #ifdef AFX_DESIGN_TIME
      enum { IDD = IDD_MFCMODALDEMO_DIALOG };
   #endif

   protected:
      virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
   
   // Implementation
   protected:
      HICON m_hIcon;
      CToolBar m_wndToolBar;
      BOOL butD;
   
      // Generated message map functions
      virtual BOOL OnInitDialog();
      afx_msg void OnPaint();
      afx_msg HCURSOR OnQueryDragIcon();
      DECLARE_MESSAGE_MAP()
	
   public:
      afx_msg void OnBnClickedOk();
};

Step 6 - अद्यतन CMFCModalDemoDlg :: OnInitDialog () निम्न कोड में दिखाया गया है।

BOOL CMFCModalDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();
   
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);       // Set big icon
   SetIcon(m_hIcon, FALSE);      // Set small icon
   
   if (!m_wndToolBar.Create(this)
      || !m_wndToolBar.LoadToolBar(IDR_TOOLBAR1))
      //if (!m_wndToolBar.CreateEx(this, TBSTYLE_FLAT, WS_CHILD |
      // WS_VISIBLE | CBRS_TOP | CBRS_GRIPPER | CBRS_TOOLTIPS |
      // CBRS_FLYBY | CBRS_SIZE_DYNAMIC) ||
      // !m_wndToolBar.LoadToolBar(IDR_TOOLBAR1)) {
         TRACE0("Failed to Create Dialog Toolbar\n");
         EndDialog(IDCANCEL);
      }
      butD = TRUE;
      CRect rcClientOld; // Old Client Rect
      CRect rcClientNew; // New Client Rect with Tollbar Added
		
      // Retrive the Old Client WindowSize
      // Called to reposition and resize control bars in the client area of a window
      // The reposQuery FLAG does not really traw the Toolbar. It only does the calculations.
      // And puts the new ClientRect values in rcClientNew so we can do the rest of the Math.
      
      GetClientRect(rcClientOld);
      RepositionBars(AFX_IDW_CONTROLBAR_FIRST, AFX_IDW_CONTROLBAR_LAST, 0, reposQuery, rcClientNew);
      // All of the Child Windows (Controls) now need to be moved so the Tollbar does not cover them up.
      // Offest to move all child controls after adding Tollbar 
      CPoint ptOffset(rcClientNew.left - rcClientOld.left, rcClientNew.top - rcClientOld.top); 
		 
      CRect rcChild;
      CWnd* pwndChild = GetWindow(GW_CHILD); //Handle to the Dialog Controls
      
      while (pwndChild) // Cycle through all child controls {
         pwndChild -> GetWindowRect(rcChild); // Get the child control RECT
         ScreenToClient(rcChild);
          
         // Changes the Child Rect by the values of the claculated offset
         rcChild.OffsetRect(ptOffset);
         pwndChild -> MoveWindow(rcChild, FALSE); // Move the Child Control
         pwndChild = pwndChild -> GetNextWindow();
      }
       
      CRect rcWindow;
      // Get the RECT of the Dialog
      GetWindowRect(rcWindow);
       
      // Increase width to new Client Width
      rcWindow.right += rcClientOld.Width() - rcClientNew.Width();
       
      // Increase height to new Client Height
       rcWindow.bottom += rcClientOld.Height() - rcClientNew.Height();
      // Redraw Window
      MoveWindow(rcWindow, FALSE);
       
      // Now we REALLY Redraw the Toolbar
      RepositionBars(AFX_IDW_CONTROLBAR_FIRST, AFX_IDW_CONTROLBAR_LAST, 0);
       
   // TODO: Add extra initialization here

   return TRUE; // return TRUE unless you set the focus to a control
}

Step 7- इस एप्लिकेशन को चलाएं। आपको निम्न डायलॉग बॉक्स दिखाई देगा जिसमें टूलबार भी है।

त्वरक

एक access keyएक पत्र है जो उपयोगकर्ता को माउस के बजाय कीबोर्ड का उपयोग करके मेनू क्रिया को तेजी से करने की अनुमति देता है। यह आमतौर पर तेजी से होता है क्योंकि उपयोगकर्ता को माउस को कहीं भी रखने की आवश्यकता नहीं होती है, जिससे कार्रवाई करने में लगने वाले समय में कमी आती है।

Step 1 - एक्सेस कुंजी बनाने के लिए, मेनू आइटम के बाईं ओर एक एम्परसेंड "और" लिखें।

Step 2- सभी मेनू विकल्पों के लिए इस चरण को दोहराएं। इस एप्लिकेशन को चलाएं और Alt दबाएं। आप देखेंगे कि सभी मेनू विकल्पों के पहले अक्षर को रेखांकित किया गया है।

शॉर्टकट की

शॉर्टकट कुंजी उन्नत उपयोगकर्ताओं द्वारा उपयोग की जाने वाली एक कुंजी या कुंजी का एक संयोजन है जो एक कार्रवाई करने के लिए होती है जो अन्यथा मेनू आइटम पर किया जाएगा। अधिकांश शॉर्टकट एक पत्र कुंजी के साथ दबाए गए एक साथ Ctrl कुंजी का एक संयोजन है। उदाहरण के लिए, Ctrl + N, Ctrl + O, या Ctrl + D।

शॉर्टकट बनाने के लिए, स्ट्रिंग के दाईं ओर जो मेनू मेनू बनाता है, मेनू आइटम पर राइट क्लिक करें और गुणों का चयन करें।

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

त्वरक तालिका

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

Step 1 - एक त्वरक तालिका बनाने के लिए, समाधान एक्सप्लोरर में * .rc फ़ाइल पर राइट-क्लिक करें।

Step 2 - एक्सेलेरेटर का चयन करें और नया पर क्लिक करें।

Step 3 - आईडी कॉम्बो बॉक्स के तीर पर क्लिक करें और मेनू आइटम का चयन करें।

Step 4 - संशोधक ड्रॉपडाउन से Ctrl का चयन करें।

Step 5 - कुंजी बॉक्स पर क्लिक करें और दोनों मेनू विकल्पों के लिए संबंधित कुंजी टाइप करें।

हम परीक्षण के लिए नई मेनू आइटम इवेंट हैंडलर भी जोड़ेंगे। न्यू मेनू विकल्प पर राइट-क्लिक करें।

Step 6- आप एक वर्ग, संदेश प्रकार और हैंडलर नाम निर्दिष्ट कर सकते हैं। अभी के लिए, आइए इसे छोड़ दें और इसे जोड़ें और संपादित करें बटन पर क्लिक करें।

Step 7 - ईवेंट हैंडलर जोड़ें का चयन करें।

Step 8 - अब आप CMFCModalDemoDlg.cpp फ़ाइल के अंत में जोड़े गए ईवेंट देखेंगे।

void CMFCModalDemoDlg::OnFileNew() {
   // TODO: Add your command handler code here
   MessageBox(L"File > New menu option");
}

Step 9 - Now हमें एक संदेश बॉक्स जोड़ें जो सरल मेनू विकल्प संदेश प्रदर्शित करेगा।

काम करने में त्वरक तालिका शुरू करने के लिए HACCEL चर और ProcessMessageFilter जोड़ें जैसा कि निम्नलिखित CMFCModalDemoApp में दिखाया गया है।

class CMFCModalDemoApp : public CWinApp {
   public:
      CMFCModalDemoApp();
   
   // Overrides
   public:
      virtual BOOL InitInstance();
      HACCEL m_hAccelTable;
      
      // Implementation

      DECLARE_MESSAGE_MAP()
      virtual BOOL ProcessMessageFilter(int code, LPMSG lpMsg);
};

Step 10 - लोड त्वरक और CMFCModalDemoApp में निम्नलिखित कॉल :: InitInstance ()।

m_hAccelTable = LoadAccelerators(AfxGetInstanceHandle(),
   MAKEINTRESOURCE(IDR_ACCELERATOR1));

Step 11 - यहाँ ProcessMessageFilter का कार्यान्वयन है।

BOOL CMFCModalDemoApp::ProcessMessageFilter(int code, LPMSG lpMsg) {
   if (code >= 0 && m_pMainWnd && m_hAccelTable) {
      if (::TranslateAccelerator(m_pMainWnd -> m_hWnd, m_hAccelTable, lpMsg))
      return TRUE;
   }
   return CWinApp::ProcessMessageFilter(code, lpMsg);
}

Step 12 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 13 - F कुंजी के बाद Alt बटन दबाएं और फिर N कुंजी या Ctrl + N। आपको निम्न संदेश दिखाई देगा।

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

प्रॉपर्टी पेज बनाने के लिए, हम MFC प्रोजेक्ट पर आधारित संवाद बनाकर एक सरल उदाहरण देखते हैं।

एक बार परियोजना बन जाने के बाद, हमें कुछ संपत्ति पृष्ठों को जोड़ना होगा।

विज़ुअल स्टूडियो संसाधन जोड़ें बॉक्स प्रदर्शित करके, डायलॉग नोड का विस्तार करके और IDD_PROPPAGE_X आइटम में से एक का चयन करके संपत्ति पृष्ठों के लिए संसाधन बनाना आसान बनाता है।

Step 1 - समाधान एक्सप्लोरर में अपनी परियोजना पर राइट-क्लिक करें और जोड़ें → संसाधन चुनें।

Step 2 - IDD_PROPPAGE_LARGE चुनें और NEW पर क्लिक करें।

Step 3 - आइए हम इस संपत्ति पृष्ठ की आईडी और कैप्शन को बदलते हैं IDD_PROPPAGE_1 तथा Property Page 1 जैसा कि ऊपर दिखाया गया है।

Step 4 - डिजाइनर विंडो में प्रॉपर्टी पेज पर राइट क्लिक करें।

Step 5 - क्लास जोड़ें विकल्प चुनें।

Step 6 - कक्षा का नाम दर्ज करें और आधार वर्ग ड्रॉपडाउन सूची से CPropertyPage का चयन करें।

Step 7 - जारी रखने के लिए समाप्त क्लिक करें।

Step 8 - उपर्युक्त चरणों का पालन करके आईडी IDD_PROPPAGE_2 और कैप्शन प्रॉपर्टी पेज 2 के साथ एक और संपत्ति पृष्ठ जोड़ें।

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

प्रॉपर्टी शीट संपत्ति के पन्नों को एक साथ रखता है और इसे इकाई के रूप में रखता है।

प्रॉपर्टी शीट बनाने के लिए, नीचे दिए गए चरणों का पालन करें -

Step 1 - अपनी परियोजना पर राइट-क्लिक करें और Add> Class मेनू विकल्प चुनें।

Step 2 - टेम्पलेट फलक में बाएं फलक और MFC वर्ग से दृश्य C ++ → MFC का चयन करें और Add पर क्लिक करें।

Step 3 - कक्षा का नाम दर्ज करें और आधार वर्ग ड्रॉपडाउन सूची से CPropertySheet चुनें।

Step 4 - जारी रखने के लिए फिनिश पर क्लिक करें।

Step 5 - इस संपत्ति पत्रक को लॉन्च करने के लिए, हमें अपने मुख्य परियोजना वर्ग में निम्नलिखित परिवर्तनों की आवश्यकता है।

Step 6 - CMFCPropSheetDemo.cpp फ़ाइल में निम्न संदर्भ जोड़ें।

#include "MySheet.h"
#include "PropPage1.h"
#include "PropPage2.h"

Step 7 - निम्नलिखित कोड में दिखाए गए अनुसार CMFCPropSheetDemoApp :: InitInstance () विधि को संशोधित करें।

CMySheet mySheet(L"Property Sheet Demo");
CPropPage1 page1;
CPropPage2 page2;

mySheet.AddPage(&page1);
mySheet.AddPage(&page2);

m_pMainWnd = &mySheet;
INT_PTR nResponse = mySheet.DoModal();

Step 8 - यहां CMFCPropSheetDemo.cpp फ़ाइल का पूर्ण कार्यान्वयन है।

// MFCPropSheetDemo.cpp : Defines the class behaviors for the application.
//
#include "stdafx.h"
#include "MFCPropSheetDemo.h"
#include "MFCPropSheetDemoDlg.h"
#include "MySheet.h"
#include "PropPage1.h"
#include "PropPage2.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CMFCPropSheetDemoApp
BEGIN_MESSAGE_MAP(CMFCPropSheetDemoApp, CWinApp)
   ON_COMMAND(ID_HELP, &CWinApp::OnHelp)
END_MESSAGE_MAP()


// CMFCPropSheetDemoApp construction

CMFCPropSheetDemoApp::CMFCPropSheetDemoApp() {

   // support Restart Manager
   m_dwRestartManagerSupportFlags = AFX_RESTART_MANAGER_SUPPORT_RESTART;
   // TODO: add construction code here,
   // Place all significant initialization in InitInstance
}


// The one and only CMFCPropSheetDemoApp object

CMFCPropSheetDemoApp theApp;


// CMFCPropSheetDemoApp initialization

BOOL CMFCPropSheetDemoApp::InitInstance() {
   
   // InitCommonControlsEx() is required on Windows XP if an application
   // manifest specifies use of ComCtl32.dll version 6 or later to enable
   // visual styles. Otherwise, any window creation will fail.
   INITCOMMONCONTROLSEX InitCtrls;
   InitCtrls.dwSize = sizeof(InitCtrls);
   // Set this to include all the common control classes you want to use
   // in your application.
   InitCtrls.dwICC = ICC_WIN95_CLASSES;
   InitCommonControlsEx(&InitCtrls);
   
   CWinApp::InitInstance();
   
   
   AfxEnableControlContainer();
   
   // Create the shell manager, in case the dialog contains
   // any shell tree view or shell list view controls.
   CShellManager *pShellManager = new CShellManager;

   // Activate "Windows Native" visual manager for enabling themes in MFC controls
   CMFCVisualManager::SetDefaultManager(RUNTIME_CLASS(CMFCVisualManagerWindows));
   // Standard initialization
   // If you are not using these features and wish to reduce the size
   // of your final executable, you should remove from the following
   // the specific initialization routines you do not need
   // Change the registry key under which our settings are stored
   // TODO: You should modify this string to be something appropriate
   // such as the name of your company or organization
   SetRegistryKey(_T("Local AppWizard-Generated Applications"));
   
   CMySheet mySheet(L"Property Sheet Demo");
   CPropPage1 page1;
   CPropPage2 page2;
   
   mySheet.AddPage(&page1);
   mySheet.AddPage(&page2);
   
   m_pMainWnd = &mySheet;
   INT_PTR nResponse = mySheet.DoModal();
   if (nResponse == IDOK) {
      // TODO: Place code here to handle when the dialog is
      // dismissed with OK
   }else if (nResponse == IDCANCEL) {
      // TODO: Place code here to handle when the dialog is
      // dismissed with Cancel
   }else if (nResponse == -1) {    
      TRACE(traceAppMsg, 0, "Warning: dialog creation failed, 
        so application is terminating unexpectedly.\n");
      TRACE(traceAppMsg, 0, "Warning: if you are using MFC controls on the dialog, 
        you cannot #define _AFX_NO_MFC_CONTROLS_IN_DIALOGS.\n");
   }

   // Delete the shell manager created above.
   if (pShellManager != NULL) {
      delete pShellManager;
   }

   // Since the dialog has been closed, return FALSE so that we exit the
   // application, rather than start the application's message pump.
   return FALSE;
}

Step 9- जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्नलिखित संवाद बॉक्स दिखाई देगा। इस संवाद बॉक्स में दो गुण पृष्ठ हैं।

Layout of controlsआवेदन प्रयोज्यता के लिए बहुत महत्वपूर्ण और महत्वपूर्ण है। इसका उपयोग आपके एप्लिकेशन में GUI तत्वों के समूह को व्यवस्थित करने के लिए किया जाता है। लेआउट का चयन करते समय कुछ महत्वपूर्ण बातें हैं -

  • बाल तत्वों की स्थिति।
  • बाल तत्वों का आकार।

नियंत्रण जोड़ना

आइए हम नए डायलॉग आधारित MFC प्रोजेक्ट MFCLayoutDemo बनाएं।

Step 1 - प्रोजेक्ट बन जाने के बाद, आपको निम्न स्क्रीन दिखाई देगी।

Step 2 - डायलॉग बॉक्स से TODO को डिलीट करें।

Step 3 - टूलबॉक्स से कुछ नियंत्रण खींचें जिन्हें आप बाईं ओर देख सकते हैं।

(हम एक स्टैटिक टेक्स्ट और एक एडिट कंट्रोल को निम्न स्नैपशॉट में दिखाए गए अनुसार खींचेंगे)।

Step 4 - स्टेटिक टेक्स्ट के कैप्शन को नाम में बदलें।

ग्रिड पर नियंत्रण रखें

नियंत्रण ग्रिड मार्गदर्शक ग्रिड डॉट्स है, जो डिजाइनिंग के समय आपके द्वारा नियंत्रित किए जा रहे नियंत्रण की स्थिति में मदद कर सकता है।

नियंत्रण ग्रिड को सक्षम करने के लिए, आपको टूलबार में टॉगल ग्रिड बटन पर क्लिक करना होगा जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

नियंत्रण आकार बदलने

आपके द्वारा डायलॉग बॉक्स में नियंत्रण जोड़ने के बाद, यह या तो इसके डिफ़ॉल्ट आकार को मान लेता है या आपके द्वारा इसे आकार दिया जाता है। प्रपत्र या संवाद बॉक्स पर नियंत्रण के आकारों के साथ मदद करने के लिए, विज़ुअल स्टूडियो काले बिंदुओं से बना एक दृश्य ग्रिड प्रदान करता है।

एक नियंत्रण का आकार बदलने के लिए, अर्थात्, इसे एक विशेष चौड़ाई या ऊँचाई देने के लिए, माउस को किसी एक हैंडल पर रखें और इसे वांछित दिशा में खींचें।

अब आप इस डॉटेड ग्रिड की मदद से नियंत्रणों का आकार बदल सकते हैं।

पदों पर नियंत्रण

नियंत्रण आप एक संवाद बॉक्स या एक फार्म पर स्थिति उनके दिए गए स्थान मान। अधिकांश समय, ये स्थिति व्यावहारिक नहीं हैं। आप उन्हें अपनी पसंद के किसी भी स्थान पर ले जा सकते हैं।

आइए हम कुछ और नियंत्रण जोड़ते हैं -

Step 1 - नियंत्रण को स्थानांतरित करने के लिए, इच्छित दिशा में पहुंचने तक इसे वांछित दिशा में क्लिक करें और खींचें।

Step 2- नियंत्रण के एक समूह को स्थानांतरित करने के लिए, पहले उन्हें चुनें। फिर चयन को वांछित स्थान पर खींचें। हमें स्टैटिक टेक्सट और एडिट कंट्रोल चुनें।

Step 3 - इन चयनित नियंत्रणों को बाईं ओर ले जाएं।

नियंत्रणों की स्थिति में मदद करने के लिए, विजुअल स्टूडियो निम्नलिखित बटन के साथ डायलॉग टूलबार प्रदान करता है।

Step 1 - हमें इन सभी नियंत्रणों का चयन करके बाईं ओर चेक बॉक्स और स्टेटिक टेक्स्ट नियंत्रणों को संरेखित करें।

Step 2 - प्रारूप का चयन करें → संरेखित करें → Lefts।

Step 3 - अब आप देख सकते हैं कि ये सभी नियंत्रण बाईं ओर संरेखित हैं।

टैब ऑर्डर करना

आपके द्वारा किसी प्रपत्र या संवाद बॉक्स में जो नियंत्रण जोड़े जाते हैं, वे उस क्रम में स्थित होते हैं, जो उनके द्वारा जोड़े गए आदेश का पालन करता है। जब आप उस अनुभाग या क्षेत्र की परवाह किए बिना नियंत्रण जोड़ते हैं, तो आप नए नियंत्रण को रखते हैं, यह क्रमिक रूप से मौजूदा नियंत्रणों के अंत में स्थित होता है। यदि आप इसे ठीक नहीं करते हैं, तो उपयोगकर्ता को नियंत्रण नेविगेट करने में एक कठिन समय होगा। नियंत्रण नेविगेशन के अनुक्रम को टैब ऑर्डर के रूप में भी जाना जाता है।

टैब बदलने के लिए, आप या तो प्रारूप → टैब ऑर्डर मेनू विकल्प का उपयोग कर सकते हैं या आप Ctrl + D शॉर्टकट का भी उपयोग कर सकते हैं। हमें Ctrl + D दबाएं।

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

इस उदाहरण में, हम पहले चेकबॉक्स पर क्लिक करेंगे, जिसके बाद नाम और पता संपादित नियंत्रण होगा। फिर ठीक पर क्लिक करें और रद्द करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

आइए हम इस एप्लिकेशन को चलाते हैं और आपको निम्न आउटपुट दिखाई देगा।

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

  • एक चर का उपयोग नियंत्रण में संग्रहीत जानकारी के लिए किया जाता है, जिसे इस रूप में भी जाना जाता है Control Variable/Instance

  • अन्य चर के रूप में जाना जाता है Control Value Variable। एक उपयोगकर्ता इस चर के साथ उस नियंत्रण पर कुछ प्रकार की क्रियाएं कर सकता है।

नियंत्रण चर / आवृत्ति

एक नियंत्रण चर वर्ग पर आधारित एक चर है जो नियंत्रण का प्रबंधन करता है। उदाहरण के लिए, एक बटन नियंत्रण CButton वर्ग पर आधारित है।

इन अवधारणाओं को वास्तविक प्रोग्रामिंग में देखने के लिए, हमें एक एमएफसी संवाद आधारित परियोजना MFCControlManagement बनाएं।

प्रोजेक्ट बन जाने के बाद, आपको डिज़ाइनर विंडो में निम्नलिखित डायलॉग बॉक्स दिखाई देगा।

Step 1- TODO लाइन हटाएं और एक चेकबॉक्स और एक एडिट कंट्रोल को नीचे दिए गए स्नैपशॉट में दिखाए अनुसार खींचें। नियंत्रण सक्षम करने के लिए चेकबॉक्स के कैप्शन को बदलें।

Step 2 - चेकबॉक्स पर राइट क्लिक करें।

Step 3 - Add Variable चुनें।

Step 4 - अब आप Add Member Variable Wizard देख सकते हैं।

आप इस डायलॉग बॉक्स पर विभिन्न विकल्पों का चयन कर सकते हैं। चेकबॉक्स के लिए, चर प्रकार CButton है। यह इस संवाद बॉक्स में डिफ़ॉल्ट रूप से चयनित है।

इसी प्रकार, नियंत्रण आईडी भी डिफ़ॉल्ट रूप से चयनित है अब हमें श्रेणी कॉम्बो बॉक्स में नियंत्रण का चयन करने की आवश्यकता है, और चर नाम संपादित करें बॉक्स में m_enableDisableCheck टाइप करें और फिनिश पर क्लिक करें।

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

संवाद वर्ग की हेडर फ़ाइल का निरीक्षण करें। आप देख सकते हैं कि नए वेरिएबल को अब जोड़ दिया गया है।

CButton m_enableDisableCheck;
CEdit m_myEditControl;

नियंत्रण मूल्य चर

एक अन्य प्रकार का चर जिसे आप नियंत्रण के लिए घोषित कर सकते हैं वह है मूल्य चर। सभी नियंत्रण एक मान चर प्रदान नहीं करते हैं।

  • मान चर को उस नियंत्रण में संग्रहीत मान के प्रकार को संभालने में सक्षम होना चाहिए जिसे इसे संदर्भित करना है।

  • उदाहरण के लिए, क्योंकि पाठ को संभालने के लिए एक पाठ आधारित नियंत्रण का उपयोग किया जाता है, आप इसके लिए एक पाठ-आधारित डेटा प्रकार की घोषणा कर सकते हैं। यह आमतौर पर एक CString चर होगा।

आइए हम चेकबॉक्स और संपादन नियंत्रण के लिए इस प्रकार के चर को देखें।

Step 1 - चेकबॉक्स पर राइट-क्लिक करें और Add Variable चुनें।

Step 2- चर प्रकार BOOL है। श्रेणी ड्रॉपडाउन सूची से मान का चयन करें।

Step 3 - जारी रखने के लिए समाप्त क्लिक करें।

Step 4 - इसी तरह, निम्नलिखित स्नैपशॉट में दिखाए अनुसार सेटिंग्स के साथ संपादन नियंत्रण के लिए वैरिएबल जोड़ें।

Step 5 - चर प्रकार में CString और चर नाम फ़ील्ड में m_editControlVal लिखें।

Step 6 - अब आप हैडर फ़ाइल में जोड़े गए इन चरों को देख सकते हैं।

bool m_enableDisableVal;
CString m_editControlVal;

ईवेंट हैंडलर्स को नियंत्रित करता है

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

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

  • आप डिफ़ॉल्ट नियंत्रण अधिसूचना घटना के लिए या किसी भी लागू विंडोज संदेश के लिए जल्दी से एक हैंडलर बना सकते हैं।

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

Step 1 - उस कंट्रोल को राइट-क्लिक करें जिसके लिए आप नोटिफिकेशन इवेंट को हैंडल करना चाहते हैं।

Step 2 - शॉर्टकट मेनू पर, ईवेंट हैंडलर विज़ार्ड प्रदर्शित करने के लिए इवेंट हैंडलर जोड़ें पर क्लिक करें।

Step 3 - क्लास सूची बॉक्स में चयनित वर्ग में जोड़ने के लिए संदेश प्रकार बॉक्स में घटना का चयन करें।

Step 4 - फ़ंक्शन हैंडलर नाम बॉक्स में डिफ़ॉल्ट नाम को स्वीकार करें, या अपनी पसंद का नाम प्रदान करें।

Step 5 - ईवेंट हैंडलर जोड़ने के लिए जोड़ें और संपादित करें पर क्लिक करें।

Step 6 - अब आप CMFCControlManagementDlg.cpp फ़ाइल के अंत में जोड़े गए निम्न ईवेंट को देख सकते हैं।

void CMFCControlManagementDlg::OnBnClickedCheck1() {
   // TODO: Add your control notification handler code here
}

नियंत्रण प्रबंधन

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

Step 1- आइए हम निम्नलिखित उदाहरण देखें। जब चेकबॉक्स चेक / अनचेक किया जाता है, तो हम संपादन नियंत्रण को सक्षम / अक्षम कर देंगे।

Step 2- हमने अब चेकबॉक्स क्लिक ईवेंट हैंडलर जोड़ा है। यहाँ कार्यान्वयन है -

void CMFCControlManagementDlg::OnBnClickedCheck1() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   if (m_enableDisableVal)
      m_myEditControl.EnableWindow(TRUE);
   else
      m_myEditControl.EnableWindow(FALSE);
}

Step 3- जब संवाद बनाया जाता है, तो हमें निम्नलिखित कोड को CMFCControlManagementDlg :: OnInitDialog () में जोड़ना होगा। यह इन नियंत्रणों का प्रबंधन करेगा।

UpdateData(TRUE);
if (m_enableDisableVal)
   m_myEditControl.EnableWindow(TRUE);
else
   m_myEditControl.EnableWindow(FALSE);

Step 4 - यहां CMFCControlManagementDlg.cpp फ़ाइल का पूर्ण कार्यान्वयन है।

// MFCControlManagementDlg.cpp : implementation file
//

#include "stdafx.h"
#include "MFCControlManagement.h"
#include "MFCControlManagementDlg.h"
#include "afxdialogex.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif


// CAboutDlg dialog used for App About

class CAboutDlg : public CDialogEx {
   public:
      CAboutDlg();
	
   // Dialog Data
   #ifdef AFX_DESIGN_TIME
      enum { IDD = IDD_ABOUTBOX };
   #endif

   protected:
      virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
      
   // Implementation
   protected:
      DECLARE_MESSAGE_MAP()
};

CAboutDlg::CAboutDlg() : CDialogEx(IDD_ABOUTBOX) {

}
void CAboutDlg::DoDataExchange(CDataExchange* pDX) {
   CDialogEx::DoDataExchange(pDX);
}

BEGIN_MESSAGE_MAP(CAboutDlg, CDialogEx)
END_MESSAGE_MAP()

// CMFCControlManagementDlg dialog


CMFCControlManagementDlg::CMFCControlManagementDlg(CWnd* pParent /* = NULL*/)
   :CDialogEx(IDD_MFCCONTROLMANAGEMENT_DIALOG, pParent) , 
   m_enableDisableVal(FALSE) , m_editControlVal(_T("")) {
   m_hIcon = AfxGetApp()&rarr LoadIcon(IDR_MAINFRAME);
}

void CMFCControlManagementDlg::DoDataExchange(CDataExchange* pDX) {
   CDialogEx::DoDataExchange(pDX);
   DDX_Control(pDX, IDC_CHECK1, m_enableDisableCheck);
   DDX_Control(pDX, IDC_EDIT1, m_myEditControl);
   DDX_Check(pDX, IDC_CHECK1, m_enableDisableVal);
   DDX_Text(pDX, IDC_EDIT1, m_editControlVal);
}
BEGIN_MESSAGE_MAP(CMFCControlManagementDlg, CDialogEx)
   ON_WM_SYSCOMMAND()
   ON_WM_PAINT()
   ON_WM_QUERYDRAGICON()
   ON_BN_CLICKED(IDC_CHECK1, &CMFCControlManagementDlg::OnBnClickedCheck1)
END_MESSAGE_MAP()

// CMFCControlManagementDlg message handlers

BOOL CMFCControlManagementDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();
      
   // Add "About..." menu item to system menu.
   // IDM_ABOUTBOX must be in the system command range.
   ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
   ASSERT(IDM_ABOUTBOX < 0xF000);
      
   CMenu* pSysMenu = GetSystemMenu(FALSE);
   if (pSysMenu != NULL) {
      BOOL bNameValid;
      CString strAboutMenu;
      bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
      ASSERT(bNameValid);
      if (!strAboutMenu.IsEmpty()) {
         pSysMenu → AppendMenu(MF_SEPARATOR);
         pSysMenu → AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
      }
   }
	
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);        // Set big icon
   SetIcon(m_hIcon, FALSE);       // Set small icon

   // TODO: Add extra initialization here
   UpdateData(TRUE);
   if (m_enableDisableVal)
      m_myEditControl.EnableWindow(TRUE);
   else
      m_myEditControl.EnableWindow(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}
void CMFCControlManagementDlg::OnSysCommand(UINT nID, LPARAM lParam) {
   if ((nID & 0xFFF0) == IDM_ABOUTBOX) {
      CAboutDlg dlgAbout;
      dlgAbout.DoModal();
   }else {
      CDialogEx::OnSysCommand(nID, lParam);
   }
}

// If you add a minimize button to your dialog, you will need the code below
// to draw the icon. For MFC applications using the document/view model,
// this is automatically done for you by the framework.

void CMFCControlManagementDlg::OnPaint() {
   if (IsIconic()) {
      CPaintDC dc(this); // device context for painting
      
      SendMessage(WM_ICONERASEBKGND,
         reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
			
      // Center icon in client rectangle
      int cxIcon = GetSystemMetrics(SM_CXICON);
      int cyIcon = GetSystemMetrics(SM_CYICON);
      CRect rect;
      GetClientRect(&rect);
      int x = (rect.Width() - cxIcon + 1) / 2;
      int y = (rect.Height() - cyIcon + 1) / 2;
		
      // Draw the icon
      dc.DrawIcon(x, y, m_hIcon);
   }else {
      CDialogEx::OnPaint();
   }
}

// The system calls this function to obtain the cursor to display while the user drags
// the minimized window.
HCURSOR CMFCControlManagementDlg::OnQueryDragIcon() {
   return static_cast<HCURSOR>(m_hIcon);
}

void CMFCControlManagementDlg::OnBnClickedCheck1() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   if (m_enableDisableVal)
      m_myEditControl.EnableWindow(TRUE);
   else
      m_myEditControl.EnableWindow(FALSE);
}

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

Step 6- नियंत्रण नियंत्रण सक्षम करें चेकबॉक्स की जांच करें। यह स्वचालित रूप से संपादन नियंत्रण को सक्षम करेगा।

Windows controlsवे ऑब्जेक्ट हैं जो उपयोगकर्ता डेटा दर्ज करने या हेरफेर करने के लिए बातचीत कर सकते हैं। वे आमतौर पर डायलॉग बॉक्स या टूलबार पर दिखाई देते हैं। विभिन्न प्रकार के नियंत्रण हैं -

  • text based control जिसका उपयोग उपयोगकर्ता को पाठ प्रदर्शित करने या उपयोगकर्ता से पाठ का अनुरोध करने के लिए किया जाता है।

  • list based control वस्तुओं की एक सूची प्रदर्शित करता है।

  • progress based control एक कार्रवाई की प्रगति दिखाने के लिए प्रयोग किया जाता है।

  • static control रंग दिखाने के लिए इस्तेमाल किया जा सकता है, एक तस्वीर या ऐसा कुछ जो नियमित रूप से उपरोक्त श्रेणियों में फिट नहीं होता है।

अनु क्रमांक। नियंत्रण और विवरण
1 स्थैतिक नियंत्रण

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

2 एनीमेशन नियंत्रण

एक एनीमेशन नियंत्रण एक विंडो है जो AVI प्रारूप में एक ऑडियो क्लिप प्रदर्शित करता है। एक AVI क्लिप बिटमैप फ्रेम की एक श्रृंखला है, एक फिल्म की तरह। एनीमेशन नियंत्रण केवल साधारण एवीआई क्लिप खेल सकते हैं, और वे ध्वनि का समर्थन नहीं करते हैं। यह द्वारा प्रतिनिधित्व किया हैCAnimateCtrl कक्षा।

3 बटन

buttonएक वस्तु है जो उपयोगकर्ता कार्रवाई शुरू करने के लिए क्लिक करता है। बटन नियंत्रण द्वारा दर्शाया गया हैCButton class

4 बिटमैप बटन

bitmap buttonएक तस्वीर या एक तस्वीर और उसके चेहरे पर पाठ प्रदर्शित करता है। यह आमतौर पर बटन को थोड़ा स्पष्ट करने के लिए होता है। एक बिटमैप बटन का उपयोग करके बनाया गया हैCBitmapButton class, जो CButton से प्राप्त हुआ है।

5 कमांड बटन

command buttonनियमित बटन का एक बढ़ाया संस्करण है। यह बाईं ओर एक हरे रंग का तीर आइकन प्रदर्शित करता है, इसके बाद नियमित आकार में एक कैप्शन होता है। मुख्य कैप्शन के तहत, यह एक और छोटा कैप्शन प्रदर्शित कर सकता है जो अधिक जानकारी प्रदान करने के संकेत के रूप में कार्य करता है।

6 स्थैतिक पाठ

static controlएक पाठ स्ट्रिंग, बॉक्स, आयत, आइकन, कर्सर, बिटमैप, या उन्नत मेटाफ़ाइल प्रदर्शित करता है। यह द्वारा प्रतिनिधित्व किया हैCStatic class। इसका उपयोग लेबल, बॉक्स या अलग-अलग नियंत्रणों के लिए किया जा सकता है। एक स्थैतिक नियंत्रण आम तौर पर कोई इनपुट नहीं लेता है और कोई आउटपुट नहीं देता है।

7 सूची बाक्स

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

8 कॉम्बो बॉक्स

combo boxएक स्थिर नियंत्रण या संपादन नियंत्रण के साथ संयुक्त सूची बॉक्स शामिल है। यह प्रतिनिधित्व करता हैCComboBox class। नियंत्रण के सूची-बॉक्स भाग को हर समय प्रदर्शित किया जा सकता है या केवल तभी ड्रॉप हो सकता है जब उपयोगकर्ता नियंत्रण के बगल में ड्रॉप-डाउन तीर का चयन करता है।

9 रेडियो के बटन

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

10 चेक बॉक्स

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

1 1 छवि सूची

एक Image Listसमान आकार की छवियों का एक संग्रह है, जिनमें से प्रत्येक को इसके शून्य-आधारित सूचकांक द्वारा संदर्भित किया जा सकता है। छवि सूचियों का उपयोग कुशलतापूर्वक माउस या बिटमैप के बड़े सेट को प्रबंधित करने के लिए किया जाता है। छवि सूचियों द्वारा प्रतिनिधित्व किया जाता हैCImageList class

12 बॉक्स संपादित करें

एक Edit Boxएक आयताकार बाल खिड़की है जिसमें उपयोगकर्ता पाठ दर्ज कर सकता है। यह द्वारा प्रतिनिधित्व किया हैCEdit class

13 समृद्ध संपादन

Rich Editनियंत्रण एक खिड़की है जिसमें उपयोगकर्ता पाठ दर्ज और संपादित कर सकता है। पाठ को वर्ण और अनुच्छेद प्रारूपण सौंपा जा सकता है, और इसमें एम्बेडेड OLE ऑब्जेक्ट शामिल हो सकते हैं। यह द्वारा प्रतिनिधित्व किया हैCRichEditCtrl class

14 समूह बॉक्स

group boxएक स्थिर नियंत्रण है जो नियंत्रण के दृश्यमान या प्रोग्रामेटिक समूह को सेट करने के लिए उपयोग किया जाता है। नियंत्रण एक आयत है जो अन्य समूहों को एक साथ नियंत्रित करता है।

15 स्पिन बटन

Spin Buttonनियंत्रण (जिसे अप-डाउन नियंत्रण के रूप में भी जाना जाता है) तीर बटन की एक जोड़ी है जिसे उपयोगकर्ता मूल्य बढ़ाने या घटाने के लिए क्लिक कर सकता है, जैसे कि स्क्रॉल स्थिति या साथी नियंत्रण में प्रदर्शित संख्या। यह प्रतिनिधित्व करता हैCSpinButtonCtrl class

16 अद्यतन नियंत्रण का प्रबंधन

यह अद्यतन नियंत्रण को प्रबंधित करता है।

17 प्रगति नियंत्रण

progress bar controlएक खिड़की है कि एक आवेदन एक लंबा ऑपरेशन की प्रगति को इंगित करने के लिए उपयोग कर सकते हैं। इसमें एक आयताकार होता है जो धीरे-धीरे भरा जाता है, बाएं से दाएं, सिस्टम के साथ रंग को हाइलाइट करता है जैसे ऑपरेशन आगे बढ़ता है। यह द्वारा प्रतिनिधित्व किया हैCProgressCtrl class

18 प्रगति पट्टी

progress bars एक खिड़की है जो एक अनुप्रयोग एक ऑपरेशन की प्रगति को इंगित करने के लिए उपयोग कर सकता है।

19 घड़ी

timerएक गैर-स्थानिक वस्तु है जो कंप्यूटर या डिक्योर एप्लिकेशन से समय के आवर्ती लेप्स का उपयोग करता है। काम करने के लिए, अवधि की प्रत्येक चूक, नियंत्रण ऑपरेटिंग सिस्टम को एक संदेश भेजता है। अधिकांश अन्य नियंत्रणों के विपरीत, MFC टाइमर के पास न तो इसका प्रतिनिधित्व करने के लिए कोई बटन है और न ही एक वर्ग। टाइमर बनाने के लिए, आप बस CWnd :: SetTimer () विधि को कॉल करते हैं। यह फ़ंक्शन कॉल आपके एप्लिकेशन के लिए टाइमर बनाता है। अन्य नियंत्रणों की तरह, एक टाइमर एक पहचानकर्ता का उपयोग करता है।

20 दिनांक और समय पिकर

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

21 चित्र

यदि आपको अपने आवेदन के लिए एक चित्र प्रदर्शित करने की आवश्यकता है, तो दृश्य C ++ उस उद्देश्य के लिए एक विशेष नियंत्रण प्रदान करता है।

22 छवि संपादक

Image editorछवियों को बनाने और संपादित करने के लिए उपकरणों का एक व्यापक सेट है, साथ ही टूलबार बिटमैप बनाने में आपकी सहायता करने के लिए वेलस सुविधाएँ हैं। बिटमैप्स, आइकन और कर्सर के अलावा, आप छवि संपादक टूलबार पर छवि मेनू और टूल पर कमांड का उपयोग करके GIF या JPEG प्रारूप में छवियों को संपादित कर सकते हैं।

23 स्लाइडर नियंत्रण

Slider Control(जिसे ट्रैकबार के रूप में भी जाना जाता है) एक खिड़की है जिसमें स्लाइडर और वैकल्पिक टिक चिह्न होते हैं। जब उपयोगकर्ता माउस या दिशा कुंजियों का उपयोग करके स्लाइडर को स्थानांतरित करता है, तो नियंत्रण परिवर्तन को इंगित करने के लिए अधिसूचना संदेश भेजता है। दो प्रकार के स्लाइडर्स हैं - क्षैतिज और ऊर्ध्वाधर। यह द्वारा प्रतिनिधित्व किया हैCSliderCtrl class

24 स्क्रॉलबार

scrollbarएक ग्राफिकल कंट्रोल तत्व है जिसके साथ एक तीर पर क्लिक करके नियंत्रण के साथ निरंतर पाठ, चित्र या अन्य कुछ भी दो दिशाओं में स्क्रॉल किया जा सकता है। यह नियंत्रण दो दिशाओं में से एक को मान सकता है - क्षैतिज या ऊर्ध्वाधर। यह द्वारा प्रतिनिधित्व किया हैCScrollBar कक्षा।

25 वृक्ष नियंत्रण

Tree View Controlएक खिड़की है जो वस्तुओं की एक श्रेणीबद्ध सूची प्रदर्शित करती है, जैसे कि किसी दस्तावेज़ में शीर्षक, एक सूचकांक में प्रविष्टियाँ, या एक डिस्क पर फ़ाइलें और निर्देशिकाएं। प्रत्येक आइटम में एक लेबल और एक वैकल्पिक बिटमैप छवि होती है, और प्रत्येक आइटम में इसके साथ जुड़े सबिटम्स की एक सूची हो सकती है। किसी आइटम पर क्लिक करके, उपयोगकर्ता उप-सूची की संबंधित सूची का विस्तार और पतन कर सकता है। यह द्वारा प्रतिनिधित्व किया हैCTreeCtrl कक्षा।

26 सूची नियंत्रण

एक सूची दृश्य नियंत्रण की कार्यक्षमता को एन्क्रिप्ट करता है, जो एक आइकन (एक छवि सूची से) और एक लेबल वाले प्रत्येक आइटम का एक संग्रह प्रदर्शित करता है। यह द्वारा प्रतिनिधित्व किया हैCListCtrlकक्षा। सूची नियंत्रण में वस्तुओं की सूची प्रदर्शित करने के लिए चार में से एक दृश्य का उपयोग करना शामिल है।

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

अवलोकन

  • Microsoft Windows ऑपरेटिंग सिस्टम यह अनुमान नहीं लगा सकता है कि किसी वस्तु को किस प्रकार के अनुरोधों की देखभाल करनी होगी और किस प्रकार के असाइनमेंट के लिए किसी अन्य ऑब्जेक्ट की आवश्यकता होगी।

  • इन सभी असाइनमेंट और अनुरोधों को प्रबंधित करने के लिए, ऑब्जेक्ट संदेश भेजते हैं।

  • प्रत्येक वस्तु की जिम्मेदारी है कि वह तय करे कि उसे क्या संदेश देना है और कब भेजना है।

  • संदेश भेजने के लिए, एक नियंत्रण एक घटना बनाना होगा।

  • दोनों के बीच अंतर करने के लिए, एक संदेश का नाम आमतौर पर WM_ के साथ शुरू होता है जो विंडो संदेश के लिए खड़ा है।

  • किसी घटना का नाम आमतौर पर शुरू होता है, जिस पर कार्रवाई का संकेत मिलता है।

  • घटना संदेश भेजने की क्रिया है।

संदेशों का मानचित्र

चूंकि विंडोज एक संदेश-उन्मुख ऑपरेटिंग सिस्टम है, इसलिए विंडोज वातावरण के लिए प्रोग्रामिंग के एक बड़े हिस्से में संदेश हैंडलिंग शामिल है। हर बार एक घटना जैसे किस्ट्रोक या माउस क्लिक होता है, एक संदेश आवेदन को भेजा जाता है, जिसे तब घटना को संभालना चाहिए।

  • संकलक के लिए संदेशों का प्रबंधन करने के लिए, उन्हें कक्षा की परिभाषा में शामिल किया जाना चाहिए।

  • DECLARE_MESSAGE_MAP मैक्रो को वर्ग परिभाषा के अंत में प्रदान किया जाना चाहिए जैसा कि निम्नलिखित कोड में दिखाया गया है।

class CMainFrame : public CFrameWnd {
   public:
      CMainFrame();
   protected:
      DECLARE_MESSAGE_MAP()
};
  • वास्तविक संदेशों को DECLARE_MESSAGE_MAP लाइन के ठीक ऊपर सूचीबद्ध किया जाना चाहिए।

  • संदेशों को लागू करने के लिए, आपको उन संदेशों की एक तालिका बनाने की आवश्यकता है जो आपके प्रोग्राम का उपयोग कर रहे हैं।

  • यह तालिका दो परिसीमन मैक्रो का उपयोग करती है;

  • इसकी शुरुआत ए से होती है BEGIN_MESSAGE_MAP और एक के साथ समाप्त होता है END_MESSAGE_MAP मैक्रो।

  • BEGIN_MESSAGE_MAP मैक्रो में दो तर्क होते हैं, आपकी कक्षा का नाम और MFC वर्ग जिसे आपने अपनी कक्षा से लिया है जैसा कि निम्नलिखित कोड में दिखाया गया है।

#include <afxwin.h>
class CMainFrame : public CFrameWnd {
   public:
      CMainFrame();
   protected:
      DECLARE_MESSAGE_MAP()
};
CMainFrame::CMainFrame() {

   // Create the window's frame
   Create(NULL, L"MFC Messages Demo", WS_OVERLAPPEDWINDOW,
                                      CRect(120, 100, 700, 480), NULL);
}
class CMessagesApp : public CWinApp {
   public:
      BOOL InitInstance();
};
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
END_MESSAGE_MAP()
BOOL CMessagesApp::InitInstance(){
   m_pMainWnd = new CMainFrame;
   m_pMainWnd->ShowWindow(SW_SHOW);
   m_pMainWnd->UpdateWindow();
   return TRUE;
}
CMessagesApp theApp;

हमें एक नया Win32 प्रोजेक्ट बनाकर एक साधारण उदाहरण में देखें।

Step 1 - एमएफसी परियोजना बनाने के लिए, परियोजना पर राइट-क्लिक करें और गुण चुनें।

Step 2 - बाएं अनुभाग में, कॉन्फ़िगरेशन गुण → सामान्य पर क्लिक करें।

Step 3 - प्रोजेक्ट डिफॉल्ट सेक्शन में 'यूज एमएफसी इन शेयर्ड डीएलएल' विकल्प चुनें और ओके पर क्लिक करें।

Step 4 - हमें एक नई स्रोत फ़ाइल जोड़ने की आवश्यकता है।

Step 5 - अपने प्रोजेक्ट पर राइट-क्लिक करें और Add → New Item चुनें।

Step 6 - टेम्प्लेट अनुभाग में, C ++ फ़ाइल (.cpp) पर क्लिक करें।

Step 7 - Add to Continue पर क्लिक करें।

Step 8 - अब, * .cpp फ़ाइल में निम्न कोड जोड़ें।

#include <afxwin.h>
class CMainFrame : public CFrameWnd {
   public:
      CMainFrame();
   protected:
      DECLARE_MESSAGE_MAP()
};

CMainFrame::CMainFrame() {
   // Create the window's frame
   Create(NULL, L"MFC Messages Demo", WS_OVERLAPPEDWINDOW,
      CRect(120, 100, 700, 480), NULL);
}

class CMessagesApp : public CWinApp {
   public:
      BOOL InitInstance();
};

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
END_MESSAGE_MAP()
BOOL CMessagesApp::InitInstance() {
   m_pMainWnd = new CMainFrame;
   m_pMainWnd->ShowWindow(SW_SHOW);
   m_pMainWnd->UpdateWindow();
   return TRUE;
}
CMessagesApp theApp;

विंडोज संदेश

विभिन्न प्रकार के विंडोज मैसेज हैं जैसे कि विंडो बनाना, विंडो दिखाना आदि। यहां आमतौर पर इस्तेमाल किए जाने वाले विंडो मैसेज में से कुछ हैं।

संदेश नक्शा प्रविष्टि विवरण
WM_ACTIVATE ON_WM_ACTIVATE () जब कोई CWnd ऑब्जेक्ट सक्रिय या निष्क्रिय किया जा रहा हो, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_ACTIVATEA PP ON_WM_ACTIVATEAPP () कार्य के सभी शीर्ष-स्तरीय विंडो के लिए फ्रेमवर्क इस सदस्य फ़ंक्शन को सक्रिय करता है और कार्य के सभी शीर्ष-स्तरीय विंडो के लिए निष्क्रिय किया जा रहा है।
WM_APPCOMM और ON_WM_APPCOMMAND () जब उपयोगकर्ता एप्लिकेशन कमांड इवेंट बनाता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_CANCELMODE WM_CANCELMODE () किसी भी आंतरिक मोड को रद्द करने के लिए CWnd को सूचित करने के लिए फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_CHILDACTIVATE ON_WM_CHILDACTIVATE () यदि CWnd ऑब्जेक्ट एक मल्टीपल डॉक्यूमेंट इंटरफ़ेस (MDI) चाइल्ड विंडो है, तो OnChildActivate को फ्रेमवर्क द्वारा बुलाया जाता है, जब उपयोगकर्ता विंडो के टाइटल बार पर क्लिक करता है या जब विंडो एक्टिवेट, मूव या साइज़ होता है।
WM_CLIPBOAR DUPDATE ON_WM_CLIPBOARDUPDATE () जब क्लिपबोर्ड की सामग्री बदल गई है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_CLOSE ON_WM_CLOSE () फ्रेमवर्क इस सदस्य फ़ंक्शन को एक संकेत के रूप में कहता है कि CWnd या एक एप्लिकेशन को समाप्त करना है।
WM_CONTEXTMENU ON_WM_CONTEXTMENU () फ्रेमवर्क द्वारा कॉल किया जाता है जब उपयोगकर्ता ने विंडो में राइट माउस बटन (राइटक्लिप्ड) पर क्लिक किया है।
WM_COPYDATA ON_WM_COPYDATA () इस सदस्य फ़ंक्शन को एक एप्लिकेशन से दूसरे में डेटा कॉपी करने के लिए फ्रेमवर्क द्वारा बुलाया जाता है।
WM_CREATE ON_WM_CREATE () जब अनुप्रयोग का अनुरोध या CreateEx सदस्य फ़ंक्शन को कॉल करके Windows विंडो बनाई जाती है, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_CTLCOLOR ON_WM_CTLCOLOR () जब बच्चा नियंत्रण तैयार करने वाला होता है, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_DELETEITEM ON_WM_DELETEITEM () किसी स्वामी द्वारा ड्रॉ सूची बॉक्स या कॉम्बो बॉक्स के स्वामी को सूचित करने के लिए कि इस सूची बॉक्स या कॉम्बो बॉक्स को नष्ट कर दिया गया है या आइटम हटा दिए गए हैं, फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_DESTROY ON_WM_DESTROY () उन्होंने सीडब्ल्यूएनडी वस्तु को सूचित करने के लिए इस सदस्य समारोह को फ्रेमवर्क कहा कि यह नष्ट हो रहा है।
WM_DRAWITEM ON_WM_DRAWITEM () फ्रेमवर्क इस सदस्य फ़ंक्शन को स्वामी-ड्रा बटन नियंत्रण, कॉम्बो-बॉक्स नियंत्रण, सूची-बॉक्स नियंत्रण, या मेनू के मालिक के लिए कहता है जब नियंत्रण या मेनू का एक दृश्य पहलू बदल गया है।
WM_DROPFILES ON_WM_DROPFILES () जब उपयोगकर्ता बाएं विंडो पर बाईं माउस बटन छोड़ता है, जो स्वयं को पंजीकृत फाइलों के प्राप्तकर्ता के रूप में पंजीकृत करता है, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_ENABLE ON_WM_ENABLE () जब कोई अनुप्रयोग CWnd ऑब्जेक्ट की सक्षम स्थिति को बदलता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है। वाक्य - विन्यास।
WM_HELPINFO ON_WM_HELPINFO () अनुप्रयोग के भीतर एफ 1 मदद (वर्तमान संदर्भ का उपयोग करके) संभालती है।
WM_HOTKEY ON_WM_HOTKEY () जब उपयोगकर्ता सिस्टम-वाइड हॉट कुंजी दबाता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_HSCROLL ON_WM_HSCROLL () जब उपयोगकर्ता किसी विंडो के क्षैतिज स्क्रॉल बार पर क्लिक करता है, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_KEYDOWN ON_WM_KEYDOWN () जब nonsystem कुंजी दबाया जाता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_KEYUP ON_WM_KEYUP () जब एक nonsystem कुंजी जारी की जाती है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_KILLFOCUS ON_WM_KILLFOCUS () इनपुट फ़ोकस खोने से तुरंत पहले फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_LBUTTONDBLCLK ON_WM_LBUTTONDBLCLK () जब उपयोगकर्ता बाईं माउस बटन को डबल-क्लिक करता है, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_LBUTTONDOWN ON_WM_LBUTTONDOWN () जब उपयोगकर्ता बाईं माउस बटन दबाता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_LBUTTONUP ON_WM_LBUTTONUP () जब उपयोगकर्ता बाईं माउस बटन को छोड़ता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_MBUTTONDBLCLK ON_WM_MBUTTONDBLCLK () उपयोगकर्ता द्वारा मध्य माउस बटन को डबल-क्लिक करने पर फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_MBUTTONDOWN ON_WM_MBUTTONDOWN () जब उपयोगकर्ता मध्य माउस बटन दबाता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_MBUTTONUP ON_WM_MBUTTONUP () उपयोगकर्ता द्वारा मध्य माउस बटन को छोड़ने पर फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_MENUSELECT ON_WM_MENUSELECT () यदि CWnd ऑब्जेक्ट मेनू से जुड़ा होता है, तो उपयोगकर्ता द्वारा मेनू आइटम का चयन करने पर OnMenuSelect को फ्रेमवर्क द्वारा बुलाया जाता है।
WM_MOUSEACTIVATE ON_WM_MOUSEACTIVATE () जब फ्रेम एक निष्क्रिय विंडो में होता है और उपयोगकर्ता माउस बटन दबाता है, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_MOUSEHOVER ON_WM_MOUSEHOVER () फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है जब कर्सर विंडो के क्लाइंट क्षेत्र पर हो जाता है, जो कि TrackMouseEvent के पहले कॉल में निर्दिष्ट समय की अवधि के लिए है।
WM_MOUSEHWHEEL ON_WM_MOUSEHWHEEL () जब वर्तमान विंडो डेस्कटॉप विंडो मैनेजर (DWM) द्वारा बनाई जाती है, और वह विंडो अधिकतम हो जाती है, तो फ्रेमवर्क इस सदस्य को कॉल करता है।
WM_MOUSELEAVE ON_WM_MOUSELEAVE () फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है जब कर्सर TrackMouseEvent के पूर्व कॉल में निर्दिष्ट विंडो के क्लाइंट क्षेत्र को छोड़ देता है।
WM_MOUSEMOVE ON_WM_MOUSEMOVE () जब माउस कर्सर चलता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_MOVE ON_WM_MOVE () CWnd ऑब्जेक्ट को स्थानांतरित करने के बाद फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_PAINT ON_WM_PAINT () जब विंडोज या कोई एप्लिकेशन विंडो के एक हिस्से को फिर से बनाने के लिए अनुरोध करता है, तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_SETFOCUS () ON_WM_SETFOCUS () इनपुट फोकस प्राप्त करने के बाद फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_SIZE () ON_WM_SIZE () विंडो का आकार बदलने के बाद फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_TIMER ON_WM_TIMER () टाइमर स्थापित करने के लिए उपयोग किए जाने वाले सेटटीमर सदस्य फ़ंक्शन में निर्दिष्ट प्रत्येक अंतराल के बाद फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_VSCROLL ON_WM_VSCROLL () जब उपयोगकर्ता विंडो के ऊर्ध्वाधर स्क्रॉल बार पर क्लिक करता है तो फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है।
WM_WINDOWPOSCHANGED ON_WM_WINDOWPOSCHANGED () फ्रेमवर्क इस सदस्य फ़ंक्शन को कॉल करता है जब आकार, स्थिति या जेड-ऑर्डर सेटविंडोवोस सदस्य फ़ंक्शन या किसी अन्य विंडो-प्रबंधन फ़ंक्शन के लिए कॉल के परिणामस्वरूप बदल गया है।

आइए हम खिड़की के निर्माण का एक सरल उदाहरण देखें।

WM_CREATE - जब कोई ऑब्जेक्ट, जिसे विंडो कहा जाता है, बनाया जाता है, तो ऑब्जेक्ट्स बनाने वाला फ्रेम एक संदेश भेजता है जिसे पहचान लिया जाता है ON_WM_CREATE

Step 1- ON_WM_CREATE बनाने के लिए, afx_msg int OnCreate (LPCREATESTRUCT lpCreateStruct) जोड़ें; नीचे दिखाए अनुसार DECLARE_MESSAGE_MAP () से पहले।

class CMainFrame : public CFrameWnd {
   public:
      CMainFrame();
   protected:
      afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);
      DECLARE_MESSAGE_MAP()
};

Step 2 - BEGIN_MESSAGE_MAP (CMainFrame, CFrameWnd) के बाद और END_MESSAGE_MAP से पहले ON_WM_CREATE () जोड़ें

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
   ON_WM_CREATE()
END_MESSAGE_MAP()

Step 3 - यहाँ OnCreate का कार्यान्वयन है ()

int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) {
   // Call the base class to create the window
   if (CFrameWnd::OnCreate(lpCreateStruct) == 0) {

      // If the window was successfully created, let the user know
      MessageBox(L"The window has been created!!!");
      // Since the window was successfully created, return 0
      return 0;
   }
   // Otherwise, return -1
   return -1;
}

Step 4 - अब आपकी * .cpp फ़ाइल निम्न कोड में दिखाए गए अनुसार दिखाई देगी।

#include <afxwin.h>
class CMainFrame : public CFrameWnd {
   public:
      CMainFrame();
   protected:
      afx_msg int OnCreate(LPCREATESTRUCT lpCreateStruct);
      DECLARE_MESSAGE_MAP()
};
CMainFrame::CMainFrame() {

   // Create the window's frame
   Create(NULL, L"MFC Messages Demo", WS_OVERLAPPEDWINDOW,
      CRect(120, 100, 700, 480), NULL);
}
class CMessagesApp : public CWinApp {
   public:
      BOOL InitInstance();
};
BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
   ON_WM_CREATE()
END_MESSAGE_MAP()
int CMainFrame::OnCreate(LPCREATESTRUCT lpCreateStruct) {
   // Call the base class to create the window
   if (CFrameWnd::OnCreate(lpCreateStruct) == 0) {
      // If the window was successfully created, let the user know
      MessageBox(L"The window has been created!!!");
      // Since the window was successfully created, return 0
      return 0;
   }
   // Otherwise, return -1
   return -1;
}
BOOL CMessagesApp::InitInstance() { 
   m_pMainWnd = new CMainFrame;
   m_pMainWnd -> ShowWindow(SW_SHOW);
   m_pMainWnd -> UpdateWindow();
   return TRUE;
}
CMessagesApp theApp;

Step 5 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 6 - जब आप ओके पर क्लिक करेंगे, तो यह मुख्य विंडो को प्रदर्शित करेगा।

आदेश संदेश

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

पिछले पाठ में हमने एक प्रकार का संसाधन पेश किया है। जब उपयोगकर्ता क्लिक करता है तो ऐसे नियंत्रण और संसाधन अपने स्वयं के संदेश आरंभ कर सकते हैं। एक संदेश जो विंडोज नियंत्रण या एक संसाधन से निकलता है उसे कमांड संदेश कहा जाता है।

आइए हम कमांड संदेशों का एक सरल उदाहरण देखें।

आपके आवेदन को एक नया दस्तावेज़ बनाने की क्षमता प्रदान करने के लिए, CWinApp वर्ग OnFileNew () विधि प्रदान करता है।

afx_msg void OnFileNew();

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
   ON_COMMAND(ID_FILE_NEW, CMainFrame::OnFileNew)
END_MESSAGE_MAP()

यहाँ विधि परिभाषा है -

void CMainFrame::OnFileNew() {
   // Create New file
}

कीबोर्ड संदेश

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

प्रत्येक कुंजी में एक कोड होता है जिसे ऑपरेटिंग सिस्टम पहचान सकता है। इस कोड के रूप में जाना जाता हैvirtual key code

अनु क्रमांक। लगातार / मूल्य और विवरण
1

VK_LBUTTON

माउस बटन छोड़ें

2

VK_RBUTTON

दायाँ माउस बटन

3

VK_CANCEL

नियंत्रण-ब्रेक प्रसंस्करण

4

VK_MBUTTON

मध्य माउस बटन (तीन बटन माउस)

5

VK_BACK

बैकस्पेस कुंजी

6

VK_RETURN

कुंजी दर्ज

7

VK_TAB

चाबी दबाएं

8

VK_CLEAR

स्पष्ट कुंजी

9

VK_SHIFT

शिफ्ट कुंजी

10

VK_CONTROL

CTRL कुंजी

1 1

VK_MENU

ऑल्ट की

12

VK_PAUSE

PAUSE कुंजी

13

VK_CAPITAL

कैप्स लॉक कुंजी

14

VK_ESCAPE

ESC कुंजी

15

VK_SPACE

स्पेसबार

16

VK_PRIOR

पेज यूपी कुंजी

17

VK_NEXT

पेज डाउनलोड कुंजी

18

VK_END

अंत कुंजी

19

VK_HOME

घर की चाबी

20

VK_LEFT

बाएँ तीर कुंजी

21

VK_UP

UP तीर कुंजी

22

VK_RIGHT

सही तीर कुंजी

23

VK_DOWN

नीचे तीर कुंजी

24

VK_SELECT

कुंजी का चयन करें

25

VK_PRINT

प्रिंट कुंजी

26

VK_EXECUTE

महत्वपूर्ण कुंजी

27

VK_SNAPSHOT

प्रिंट स्क्रीन कुंजी

28

VK_INSERT

आईएनएस कुंजी

29

VK_DELETE

DEL कुंजी

30

VK_NUMPAD0

संख्यात्मक कीपैड 0 कुंजी

31

VK_NUMPAD1

संख्यात्मक कीपैड 1 कुंजी

32

VK_NUMPAD2

न्यूमेरिक कीपैड 2 की

33

VK_NUMPAD3

संख्यात्मक कीपैड 3 कुंजी

34

VK_NUMPAD4

न्यूमेरिक कीपैड 4 कुंजी

35

VK_NUMPAD5

संख्यात्मक कीपैड 5 कुंजी

36

VK_NUMPAD6

न्यूमेरिक कीपैड 6 की

37

VK_NUMPAD7

संख्यात्मक कीपैड 7 कुंजी

38

VK_NUMPAD8

संख्यात्मक कीपैड 8 कुंजी

39

VK_NUMPAD9

न्यूमेरिक कीपैड 9 की

40

VK_MULTIPLY

बहु की कुंजी

41

VK_ADD

कुंजी जोड़ें

42

VK_SEPARATOR

सेपरेटर की

43

VK_SUBTRACT

घटाना कुंजी

44

VK_DECIMAL

दशमलव कुंजी

45

VK_DIVIDE

कुंजी विभाजित करें

46

VK_F1

एफ 1 की

47

VK_F2

F2 कुंजी

48

VK_F3

F3 कुंजी

49

VK_F4

F4 कुंजी

50

VK_F5

F5 कुंजी

52

VK_F6

F6 कुंजी

53

VK_F7

F7 कुंजी

54

VK_F8

F8 कुंजी

55

VK_F9

F9 कुंजी

56

VK_F10

F10 कुंजी

57

VK_F11

F11 कुंजी

58

VK_F12

F12 कुंजी

59

VK_NUMLOCK

NUM लॉक कुंजी

60

VK_SCROLL

स्क्रोल लॉक कुंजी

61

VK_LSHIFT

बाएँ SHIFT कुंजी

62

VK_RSHIFT

सही SHIFT कुंजी

63

VK_LCONTROL

लेफ्ट कंट्रोल की

64

VK_RCONTROL

सही नियंत्रण कुंजी

कुंजी दबाने से WM_KEYDOWN या WM_SYSKEYDOWN संदेश को थ्रेड संदेश में रखा जाता है। इसे निम्नानुसार परिभाषित किया जा सकता है -

afx_msg void OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags);

आइए एक सरल उदाहरण देखें।

Step 1 - यहाँ संदेश है।

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
   ON_WM_CREATE()
   ON_WM_KEYDOWN()
END_MESSAGE_MAP()

Step 2 - यहाँ OnKeyDown () का कार्यान्वयन है।

void CMainFrame::OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags) {
   switch (nChar) {

      case VK_RETURN:
         MessageBox(L"You pressed Enter");
         break;
      case VK_F1:
         MessageBox(L"Help is not available at the moment");
         break;
      case VK_DELETE:
         MessageBox(L"Can't Delete This");
         break;
      default:
         MessageBox(L"Whatever");
   }
}

Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 4 - जब आप Enter दबाते हैं, तो यह निम्न संदेश प्रदर्शित करेगा।

माउस संदेश

माउस एक अन्य ऑब्जेक्ट है जो कंप्यूटर से जुड़ा होता है जिससे उपयोगकर्ता मशीन से बातचीत कर सकता है।

  • यदि बाईं माउस बटन दबाया गया था, तो ON_WM_LBUTTONDOWN संदेश भेजा जाता है। इस संदेश का सिंटैक्स है -

    • afx_msg शून्य OnLButtonDown (UINT nFlags, CPoint बिंदु)

  • यदि सही माउस बटन दबाया गया था, तो ON_WM_RBUTTONDOWN संदेश भेजा जाता है। इसका सिंटैक्स है -

    • afx_msg शून्य OnRButtonDown (UINT nFlags, CPoint बिंदु)

  • इसी तरह यदि बाईं माउस छोड़ा जा रहा है, तो ON_WM_LBUTTONUP संदेश भेजा जाता है। इसका सिंटैक्स है -

    • afx_msg शून्य OnLButtonUp (UINT nFlags, CPoint बिंदु)

  • यदि सही माउस छोड़ा जा रहा है, तो ON_WM_TBUTTONUP संदेश भेजा जाता है। इसका सिंटैक्स है -

    • afx_msg शून्य OnRButtonUp (UINT nFlags, CPoint बिंदु)

आइए एक सरल उदाहरण देखें।

Step 1 - निम्नलिखित दो कार्यों को CMainFrame वर्ग परिभाषा में जोड़ें जैसा कि निम्नलिखित कोड में दिखाया गया है।

class CMainFrame : public CFrameWnd {
   public:
      CMainFrame();
   protected:
      afx_msg void OnKeyDown(UINT nChar, UINT nRepCnt, UINT nFlags);
      afx_msg void OnLButtonDown(UINT nFlags, CPoint point);
      afx_msg void OnRButtonUp(UINT nFlags, CPoint point);
      DECLARE_MESSAGE_MAP()
};

Step 2 - निम्नलिखित दो संदेश मानचित्र जोड़ें।

BEGIN_MESSAGE_MAP(CMainFrame, CFrameWnd)
   ON_WM_KEYDOWN()
   ON_WM_LBUTTONDOWN()
   ON_WM_RBUTTONUP()
END_MESSAGE_MAP()

Step 3 - यहाँ फ़ंक्शन परिभाषा है।

void CMainFrame::OnLButtonDown(UINT nFlags, CPoint point) { 
   CString MsgCoord;
   MsgCoord.Format(L"Left Button at P(%d, %d)", point.x, point.y);
   MessageBox(MsgCoord);
}
void CMainFrame::OnRButtonUp(UINT nFlags, CPoint point) { 
   MessageBox(L"Right Mouse Button Up");
}

Step 4 - जब आप इस एप्लिकेशन को चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

Step 5 - जब आप ओके पर क्लिक करेंगे, तो आपको निम्न संदेश दिखाई देगा।

Step 6- इस विंडो पर राइट क्लिक करें। अब, जब आप माउस का दाहिना बटन छोड़ते हैं, तो यह निम्न संदेश प्रदर्शित करेगा।

एक ActiveX control container एक पैरेंट प्रोग्राम है जो चलाने के लिए ActiveX (पूर्व में OLE) नियंत्रण के लिए वातावरण की आपूर्ति करता है।

  • ActiveX नियंत्रण Microsoft ActiveX तकनीकों का उपयोग करके एक नियंत्रण है।

  • ActiveX एक प्रोग्रामिंग भाषा नहीं है, बल्कि इसके लिए नियमों का एक सेट है कि कैसे अनुप्रयोगों को जानकारी साझा करनी चाहिए।

  • प्रोग्रामर विभिन्न भाषाओं में ActiveX नियंत्रण विकसित कर सकते हैं, जिनमें C, C ++, Visual Basic और Java शामिल हैं।

  • आप MFC के साथ या उसके बिना ActiveX नियंत्रण रखने में सक्षम एप्लिकेशन बना सकते हैं, लेकिन MFC के साथ करना बहुत आसान है।

हमें अपने MFC संवाद आधारित एप्लिकेशन में ActiveX नियंत्रण जोड़ने के सरल उदाहरण पर ध्यान दें।

Step 1 - डिजाइनर विंडो में डायलॉग पर राइट-क्लिक करें और इन्सर्ट एक्टिव एक्स कंट्रोल चुनें।

Step 2 - Microsoft चित्र क्लिप नियंत्रण का चयन करें और ठीक पर क्लिक करें।

Step 3 - चित्र नियंत्रण का आकार बदलें और गुण विंडो में, चित्र फ़ील्ड पर क्लिक करें।

Step 4- उस फ़ोल्डर को ब्राउज़ करें जिसमें चित्र हों। किसी भी चित्र का चयन करें।

Step 5 - जब आप इस एप्लिकेशन को चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

आइए हम एक और सरल उदाहरण देखें।

Step 1 - डिजाइनर विंडो में डायलॉग पर राइट क्लिक करें।

Step 2 - इन्सर्ट ActiveX कंट्रोल चुनें।

Step 3 - Microsoft ProgressBar Control 6.0 का चयन करें, ठीक पर क्लिक करें।

Step 4 - प्रगति बार का चयन करें और गुण विंडो में इसकी ओरिएंटेशन सेट करें 1 – ccOrientationVertical

Step 5 - प्रगति पट्टी के लिए नियंत्रण चर जोड़ें।

Step 6 - OnInitDialog () में निम्न कोड जोड़ें

m_progBarCtrl.SetScrollRange(0,100,TRUE);
m_progBarCtrl.put_Value(53);

Step 7 - जब आप इस एप्लिकेशन को फिर से चलाते हैं, तो आप प्रगति पट्टी को ऊर्ध्वाधर दिशा में भी देखेंगे।

इस अध्याय में, हम फाइल सिस्टम के विभिन्न घटकों पर चर्चा करेंगे।

ड्राइव

driveएक कंप्यूटर से जुड़ी एक भौतिक डिवाइस है ताकि यह जानकारी संग्रहीत कर सके। एक लॉजिकल डिस्क, लॉजिकल वॉल्यूम या वर्चुअल डिस्क (VD या vdisk for short) एक वर्चुअल डिवाइस है जो कंप्यूटर सिस्टम में एक या अधिक भौतिक डिस्क ड्राइव (एस) पर प्रयोग करने योग्य भंडारण क्षमता का एक क्षेत्र प्रदान करता है। एक ड्राइव एक हार्ड डिस्क, एक सीडी रॉम, एक डीवीडी रॉम, एक फ्लैश (यूएसबी) ड्राइव, एक मेमोरी कार्ड, आदि हो सकती है।

आपके द्वारा किए जाने वाले प्राथमिक कार्यों में से एक कंप्यूटर पर ड्राइव की सूची प्राप्त करना है।

एक नया एमएफसी संवाद आधारित एप्लिकेशन बनाकर हमें एक सरल उदाहरण में देखें।

Step 1 - टूलबॉक्स से एक बटन खींचें, इसके कैप्शन को गेट ड्राइव की जानकारी में बदलें।

Step 2 - स्टेटिक कंट्रोल के कैप्शन (TODO लाइन) को हटाएं और इसकी ID को IDC_STATIC_TEXT में बदलें।

Step 3 - बटन पर राइट क्लिक करें और Add Event Handler चुनें।

Step 4 - BN_CLICKED संदेश प्रकार का चयन करें और जोड़ें और संपादित करें बटन पर क्लिक करें।

Step 5 - स्थैतिक पाठ नियंत्रण के लिए मान चर m_strDrives जोड़ें।

कंप्यूटर पर ड्राइव का समर्थन करने के लिए, Win32 लाइब्रेरी Microsoft विंडो का GetLogicalDrives () फ़ंक्शन प्रदान करता है, जो वर्तमान कंप्यूटर पर सभी ड्राइव की एक सूची को पुनः प्राप्त करेगा।

Step 6 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 7 - जब आप बटन पर क्लिक करते हैं, तो आप अपने कंप्यूटर पर सभी ड्राइव देख सकते हैं।

निर्देशिका

कंप्यूटिंग में, ए directoryएक फ़ाइल सिस्टम कैटलॉगिंग संरचना है जिसमें अन्य कंप्यूटर फ़ाइलों और संभवतः अन्य निर्देशिकाओं का संदर्भ होता है। निर्देशिका एक भौतिक स्थान है। यह एक ड्राइव पर उपलब्ध संचालन को संभाल सकता है।

एक नया एमएफसी संवाद आधारित एप्लिकेशन बनाकर हमें एक सरल उदाहरण में देखें

Step 1- टूलबॉक्स से तीन बटन खींचें। निर्देशिका बनाने, निर्देशिका हटाने और निर्देशिका को स्थानांतरित करने के लिए उनके कैप्शन बदलें।

Step 2 - इन बटनों की आईडी को बदलें IDC_BUTTON_CREATE, IDC_BUTTON_DELETE तथा IDC_BUTTON_MOVE

Step 3 - TODO लाइन निकालें।

Step 4 - प्रत्येक बटन के लिए घटना हैंडलर जोड़ें।

Step 5 - डायरेक्टरी बनाने के लिए, आप Win32 लाइब्रेरी की CreateDirectory () विधि को कॉल कर सकते हैं।

Step 6 - यहां Create बटन इवेंट हैंडलर कार्यान्वयन है जिसमें हम एक निर्देशिका और फिर दो और उप निर्देशिकाएं बनाएंगे।

void CMFCDirectoriesDemoDlg::OnBnClickedButtonCreate() {
   // TODO: Add your control notification handler code here
   SECURITY_ATTRIBUTES saPermissions;

   saPermissions.nLength = sizeof(SECURITY_ATTRIBUTES);
   saPermissions.lpSecurityDescriptor = NULL;
   saPermissions.bInheritHandle = TRUE;

   if (CreateDirectory(L"D:\\MFCDirectoryDEMO", &saPermissions) == TRUE)
      AfxMessageBox(L"The directory was created.");
   CreateDirectory(L"D:\\MFCDirectoryDEMO\\Dir1", NULL);
   CreateDirectory(L"D:\\MFCDirectoryDEMO\\Dir2", NULL);
}

Step 7 - एक निर्देशिका से छुटकारा पाने के लिए, आप निर्देशिका को कॉल कर सकते हैं RemoveDirectory()Win32 लाइब्रेरी का कार्य। यहां डिलीट बटन इवेंट हैंडलर का कार्यान्वयन है।

void CMFCDirectoriesDemoDlg::OnBnClickedButtonDelete() {
   // TODO: Add your control notification handler code here
   if (RemoveDirectory(L"D:\\MFCDirectoryDEMO\\Dir1") == TRUE)
      AfxMessageBox(L"The directory has been deleted");
}

Step 8- यदि आप डायरेक्टरी को स्थानांतरित करना चाहते हैं, तो आप उसी मूवफाइल () फ़ंक्शन को भी कॉल कर सकते हैं। यहाँ चाल बटन ईवेंट हैंडलर का कार्यान्वयन है जिसमें हम पहले नई निर्देशिका बनाएंगे और फिर Dir2 को उस निर्देशिका में स्थानांतरित करेंगे।

void CMFCDirectoriesDemoDlg::OnBnClickedButtonMove() {
   // TODO: Add your control notification handler code here
   CreateDirectory(L"D:\\MFCDirectory", NULL);

   if (MoveFile(L"D:\\MFCDirectoryDEMO\\Dir1", L"D:\\MFCDirectory\\Dir1") == TRUE)
      AfxMessageBox(L"The directory has been moved");
}

Step 9 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 10 - जब आप Create Directory बटन पर क्लिक करते हैं, तो यह इन निर्देशिकाओं को बनाएगा।

Step 11 - जब आप डिलीट डायरेक्टरी बटन पर क्लिक करते हैं, तो यह Dir1 डिलीट हो जाएगा।

फ़ाइल प्रसंस्करण

अधिकतर file processing एक एमएफसी आवेदन में एक वर्ग के नाम के साथ किया जाता है CArchive। CArchive वर्ग अनुप्रयोग और माध्यम के बीच एक रिले के रूप में कार्य करता है जो डेटा को स्टोर करने या उसे उपलब्ध कराने के लिए उपयोग किया जाता है। यह आपको स्थायी बाइनरी फॉर्म (आमतौर पर डिस्क स्टोरेज) में ऑब्जेक्ट के एक जटिल नेटवर्क को सहेजने की अनुमति देता है जो उन ऑब्जेक्ट्स को हटाने के बाद बनी रहती है।

यहाँ CArchive कक्षा में विधियों की सूची दी गई है -

अनु क्रमांक। नाम और विवरण
1

Abort

एक अपवाद को फेंकने के बिना एक संग्रह को बंद करता है।

2

Close

अलिखित डेटा को फ्लश करता है और से डिस्कनेक्ट करता है CFile

3

Flush

संग्रह बफर से अलिखित डेटा फ्लश करता है।

4

GetFile

इस संग्रह के लिए CFile ऑब्जेक्ट पॉइंटर जाता है।

5

GetObjectSchema

से पुकारा गया Serialize ऑब्जेक्ट के संस्करण को निर्धारित करने के लिए फ़ंक्शन जो कि डिसेरिएलाइज़ किया जा रहा है।

6

IsBufferEmpty

निर्धारित करता है कि क्या विंडोज सॉकेट्स प्राप्त करने की प्रक्रिया के दौरान बफर को खाली कर दिया गया है।

7

IsLoading

निर्धारित करता है कि संग्रह लोड हो रहा है या नहीं।

8

IsStoring

यह निर्धारित करता है कि संग्रह संग्रहीत हो रहा है या नहीं।

9

MapObject

मानचित्र में ऑब्जेक्ट्स जो फ़ाइल में क्रमबद्ध नहीं हैं, लेकिन संदर्भ के लिए उप-संदर्भों के लिए उपलब्ध हैं।

10

Read

कच्चे बाइट्स पढ़ता है।

1 1

ReadClass

पहले से संगृहीत एक वर्ग संदर्भ पढ़ता है WriteClass

12

ReadObject

लोड करने के लिए किसी ऑब्जेक्ट के सीरियल फ़ंक्शन को कॉल करता है।

13

ReadString

पाठ की एक पंक्ति पढ़ता है।

14

SerializeClass

CArchive की दिशा के आधार पर CArchive ऑब्जेक्ट के वर्ग संदर्भ को पढ़ता है या लिखता है।

15

SetLoadParams

उस आकार को सेट करता है जिसमें भार सरणी बढ़ती है। किसी भी वस्तु को लोड करने से पहले या उससे पहले बुलाया जाना चाहिएMapObject या ReadObject कहा जाता है।

16

SetObjectSchema

संग्रह ऑब्जेक्ट में संग्रहीत ऑब्जेक्ट स्कीमा सेट करता है।

17

SetStoreParams

क्रमांकन प्रक्रिया के दौरान अद्वितीय ऑब्जेक्ट्स की पहचान करने के लिए उपयोग किए जाने वाले मानचित्र का हैश तालिका आकार और ब्लॉक आकार सेट करता है।

18

Write

कच्चे बाइट्स लिखता है।

19

WriteClass

के लिए एक संदर्भ लिखता है CRuntimeClass CArchive को।

20

WriteObject

एक वस्तु के भंडारण के लिए सीरियल फ़ंक्शन को कॉल करता है।

21

WriteString

पाठ की एक पंक्ति लिखता है।

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

अनु क्रमांक। नाम और विवरण
1

operator <<

संग्रह के लिए ऑब्जेक्ट और आदिम प्रकार संग्रहीत करता है।

2

operator >>

पुरालेख से भार वस्तुओं और आदिम प्रकार।

एक नया एमएफसी संवाद आधारित एप्लिकेशन बनाकर हमें एक सरल उदाहरण में देखें।

Step 1 - निम्नलिखित स्नैपशॉट में दिखाए गए अनुसार एक संपादन नियंत्रण और दो बटन खींचें।

Step 2 - नियंत्रण चर जोड़ें m_editCtrl और मूल्य चर m_strEdit नियंत्रण संपादित करने के लिए।

Step 3 - ओपन और सेव बटन के लिए क्लिक इवेंट हैंडलर जोड़ें।

Step 4 - यहां इवेंट हैंडलर का कार्यान्वयन है।

void CMFCFileProcessingDlg::OnBnClickedButtonOpen() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   
   CFile file;
   
   file.Open(L"ArchiveText.rpr", CFile::modeRead);
   if(file) {
      CArchive ar(&file, CArchive::load);
   
      ar >> m_strEdit;
   
      ar.Close();
      file.Close();
   }
   UpdateData(FALSE);
}

void CMFCFileProcessingDlg::OnBnClickedButtonSave() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);

   if (m_strEdit.GetLength() == 0) {
      AfxMessageBox(L"You must enter the name of the text.");
      return;
   }
   CFile file;
   
   file.Open(L"ArchiveText.rpr", CFile::modeCreate | CFile::modeWrite);
   CArchive ar(&file, CArchive::store);
   ar << m_strEdit;
   
   ar.Close();
   file.Close();
}

Step 5 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 6- कुछ लिखें और सेव पर क्लिक करें। यह बाइनरी प्रारूप में डेटा को बचाएगा।

Step 7- संपादन नियंत्रण से परीक्षण निकालें। जैसे ही आप Open पर क्लिक करते हैं, निरीक्षण करते हैं कि वही टेक्स्ट फिर से लोड किया गया है।

MFC लाइब्रेरी फ़ाइल प्रसंस्करण का अपना संस्करण प्रदान करती है। यह CStdioFile नामक एक वर्ग के माध्यम से किया जाता है। CStdioFile वर्ग CFile से लिया गया है। यह यूनिकोड पाठ फ़ाइलों के पढ़ने और लिखने के साथ-साथ साधारण मल्टी-बाइट पाठ फ़ाइलों को भी संभाल सकता है।

यहां कंस्ट्रक्टरों की सूची दी गई है, जो CStdioFile ऑब्जेक्ट को इनिशियलाइज़ कर सकते हैं -

CStdioFile();
CStdioFile(CAtlTransactionManager* pTM);
CStdioFile(FILE* pOpenStream);
CStdioFile(LPCTSTR lpszFileName, UINT nOpenFlags);
CStdioFile(LPCTSTR lpszFileName, UINT nOpenFlags, CAtlTransactionManager* pTM);

CStdioFile में विधियों की सूची इस प्रकार है -

अनु क्रमांक। नाम और विवरण
1

Open

अतिभारित। ओपन को डिफ़ॉल्ट CStdioFile कंस्ट्रक्टर (ओवरराइड्स CFile :: Open) के साथ उपयोग के लिए डिज़ाइन किया गया है।

2

ReadString

पाठ की एक पंक्ति पढ़ता है।

3

Seek

वर्तमान फ़ाइल पॉइंटर को बताता है।

4

WriteString

पाठ की एक पंक्ति लिखता है।

नए MFC संवाद आधारित एप्लिकेशन बनाकर हमें फिर से एक सरल उदाहरण पर ध्यान दें।

Step 1 - निम्नलिखित स्नैपशॉट में दिखाए गए अनुसार एक संपादन नियंत्रण और दो बटन खींचें।

Step 2 - मान चर जोड़ें m_strEditCtrl नियंत्रण संपादित करने के लिए।

Step 3 - ओपन और सेव बटन के लिए क्लिक इवेंट हैंडलर जोड़ें।

Step 4 - यहां इवेंट हैंडलर का कार्यान्वयन है।

void CMFCStandardIODlg::OnBnClickedButtonOpen() {
   
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);

   CStdioFile file;
   file.Open(L"D:\\MFCDirectoryDEMO\\test.txt", CFile::modeRead | CFile::typeText);
   
   file.ReadString(m_strEditCtrl);
   file.Close();
   UpdateData(FALSE);
}

void CMFCStandardIODlg::OnBnClickedButtonSave() {
   
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   CStdioFile file;
   if (m_strEditCtrl.GetLength() == 0) {

      AfxMessageBox(L"You must specify the text.");
      return;
   }
   file.Open(L"D:\\MFCDirectoryDEMO\\test.txt", CFile::modeCreate |
      CFile::modeWrite | CFile::typeText);
   file.WriteString(m_strEditCtrl);
   file.Close();
}

Step 5 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 6- कुछ लिखें और सेव पर क्लिक करें। यह डेटा को * .txt फाइल में सेव करेगा।

Step 7 - यदि आप फ़ाइल के स्थान को देखते हैं, तो आप देखेंगे कि इसमें test.txt फ़ाइल है।

Step 8- अब, एप्लिकेशन को बंद करें। एक ही एप्लिकेशन चलाएँ। जब आप Open पर क्लिक करते हैं, तो वही टेक्स्ट फिर से लोड होता है।

Step 9 - यह फ़ाइल को खोलने से शुरू होता है, फ़ाइल को पढ़ना, इसके बाद एडिट कंट्रोल को अपडेट करना।

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

दस्तावेज़ / दृश्य वास्तुकला की रचना करने वाले हिस्से एक फ्रेम, एक या अधिक दस्तावेज़ और दृश्य हैं। एक साथ रखो, इन संस्थाओं को एक प्रयोग करने योग्य अनुप्रयोग बनाते हैं।

राय

viewवह प्लेटफॉर्म है जिस पर उपयोगकर्ता अपना काम करने के लिए काम कर रहा है। उपयोगकर्ता को किसी एप्लिकेशन पर कुछ भी करने देने के लिए, आपको एक दृश्य प्रदान करना होगा, जो कि CView वर्ग पर आधारित एक वस्तु है। आप या तो सीधे से व्युत्पन्न CView में से किसी एक वर्ग का उपयोग कर सकते हैं या आप अपनी स्वयं की कस्टम क्लास को CView या उसके किसी एक बाल वर्ग से प्राप्त कर सकते हैं।

डाक्यूमेंट

documentएक बाल्टी के समान है। एक कंप्यूटर अनुप्रयोग के लिए, एक दस्तावेज़ उपयोगकर्ता के डेटा को रखता है। इस आर्किटेक्चर का डॉक्यूमेंट पार्ट बनाने के लिए, आपको CDocument वर्ग से एक ऑब्जेक्ट प्राप्त करना होगा।

ढांचा

जैसा कि नाम से पता चलता है, ए frameबिल्डिंग ब्लॉक्स, संरचना और किसी वस्तु की सीमाओं का एक संयोजन है। एक फ्रेम एक खिड़की के लिए "भौतिक" उपस्थिति देता है। यह विंडोज डेस्कटॉप के संबंध में एक वस्तु के स्थान को भी परिभाषित करता है।

एकल दस्तावेज़ इंटरफ़ेस (SDI)

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

हमें नए MFC संवाद आधारित अनुप्रयोग बनाकर एकल दस्तावेज़ इंटरफ़ेस या SDI के एक सरल उदाहरण पर ध्यान दें।

Step 1 - आइए हम एक नया MFC एप्लिकेशन बनाएं MFCSDIDemo नीचे उल्लेख सेटिंग्स के साथ।

Step 2 - प्रोजेक्ट स्टाइल से एप्लिकेशन प्रकार और एमएफसी मानक से एकल दस्तावेज़ का चयन करें।

Step 3 - जारी रखने के लिए समाप्त पर क्लिक करें।

Step 4 - प्रोजेक्ट बन जाने के बाद, एप्लिकेशन रन करें और आपको निम्न आउटपुट दिखाई देगा।

एकाधिक दस्तावेज़ इंटरफ़ेस (MDI)

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

नए MFC संवाद आधारित एप्लिकेशन बनाकर हमें कई दस्तावेज़ इंटरफ़ेस या MDI का एक सरल उदाहरण देखें।

Step 1 - आइए हम एक नया MFC एप्लिकेशन बनाएं MFCMDIDemo नीचे उल्लेख सेटिंग्स के साथ।

Step 2 - प्रोजेक्ट स्टाइल से एप्लिकेशन प्रकार और एमएफसी मानक से कई दस्तावेज का चयन करें।

Step 3 - जारी रखने के लिए समाप्त पर क्लिक करें।

Step 4 - प्रोजेक्ट बन जाने के बाद, एप्लिकेशन रन करें और आपको निम्न आउटपुट दिखाई देगा।

Step 5 - जब आप फ़ाइल → न्यू मेनू विकल्प पर क्लिक करते हैं, तो यह निम्नलिखित स्नैपशॉट में दिखाए गए अनुसार एक और चाइल्ड विंडो बनाएगा।

Step 6- मल्टीपल डॉक्यूमेंट इंटरफेस (एमडीआई) एप्लिकेशन में, प्रति एप्लिकेशन एक मुख्य फ्रेम होता है। इस मामले में, एक CMDIFrameWnd, और एक CMDIChildWnd प्रत्येक दस्तावेज़ के लिए चाइल्ड फ्रेम प्राप्त करता है।

Stringsऐसी वस्तुएँ हैं जो वर्णों के अनुक्रम का प्रतिनिधित्व करती हैं। C- शैली वर्ण स्ट्रिंग C भाषा के भीतर उत्पन्न हुई और C ++ के भीतर समर्थित होना जारी है।

  • यह स्ट्रिंग वास्तव में वर्णों का एक आयामी आयाम है, जिसे एक अशक्त चरित्र '\ 0' द्वारा समाप्त किया जाता है।

  • अशक्त-समाप्त स्ट्रिंग में वर्ण होते हैं जिसमें एक नल के बाद स्ट्रिंग शामिल होता है।

यहाँ चरित्र सरणी का सरल उदाहरण है।

char word[12] = { 'H', 'e', 'l', 'l', 'o', ' ', 'W', 'o', 'r', 'l', 'd', '\0' };

इसका प्रतिनिधित्व करने का एक और तरीका निम्नलिखित है।

char word[] = "Hello, World";

Microsoft Foundation Class (MFC) लाइब्रेरी स्ट्रिंग नामक हेरफेर करने के लिए एक वर्ग प्रदान करता है CString। सीएसट्रिंग की कुछ महत्वपूर्ण विशेषताएं निम्नलिखित हैं।

  • CString में बेस क्लास नहीं है।

  • एक CString ऑब्जेक्ट वर्णों की एक चर-लंबाई अनुक्रम के होते हैं।

  • CString बेसिक के समान सिंटैक्स का उपयोग करके फ़ंक्शंस और ऑपरेटर प्रदान करता है।

  • सरलीकरण और तुलना ऑपरेटरों, सरलीकृत स्मृति प्रबंधन के साथ मिलकर, CString वस्तुओं को साधारण चरित्र सरणियों की तुलना में उपयोग करना आसान बनाते हैं।

यहाँ CString का निर्माण है।

अनु क्रमांक। विधि और विवरण
1

CString

विभिन्न तरीकों से सीएसट्रिंग ऑब्जेक्ट्स का निर्माण करता है

यहाँ ऐरे तरीकों की एक सूची है -

अनु क्रमांक। विधि और विवरण
1

GetLength

एक CString ऑब्जेक्ट में वर्णों की संख्या देता है।

2

IsEmpty

टेस्ट कि क्या एक CString ऑब्जेक्ट में कोई वर्ण नहीं है।

3

Empty

एक स्ट्रिंग को 0 लंबाई के लिए मजबूर करता है।

4

GetAt

एक निर्दिष्ट स्थान पर चरित्र लौटाता है।

5

SetAt

एक निर्दिष्ट स्थान पर एक चरित्र सेट करता है।

यहाँ तुलना विधियों की एक सूची है -

अनु क्रमांक। विधि और विवरण
1

Compare

दो स्ट्रिंग्स (केस संवेदनशील) की तुलना करता है।

2

CompareNoCase

दो तारों की तुलना करता है (केस असंवेदनशील)।

यहाँ निष्कर्षण विधियों की एक सूची है -

अनु क्रमांक। विधि और विवरण
1

Mid

एक स्ट्रिंग के मध्य भाग को निकालता है (जैसे बेसिक एमआईडी $ फंक्शन)।

2

Left

एक स्ट्रिंग के बाएं हिस्से को निकालता है (जैसे मूल बाएँ $ फ़ंक्शन)।

3

Right

एक स्ट्रिंग के दाहिने हिस्से को निकालता है (जैसे बेसिक राइट $ फंक्शन)।

4

SpanIncluding

स्ट्रिंग से वर्णों को निकालता है, जो दिए गए वर्ण सेट में हैं।

5

SpanExcluding

स्ट्रिंग से वर्णों को निकालता है जो दिए गए वर्ण सेट में नहीं हैं।

यहां रूपांतरण विधियों की एक सूची दी गई है।

अनु क्रमांक। विधि और विवरण
1

MakeUpper

इस स्ट्रिंग के सभी वर्णों को अपरकेस वर्णों में परिवर्तित करता है।

2

MakeLower

इस स्ट्रिंग के सभी वर्णों को अक्षरों को नीचे करने के लिए रूपांतरित करता है।

3

MakeReverse

इस स्ट्रिंग में वर्णों को उलट देता है।

4

Format

स्प्रिंट के रूप में स्ट्रिंग को प्रारूपित करें।

5

TrimLeft

स्ट्रिंग से प्रमुख सफेद-अंतरिक्ष वर्णों को ट्रिम करें।

6

TrimRight

स्ट्रिंग से सफेद-अंतरिक्ष वर्णों को ट्रिम करें।

यहाँ खोज विधियों की एक सूची दी गई है।

अनु क्रमांक। विधि और विवरण
1

Find

एक चरित्र को ढूँढता है या एक बड़ी स्ट्रिंग के अंदर प्रतिस्थापित करता है।

2

ReverseFind

एक बड़े स्ट्रिंग के अंदर एक चरित्र पाता है; अंत से शुरू होता है।

3

FindOneOf

एक सेट से पहला मिलान चरित्र पाता है।

यहाँ बफर एक्सेस मेथड्स की एक सूची दी गई है।

अनु क्रमांक। विधि और विवरण
1

GetBuffer

CString में वर्णों के लिए एक सूचक लौटाता है।

2

GetBufferSetLength

निर्दिष्ट लंबाई को रौंदते हुए, CString में वर्णों के लिए एक सूचक लौटाता है।

3

ReleaseBuffer

GetBuffer द्वारा लौटाए गए बफ़र का नियंत्रण

4

FreeExtra

स्ट्रिंग को पहले से आवंटित किसी अतिरिक्त मेमोरी को मुक्त करके इस स्ट्रिंग ऑब्जेक्ट के किसी भी ओवरहेड को हटा देता है।

5

LockBuffer

संदर्भ गिनती को अक्षम करता है और बफर में स्ट्रिंग की सुरक्षा करता है।

6

UnlockBuffer

संदर्भ गिनती में सक्षम करता है और स्ट्रिंग को बफर में जारी करता है।

यहां विंडोज-स्पेसिफिक मेथड्स की सूची दी गई है।

अनु क्रमांक। विधि और विवरण
1

AllocSysString

CString डेटा से BSTR आवंटित करता है।

2

SetSysString

किसी मौजूदा BSTR ऑब्जेक्ट को CString ऑब्जेक्ट के डेटा के साथ सेट करता है।

3

LoadString

Windows CE संसाधन से एक मौजूदा CString ऑब्जेक्ट लोड करता है।

CString ऑब्जेक्ट्स पर विभिन्न ऑपरेशन निम्नलिखित हैं -

स्ट्रिंग बनाएँ

आप एक स्ट्रिंग शाब्दिक का उपयोग करके या CString वर्ग का एक उदाहरण बनाकर एक स्ट्रिंग बना सकते हैं।

BOOL CMFCStringDemoDlg::OnInitDialog() {

   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);         // Set big icon
   SetIcon(m_hIcon, FALSE);       // Set small icon

   CString string1 = _T("This is a string1");
   CString string2("This is a string2");

   m_strText.Append(string1 + L"\n");
   m_strText.Append(string2);

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

खाली स्ट्रिंग

आप खाली स्ट्रिंग शाब्दिक का उपयोग करके या CString :: खाली () विधि का उपयोग करके एक खाली स्ट्रिंग बना सकते हैं। आप यह भी जांच सकते हैं कि बूलियन संपत्ति का उपयोग करते हुए कोई स्ट्रिंग खाली है या नहीं।

BOOL CMFCStringDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);            // Set big icon
   SetIcon(m_hIcon, FALSE);           // Set small icon

   CString string1 = _T("");
   CString string2;
   string2.Empty();

   if(string1.IsEmpty())
      m_strText.Append(L"String1 is empty\n");
   else
      m_strText.Append(string1 + L"\n");
   
   if(string2.IsEmpty())
      m_strText.Append(L"String2 is empty");
   else
      m_strText.Append(string2);
   UpdateData(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है तो आपको निम्न आउटपुट दिखाई देगा।

स्ट्रिंग कॉनटेनटेशन

दो या अधिक स्ट्रिंग्स को समेटने के लिए, आप दो स्ट्रिंग्स या एक CString :: परिशिष्ट () विधि को संक्षिप्त करने के लिए + ऑपरेटर का उपयोग कर सकते हैं।

BOOL CMFCStringDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);              // Set big icon
   SetIcon(m_hIcon, FALSE);              // Set small icon

   //To concatenate two CString objects
   CString s1 = _T("This ");           // Cascading concatenation
   s1 += _T("is a ");
   CString s2 = _T("test");
   CString message = s1;
   message.Append(_T("big ") + s2);
   // Message contains "This is a big test".

   m_strText = L"message: " + message;

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है तो आपको निम्न आउटपुट दिखाई देगा।

स्ट्रिंग लंबाई

स्ट्रिंग की लंबाई का पता लगाने के लिए आप CString :: GetLength () विधि का उपयोग कर सकते हैं, जो एक CString ऑब्जेक्ट में वर्णों की संख्या लौटाता है।

BOOL CMFCStringDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();
   
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);              // Set big icon
   SetIcon(m_hIcon, FALSE);              // Set small icon

   CString string1 = _T("This is string 1");
   int length = string1.GetLength();
   CString strLen;

   strLen.Format(L"\nString1 contains %d characters", length);
   m_strText = string1 + strLen;

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है तो आपको निम्न आउटपुट दिखाई देगा।

स्ट्रिंग तुलना

दो स्ट्रिंग चर की तुलना करने के लिए आप == ऑपरेटर का उपयोग कर सकते हैं

BOOL CMFCStringDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();
   
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);            // Set big icon
   SetIcon(m_hIcon, FALSE);          // Set small icon

   CString string1 = _T("Hello");
   CString string2 = _T("World");

   CString string3 = _T("MFC Tutorial");
   CString string4 = _T("MFC Tutorial");

   if (string1 == string2)
      m_strText = "string1 and string1 are same\n";
   else
      m_strText = "string1 and string1 are not same\n";

   if (string3 == string4)
      m_strText += "string3 and string4 are same";
   else
      m_strText += "string3 and string4 are not same";

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है तो आपको निम्न आउटपुट दिखाई देगा।

CArrayएक ऐसा संग्रह है जो डेटा के लिए सबसे अच्छा उपयोग किया जाता है जिसे यादृच्छिक या गैर-अनुक्रमिक तरीके से एक्सेस किया जाना है। CArray क्लास उन सरणियों का समर्थन करता है जो C सरणियों की तरह हैं, लेकिन गतिशील रूप से सिकुड़ सकते हैं और आवश्यकतानुसार बढ़ सकते हैं।

  • ऐरे इंडेक्स हमेशा 0 की स्थिति में शुरू होते हैं।

  • आप तय कर सकते हैं कि ऊपरी बाउंड को ठीक करें या वर्तमान बाउंड के पिछले तत्वों को जोड़ने पर एरे को विस्तारित करने में सक्षम करें।

  • स्मृति को ऊपरी रूप से ऊपरी तौर पर आवंटित किया जाता है, भले ही कुछ तत्व शून्य हों।

अनु क्रमांक। नाम और विवरण
1

Add

सरणी के अंत में एक तत्व जोड़ता है; यदि आवश्यक हो तो सरणी बढ़ता है।

2

Append

सरणी के लिए एक और सरणी जोड़ता है; यदि आवश्यक हो तो सरणी बढ़ता है

3

Copy

सरणी के लिए एक और सरणी की प्रतिलिपि बनाता है; यदि आवश्यक हो तो सरणी बढ़ता है।

4

ElementAt

सरणी के भीतर तत्व सूचक के लिए एक अस्थायी संदर्भ देता है।

5

FreeExtra

वर्तमान अपर बाउंड के ऊपर सभी अप्रयुक्त मेमोरी को हटा देता है।

6

GetAt

वर्तमान अपर बाउंड के ऊपर सभी अप्रयुक्त मेमोरी को हटा देता है।

7

GetCount

इस सरणी में तत्वों की संख्या हो जाती है।

8

GetData

सरणी में तत्वों तक पहुंच की अनुमति देता है। हो सकता हैNULL

9

GetSize

इस सरणी में तत्वों की संख्या हो जाती है।

10

GetUpperBound

सबसे बड़ा वैध सूचकांक लौटाता है।

1 1

InsertAt

एक निर्दिष्ट सूचकांक में एक तत्व (या किसी अन्य सरणी में सभी तत्व) सम्मिलित करता है।

12

IsEmpty

निर्धारित करता है कि सरणी खाली है या नहीं।

13

RemoveAll

इस सरणी से सभी तत्वों को निकालता है।

14

RemoveAt

एक विशिष्ट सूचकांक पर एक तत्व निकालता है।

15

SetAt

किसी दिए गए सूचकांक के लिए मूल्य निर्धारित करता है; सरणी को बढ़ने की अनुमति नहीं है।

16

SetAtGrow

किसी दिए गए सूचकांक के लिए मूल्य निर्धारित करता है; यदि आवश्यक हो तो सरणी बढ़ता है।

17

SetSize

इस सरणी में शामिल किए जाने वाले तत्वों की संख्या निर्धारित करता है।

CArray ऑब्जेक्ट्स पर विभिन्न ऑपरेशन निम्नलिखित हैं -

कैरीरे ऑब्जेक्ट बनाएं

CArray मान या ऑब्जेक्ट का संग्रह बनाने के लिए, आपको पहले संग्रह के मानों का प्रकार तय करना होगा। आप नीचे दिखाए गए अनुसार मौजूदा आदिम डेटा प्रकारों में से एक का उपयोग कर सकते हैं जैसे int, CString, डबल आदि;

CArray<CString, CString>strArray;

सामगंरियां जोड़ें

एक आइटम जोड़ने के लिए आप CArray :: Add () फ़ंक्शन का उपयोग कर सकते हैं। यह सरणी के अंत में एक आइटम जोड़ता है। OnInitDialog () में, CArray ऑब्जेक्ट बनाया जाता है और निम्न कोड में दिखाए गए अनुसार तीन नाम जोड़े जाते हैं।

CArray<CString, CString>strArray;

//Add names to CArray
strArray.Add(L"Ali");
strArray.Add(L"Ahmed");
strArray.Add(L"Mark");

आइटम पुनर्प्राप्त करें

किसी भी आइटम को पुनः प्राप्त करने के लिए, आप CArray :: GetAt () फ़ंक्शन का उपयोग कर सकते हैं। यह फ़ंक्शन सरणी के एक इंडेक्स के रूप में एक पूर्णांक पैरामीटर लेता है।

Step 1 - आइए हम एक साधारण उदाहरण देखें, जो सभी नामों को पुनः प्राप्त करेगा।

//Retrive names from CArray
   for (int i = 0; i < strArray.GetSize(); i++) {
      m_strText.Append(strArray.GetAt(i) + L"\n");
   }

Step 2 - यहाँ CMFCCArrayDlg का पूरा कार्यान्वयन है: OnInitDialog ()

BOOL CMFCCArrayDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);               // Set big icon
   SetIcon(m_hIcon, FALSE);             // Set small icon

   // TODO: Add extra initialization here
   CArray<CString, CString>strArray;
   
   //Add names to CArray
   strArray.Add(L"Ali");
   strArray.Add(L"Ahmed");
   strArray.Add(L"Mark");
   
   //Retrive names from CArray
   for (int i = 0; i < strArray.GetSize(); i++) {
      m_strText.Append(strArray.GetAt(i) + L"\n");
   }
   
   UpdateData(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}

Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

मध्य में आइटम जोड़ें

सरणी के बीच में आइटम जोड़ने के लिए आप CArray :: InsertAt () फ़ंक्शन का उपयोग कर सकते हैं। यह दो पैरामर्टर्स लेता है - पहला, सूचकांक और दूसरा, मूल्य।

निम्नलिखित कोड में दिखाए अनुसार इंडेक्स 1 पर एक नया आइटम डालें।

BOOL CMFCCArrayDlg::OnInitDialog() {
   
   CDialogEx::OnInitDialog();
   
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);             // Set big icon
   SetIcon(m_hIcon, FALSE);            // Set small icon

   // TODO: Add extra initialization here
   CArray<CString, CString>strArray;
   //Add names to CArray
   strArray.Add(L"Ali");
   strArray.Add(L"Ahmed");
   strArray.Add(L"Mark");

   strArray.InsertAt(1, L"Allan");

   //Retrive names from CArray
   for (int i = 0; i < strArray.GetSize(); i++) {
      m_strText.Append(strArray.GetAt(i) + L"\n");
   }

   UpdateData(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}

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

अद्यतन आइटम मान

सरणी के बीच में आइटम को अपडेट करने के लिए आप CArray ::। SetAt () फ़ंक्शन का उपयोग कर सकते हैं। यह दो पैरामर्टर्स लेता है - पहला, सूचकांक और दूसरा, मूल्य।

हमें निम्न कोड में दिखाए अनुसार सरणी में तीसरे तत्व को अपडेट करें।

BOOL CMFCCArrayDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);                 // Set big icon
   SetIcon(m_hIcon, FALSE);               // Set small icon

   // TODO: Add extra initialization here
   CArray<CString, CString>strArray;

   //Add names to CArray
   strArray.Add(L"Ali");
   strArray.Add(L"Ahmed");
   strArray.Add(L"Mark");
  
   strArray.InsertAt(1, L"Allan");
   
   strArray.SetAt(2, L"Salman");
   
   //Retrive names from CArray
   for (int i = 0; i < strArray.GetSize(); i++) {
      m_strText.Append(strArray.GetAt(i) + L"\n");
   }

   UpdateData(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा। अब आप देख सकते हैं कि तीसरे तत्व का मान अद्यतन है।

एरे को कॉपी करें

संपूर्ण सरणी को किसी अन्य CArray ऑब्जेक्ट में कॉपी करने के लिए, आप CArray :: Copy () फ़ंक्शन का उपयोग कर सकते हैं।

Step1 - आइए हम एक और ऐरे बनाते हैं और पहले ऐरे से उन सभी एलिमेंट्स को कॉपी करते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

BOOL CMFCCArrayDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Add "About..." menu item to system menu.

   // IDM_ABOUTBOX must be in the system command range.
   ASSERT((IDM_ABOUTBOX & 0xFFF0) == IDM_ABOUTBOX);
   ASSERT(IDM_ABOUTBOX < 0xF000);
   CMenu* pSysMenu = GetSystemMenu(FALSE);
   if (pSysMenu != NULL) {
      BOOL bNameValid;
      CString strAboutMenu;
      bNameValid = strAboutMenu.LoadString(IDS_ABOUTBOX);
      ASSERT(bNameValid);
      if (!strAboutMenu.IsEmpty()) {
         pSysMenu→AppendMenu(MF_SEPARATOR);
         pSysMenu→AppendMenu(MF_STRING, IDM_ABOUTBOX, strAboutMenu);
      }
   }
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);               // Set big icon
   SetIcon(m_hIcon, FALSE);              // Set small icon

   // TODO: Add extra initialization here
   CArray<CString, CString>strArray;
   //Add names to CArray
   strArray.Add(L"Ali");
   strArray.Add(L"Ahmed");
   strArray.Add(L"Mark");

   strArray.InsertAt(1, L"Allan");

   strArray.SetAt(2, L"Salman");

   CArray<CString, CString>strArray2;
   strArray2.Copy(strArray);
   //Retrive names from CArray
   for (int i = 0; i < strArray2.GetSize(); i++) {
      m_strText.Append(strArray2.GetAt(i) + L"\n");
   }

   UpdateData(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}

अब आप देख सकते हैं कि हमने 2 एन डी सरणी से तत्व को पुनः प्राप्त किया है और आउटपुट समान है क्योंकि हमने कॉपी फ़ंक्शन का उपयोग किया है।

आइटम हटाएँ

किसी विशेष आइटम को हटाने के लिए, आप CArray :: RemoveAt () फ़ंक्शन का उपयोग कर सकते हैं। सूची से सभी तत्व निकालने के लिए, CArray :: RemoveAll () फ़ंक्शन का उपयोग किया जा सकता है।

आइए हम एक सरणी से दूसरा तत्व निकालें।

BOOL CMFCCArrayDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   SetIcon(m_hIcon, TRUE);             // Set big icon
   SetIcon(m_hIcon, FALSE);            // Set small icon

   // TODO: Add extra initialization here
   CArray<CString, CString>strArray;

   //Add names to CArray
   strArray.Add(L"Ali");
   strArray.Add(L"Ahmed");
   strArray.Add(L"Mark");

   strArray.InsertAt(1, L"Allan");

   strArray.SetAt(2, L"Salman");

   CArray<CString, CString>strArray2;
   strArray2.Copy(strArray);

   strArray2.RemoveAt(1);

   //Retrive names from CArray
   for (int i = 0; i < strArray2.GetSize(); i++) {
      m_strText.Append(strArray2.GetAt(i) + L"\n");
   }

   UpdateData(FALSE);
   return TRUE; // return TRUE unless you set the focus to a control
}

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

linked listएक रेखीय डेटा संरचना है जहाँ प्रत्येक तत्व एक अलग वस्तु है। सूची के प्रत्येक तत्व (हम इसे नोड कहेंगे) में दो आइटम शामिल हैं - डेटा और अगले नोड का संदर्भ। अंतिम नोड में शून्य का संदर्भ है।

एक लिंक की गई सूची एक डेटा संरचना है जिसमें नोड्स के समूह शामिल हैं जो एक साथ एक अनुक्रम का प्रतिनिधित्व करते हैं। यह संरचनाओं के साथ डेटा स्टोर करने का एक तरीका है ताकि प्रोग्रामर जब भी आवश्यक हो डेटा को स्टोर करने के लिए स्वचालित रूप से एक नई जगह बना सके। इसकी कुछ मुख्य विशेषताएं हैं -

  • लिंक्ड लिस्ट उन लिंक्स का एक क्रम है जिसमें आइटम होते हैं।

  • प्रत्येक लिंक में दूसरे लिंक का कनेक्शन होता है।

  • सूची में प्रत्येक आइटम को नोड कहा जाता है।

  • यदि सूची में कम से कम एक नोड है, तो एक नया नोड सूची में अंतिम तत्व के रूप में तैनात है।

  • यदि सूची में केवल एक नोड है, तो वह नोड पहले और अंतिम आइटम का प्रतिनिधित्व करता है।

लिंक सूची के दो प्रकार हैं -

सिंगली लिंक्ड लिस्ट

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

संदेह से जुड़ी सूची

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

CList वर्ग

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

अनु क्रमांक। नाम और विवरण
1

AddHead

एक तत्व (या किसी अन्य सूची में सभी तत्व) को सूची के प्रमुख में जोड़ता है (एक नया सिर बनाता है)।

2

AddTail

एक तत्व (या किसी अन्य सूची में सभी तत्व) को सूची की पूंछ में जोड़ता है (एक नई पूंछ बनाता है)।

3

Find

पॉइंटर मान द्वारा निर्दिष्ट तत्व की स्थिति प्राप्त करता है।

4

FindIndex

शून्य-आधारित सूचकांक द्वारा निर्दिष्ट तत्व की स्थिति प्राप्त करता है।

5

GetAt

किसी दिए गए स्थान पर तत्व प्राप्त करता है।

6

GetCount

इस सूची में तत्वों की संख्या लौटाता है।

7

GetHead

सूची का मुख्य तत्व लौटाता है (खाली नहीं हो सकता)।

8

GetHeadPosition

सूची के प्रमुख तत्व की स्थिति लौटाता है।

9

GetNext

पुनरावृति के लिए अगला तत्व प्राप्त करता है।

10

GetPrev

पुनरावृत्ति के लिए पिछले तत्व प्राप्त करता है।

1 1

GetSize

इस सूची में तत्वों की संख्या लौटाता है।

12

GetTail

सूची का टेल एलिमेंट लौटाता है (खाली नहीं हो सकता)।

13

GetTailPosition

सूची के पूंछ तत्व की स्थिति देता है।

14

InsertAfter

किसी दिए गए स्थान के बाद एक नया तत्व सम्मिलित करता है।

15

InsertBefore

किसी दिए गए पद से पहले एक नया तत्व सम्मिलित करता है।

16

IsEmpty

खाली सूची की स्थिति के लिए टेस्ट (कोई तत्व नहीं)।

17

RemoveAll

इस सूची से सभी तत्वों को निकालता है।

18

RemoveAt

इस सूची से एक तत्व निकालता है, स्थिति द्वारा निर्दिष्ट।

19

RemoveHead

सूची के प्रमुख से तत्व को निकालता है।

20

RemoveTail

सूची की पूंछ से तत्व को निकालता है।

21

SetAt

तत्व को दिए गए स्थान पर सेट करता है।

CList वस्तुओं पर विभिन्न प्रचालन निम्नलिखित हैं -

सीएलस्ट ऑब्जेक्ट बनाएँ

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

CList<double, double>m_list;

सामगंरियां जोड़ें

किसी आइटम को जोड़ने के लिए, आप CList :: AddTail () फ़ंक्शन का उपयोग कर सकते हैं। यह सूची के अंत में एक आइटम जोड़ता है। सूची की शुरुआत में एक तत्व जोड़ने के लिए, आप CList :: AddHead () फ़ंक्शन का उपयोग कर सकते हैं। OnInitDialog () CList में, ऑब्जेक्ट बनाया जाता है और निम्न कोड में दिखाए गए अनुसार चार मान जोड़े जाते हैं।

CList<double, double>m_list;

//Add items to the list
m_list.AddTail(100.75);
m_list.AddTail(85.26);
m_list.AddTail(95.78);
m_list.AddTail(90.1);

आइटम पुनर्प्राप्त करें

सूची का एक प्रकार सूची के लिए एक कुंजी है। क्रमिक रूप से किसी सूची को ट्रेस करने के लिए आप एक पुनरावृत्ति के रूप में एक स्थिति चर का उपयोग कर सकते हैं।

Step 1 - सूची से तत्व को पुनः प्राप्त करने के लिए, हम निम्नलिखित कोड का उपयोग कर सकते हैं जो सभी मूल्यों को पुनः प्राप्त करेगा।

//iterate the list
POSITION pos = m_list.GetHeadPosition();
while (pos) { 
   double nData = m_list.GetNext(pos);
   CString strVal;
   strVal.Format(L"%.2f\n", nData);
   m_strText.Append(strVal);
}

Step 2 - यहाँ पूरा CMFCCListDemoDlg :: OnInitDialog () फ़ंक्शन है।

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);             // Set big icon
   SetIcon(m_hIcon, FALSE);             // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.f\n", nData);
      m_strText.Append(strVal);
   }

   UpdateData(FALSE);
 
   return TRUE; // return TRUE unless you set the focus to a control
}

Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

मध्य में आइटम जोड़ें

सूची के बीच में आइटम जोड़ने के लिए, आप CList ::। InsertAfter () और CList :: InsertBeforefore () फ़ंक्शन का उपयोग कर सकते हैं। यह दो पैरामीटर्स लेता है - पहला, स्थिति (जहां इसे जोड़ा जा सकता है) और दूसरा, मान।

Step 1 - हमें एक नया आइटम डालें जैसा कि followng कोड में दिखाया गया है।

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();
   
   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);             // Set big icon
   SetIcon(m_hIcon, FALSE);          // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   POSITION position = m_list.Find(85.26);
   m_list.InsertBefore(position, 200.0);
   m_list.InsertAfter(position, 300.0);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.2f\n", nData);
      m_strText.Append(strVal);
   }

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

Step 2 - अब आप देख सकते हैं कि हमने पहले मूल्य की स्थिति को पुनः प्राप्त किया 85.26 और फिर एक तत्व को उस मूल्य के पहले और एक तत्व डाला।

Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

अद्यतन आइटम मान

सरणी के मध्य में आइटम को अपडेट करने के लिए, आप CArray ::। SetAt () फ़ंक्शन का उपयोग कर सकते हैं। यह दो पैरामर्टर्स लेता है - पहला, स्थिति और दूसरा, मूल्य।

निम्नलिखित कोड में दिखाए अनुसार सूची में 300.00 से 400 अपडेट करते हैं।

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);              // Set big icon
   SetIcon(m_hIcon, FALSE);            // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   POSITION position = m_list.Find(85.26);
   m_list.InsertBefore(position, 200.0);
   m_list.InsertAfter(position, 300.0);

   position = m_list.Find(300.00);
   m_list.SetAt(position, 400.00);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.2f\n", nData);
      m_strText.Append(strVal);
   }

   UpdateData(FALSE);

   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा। अब आप देख सकते हैं कि 300.00 का मान 400.00 में अपडेट किया गया है।

आइटम हटाएँ

किसी विशेष आइटम को हटाने के लिए, आप CList :: RemoveAt () फ़ंक्शन का उपयोग कर सकते हैं। सूची से सभी तत्व को हटाने के लिए, CList :: RemoveAll () फ़ंक्शन का उपयोग किया जा सकता है।

आइए हम उस तत्व को हटाते हैं, जिसका मूल्य 95.78 है।

BOOL CMFCCListDemoDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);              // Set big icon
   SetIcon(m_hIcon, FALSE);             // Set small icon

   // TODO: Add extra initialization here
   CList<double, double>m_list;

   //Add items to the list
   m_list.AddTail(100.75);
   m_list.AddTail(85.26);
   m_list.AddTail(95.78);
   m_list.AddTail(90.1);

   POSITION position = m_list.Find(85.26);
   m_list.InsertBefore(position, 200.0);
   m_list.InsertAfter(position, 300.0);
   
   position = m_list.Find(300.00);
   m_list.SetAt(position, 400.00);

   position = m_list.Find(95.78);
   m_list.RemoveAt(position);

   //iterate the list
   POSITION pos = m_list.GetHeadPosition();
   while (pos) {
      double nData = m_list.GetNext(pos);
      CString strVal;
      strVal.Format(L"%.2f\n", nData);
      m_strText.Append(strVal);
   }
   UpdateData(FALSE);
   
   return TRUE; // return TRUE unless you set the focus to a control
}

जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा। अब आप देख सकते हैं कि 95.78 का मान सूची का हिस्सा नहीं है।

databaseसूचनाओं का एक संग्रह है जो व्यवस्थित है ताकि इसे आसानी से एक्सेस, प्रबंधित और अद्यतन किया जा सके। ODBC पर आधारित MFC डेटाबेस कक्षाएं किसी भी डेटाबेस के लिए पहुँच प्रदान करने के लिए डिज़ाइन की गई हैं, जिसके लिए ODBC ड्राइवर उपलब्ध है। क्योंकि कक्षाएं ODBC का उपयोग करती हैं, इसलिए आपका एप्लिकेशन कई अलग-अलग डेटा स्वरूपों और विभिन्न स्थानीय / दूरस्थ कॉन्फ़िगरेशन में डेटा तक पहुंच सकता है।

आपको अलग-अलग डेटाबेस मैनेजमेंट सिस्टम (DBMS) को संभालने के लिए विशेष-केस कोड लिखने की आवश्यकता नहीं है। जब तक आपके उपयोगकर्ताओं के पास उस डेटा के लिए एक उपयुक्त ODBC ड्राइवर है, जिसे वे एक्सेस करना चाहते हैं, वे आपके प्रोग्राम का उपयोग वहां संग्रहीत तालिकाओं में डेटा में हेरफेर करने के लिए कर सकते हैं। डेटा स्रोत कुछ डेटाबेस प्रबंधन प्रणाली (DBMS) द्वारा होस्ट किए गए डेटा का एक विशिष्ट उदाहरण है। उदाहरणों में Microsoft SQL सर्वर, Microsoft Access आदि शामिल हैं।

CDatabase

MFC एक वर्ग प्रदान करता है CDatabaseजो डेटा स्रोत से एक कनेक्शन का प्रतिनिधित्व करता है, जिसके द्वारा आप डेटा स्रोत पर काम कर सकते हैं। आपके आवेदन में एक समय में एक या एक से अधिक सीडीटैब वस्तुएं सक्रिय हो सकती हैं।

अनु क्रमांक। नाम और विवरण
1

BeginTrans

"लेन-देन" शुरू करता है - AddNew के लिए प्रतिवर्ती कॉल की एक श्रृंखला, संपादित करें, हटाएं और कक्षा के सदस्य कार्यों को अपडेट करें CRecordset- जुड़े डेटा स्रोत पर। डेटा स्रोत के लिए लेनदेन का समर्थन करना चाहिएBeginTrans किसी भी प्रभाव के लिए।

2

BindParameters

आपको कॉल करने से पहले मापदंडों को बांधने की अनुमति देता है ExecuteSQL

3

Cancel

एक एसिंक्रोनस ऑपरेशन या एक दूसरे धागे से एक प्रक्रिया रद्द करता है।

4

CanTransact

यदि डेटा स्रोत लेनदेन का समर्थन करता है तो नॉनज़रो लौटाता है।

5

CanUpdate

यदि नॉनजरो लौटाता है तो CDatabase ऑब्जेक्ट अद्यतन करने योग्य है (केवल पढ़ने के लिए नहीं)।

6

Close

डेटा स्रोत कनेक्शन बंद कर देता है।

7

CommitTrans

BeginTrans द्वारा शुरू किए गए लेनदेन को पूरा करता है। डेटा स्रोत को बदलने वाले लेनदेन में शामिल हैं।

8

ExecuteSQL

SQL कथन निष्पादित करता है। कोई डेटा रिकॉर्ड वापस नहीं किया जाता है।

9

GetBookmarkPersistence

उन कार्यों की पहचान करता है जिनके माध्यम से बुकमार्क रिकॉर्ड की गई वस्तुओं पर बने रहते हैं।

10

GetConnect

डेटा स्रोत से CDatabase ऑब्जेक्ट को कनेक्ट करने के लिए उपयोग किए गए ODBC कनेक्शन स्ट्रिंग लौटाता है।

1 1

GetCursorCommitBehavior

एक ओपन रिकॉर्डसेट ऑब्जेक्ट पर लेनदेन करने के प्रभाव की पहचान करता है।

12

GetCursorRollbackBehavior

एक ओपन रिकॉर्डसेट ऑब्जेक्ट पर एक लेनदेन को वापस करने के प्रभाव की पहचान करता है।

13

GetDatabaseName

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

14

IsOpen

यदि नॉनजरो लौटाता है तो CDatabase ऑब्जेक्ट वर्तमान में डेटा स्रोत से जुड़ा हुआ है।

15

OnSetOptions

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

16

Open

एक डेटा स्रोत (एक ओडीबीसी ड्राइवर के माध्यम से) के लिए एक कनेक्शन स्थापित करता है।

17

OpenEx

एक डेटा स्रोत (एक ओडीबीसी ड्राइवर के माध्यम से) के लिए एक कनेक्शन स्थापित करता है।

18

Rollback

वर्तमान लेन-देन के दौरान किए गए परिवर्तनों को उलट देता है। डेटा स्रोत अपनी पिछली स्थिति में लौटता है, जैसा कि शुरुआत में कॉल किया गया था, अनलेडेड।

19

SetLoginTimeout

सेकंड की संख्या सेट करता है जिसके बाद डेटा स्रोत कनेक्शन का प्रयास समाप्त हो जाएगा।

20

SetQueryTimeout

सेकंड की संख्या सेट करता है जिसके बाद डेटाबेस क्वेरी ऑपरेशन टाइम आउट हो जाएगा। सभी बाद के रिकॉर्डसेट खोलें, AddNew, Edit और Delete कॉल को प्रभावित करता है।

एक नया एमएफसी संवाद आधारित एप्लिकेशन बनाकर हमें एक सरल उदाहरण में देखें।

Step 1 - TODO लाइन के कैप्शन को बदलें Retrieve Data from Database और निम्न स्नैपशॉट में दिखाए अनुसार एक बटन और एक सूची नियंत्रण खींचें।

Step 2 - बटन के लिए क्लिक इवेंट हैंडलर जोड़ें और सूची नियंत्रण के लिए चर m_ListControl को नियंत्रित करें।

Step 3 - हमारे पास सरल डेटाबेस है जिसमें कुछ रिकॉर्ड के साथ एक कर्मचारी तालिका है जो निम्न स्नैपशॉट में दिखाया गया है।

Step 4 - हमें निम्नलिखित हेडर फ़ाइल को शामिल करने की आवश्यकता है ताकि हम सीडीटाबेस वर्ग का उपयोग कर सकें।

#include "odbcinst.h"
#include "afxdb.h"

क्वेरी डालें

SQL INSERT INTO स्टेटमेंट का उपयोग डेटाबेस में टेबल पर डेटा की नई पंक्तियों को जोड़ने के लिए किया जाता है।

Step 1 - नए रिकॉर्ड जोड़ने के लिए, हम निम्न कोड में दिखाए गए के अनुसार ExecuteSQL () फ़ंक्शन का उपयोग करेंगे।

CDatabase database;
CString SqlString;
CString strID, strName, strAge;
CString sDriver = L"MICROSOFT ACCESS DRIVER (*.mdb)";
CString sDsn;
CString sFile = L"D:\\Test.mdb";
// You must change above path if it's different
int iRec = 0;

// Build ODBC connection string
sDsn.Format(L"ODBC;DRIVER={%s};DSN='';DBQ=%s", sDriver, sFile);
TRY {
   // Open the database
   database.Open(NULL,false,false,sDsn);

   SqlString = "INSERT INTO Employees (ID,Name,age) VALUES (5,'Sanjay',69)";
   database.ExecuteSQL(SqlString);
   // Close the database
   database.Close();
}CATCH(CDBException, e) {
   // If a database exception occured, show error msg
   AfxMessageBox(L"Database error: " + e→m_strError);
}
END_CATCH;

Step 2 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आप देखेंगे कि आपके डेटाबेस में एक नया रिकॉर्ड जोड़ा गया है।

पुनः प्राप्त रिकॉर्ड

MFC एप्लिकेशन में उपरोक्त तालिका को पुनः प्राप्त करने के लिए, हम बटन इवेंट हैंडलर में डेटाबेस से संबंधित संचालन को कार्यान्वित करते हैं जैसा कि निम्नलिखित चरणों में दिखाया गया है।

Step 1- सीडीटाबेस का उपयोग करने के लिए, सीडीटैबस ऑब्जेक्ट का निर्माण करें और इसके ओपन () फ़ंक्शन को कॉल करें। इससे कनेक्शन खुल जाएगा।

Step 2 - कनेक्टेड डेटा स्रोत पर संचालन के लिए CRecordet ऑब्जेक्ट्स का निर्माण करें, अपने CDatabase ऑब्जेक्ट के लिए रिकॉर्डर कंस्ट्रक्टर को पॉइंटर पास करें।

Step 3 - कनेक्शन का उपयोग करने के बाद, क्लोज फ़ंक्शन को कॉल करें और सीडीटाबेस ऑब्जेक्ट को नष्ट करें।

void CMFCDatabaseDemoDlg::OnBnClickedButtonRead() {
   // TODO: Add your control notification handler code here
   CDatabase database;
   CString SqlString;
   CString strID, strName, strAge;
   CString sDriver = "MICROSOFT ACCESS DRIVER (*.mdb)";
   CString sFile = L"D:\\Test.mdb";
   // You must change above path if it's different
   int iRec = 0;

   // Build ODBC connection string
   sDsn.Format("ODBC;DRIVER={%s};DSN='';DBQ=%s",sDriver,sFile);
   TRY {
      // Open the database
      database.Open(NULL,false,false,sDsn);

      // Allocate the recordset
      CRecordset recset( &database );

      // Build the SQL statement
      SqlString = "SELECT ID, Name, Age " "FROM Employees";

      // Execute the query
	  
      recset.Open(CRecordset::forwardOnly,SqlString,CRecordset::readOnly);
      // Reset List control if there is any data
      ResetListControl();
      // populate Grids
      ListView_SetExtendedListViewStyle(m_ListControl,LVS_EX_GRIDLINES);

      // Column width and heading
      m_ListControl.InsertColumn(0,"Emp ID",LVCFMT_LEFT,-1,0);
      m_ListControl.InsertColumn(1,"Name",LVCFMT_LEFT,-1,1);
      m_ListControl.InsertColumn(2, "Age", LVCFMT_LEFT, -1, 1);
      m_ListControl.SetColumnWidth(0, 120);
      m_ListControl.SetColumnWidth(1, 200);
      m_ListControl.SetColumnWidth(2, 200);

      // Loop through each record
      while( !recset.IsEOF() ) {
         // Copy each column into a variable
         recset.GetFieldValue("ID",strID);
         recset.GetFieldValue("Name",strName);
         recset.GetFieldValue("Age", strAge);

         // Insert values into the list control
         iRec = m_ListControl.InsertItem(0,strID,0);
         m_ListControl.SetItemText(0,1,strName);
         m_ListControl.SetItemText(0, 2, strAge);

         // goto next record
         recset.MoveNext();
      }
      // Close the database
      database.Close();
   }CATCH(CDBException, e) {
      // If a database exception occured, show error msg
      AfxMessageBox("Database error: "+e→m_strError);
   }
   END_CATCH; 
}

// Reset List control
void CMFCDatabaseDemoDlg::ResetListControl() {
   m_ListControl.DeleteAllItems();
   int iNbrOfColumns;
   CHeaderCtrl* pHeader = (CHeaderCtrl*)m_ListControl.GetDlgItem(0);
   if (pHeader) {
      iNbrOfColumns = pHeader→GetItemCount();
   }
   for (int i = iNbrOfColumns; i >= 0; i--) {
      m_ListControl.DeleteColumn(i);
   }
}

Step 4 - यहां हेडर फाइल है।

// MFCDatabaseDemoDlg.h : header file
//

#pragma once
#include "afxcmn.h"


// CMFCDatabaseDemoDlg dialog
class CMFCDatabaseDemoDlg : public CDialogEx {
   // Construction
   public:
      CMFCDatabaseDemoDlg(CWnd* pParent = NULL);    // standard constructor

   // Dialog Data
   #ifdef AFX_DESIGN_TIME
      enum { IDD = IDD_MFCDATABASEDEMO_DIALOG };
   #endif

   protected:
      virtual void DoDataExchange(CDataExchange* pDX);    // DDX/DDV support
      void ResetListControl();

   // Implementation
   protected:
      HICON m_hIcon;

      // Generated message map functions
      virtual BOOL OnInitDialog();
      afx_msg void OnPaint();
      afx_msg HCURSOR OnQueryDragIcon();
      DECLARE_MESSAGE_MAP()
   public:
      CListCtrl m_ListControl;
      afx_msg void OnBnClickedButtonRead();
};

Step 5 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 6- डेटाबेस संचालन को निष्पादित करने के लिए रीड बटन दबाएं। यह कर्मचारी तालिका को पुनः प्राप्त करेगा।

अद्यतन रिकॉर्ड

SQL UPDATE क्वेरी का उपयोग किसी तालिका में मौजूदा रिकॉर्ड को संशोधित करने के लिए किया जाता है। आप चयनित पंक्तियों को अद्यतन करने के लिए UPDATE क्वेरी के साथ जहां खंड का उपयोग कर सकते हैं अन्यथा सभी पंक्तियाँ प्रभावित होंगी।

Step 1 - आइए हम आयु को अपडेट करके एक सरल उदाहरण देखें जहां आईडी 5 के बराबर है।

SqlString = L"UPDATE Employees SET Age = 59 WHERE ID = 5;";
database.ExecuteSQL(SqlString);

Step 2 - यहां बटन क्लिक इवेंट का पूरा कोड है।

void CMFCDatabaseDemoDlg::OnBnClickedButtonRead() {
   // TODO: Add your control notification handler code here
   CDatabase database;
   CString SqlString;
   CString strID, strName, strAge;
   CString sDriver = L"MICROSOFT ACCESS DRIVER (*.mdb)";
   CString sDsn;
   CString sFile =
      L"C:\\Users\\Muhammad.Waqas\\Downloads\\Compressed\\ReadDB_demo\\Test.mdb";
   // You must change above path if it's different
   int iRec = 0;

   // Build ODBC connection string
   sDsn.Format(L"ODBC;DRIVER={%s};DSN='';DBQ=%s", sDriver, sFile);
   TRY {
      // Open the database
      database.Open(NULL,false,false,sDsn);

      // Allocate the recordset
      CRecordset recset(&database);

      SqlString = L"UPDATE Employees SET Age = 59 WHERE ID = 5;";

      database.ExecuteSQL(SqlString);

      SqlString = "SELECT ID, Name, Age FROM Employees";

      // Build the SQL statement
      SqlString = "SELECT ID, Name, Age FROM Employees";

      // Execute the query
      recset.Open(CRecordset::forwardOnly,SqlString,CRecordset::readOnly);

      // Reset List control if there is any data
      ResetListControl();
      // populate Grids
      ListView_SetExtendedListViewStyle(m_listCtrl,LVS_EX_GRIDLINES);

      // Column width and heading
      m_listCtrl.InsertColumn(0,L"Emp ID",LVCFMT_LEFT,-1,0);
      m_listCtrl.InsertColumn(1,L"Name",LVCFMT_LEFT,-1,1);
      m_listCtrl.InsertColumn(2, L"Age", LVCFMT_LEFT, -1, 1);
      m_listCtrl.SetColumnWidth(0, 120);
      m_listCtrl.SetColumnWidth(1, 200);
      m_listCtrl.SetColumnWidth(2, 200);

      // Loop through each record
      while (!recset.IsEOF()) {
         // Copy each column into a variable
         recset.GetFieldValue(L"ID",strID);
         recset.GetFieldValue(L"Name",strName);
         recset.GetFieldValue(L"Age", strAge);

         // Insert values into the list control
         iRec = m_listCtrl.InsertItem(0,strID,0);
         m_listCtrl.SetItemText(0,1,strName);
         m_listCtrl.SetItemText(0, 2, strAge);

         // goto next record
         recset.MoveNext();
      }

      // Close the database
      database.Close();
   }CATCH(CDBException, e) {
      // If a database exception occured, show error msg
      AfxMessageBox(L"Database error: " + e→m_strError);
   }
   END_CATCH;
}

Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 4- डेटाबेस संचालन को निष्पादित करने के लिए रीड बटन दबाएं। यह निम्नलिखित कर्मचारी तालिका को पुनः प्राप्त करेगा।

Step 5 - अब आप देख सकते हैं कि आयु 69 से 59 तक अपडेट की गई है।

रिकॉर्ड हटाएं

SQL DELETE क्वेरी का उपयोग किसी तालिका से मौजूदा रिकॉर्ड को हटाने के लिए किया जाता है। आप चयनित पंक्तियों को हटाने के लिए DELETE क्वेरी के साथ WHERE क्लॉज़ का उपयोग कर सकते हैं, अन्यथा सभी रिकॉर्ड हटा दिए जाएंगे।

Step 1 - आइए रिकॉर्ड को हटाकर एक साधारण उदाहरण देखें, जहां आईडी 3 के बराबर है।

SqlString = L"DELETE FROM Employees WHERE ID = 3;";

database.ExecuteSQL(SqlString);

Step 2 - यहां बटन क्लिक इवेंट का पूरा कोड है।

void CMFCDatabaseDemoDlg::OnBnClickedButtonRead() {
   // TODO: Add your control notification handler code here
   CDatabase database;
   CString SqlString;
   CString strID, strName, strAge;
   CString sDriver = L"MICROSOFT ACCESS DRIVER (*.mdb)";
   CString sDsn;
   CString sFile =
       L"C:\\Users\\Muhammad.Waqas\\Downloads\\Compressed\\ReadDB_demo\\Test.mdb";

   // You must change above path if it's different
   int iRec = 0;

   // Build ODBC connection string
   sDsn.Format(L"ODBC;DRIVER={%s};DSN='';DBQ=%s", sDriver, sFile);
   TRY {
      // Open the database
      database.Open(NULL,false,false,sDsn);

      // Allocate the recordset
      CRecordset recset(&database);

      SqlString = L"DELETE FROM Employees WHERE ID = 3;";

      database.ExecuteSQL(SqlString);

      SqlString = "SELECT ID, Name, Age FROM Employees";

      // Build the SQL statement
      SqlString = "SELECT ID, Name, Age FROM Employees";

      // Execute the query
      recset.Open(CRecordset::forwardOnly,SqlString,CRecordset::readOnly);

      // Reset List control if there is any data
      ResetListControl();
      // populate Grids
      ListView_SetExtendedListViewStyle(m_listCtrl,LVS_EX_GRIDLINES);
      // Column width and heading
      m_listCtrl.InsertColumn(0,L"Emp ID",LVCFMT_LEFT,-1,0);
      m_listCtrl.InsertColumn(1,L"Name",LVCFMT_LEFT,-1,1);
      m_listCtrl.InsertColumn(2, L"Age", LVCFMT_LEFT, -1, 1);
      m_listCtrl.SetColumnWidth(0, 120);
      m_listCtrl.SetColumnWidth(1, 200);
      m_listCtrl.SetColumnWidth(2, 200);

      // Loop through each record
      while (!recset.IsEOF()) {
         // Copy each column into a variable
         recset.GetFieldValue(L"ID",strID);
         recset.GetFieldValue(L"Name",strName);
         recset.GetFieldValue(L"Age", strAge);

         // Insert values into the list control
         iRec = m_listCtrl.InsertItem(0,strID,0);
         m_listCtrl.SetItemText(0,1,strName);
         m_listCtrl.SetItemText(0, 2, strAge);

         // goto next record
         recset.MoveNext();
      }
      // Close the database
      database.Close();
   }CATCH(CDBException, e) {
      // If a database exception occured, show error msg
      AfxMessageBox(L"Database error: " + e→m_strError);
   }
   END_CATCH;
}

Step 3 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 4- डेटाबेस संचालन को निष्पादित करने के लिए रीड बटन दबाएं। यह कर्मचारी तालिका को पुनः प्राप्त करेगा।

Serializationएक डिस्क फ़ाइल जैसे एक स्थिर भंडारण माध्यम से या उससे एक वस्तु को लिखने या पढ़ने की प्रक्रिया है। सीरियलाइज़ेशन उन परिस्थितियों के लिए आदर्श है जहाँ किसी प्रोग्राम के निष्पादन के दौरान या बाद में संरचित डेटा (जैसे C ++ क्लासेस या स्ट्रक्चर्स) की स्थिति को बनाए रखना वांछित है।

फ़ाइल प्रसंस्करण करते समय, मान आमतौर पर आदिम प्रकार (चार, लघु, इंट, फ्लोट या डबल) के होते हैं। उसी तरह, हम व्यक्तिगत रूप से कई मूल्यों को बचा सकते हैं, एक बार में। इस तकनीक में एक वर्ग से (एक चर के रूप में) बनाई गई वस्तु शामिल नहीं है।

MFC लाइब्रेरी में क्रमांकन के लिए उच्च स्तर का समर्थन है। यह COBject क्लास से शुरू होता है जो अधिकांश MFC क्लासेस का पूर्वज है, जो एक Serialize () सदस्य फ़ंक्शन से सुसज्जित है।

एक नया MFC प्रोजेक्ट बनाकर एक साधारण उदाहरण देखते हैं।

Step 1 - TODO लाइन निकालें और अपने संवाद बॉक्स को डिज़ाइन करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

Step 2- सभी संपादन नियंत्रणों के लिए मूल्य चर जोड़ें। उल्लिखित ईएम आईडी और आयु के लिए, मूल्य प्रकार एक पूर्णांक है जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

Step 3 - दोनों बटनों के लिए ईवेंट हैंडलर जोड़ें।

Step 4- अब हम एक साधारण कर्मचारी वर्ग जोड़ते हैं, जिसे हमें क्रमबद्ध करना है। यहाँ हैडर फ़ाइल में कर्मचारी वर्ग की घोषणा है।

class CEmployee : public CObject {
   public:
      int empID;
      CString empName;
      int age;
      CEmployee(void);
      ~CEmployee(void);
   private:

   public:
      void Serialize(CArchive& ar);
      DECLARE_SERIAL(CEmployee);
};

Step 5 - यहाँ कर्मचारी वर्ग की परिभाषा स्रोत (* .cpp) फ़ाइल में दी गई है।

IMPLEMENT_SERIAL(CEmployee, CObject, 0)
CEmployee::CEmployee(void) {

}

CEmployee::~CEmployee(void) {

}

void CEmployee::Serialize(CArchive& ar) {
   CObject::Serialize(ar);

   if (ar.IsStoring())
      ar << empID << empName << age;
   else
      ar >> empID >> empName >> age;
}

Step 6 - यहां सेव बटन इवेंट हैंडलर का कार्यान्वयन है।

void CMFCSerializationDlg::OnBnClickedButtonSave() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   CEmployee employee;
   CFile file;
   file.Open(L"EmployeeInfo.hse", CFile::modeCreate | CFile::modeWrite);
   CArchive ar(&file, CArchive::store);
   employee.empID = m_id;
   employee.empName = m_strName;
   employee.age = m_age;
   employee.Serialize(ar);
   ar.Close();
}

Step 7 - यहां ओपन बटन ईवेंट हैंडलर का कार्यान्वयन है।

void CMFCSerializationDlg::OnBnClickedButtonOpen() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);

   CFile file;

   file.Open(L"EmployeeInfo.hse", CFile::modeRead);
   CArchive ar(&file, CArchive::load);
   CEmployee employee;

   employee.Serialize(ar);

   m_id = employee.empID;
   m_strName = employee.empName;
   m_age = employee.age;
   ar.Close();
   file.Close();

   UpdateData(FALSE);
}

Step 8 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 9 - सभी क्षेत्रों में जानकारी दर्ज करें और सहेजें पर क्लिक करें और इस कार्यक्रम को बंद करें।

Step 10- यह डेटा को बचाएगा। एप्लिकेशन को फिर से चलाएँ और खुले पर क्लिक करें। यह कर्मचारी जानकारी लोड करेगा।

Microsoft Foundation Class (MFC) लाइब्रेरी मल्टीथ्रेड एप्लिकेशन के लिए सहायता प्रदान करती है। एक धागा एक प्रक्रिया के भीतर निष्पादन का एक मार्ग है। जब आप नोटपैड शुरू करते हैं, तो ऑपरेटिंग सिस्टम एक प्रक्रिया बनाता है और उस प्रक्रिया के प्राथमिक धागे को निष्पादित करना शुरू करता है। जब यह धागा समाप्त हो जाता है, तो प्रक्रिया होती है।

यदि आप चाहें तो अपने आवेदन में अतिरिक्त धागे बना सकते हैं। MFC अनुप्रयोगों में सभी धागे CWinThread ऑब्जेक्ट्स द्वारा दर्शाए गए हैं। ज्यादातर स्थितियों में, आपको इन वस्तुओं को स्पष्ट रूप से बनाने की आवश्यकता नहीं है; इसके बजाय फ्रेमवर्क हेल्पर फ़ंक्शन को कॉल करें AfxBeginThread, जो आपके लिए CWinThread ऑब्जेक्ट बनाता है।

एक नया एमएफसी संवाद आधारित एप्लिकेशन बनाकर हमें एक सरल उदाहरण में देखें।

Step 1 - स्थैतिक नियंत्रण के कैप्शन और आईडी को बदलें Click on Start Thread button तथा IDC_STATIC_TEXT क्रमशः।

Step 2 - दो बटन खींचें और इन बटनों के लिए क्लिक इवेंट हैंडलर जोड़ें।

Step 3 - स्थिर पाठ नियंत्रण के लिए नियंत्रण चर जोड़ें।

Step 4 - अब CMFCMultithreadingDlg.cpp फ़ाइल की शुरुआत में निम्नलिखित तीन वैश्विक चर जोड़ें।

int currValue;
int maxValue;
BOOL stopNow;

Step 5 - CMFCMultithreadingDlg वर्ग में WM_TIMER संदेश जोड़ें।

यहाँ OnTimer का कार्यान्वयन है ()

void CMFCMultithreadingDlg::OnTimer(UINT_PTR nIDEvent) {
   // TODO: Add your message handler code here and/or call default
   CString sStatusMsg;
   sStatusMsg.Format(L"Running: %d", currValue);
   m_ctrlStatus.SetWindowText(sStatusMsg);

   CDialogEx::OnTimer(nIDEvent);
}

Step 6 - अब CMFCMultithreadingDlg वर्ग में AfxBeginThread में उपयोग करने के लिए एक नमूना फ़ंक्शन जोड़ें।

UINT MyThreadProc(LPVOID Param) {
   while (!stopNow && (currValue < maxValue)) {
      currValue++;
      Sleep(50);     // would do some work here
   }
   
   return TRUE;
}

Step 7 - यहां स्टार्ट थ्रेड बटन के लिए ईवेंट हैंडलर का कार्यान्वयन है, जो थ्रेड शुरू करेगा।

void CMFCMultithreadingDlg::OnBnClickedButtonStart() {
   // TODO: Add your control notification handler code here
   currValue = 0;
   maxValue = 5000;
   stopNow = 0;
   m_ctrlStatus.SetWindowText(L"Starting...");
   SetTimer(1234, 333, 0); // 3 times per second

   AfxBeginThread(MyThreadProc, 0); // <<== START THE THREAD
}

Step 8 - यहां स्टॉप थ्रेड बटन के लिए ईवेंट हैंडलर का कार्यान्वयन है, जो थ्रेड को रोक देगा।

void CMFCMultithreadingDlg::OnBnClickedButtonStop() {
   
   // TODO: Add your control notification handler code here
   stopNow = TRUE;
   KillTimer(1234);
   m_ctrlStatus.SetWindowText(L"Stopped");
}

Step 9 - यहां पूरा सोर्स फाइल है।

// MFCMultithreadingDlg.cpp : implementation file
//

#include "stdafx.h"
#include "MFCMultithreading.h"
#include "MFCMultithreadingDlg.h"
#include "afxdialogex.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#endif

// CMFCMultithreadingDlg dialog

int currValue;
int maxValue;
BOOL stopNow;

CMFCMultithreadingDlg::CMFCMultithreadingDlg(CWnd* pParent /* = NULL*/)
   : CDialogEx(IDD_MFCMULTITHREADING_DIALOG, pParent) {
   m_hIcon = AfxGetApp() -> LoadIcon(IDR_MAINFRAME);
}
void CMFCMultithreadingDlg::DoDataExchange(CDataExchange* pDX) {
   CDialogEx::DoDataExchange(pDX);
   DDX_Control(pDX, IDC_STATIC_TEXT, m_ctrlStatus);
}

BEGIN_MESSAGE_MAP(CMFCMultithreadingDlg, CDialogEx)
   ON_WM_PAINT()
   ON_WM_QUERYDRAGICON()
   ON_BN_CLICKED(IDC_BUTTON_START,
      &CMFCMultithreadingDlg::OnBnClickedButtonStart)
   ON_WM_TIMER()
   ON_BN_CLICKED(IDC_BUTTON_STOP,
      &CMFCMultithreadingDlg::OnBnClickedButtonStop)
END_MESSAGE_MAP()

// CMFCMultithreadingDlg message handlers

BOOL CMFCMultithreadingDlg::OnInitDialog() {
   CDialogEx::OnInitDialog();

   // Set the icon for this dialog. The framework does this automatically
   // when the application's main window is not a dialog
   SetIcon(m_hIcon, TRUE);        // Set big icon
   SetIcon(m_hIcon, FALSE);       // Set small icon

   // TODO: Add extra initialization here

   return TRUE; // return TRUE unless you set the focus to a control
}

// If you add a minimize button to your dialog, you will need the code below
// to draw the icon. For MFC applications using the document/view model,
// this is automatically done for you by the framework.

void CMFCMultithreadingDlg::OnPaint() {
   if (IsIconic()) {
      CPaintDC dc(this); // device context for painting
      SendMessage(WM_ICONERASEBKGND,
         reinterpret_cast<WPARAM>(dc.GetSafeHdc()), 0);
			
      // Center icon in client rectangle
      int cxIcon = GetSystemMetrics(SM_CXICON);
      int cyIcon = GetSystemMetrics(SM_CYICON);
      CRect rect;
      GetClientRect(&rect);
      int x = (rect.Width() - cxIcon + 1) / 2;
      int y = (rect.Height() - cyIcon + 1) / 2;

      // Draw the icon
      dc.DrawIcon(x, y, m_hIcon);
   }else {
      CDialogEx::OnPaint();
   }
}
// The system calls this function to obtain the cursor to display while the user drags
// the minimized window.
HCURSOR CMFCMultithreadingDlg::OnQueryDragIcon() {
   return static_cast<HCURSOR>(m_hIcon);
}

UINT /*CThreadDlg::*/MyThreadProc(LPVOID Param) //Sample function for using in
AfxBeginThread {
   while (!stopNow && (currValue < maxValue)) {
      currValue++;
      Sleep(50); // would do some work here
   }
   return TRUE;
}
void CMFCMultithreadingDlg::OnBnClickedButtonStart() {
   // TODO: Add your control notification handler code here
   currValue = 0;
   maxValue = 5000;
   stopNow = 0;
   m_ctrlStatus.SetWindowText(L"Starting...");
   SetTimer(1234, 333, 0); // 3 times per second

   AfxBeginThread(MyThreadProc, 0); // <<== START THE THREAD
}

void CMFCMultithreadingDlg::OnTimer(UINT_PTR nIDEvent) {
   // TODO: Add your message handler code here and/or call default
   CString sStatusMsg;
   sStatusMsg.Format(L"Running: %d", currValue);
   m_ctrlStatus.SetWindowText(sStatusMsg);

   CDialogEx::OnTimer(nIDEvent);
}

void CMFCMultithreadingDlg::OnBnClickedButtonStop() {
   // TODO: Add your control notification handler code here
   stopNow = TRUE;
   KillTimer(1234);
   m_ctrlStatus.SetWindowText(L"Stopped");
}

Step 10 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 11 - अब स्टार्ट थ्रेड बटन पर क्लिक करें।

Step 12- स्टॉप थ्रेड बटन पर क्लिक करें। यह धागा बंद कर देगा।

Microsoft क्लाइंट और सर्वर एप्लिकेशन दोनों की प्रोग्रामिंग के लिए कई एपीआई प्रदान करता है। इंटरनेट के लिए कई नए एप्लिकेशन लिखे जा रहे हैं, और प्रौद्योगिकियों, ब्राउज़र क्षमताओं और सुरक्षा विकल्पों में परिवर्तन के रूप में, नए प्रकार के एप्लिकेशन लिखे जाएंगे। आपका कस्टम एप्लिकेशन इंटरनेट पर जानकारी प्राप्त कर सकता है और डेटा प्रदान कर सकता है।

MFC एक वर्ग प्रदान करता है CSocket विंडोज़ सॉकेट के साथ नेटवर्क संचार कार्यक्रम लिखने के लिए।

यहाँ CSocket वर्ग के तरीकों की एक सूची दी गई है।

अनु क्रमांक। नाम और विवरण
1

Attach

CS सॉकेट ऑब्जेक्ट पर एक सॉकेट हैंडल देता है।

2

CancelBlockingCall

एक अवरुद्ध कॉल रद्द करता है जो इस समय प्रगति पर है।

3

Create

एक सॉकेट बनाता है।

4

FromHandle

SOCKET हैंडल दिए जाने पर एक पॉइंटर को CSocket ऑब्जेक्ट पर लौटाता है।

5

IsBlocking

निर्धारित करता है कि अवरुद्ध कॉल जारी है या नहीं।

आइए, एक एमएफएस एसडीआई एप्लिकेशन बनाकर एक सरल उदाहरण देखें।

Step 1 - नाम क्षेत्र में MFCServer दर्ज करें और ठीक पर क्लिक करें।

Step 2 - एडवांस्ड फीचर्स टैब पर, विंडोज सॉकेट्स विकल्प की जांच करें।

Step 3 - प्रोजेक्ट बनने के बाद, एक नया MFC वर्ग CServerSocket जोड़ें।

Step 4 - बेस क्लास के रूप में सीएसकेट चुनें और फिनिश पर क्लिक करें।

Step 5 - अधिक MFC वर्ग CReceivingSocket जोड़ें।

Step 6 - CRecevingSocket क्लाइंट से आने वाले संदेशों को प्राप्त करेगा।

CMFCServerApp में, हेडर फ़ाइल में निम्न फाइलें शामिल हैं -

#include "ServerSocket.h"
#include "MFCServerView.h"

Step 7 - CMFCServerApp वर्ग में निम्नलिखित दो वर्ग चर जोड़ें।

CServerSocket m_serverSocket;
CMFCServerView m_pServerView;

Step 8 - CMFCServerApp :: InitInstance () विधि में, सॉकेट बनाएं और पोर्ट निर्दिष्ट करें और फिर नीचे बताए अनुसार सुनो विधि को कॉल करें।

m_serverSocket.Create(6666);
m_serverSocket.Listen();

Step 9 - CMFCServerView हेडर फाइल में निम्नलिखित हेडर फाइल शामिल करें।

#include "MFCServerDoc.h"

Step 10 - सॉकेट क्लास से OnAccept फ़ंक्शन को ओवरराइड करें।

Step 11- वर्ग दृश्य में CServerSocket और गुण विंडो में हाइलाइट किए गए आइकन का चयन करें। अब, OnAccept जोड़ें। यहाँ OnAccept फ़ंक्शन का कार्यान्वयन है।

void CServerSocket::OnAccept(int nErrorCode) {

   // TODO: Add your specialized code here and/or call the base class
   AfxMessageBox(L"Connection accepted");
   CSocket::OnAccept(nErrorCode);
}

Step 12 - OnReceive () फ़ंक्शन जोड़ें।

void CServerSocket::OnReceive(int nErrorCode) { 
   
   // TODO: Add your specialized code here and/or call the base class
   AfxMessageBox(L"Data Received");
   CSocket::OnReceive(nErrorCode);
}

Step 13 - CReceivingSocket क्लास में OnReceive () फंक्शन जोड़ें।

समाधान एक्सप्लोरर में CMFCServerView वर्ग पर राइट-क्लिक करें और Add → AddFunction का चयन करें।

Step 14 - ऊपर दी गई जानकारी दर्ज करें और फिनिश पर क्लिक करें।

Step 15 - CMFCServerView हैडर फ़ाइल में निम्नलिखित CStringArray वैरिएबल जोड़ें।

CStringArray m_msgArray;

Step 16 - यहाँ AddMsg () फ़ंक्शन का कार्यान्वयन है।

void CMFCServerView::AddMsg(CString message) {

   m_msgArray.Add(message);
   Invalidate();
}

Step 17 - कंस्ट्रक्टर को अपडेट करें जैसा कि निम्नलिखित कोड में दिखाया गया है।

CMFCServerView::CMFCServerView() {

   ((CMFCServerApp*)AfxGetApp()) -> m_pServerView = this;
}

Step 18 - यहाँ OnDraw () फ़ंक्शन का कार्यान्वयन है, जो संदेश प्रदर्शित करता है।

void CMFCServerView::OnDraw(CDC* pDC) {

   int y = 100;
   for (int i = 0; m_msgArray.GetSize(); i++) {
   
      pDC->TextOut(100, y, m_msgArray.GetAt(i));
      y += 50;
   }
   CMFCServerDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

Step 19- सर्वर साइड अब पूरा हो गया है। यह क्लाइंट से संदेश प्राप्त करेगा।

क्लाइंट साइड एप्लिकेशन बनाएं

Step 1 - क्लाइंट साइड एप्लिकेशन के लिए नया MFC संवाद आधारित एप्लिकेशन बनाएं।

Step 2 - उन्नत सुविधाओं टैब पर, ऊपर दिखाए गए अनुसार विंडोज सॉकेट्स विकल्प की जांच करें।

Step 3 - प्रोजेक्ट बन जाने के बाद, अपने संवाद बॉक्स को डिज़ाइन करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

Step 4 - कनेक्ट और भेजें बटन के लिए घटना संचालकों जोड़ें।

Step 5- सभी तीन संपादन नियंत्रणों के लिए मूल्य चर जोड़ें। पोर्ट एडिट कंट्रोल के लिए, वेरिएबल टाइप UINT को चुनें।

Step 6 - संदेश जोड़ने और भेजने के लिए MFC वर्ग जोड़ें।

Step 7- शीर्ष लेख फ़ाइल CMFCClientDemoApp वर्ग में CClientSocket वर्ग की हेडर फ़ाइल शामिल करें और वर्ग चर जोड़ें। इसी तरह, CMFCClientDemoDlg हेडर फ़ाइल में वर्ग चर को भी जोड़ें।

CClientSocket m_clientSocket;

Step 8 - यहां कनेक्ट बटन इवेंट हैंडलर का कार्यान्वयन है।

void CMFCClientDemoDlg::OnBnClickedButtonConnect() {

   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   m_clientSocket.Create();
   if (m_clientSocket.Connect(m_ipAddress, m_port)) {
      AfxMessageBox(L"Connection Successfull");
   }else {
      AfxMessageBox(L"Connection Failed");
   }
   DWORD error = GetLastError();
}

Step 9 - यहां सेंड बटन इवेंट हैंडलर का कार्यान्वयन है।

void CMFCClientDemoDlg::OnBnClickedButtonSend() {

   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   if (m_clientSocket.Send(m_message.GetBuffer(m_message.GetLength()), m_message.GetLength())) {
   
   }else {
      AfxMessageBox(L"Failed to send message");
   }
}

Step 10- सबसे पहले सर्वर एप्लिकेशन और फिर क्लाइंट एप्लिकेशन को चलाएं। स्थानीय होस्ट आईपी और पोर्ट दर्ज करें और कनेक्ट पर क्लिक करें।

Step 11 - अब आपको सर्वर की तरफ का संदेश दिखाई देगा जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

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

चित्रकारी

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

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

CDCMFC में आकर्षित करने वाला सबसे मौलिक वर्ग है। सीडीसी ऑब्जेक्ट मूल ड्राइंग चरणों को निष्पादित करने के लिए सदस्य कार्य प्रदान करता है, साथ ही साथ सदस्य एक खिड़की के क्लाइंट क्षेत्र से जुड़े प्रदर्शन संदर्भ के साथ काम करने के लिए प्रदान करता है।

अनु क्रमांक। नाम और विवरण
1

AbortDoc

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

2

AbortPath

डिवाइस के संदर्भ में किसी भी पथ को बंद और डिस्क्राइब करता है।

3

AddMetaFileComment

एक बफ़र से टिप्पणी को एक निर्दिष्ट एन्हांस्ड-स्वरूप मेटाफ़ाइल में कॉपी करता है।

4

AlphaBlend

ऐसे बिटमैप्स प्रदर्शित करता है जिनमें पारदर्शी या सेमीट्रांसपेरेंट पिक्सेल होते हैं।

5

AngleArc

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

6

Arc

एक अण्डाकार चाप खींचता है।

7

ArcTo

एक अण्डाकार चाप खींचता है। यह फ़ंक्शन आर्क के समान है, सिवाय इसके कि वर्तमान स्थिति अपडेट की गई है।

8

Attach

इस CDC ऑब्जेक्ट के लिए एक Windows डिवाइस संदर्भ देता है।

9

BeginPath

डिवाइस के संदर्भ में एक पथ कोष्ठक खोलता है।

10

BitBlt

एक निर्दिष्ट डिवाइस के संदर्भ से एक बिटमैप की प्रतिलिपि बनाता है।

1 1

Chord

एक राग (एक दीर्घवृत्त और एक पंक्ति खंड के प्रतिच्छेदन से घिरा एक बंद आकृति) खींचता है।

12

CloseFigure

एक रास्ते में एक खुला आंकड़ा बंद कर देता है।

13

CreateCompatibleDC

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

14

CreateDC

एक विशिष्ट उपकरण के लिए एक उपकरण संदर्भ बनाता है।

15

CreateIC

एक विशिष्ट डिवाइस के लिए एक सूचना संदर्भ बनाता है। यह डिवाइस का संदर्भ बनाए बिना डिवाइस के बारे में जानकारी प्राप्त करने का एक तेज़ तरीका प्रदान करता है।

16

DeleteDC

इस सीडीसी ऑब्जेक्ट से जुड़े विंडोज डिवाइस के संदर्भ को हटाता है।

17

DeleteTempMap

द्वारा बुलाया गया CWinAppनिष्क्रिय-समय हैंडलर FromHandle द्वारा बनाई गई किसी भी अस्थायी सीडीसी ऑब्जेक्ट को हटाने के लिए। डिवाइस संदर्भ को भी अलग कर देता है।

18

Detach

इस CDC ऑब्जेक्ट से Windows डिवाइस संदर्भ को अलग करता है।

19

DPtoHIMETRIC

डिवाइस इकाइयों में परिवर्तित करता है HIMETRIC इकाइयों।

20

DPtoLP

डिवाइस इकाइयों को तार्किक इकाइयों में परिवर्तित करता है।

21

Draw3dRect

एक त्रि-आयामी आयत खींचता है।

22

DrawDragRect

एक आयत को मिटाता है और मिटाता है क्योंकि इसे खींचा जाता है।

23

DrawEdge

एक आयत के किनारों को खींचता है।

24

DrawEscape

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

25

DrawFocusRect

फोकस इंगित करने के लिए उपयोग की जाने वाली शैली में एक आयत खींचता है।

26

DrawFrameControl

एक फ्रेम नियंत्रण ड्रा।

27

DrawIcon

एक आइकन बनाता है।

28

DrawState

एक छवि प्रदर्शित करता है और एक राज्य को इंगित करने के लिए एक दृश्य प्रभाव लागू करता है।

29

DrawText

निर्दिष्ट आयत में स्वरूपित पाठ खींचता है।

30

DrawTextEx

अतिरिक्त स्वरूपों का उपयोग करके निर्दिष्ट आयत में स्वरूपित पाठ को खींचता है।

31

Ellipse

एक दीर्घवृत्त खींचता है।

32

EndDoc

StartDoc सदस्य फ़ंक्शन द्वारा शुरू किया गया एक प्रिंट कार्य समाप्त करता है।

33

EndPage

डिवाइस ड्राइवर को सूचित करता है कि एक पृष्ठ समाप्त हो रहा है।

34

EndPath

एक पथ कोष्ठक को बंद करता है और डिवाइस के संदर्भ में ब्रैकेट द्वारा परिभाषित पथ का चयन करता है।

35

EnumObjects

एक उपकरण के संदर्भ में उपलब्ध कलम और ब्रश की गणना करता है।

36

Escape

एप्लिकेशन को उन सुविधाओं तक पहुंचने की अनुमति देता है जो GDI के माध्यम से किसी विशेष उपकरण से सीधे उपलब्ध नहीं हैं। इसके अलावा विंडोज भागने के कार्यों के लिए उपयोग की अनुमति देता है। एप्लिकेशन द्वारा किए गए एस्केप कॉल का अनुवाद किया जाता है और डिवाइस ड्राइवर को भेजा जाता है।

37

ExcludeClipRect

एक नया क्लिपिंग क्षेत्र बनाता है जिसमें मौजूदा क्लिपिंग क्षेत्र होता है जो निर्दिष्ट आयत को घटाता है।

38

ExcludeUpdateRgn

क्लिपिंग क्षेत्र से विंडो में एक अद्यतन क्षेत्र को छोड़कर खिड़की के अवैध क्षेत्रों के भीतर ड्राइंग को रोकता है।

39

ExtFloodFill

वर्तमान ब्रश के साथ एक क्षेत्र को भरता है। से अधिक लचीलापन प्रदान करता हैFloodFill सदस्य समारोह।

40

ExtTextOut

वर्तमान में चयनित फ़ॉन्ट का उपयोग करते हुए एक आयताकार क्षेत्र के भीतर एक वर्ण स्ट्रिंग लिखता है।

41

FillPath

वर्तमान पथ में किसी भी खुले आंकड़े को बंद करता है और वर्तमान ब्रश और पॉलीगोनफिलिंग मोड का उपयोग करके पथ के आंतरिक को भरता है।

42

FillRect

एक विशिष्ट ब्रश का उपयोग करके दिए गए आयत को भरता है।

43

FillRgn

निर्दिष्ट ब्रश के साथ एक विशिष्ट क्षेत्र को भरता है।

44

FillSolidRect

एक ठोस रंग के साथ एक आयत भरता है।

45

FlattenPath

वर्तमान डिवाइस संदर्भ में चयनित पथ में किसी भी घटता को रूपांतरित करता है, और प्रत्येक वक्र को लाइनों के अनुक्रम में बदल देता है।

46

FloodFill

वर्तमान ब्रश के साथ एक क्षेत्र को भरता है।

47

FrameRect

एक आयत के चारों ओर एक सीमा खींचता है।

48

FrameRgn

ब्रश का उपयोग करके एक विशिष्ट क्षेत्र के चारों ओर एक सीमा खींचता है।

49

FromHandle

डिवाइस के संदर्भ में हैंडल दिए जाने पर सीडीसी ऑब्जेक्ट के लिए एक पॉइंटर लौटाता है। यदि CDC ऑब्जेक्ट हैंडल से जुड़ा नहीं है, तो एक अस्थायी CDC ऑब्जेक्ट बनाया और संलग्न है।

50

GetArcDirection

डिवाइस के संदर्भ के लिए वर्तमान आर्क दिशा देता है।

51

GetAspectRatioFilter

वर्तमान पहलू-अनुपात फ़िल्टर के लिए सेटिंग को पुनः प्राप्त करता है।

52

GetBkColor

वर्तमान पृष्ठभूमि के रंग को पुनः प्राप्त करता है।

53

GetBkMode

पृष्ठभूमि मोड को पुनर्प्राप्त करता है।

54

GetBoundsRect

निर्दिष्ट डिवाइस संदर्भ के लिए वर्तमान संचित बाउंडिंग आयत लौटाता है।

55

GetBrushOrg

वर्तमान ब्रश की उत्पत्ति को पुनः प्राप्त करता है।

56

GetCharABCWidths

वर्तमान फ़ॉन्‍ट से दी गई श्रेणी में, निरंतर वर्णों की, तार्किक इकाइयों में, चौड़ाई को पुनः प्राप्त करता है।

57

GetCharABCWidthsI

वर्तमान ट्रू टाइप फ़ॉन्ट से एक निर्दिष्ट सीमा में लगातार ग्लिफ़ सूचकांकों की तार्किक इकाइयों में चौड़ाई निकालता है।

58

GetCharacterPlacement

एक चरित्र स्ट्रिंग पर विभिन्न प्रकार की जानकारी प्राप्त करता है।

59

GetCharWidth

वर्तमान फ़ॉन्ट से दी गई श्रेणी में लगातार वर्णों की भिन्नात्मक चौड़ाई को हटाता है।

60

GetCharWidthI

वर्तमान फॉन्ट से एक निर्दिष्ट सीमा में लगातार ग्लिफ़ सूचकांकों के तार्किक निर्देशांक में चौड़ाई को हटाता है।

61

GetClipBox

वर्तमान क्लिपिंग सीमा के चारों ओर सबसे तंग बाउंडिंग आयत के आयामों को पुनः प्राप्त करता है।

62

GetColorAdjustment

डिवाइस के संदर्भ के लिए रंग समायोजन मूल्यों को पुनः प्राप्त करता है।

63

GetCurrentBitmap

वर्तमान में चयनित एक पॉइंटर लौटाता है CBitmap वस्तु।

64

GetCurrentBrush

वर्तमान में चयनित एक पॉइंटर लौटाता है CBrush वस्तु।

65

GetCurrentFont

वर्तमान में चयनित एक पॉइंटर लौटाता है CFont वस्तु।

66

GetCurrentPalette

वर्तमान में चयनित एक पॉइंटर लौटाता है CPalette वस्तु।

48

GetCurrentPen

वर्तमान में चयनित एक पॉइंटर लौटाता है CPen वस्तु।

67

GetCurrentPosition

कलम की वर्तमान स्थिति (तार्किक निर्देशांक में) को पुनः प्राप्त करता है।

68

GetDCBrushColor

वर्तमान ब्रश रंग को पुनः प्राप्त करता है।

69

GetDCPenColor

वर्तमान कलम रंग को पुनः प्राप्त करता है।

70

GetDeviceCaps

किसी दिए गए प्रदर्शन डिवाइस की क्षमताओं के बारे में एक विशेष प्रकार की डिवाइस-विशिष्ट जानकारी को पुनर्प्राप्त करता है।

71

GetFontData

एक स्केलेबल फ़ॉन्ट फ़ाइल से फ़ॉन्ट मीट्रिक जानकारी पुनर्प्राप्त करता है। पुनर्प्राप्त करने के लिए जानकारी फ़ॉन्ट फ़ाइल में एक ऑफसेट निर्दिष्ट करके और लौटने के लिए जानकारी की लंबाई के द्वारा पहचाना जाता है।

72

GetFontLanguageInfo

निर्दिष्ट प्रदर्शन संदर्भ के लिए वर्तमान में चयनित फ़ॉन्ट के बारे में जानकारी देता है।

73

GetGlyphOutline

वर्तमान फ़ॉन्ट में एक बाह्यरेखा वर्ण के लिए रूपरेखा वक्र या बिटमैप को पुनः प्राप्त करता है।

74

GetGraphicsMode

निर्दिष्ट डिवाइस संदर्भ के लिए वर्तमान ग्राफिक्स मोड को पुनः प्राप्त करता है।

75

GetHalftoneBrush

हलफ़टोन ब्रश को पुनः प्राप्त करता है।

76

GetKerningPairs

वर्तमान में निर्दिष्ट डिवाइस संदर्भ में चुने गए फ़ॉन्ट के लिए वर्ण कर्लिंग जोड़े को पुनः प्राप्त करता है।

77

GetLayout

डिवाइस संदर्भ (DC) के लेआउट को पुनर्प्राप्त करता है। लेआउट या तो दाएं से बाएं (डिफ़ॉल्ट) या दाएं से बाएं (मिरर किए हुए) हो सकते हैं।

78

GetMapMode

वर्तमान मानचित्रण मोड को पुनः प्राप्त करता है।

79

GetMiterLimit

डिवाइस के संदर्भ के लिए मैटर सीमा लौटाता है।

80

GetNearestColor

निकटतम तार्किक रंग को एक निर्दिष्ट तार्किक रंग से हटाता है जो दिए गए डिवाइस का प्रतिनिधित्व कर सकता है।

81

GetOutlineTextMetrics

TrueType फोंट के लिए फ़ॉन्ट मीट्रिक जानकारी पुनर्प्राप्त करता है।

82

GetOutputCharWidth

आउटपुट डिवाइस संदर्भ का उपयोग करके वर्तमान फ़ॉन्ट से वर्णों के एक समूह में अलग-अलग वर्णों की चौड़ाई निकालता है।

83

GetOutputTabbedTextExtent

आउटपुट डिवाइस संदर्भ पर एक चरित्र स्ट्रिंग की चौड़ाई और ऊंचाई की गणना करता है।

84

GetOutputTextExtent

आयामों को निर्धारित करने के लिए वर्तमान फ़ॉन्ट का उपयोग करके आउटपुट डिवाइस संदर्भ पर पाठ की एक पंक्ति की चौड़ाई और ऊंचाई की गणना करता है।

85

GetOutputTextMetrics

आउटपुट डिवाइस संदर्भ से वर्तमान फ़ॉन्ट के लिए मैट्रिक्स को पुनर्प्राप्त करता है।

86

GetPath

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

87

GetPixel

निर्दिष्ट बिंदु पर पिक्सेल के RGB रंग मान को पुनः प्राप्त करता है।

88

GetPolyFillMode

वर्तमान बहुभुज-भरने मोड को पुनः प्राप्त करता है।

89

GetROP2

वर्तमान ड्राइंग मोड को पुनः प्राप्त करता है।

90

GetSafeHdc

रिटर्न m_hDC, आउटपुट डिवाइस संदर्भ।

91

GetStretchBltMode

वर्तमान बिटमैप-स्ट्रेचिंग मोड को पुनः प्राप्त करता है।

92

GetTabbedTextExtent

विशेषता डिवाइस संदर्भ पर एक चरित्र स्ट्रिंग की चौड़ाई और ऊंचाई की गणना करता है।

93

GetTextAlign

पाठ-संरेखण झंडे को पुनः प्राप्त करता है।

94

GetTextCharacterExtra

इंटरचैकर रिक्ति की मात्रा के लिए वर्तमान सेटिंग को पुनर्प्राप्त करता है।

95

GetTextColor

वर्तमान पाठ रंग को पुनः प्राप्त करता है।

96

GetTextExtent

आयामों को निर्धारित करने के लिए वर्तमान फ़ॉन्ट का उपयोग करके विशेषता डिवाइस संदर्भ पर पाठ की एक पंक्ति की चौड़ाई और ऊंचाई की गणना करता है।

97

GetTextExtentExPointI

एक निर्दिष्ट स्ट्रिंग में वर्णों की संख्या को पुनर्प्राप्त करता है जो एक निर्दिष्ट स्थान के भीतर फिट होगा और उन वर्णों में से प्रत्येक के लिए पाठ सीमा के साथ एक सरणी भरता है।

98

GetTextExtentPointI

ग्लिफ़ सूचकांकों के निर्दिष्ट सरणी की चौड़ाई और ऊँचाई को पुनः प्राप्त करता है।

99

GetTextFace

वर्तमान फ़ॉन्ट के टाइपफेस नाम को एक शून्य-समाप्त स्ट्रिंग के रूप में बफर में कॉपी करता है।

100

GetTextMetrics

विशेषता डिवाइस संदर्भ से वर्तमान फ़ॉन्ट के लिए मैट्रिक्स को पुनर्प्राप्त करता है।

101

GetViewportExt

व्यूपोर्ट के x- और y- extents को पुनः प्राप्त करता है।

102

GetViewportOrg

व्यूपोर्ट मूल के x- और y- निर्देशांक को पुनः प्राप्त करता है।

103

GetWindow

डिस्प्ले डिवाइस के संदर्भ से जुड़ी विंडो को लौटाता है।

104

GetWindowExt

संबंधित विंडो के x- और y- extents को पुनः प्राप्त करता है।

105

GetWindowOrg

संबंधित विंडो की उत्पत्ति के x- और y- निर्देशांक को पुनर्प्राप्त करता है।

106

GetWorldTransform

वर्तमान विश्व-स्थान को पृष्ठ-स्थान परिवर्तन के लिए पुनः प्राप्त करता है।

107

GradientFill

एक आयताकार रंग के साथ आयत और त्रिभुज संरचनाओं को भरता है।

108

GrayString

दिए गए स्थान पर मंद (धूसर) पाठ खींचता है।

109

HIMETRICtoDP

डिवाइस इकाइयों में HIMETRIC इकाइयों को परिवर्तित करता है।

110

HIMETRICtoLP

HIMETRIC इकाइयों को तार्किक इकाइयों में परिवर्तित करता है।

111

IntersectClipRect

वर्तमान क्षेत्र और एक आयत के चौराहे का निर्माण करके एक नया कतरन क्षेत्र बनाता है।

112

InvertRect

एक आयत की सामग्री को सम्मिलित करता है।

113

InvertRgn

एक क्षेत्र में रंगों को सम्मिलित करता है।

114

IsPrinting

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

115

LineTo

वर्तमान स्थिति से एक रेखा खींचता है, लेकिन शामिल नहीं है, एक बिंदु।

116

LPtoDP

तार्किक इकाइयों को उपकरण इकाइयों में परिवर्तित करता है।

117

LPtoHIMETRIC

तार्किक इकाइयों को HIMETRIC इकाइयों में परिवर्तित करता है।

118

MaskBlt

दिए गए मास्क और रेखापुंज ऑपरेशन का उपयोग करके स्रोत और गंतव्य बिटमैप के लिए रंग डेटा को जोड़ता है।

119

ModifyWorldTransform

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

120

MoveTo

वर्तमान स्थिति को बढ़ाता है।

121

OffsetClipRgn

दिए गए डिवाइस के क्लिपिंग क्षेत्र को स्थानांतरित करता है।

122

OffsetViewportOrg

वर्तमान व्यूपोर्ट मूल के निर्देशांक के सापेक्ष व्यूपोर्ट मूल को संशोधित करता है।

123

OffsetWindowOrg

वर्तमान विंडो मूल के निर्देशांक के सापेक्ष विंडो मूल को संशोधित करता है।

124

PaintRgn

चयनित ब्रश के साथ एक क्षेत्र भरता है।

125

PatBlt

थोड़ा पैटर्न बनाता है।

126

Pie

पाई के आकार का पच्चर खींचता है।

127

PlayMetaFile

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

128

PlgBlt

स्रोत डिवाइस के संदर्भ में निर्दिष्ट आयत से रंगीन डेटा के बिट्स के बिट-ब्लॉक हस्तांतरण को दिए गए डिवाइस संदर्भ में निर्दिष्ट समांतरलोग्राम पर करता है।

129

PolyBezier

एक या एक से अधिक बेज़ियर विभाजन खींचता है। वर्तमान स्थिति का न तो उपयोग किया गया है और न ही अद्यतन किया गया है।

130

PolyBezierTo

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

131

PolyDraw

लाइन सेगमेंट और बेज़ियर स्प्लिन का एक सेट बनाता है। यह फ़ंक्शन वर्तमान स्थिति को अपडेट करता है।

132

Polygon

एक बहुभुज खींचता है जिसमें दो या दो से अधिक बिंदु (कोने) होते हैं जो लाइनों द्वारा जुड़े होते हैं।

133

Polyline

निर्दिष्ट बिंदुओं को जोड़ने वाले लाइन खंडों का एक समूह बनाता है।

134

PolylineTo

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

135

PolyPolygon

दो या अधिक बहुभुज बनाता है जो वर्तमान बहुभुज-भरने मोड का उपयोग करके भरे जाते हैं। बहुभुज असंतुष्ट हो सकते हैं या वे ओवरलैप हो सकते हैं।

136

PolyPolyline

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

137

PtVisible

निर्दिष्ट करता है कि दिए गए बिंदु क्लिपिंग क्षेत्र के भीतर है या नहीं।

138

RealizePalette

वर्तमान पैलेट में सिस्टम पैलेट में मैप्स पैलेट प्रविष्टियां।

139

Rectangle

वर्तमान पेन का उपयोग करके एक आयत खींचता है और इसे वर्तमान ब्रश का उपयोग करके भरता है।

140

RectVisible

निर्धारित करता है कि दिए गए आयत का कोई हिस्सा कतरन क्षेत्र के भीतर है या नहीं।

141

ReleaseAttribDC

विज्ञप्ति m_hAttribDC, विशेषता डिवाइस संदर्भ।

142

ReleaseOutputDC

विज्ञप्ति m_hDC, आउटपुट डिवाइस संदर्भ।

143

ResetDC

M_hAttribDC डिवाइस संदर्भ को अद्यतन करता है।

144

RestoreDC

के साथ सहेजे गए किसी पूर्व स्थिति के लिए डिवाइस संदर्भ पुनर्स्थापित करता है SaveDC

145

RoundRect

वर्तमान कलम का उपयोग करके गोल कोनों के साथ एक आयत खींचता है और वर्तमान ब्रश का उपयोग करके भरा जाता है।

146

SaveDC

डिवाइस के संदर्भ की वर्तमान स्थिति को बचाता है।

147

ScaleViewportExt

वर्तमान मूल्यों के सापेक्ष व्यूपोर्ट सीमा को संशोधित करता है।

148

ScaleWindowExt

खिड़की मौजूदा मूल्यों के सापेक्ष विस्तार करती है।

149

ScrollDC

क्षैतिज और लंबवत रूप से बिट्स की एक आयत को स्क्रॉल करता है।

150

SelectClipPath

डिवाइस के संदर्भ के लिए क्लिपिंग क्षेत्र के रूप में वर्तमान पथ का चयन करता है, निर्दिष्ट मोड का उपयोग करके किसी भी मौजूदा क्लिपिंग क्षेत्र के साथ नए क्षेत्र का संयोजन करता है।

151

SelectClipRgn

निर्दिष्ट मोड का उपयोग करके दिए गए क्षेत्र को वर्तमान क्लिपिंग क्षेत्र के साथ जोड़ता है।

152

SelectObject

एक GDI ड्राइंग ऑब्जेक्ट जैसे पेन का चयन करता है।

153

SelectPalette

तार्किक पैलेट का चयन करता है।

154

SelectStockObject

विंडोज द्वारा प्रदान किए गए पूर्वनिर्धारित स्टॉक पेन, ब्रश या फोंट में से एक का चयन करता है।

155

SetAbortProc

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

156

SetArcDirection

आर्क और आयत कार्यों के लिए उपयोग की जाने वाली ड्राइंग दिशा निर्धारित करता है।

157

SetAttribDC

सेट m_hAttribDC, विशेषता डिवाइस संदर्भ।

158

SetBkColor

वर्तमान पृष्ठभूमि का रंग सेट करता है।

159

SetBkMode

बैकग्राउंड मोड सेट करता है।

160

SetBoundsRect

निर्दिष्ट डिवाइस संदर्भ के लिए बाउंडिंग-आयत जानकारी के संचय को नियंत्रित करता है।

161

SetBrushOrg

डिवाइस संदर्भ में चयनित अगले ब्रश के लिए मूल निर्दिष्ट करता है।

162

SetColorAdjustment

निर्दिष्ट मूल्यों का उपयोग करके डिवाइस के संदर्भ के लिए रंग समायोजन मान सेट करता है।

163

SetDCBrushColor

वर्तमान ब्रश रंग सेट करता है।

164

SetDCPenColor

वर्तमान पेन रंग सेट करता है।

165

SetGraphicsMode

निर्दिष्ट डिवाइस संदर्भ के लिए वर्तमान ग्राफिक्स मोड सेट करता है।

166

SetLayout

डिवाइस संदर्भ (DC) के लेआउट को बदलता है।

167

SetMapMode

वर्तमान मैपिंग मोड सेट करता है।

168

SetMapperFlags

फोंट मैपर का उपयोग करने वाले एल्गोरिथ्म को बदल देता है जब यह तार्किक फोंट को भौतिक फोंट में मैप करता है।

169

SetMiterLimit

डिवाइस संदर्भ के लिए मैटर की लंबाई की सीमा निर्धारित होती है।

170

SetOutputDC

M_hDC, आउटपुट डिवाइस संदर्भ सेट करता है।

171

SetPixel

निर्दिष्ट रंग के निकटतम सन्निकटन के लिए निर्दिष्ट बिंदु पर पिक्सेल सेट करता है।

172

SetPixelV

निर्दिष्ट रंग के निकटतम सन्निकटन के लिए निर्दिष्ट निर्देशांक पर पिक्सेल सेट करता है। SetPixelV से तेज है SetPixel क्योंकि यह वास्तव में चित्रित बिंदु के रंग मूल्य को वापस करने की आवश्यकता नहीं है।

173

SetPolyFillMode

बहुभुज-भरने मोड सेट करता है।

175

SetROP2

वर्तमान ड्राइंग मोड सेट करता है।

176

SetStretchBltMode

बिटमैप-स्ट्रेचिंग मोड सेट करता है।

177

SetTextAlign

पाठ-संरेखण झंडे सेट करता है।

178

SetTextCharacterExtra

इंटरचैकर रिक्ति की मात्रा निर्धारित करता है।

179

SetTextColor

पाठ का रंग सेट करता है।

180

SetTextJustification

एक स्ट्रिंग में वर्णों के लिए स्थान जोड़ता है।

181

SetViewportExt

व्यूपोर्ट के x- और y-extents सेट करता है।

182

SetViewportOrg

व्यूपोर्ट मूल सेट करता है।

183

SetWindowExt

संबंधित विंडो के x- और y- extents सेट करता है।

184

SetWindowOrg

डिवाइस संदर्भ की विंडो मूल सेट करता है।

185

SetWorldTransform

वर्तमान विश्व-स्थान को पृष्ठ-स्थान परिवर्तन पर सेट करता है।

186

StartDoc

डिवाइस ड्राइवर को सूचित करता है कि एक नया प्रिंट कार्य शुरू हो रहा है।

187

StartPage

डिवाइस ड्राइवर को सूचित करता है कि एक नया पृष्ठ शुरू हो रहा है।

188

StretchBlt

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

189

StrokeAndFillPath

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

190

StrokePath

वर्तमान पेन का उपयोग करके निर्दिष्ट पथ रेंडर करें।

191

TabbedTextOut

एक निर्दिष्ट स्थान पर एक वर्ण स्ट्रिंग लिखता है, टैब-स्टॉप पदों की एक सरणी में निर्दिष्ट मानों के लिए टैब का विस्तार करता है।

192

TextOut

वर्तमान में चयनित फ़ॉन्ट का उपयोग करके एक निर्दिष्ट स्थान पर एक चरित्र स्ट्रिंग लिखता है।

193

TransparentBlt

निर्दिष्ट स्रोत डिवाइस संदर्भ से रंग डेटा के बिट-ब्लॉक को एक गंतव्य डिवाइस संदर्भ में स्थानांतरित करता है, स्थानांतरण में एक निर्दिष्ट रंग पारदर्शी प्रदान करता है।

194

UpdateColors

एक पिक्सेल-दर-पिक्सेल आधार पर सिस्टम पैलेट में क्लाइंट क्षेत्र में वर्तमान रंगों से मेल करके डिवाइस संदर्भ के क्लाइंट क्षेत्र को अपडेट करता है।

195

WidenPath

वर्तमान पथ को उस क्षेत्र के रूप में फिर से परिभाषित करता है जो कि उस समय चित्रित किया जाएगा जब पथ को डिवाइस के संदर्भ में चयनित पेन का उपयोग करके स्ट्रोक किया गया था।

पंक्तियां

Step 1 - चलिए एक नए MFC आधारित सिंगल डॉक्यूमेंट प्रोजेक्ट के साथ एक सरल उदाहरण देखते हैं MFCGDIDemo नाम दें।

Step 2 - प्रोजेक्ट बन जाने के बाद सॉल्यूशन एक्सप्लोरर पर जाएं और डबल क्लिक करें MFCGDIDemoView.cpp स्रोत फ़ाइलें फ़ोल्डर के अंतर्गत फ़ाइल।

Step 3 - नीचे दिखाए गए अनुसार रेखा खींचें CMFCGDIDemoView::OnDraw() तरीका।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   pDC->MoveTo(95, 125);
   pDC->LineTo(230, 125);
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

Step 4- इस एप्लिकेशन को चलाएं। आप निम्न आउटपुट देखेंगे।

Step 5 - CDC :: MoveTo () विधि का उपयोग लाइन की शुरुआती स्थिति को सेट करने के लिए किया जाता है।

LineTo () का उपयोग करते समय, प्रोग्राम MoveTo () बिंदु से LineTo () छोर पर शुरू होता है।

LineTo () के बाद जब आप MoveTo () को कॉल नहीं करते हैं, और दोबारा LineTo () को अन्य बिंदु मान के साथ कॉल करते हैं, तो प्रोग्राम पिछले LineTo () से नई LineTo () बिंदु तक एक रेखा खींच देगा।

Step 6 - अलग-अलग लाइनें खींचने के लिए, आप इस संपत्ति का उपयोग कर सकते हैं जैसा कि निम्नलिखित कोड में दिखाया गया है।

void CMFCGDIDemoView::OnDraw(CDC* pDC) { 
   pDC->MoveTo(95, 125);
   pDC->LineTo(230, 125);
   pDC->LineTo(230, 225);
   pDC->LineTo(95, 325);
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here 
}

Step 7- इस एप्लिकेशन को चलाएं। आप निम्न आउटपुट देखेंगे।

पॉलीलाइन

polylineकनेक्टेड लाइनों की एक श्रृंखला है। लाइनें POINT या CPoint मानों की एक सरणी में संग्रहीत की जाती हैं। पॉलीलाइन बनाने के लिए, आप CDC :: Polyline () विधि का उपयोग करें। पॉलीलाइन खींचने के लिए कम से कम दो बिंदुओं की आवश्यकता होती है। यदि आप दो से अधिक बिंदुओं को परिभाषित करते हैं, तो पहले के बाद की प्रत्येक पंक्ति पिछले बिंदु से अगले बिंदु तक खींची जाएगी जब तक कि सभी बिंदुओं को शामिल नहीं किया जाता है।

Step 1 - आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   CPoint Pt[7];
   Pt[0] = CPoint(20, 150);
   Pt[1] = CPoint(180, 150);
   Pt[2] = CPoint(180, 20);
   pDC−Polyline(Pt, 3);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

Step 2 - जब आप इस एप्लिकेशन को चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

आयत

rectangleचार भुजाओं से बना एक ज्यामितीय आकृति है जो चार समकोण बनाती है। एक आयत को खींचने के लिए लाइन की तरह, आपको यह परिभाषित करना होगा कि यह कहाँ शुरू होता है और कहाँ समाप्त होता है। आयत बनाने के लिए, आप CDC :: आयत () विधि का उपयोग कर सकते हैं।

Step 1 - आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   pDC->Rectangle(15, 15, 250, 160);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

Step 2 - जब आप इस एप्लिकेशन को चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

वर्गों

square चार भुजाओं से बना एक ज्यामितीय आकृति है जो चार समकोण बनाती है, लेकिन प्रत्येक पक्ष लंबाई में बराबर होना चाहिए।

आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   pDC->Rectangle(15, 15, 250, 250);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

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

पाईज़

pieदीर्घवृत्त के दो हिस्सों से विभाजित एक दीर्घवृत्त का एक अंश होता है, जो दीर्घवृत्त के केंद्र से प्रत्येक तरफ होता है। पाई खींचने के लिए, आप नीचे दिखाए गए अनुसार सीडीसी :: पाई () विधि का उपयोग कर सकते हैं -

BOOL पाई (int X1, int y1, int x2, int y2, int x3, int y3, int x4, int y4);

  • (X1, y1) बिंदु आयत के ऊपरी-बाएं कोने को निर्धारित करता है जिसमें पाई को दर्शाने वाला दीर्घवृत्त फिट बैठता है। (X2, y2) बिंदु आयत का निचला-दायां कोना है।

  • (X3, y3) बिंदु एक डिफ़ॉल्ट वामावर्त दिशा में पाई के शुरुआती कोने को निर्दिष्ट करता है।

  • (X4, y4) बिंदु प्रजाति पाई का अंतिम बिंदु है।

आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   pDC->Pie(40, 20, 226, 144, 155, 32, 202, 115);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

Step 2 - जब आप इस एप्लिकेशन को चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

आर्क्स

एक आर्क एक दीर्घवृत्त का एक भाग या खंड होता है, जिसका अर्थ है एक चाप एक गैर-पूर्ण दीर्घवृत्त है। चाप खींचने के लिए, आप सीडीसी :: आर्क () विधि का उपयोग कर सकते हैं।

BOOL Arc (int X1, int y1, int x2, int y2, int x3, int y3, int x4, int y4);

CDC वर्ग SetArcDirection () विधि से सुसज्जित है।

यहाँ वाक्य रचना है -

int SetArcDirection(int nArcDirection)

अनु क्रमांक। मूल्य और अभिविन्यास
1

AD_CLOCKWISE

आकृति को दक्षिणावर्त खींचा जाता है

2

AD_COUNTERCLOCKWISE

यह आंकड़ा वामावर्त है

Step 1 - आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   pDC->SetArcDirection(AD_COUNTERCLOCKWISE);
   pDC->Arc(20, 20, 226, 144, 202, 115, 105, 32);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

Step 2 - जब आप इस एप्लिकेशन को चलाते हैं, तो आपको निम्न आउटपुट दिखाई देगा।

कॉर्ड्स

हमारे द्वारा अब तक खींची गई चापों को खुले आंकड़े माना जाता है क्योंकि वे एक रेखा से बनी होती हैं जिसमें एक शुरुआत और एक अंत होता है (एक चक्र या एक आयत के विपरीत जो ऐसा नहीं होता है)। एchord एक चाप है जिसके दो सिरे एक सीधी रेखा से जुड़े होते हैं।

कॉर्ड ड्रा करने के लिए, आप CDC :: कॉर्ड () विधि का उपयोग कर सकते हैं।

BOOL कॉर्ड (int X1, int y1, int x2, int y2, int x3, int y3, int x4, int y4);

आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   pDC->SetArcDirection(AD_CLOCKWISE);
   pDC->Chord(20, 20, 226, 144, 202, 115, 105, 32);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

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

इस उदाहरण में चाप दिशा दक्षिणावर्त सेट की गई है।

रंग की

colorएक सबसे मौलिक वस्तु है जो किसी वस्तु की सौंदर्य उपस्थिति को बढ़ाता है। रंग एक गैर-स्थानिक वस्तु है जिसे किसी वस्तु में उसके कुछ दृश्य पहलुओं को संशोधित करने के लिए जोड़ा जाता है। Win32 API के साथ संयुक्त MFC लाइब्रेरी, विभिन्न कार्यों को प्रदान करती है जिनका उपयोग आप रंगों के विभिन्न पहलुओं का लाभ उठाने के लिए कर सकते हैं।

RGB मैक्रो एक फ़ंक्शन की तरह व्यवहार करता है और आपको कॉमा द्वारा अलग किए गए तीन संख्यात्मक मानों को पास करने की अनुमति देता है। प्रत्येक मान 0 और 255 के बीच होना चाहिए जैसा कि निम्नलिखित कोड में दिखाया गया है।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   COLORREF color = RGB(239, 15, 225);
}

आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   COLORREF color = RGB(239, 15, 225);
   pDC->SetTextColor(color);
   pDC->TextOut(100, 80, L"MFC GDI Tutorial", 16);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

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

फोंट्स

CFontएक विंडोज ग्राफिक्स डिवाइस इंटरफेस (GDI) फ़ॉन्ट encapsulate और फ़ॉन्ट में हेरफेर के लिए सदस्य कार्य प्रदान करता है। CFont ऑब्जेक्ट का उपयोग करने के लिए, CFont ऑब्जेक्ट का निर्माण करें और इसे एक विंडोज फ़ॉन्ट संलग्न करें, और फिर फ़ॉन्ट को हेरफेर करने के लिए ऑब्जेक्ट के सदस्य फ़ंक्शन का उपयोग करें।

अनु क्रमांक। नाम और विवरण
1

CreateFont

निर्दिष्ट विशेषताओं के साथ एक CFont शुरू करता है।

2

CreateFontIndirect

में दिए गए विशेषताओं के साथ एक CFont ऑब्जेक्ट को आरम्भ करता है LOGFONT संरचना।

3

CreatePointFont

एक बिंदु के दसवें हिस्से में मापा गया, और टाइपफेस के साथ निर्दिष्ट ऊंचाई के साथ एक CFont शुरू करता है।

4

CreatePointFontIndirect

के समान CreateFontIndirect सिवाय इसके कि फ़ॉन्ट की ऊंचाई को तार्किक इकाइयों के बजाय एक बिंदु के दसवें हिस्से में मापा जाता है।

5

FromHandle

Windows दिए जाने पर CFont ऑब्जेक्ट के लिए एक पॉइंटर लौटाता है HFONT

6

GetLogFont

किसी लॉगफ़ॉन्ट को CFont ऑब्जेक्ट से जुड़े लॉजिकल फॉन्ट की जानकारी भरता है।

आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   CFont font;
   font.CreatePointFont(920, L"Garamond");
   CFont *pFont = pDC->SelectObject(&font);
   COLORREF color = RGB(239, 15, 225);
   pDC->SetTextColor(color);
   pDC->TextOut(100, 80, L"MFC GDI Tutorial", 16);
   pDC->SelectObject(pFont);
   font.DeleteObject();
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
   return;

   // TODO: add draw code for native data here
}

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

कलम

penएक उपकरण है जो एक उपकरण के संदर्भ में लाइनों और घटता को खींचने के लिए उपयोग किया जाता है। ग्राफिक्स प्रोग्रामिंग में, एक आयत या बहुभुज जैसे ज्यामितीय बंद आकार की सीमाओं को खींचने के लिए एक कलम का भी उपयोग किया जाता है। Microsoft Windows दो प्रकार के पेन मानता है -cosmetic तथा geometric

एक पेन को कॉस्मेटिक के रूप में संदर्भित किया जाता है, जब इसे 1 पिक्सेल से कम या उसके बराबर निश्चित चौड़ाई की केवल सरल रेखाएँ खींचने के लिए उपयोग किया जा सकता है। एक पेन ज्यामितीय होता है जब वह विभिन्न चौड़ाई और विभिन्न छोरों को ग्रहण कर सकता है। MFC एक वर्ग प्रदान करता हैCPen जो विंडोज ग्राफिक्स डिवाइस इंटरफेस (GDI) पेन को एनकैप्सुलेट करता है।

अनु क्रमांक। नाम और विवरण
1

CreatePen

निर्दिष्ट शैली, चौड़ाई और ब्रश विशेषताओं के साथ एक तार्किक कॉस्मेटिक या ज्यामितीय कलम बनाता है, और इसे सीपीएन ऑब्जेक्ट में संलग्न करता है।

2

CreatePenIndirect

एक LOGPEN संरचना में दी गई शैली, चौड़ाई और रंग के साथ एक पेन बनाता है, और इसे CPen ऑब्जेक्ट में संलग्न करता है।

3

FromHandle

जब विंडोज दिया जाता है तो एक सीपीएन ऑब्जेक्ट के लिए एक पॉइंटर लौटाता है HPEN

4

GetExtLogPen

एक अंतर्निहित संरचना प्राप्त करता है।

5

GetLogPen

एक लोगो अंतर्निहित संरचना हो जाता है ।

अनु क्रमांक। Name & Description
1

PS_SOLID

एक सतत ठोस रेखा।

2

PS_DASH

धराशायी व्यवधानों के साथ एक सतत रेखा।

3

PS_DOT

हर दूसरे पिक्सेल पर एक डॉट रुकावट के साथ एक लाइन।

4

PS_DASHDOT

वैकल्पिक धराशायी और बिंदीदार बिंदुओं का एक संयोजन।

5

PS_DASHDOTDOT

डैश और डबल बिंदीदार रुकावट का एक संयोजन।

6

PS_NULL

कोई दृश्य रेखा नहीं।

7

PS_INSIDEFRAME

एक बंद आकृति की सीमा के अंदर खींची गई एक रेखा।

आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   CPen pen;
   pen.CreatePen(PS_DASHDOTDOT, 1, RGB(160, 75, 90));
   pDC->SelectObject(&pen);
   pDC->Rectangle(25, 35, 250, 125);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

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

ब्रश

brushएक आरेखण उपकरण है जिसका उपयोग बंद आकार या लाइनों के आंतरिक भाग को भरने के लिए किया जाता है। एक ब्रश पेंट की बाल्टी उठाकर कहीं फेंक देने जैसा व्यवहार करता है। MFC एक वर्ग प्रदान करता हैCBrush जो विंडोज ग्राफिक्स डिवाइस इंटरफेस (GDI) ब्रश को एनकैप्सुलेट करता है।

अनु क्रमांक। नाम और विवरण
1

CreateBrushIndirect

एक LOGBRUSH संरचना में निर्दिष्ट शैली, रंग और पैटर्न के साथ एक ब्रश को प्रारंभ करता है।

2

CreateDIBPatternBrush

डिवाइस-स्वतंत्र बिटमैप (DIB) द्वारा निर्दिष्ट पैटर्न के साथ एक ब्रश को प्रारंभ करता है।

3

CreateHatchBrush

निर्दिष्ट हैचर्ड पैटर्न और रंग के साथ एक ब्रश को प्रारंभ करता है।

4

CreatePatternBrush

एक बिटमैप द्वारा निर्दिष्ट पैटर्न के साथ एक ब्रश को प्रारंभ करता है।

5

CreateSolidBrush

निर्दिष्ट ठोस रंग के साथ एक ब्रश को प्रारंभ करता है।

6

CreateSysColorBrush

एक ब्रश बनाता है जो डिफ़ॉल्ट सिस्टम रंग है।

7

FromHandle

Windows HBRUSH ऑब्जेक्ट के लिए हैंडल दिए जाने पर CBrush ऑब्जेक्ट के लिए एक पॉइंटर लौटाता है।

8

GetLogBrush

एक लोगो संरचना बन जाता है।

आइए एक सरल उदाहरण देखें।

void CMFCGDIDemoView::OnDraw(CDC* pDC) {
   CBrush brush(RGB(100, 150, 200));
   CBrush *pBrush = pDC->SelectObject(&brush);
   pDC->Rectangle(25, 35, 250, 125);
   pDC->SelectObject(pBrush);
   
   CMFCGDIDemoDoc* pDoc = GetDocument();
   ASSERT_VALID(pDoc);
   if (!pDoc)
      return;

   // TODO: add draw code for native data here
}

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

libraryफ़ंक्शंस, क्लासेस, या अन्य संसाधनों का एक समूह है जो उन कार्यक्रमों के लिए उपलब्ध कराया जा सकता है जिन्हें इन कार्यों, कक्षाओं, या संसाधनों को बनाने की आवश्यकता के बिना पहले से ही कार्यान्वित संस्थाओं की आवश्यकता है या वे कैसे कार्य करते हैं। एक पुस्तकालय एक प्रोग्रामर के लिए किसी अन्य व्यक्ति या कंपनी द्वारा बनाए गए कार्यों, कक्षाओं और संसाधनों आदि का उपयोग करना आसान बनाता है और विश्वास करता है कि यह बाहरी स्रोत विश्वसनीय और कुशल है। पुस्तकालयों से संबंधित कुछ अनूठी विशेषताएं हैं -

  • एक पुस्तकालय बनाया जाता है और एक सामान्य नियमित कार्यक्रम की तरह कार्य करता है, कार्यों या अन्य संसाधनों का उपयोग करता है और अन्य कार्यक्रमों के साथ संचार करता है।

  • अपनी कार्यक्षमता को लागू करने के लिए, एक पुस्तकालय में ऐसे कार्य होते हैं जिन्हें अन्य कार्यक्रमों को अपनी कार्यक्षमता को पूरा करने की आवश्यकता होती है।

  • उसी समय, एक पुस्तकालय कुछ कार्यों का उपयोग कर सकता है जिन्हें अन्य कार्यक्रमों की आवश्यकता नहीं होगी।

  • पुस्तकालय का उपयोग करने वाले कार्यक्रम को पुस्तकालय के ग्राहक भी कहा जाता है।

आपके पुस्तकालयों में दो प्रकार के कार्य होंगे जो आप बनाएंगे या शामिल करेंगे -

  • एक आंतरिक फ़ंक्शन केवल लाइब्रेरी द्वारा ही उपयोग किया जाता है और लाइब्रेरी के ग्राहकों को इन कार्यों तक पहुंच की आवश्यकता नहीं होगी।

  • बाहरी कार्य वे होते हैं जिन्हें पुस्तकालय के ग्राहकों द्वारा पहुँचा जा सकता है।

पुस्तकालयों की दो व्यापक श्रेणियां हैं जिनसे आप अपने कार्यक्रमों में निपटेंगे -

  • स्थैतिक पुस्तकालय
  • गतिशील पुस्तकालय

स्टेटिक लाइब्रेरी

static libraryएक ऐसी फ़ाइल है जिसमें फ़ंक्शंस, कक्षाएं, या संसाधन होते हैं जो एक बाहरी प्रोग्राम अपनी कार्यक्षमता को पूरक करने के लिए उपयोग कर सकते हैं। एक पुस्तकालय का उपयोग करने के लिए, प्रोग्रामर को इसके लिए एक लिंक बनाना होगा। प्रोजेक्ट कंसोल एप्लिकेशन, Win32 या MFC एप्लिकेशन हो सकता है। लाइब्रेरी फ़ाइल में लिबास एक्सटेंशन है।

Step 1 - आइए हम एक नया Win32 प्रोजेक्ट बनाकर स्टैटिक लाइब्रेरी का एक सरल उदाहरण देखें।

Step 2 - एप्लीकेशन विजार्ड डायलॉग बॉक्स पर, स्टेटिक लाइब्रेरी विकल्प चुनें।

Step 3 - जारी रखने के लिए समाप्त क्लिक करें।

Step 4 - समाधान एक्सप्लोरर में प्रोजेक्ट पर राइट-क्लिक करें और Add → New Item… मेनू विकल्प से एक हेडर फ़ाइल जोड़ें।

Step 5 - Name फ़ील्ड में Calculator.h दर्ज करें और Add पर क्लिक करें।

हेडर फ़ाइल में निम्न कोड जोड़ें -

#pragma once
#ifndef _CALCULATOR_H_
#define _CALCULATOR_H_
double Min(const double *Numbers, const int Count);
double Max(const double *Numbers, const int Count);
double Sum(const double *Numbers, const int Count);
double Average(const double *Numbers, const int Count);
long GreatestCommonDivisor(long Nbr1, long Nbr2);
#endif // _CALCULATOR_H_

Step 6 - प्रोजेक्ट में सोर्स (* .cpp) फाइल जोड़ें।

Step 7 - Name फ़ील्ड में Calculator.cpp डालें और Add पर क्लिक करें।

Step 8 * .Cpp फ़ाइल में निम्न कोड जोड़ें -

#include "StdAfx.h"
#include "Calculator.h"
double Min(const double *Nbr, const int Total) {
   double Minimum = Nbr[0];
   for (int i = 0; i < Total; i++)
      if (Minimum > Nbr[i])
         Minimum = Nbr[i];
   return Minimum;
}
double Max(const double *Nbr, const int Total) {
   double Maximum = Nbr[0];
   for (int i = 0; i < Total; i++)
      if (Maximum < Nbr[i])
         Maximum = Nbr[i];
   return Maximum;
}
double Sum(const double *Nbr, const int Total) {
   double S = 0;
   for (int i = 0; i < Total; i++)
      S += Nbr[i];
   return S;
}
double Average(const double *Nbr, const int Total) {
   double avg, S = 0;
   for (int i = 0; i < Total; i++)
       S += Nbr[i];
   avg = S / Total;
   return avg;
}
long GreatestCommonDivisor(long Nbr1, long Nbr2) {
   while (true) {
      Nbr1 = Nbr1 % Nbr2;
      if (Nbr1 == 0)
         return Nbr2;
      Nbr2 = Nbr2 % Nbr1;
      if (Nbr2 == 0)
         return Nbr1;
   }
}

Step 9 - इस लाइब्रेरी को मुख्य मेनू से क्लिक करके बनाएँ Build → Build MFCLib

Step 10 - जब पुस्तकालय सफलतापूर्वक बनाया जाता है, तो यह उपरोक्त संदेश प्रदर्शित करेगा।

Step 11 - पुस्तकालय से इन कार्यों का उपयोग करने के लिए, हमें फ़ाइल → नई → परियोजना से आधारित एक और एमएफसी संवाद एप्लिकेशन जोड़ना चाहिए।

Step 12 - MFCLib \ Debug फ़ोल्डर में जाएं और शीर्ष लेख फ़ाइल और * .lib फ़ाइलों को MFCLibTest प्रोजेक्ट में कॉपी करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

Step 13 - मुख्य प्रोजेक्ट पर लाइब्रेरी को मौजूदा प्रोजेक्ट में जोड़ने के लिए, प्रोजेक्ट पर क्लिक करें → मौजूदा आइटम जोड़ें और MFCLib.lib चुनें।

Step 14 - अपने संवाद बॉक्स को डिज़ाइन करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

Step 15 - मूल्य प्रकार डबल के दोनों संपादन नियंत्रण के लिए मूल्य चर जोड़ें।

Step 16 - स्टेटिक टेक्स्ट कंट्रोल के लिए वैल्यू वैरिएबल जोड़ें, जो डायलॉग बॉक्स के अंत में है।

Step 17 - गणना बटन के लिए घटना हैंडलर जोड़ें।

लाइब्रेरी से कार्यक्षमता जोड़ने के लिए, हमें सीएमएफसीएलिबटेस्टड्लग.सीपीसी फाइल में हेडर फाइल को शामिल करना होगा।

#include "stdafx.h"
#include "MFCLibTest.h"
#include "MFCLibTestDlg.h"
#include "afxdialogex.h"
#include "Calculator.h"

Step 18 - यहां बटन ईवेंट हैंडलर का कार्यान्वयन है।

void CMFCLibTestDlg::OnBnClickedButtonCal() {
   // TODO: Add your control notification handler code here
   UpdateData(TRUE);
   CString strTemp;
   double numbers[2];
   numbers[0] = m_Num1;
   numbers[1] = m_Num2;

   strTemp.Format(L"%.2f", Max(numbers,2));
   m_strText.Append(L"Max is:\t" + strTemp);

   strTemp.Format(L"%.2f", Min(numbers, 2));
   m_strText.Append(L"\nMin is:\t" + strTemp);
   
   strTemp.Format(L"%.2f", Sum(numbers, 2));
   m_strText.Append(L"\nSum is:\t" + strTemp);

   strTemp.Format(L"%.2f", Average(numbers, 2));
   m_strText.Append(L"\nAverage is:\t" + strTemp);

   strTemp.Format(L"%d", GreatestCommonDivisor(m_Num1, m_Num2));
   m_strText.Append(L"\nGDC is:\t" + strTemp);

   UpdateData(FALSE);
}

Step 19 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 20- संपादन फ़ील्ड में दो मान दर्ज करें और गणना पर क्लिक करें। अब आप लाइब्रेरी से गणना करने के बाद परिणाम देखेंगे।

डायनेमिक लाइब्रेरी

Win32 DLL एक लाइब्रेरी है जिसे Microsoft Windows कंप्यूटर पर चलने वाले प्रोग्राम के लिए उपलब्ध कराया जा सकता है। एक सामान्य पुस्तकालय के रूप में, यह एक फ़ाइल में समूहीकृत कार्यों और / या अन्य संसाधनों से बना है।

DLL संक्षिप्त नाम डायनेमिक लिंक लाइब्रेरी के लिए है। इसका मतलब यह है कि, एक स्थिर पुस्तकालय के विपरीत, एक DLL प्रोग्रामर को यह तय करने की अनुमति देता है कि कब और कैसे अन्य अनुप्रयोगों को इस प्रकार के पुस्तकालय से जोड़ा जाएगा।

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

Step 1 - आइए हम एक नया Win32 प्रोजेक्ट बनाकर एक सरल उदाहरण देखें।

Step 2 - एप्लिकेशन टाइप सेक्शन में DLL रेडियो बटन पर क्लिक करें।

Step 3 - जारी रखने के लिए समाप्त क्लिक करें।

Step 4 - MFCDynamicLib.cpp फ़ाइल में निम्न फ़ंक्शन जोड़ें और उपयोग करके इसकी परिभाषाएँ उजागर करें -

extern "C" _declspec(dllexport)

Step 5 - DLL के बाहर एक्सेस किए जाने वाले प्रत्येक फ़ंक्शन के लिए _declspec (dllexport) संशोधक का उपयोग करें।

// MFCDynamicLib.cpp : Defines the exported functions for the DLL application.//

#include "stdafx.h"

extern "C" _declspec(dllexport) double Min(const double *Numbers, const int Count);
extern "C" _declspec(dllexport) double Max(const double *Numbers, const int Count);
extern "C" _declspec(dllexport) double Sum(const double *Numbers, const int Count);
extern "C" _declspec(dllexport) double Average(const double *Numbers, const int Count);
extern "C" _declspec(dllexport) long GreatestCommonDivisor(long Nbr1, long Nbr2);

double Min(const double *Nbr, const int Total) {
   double Minimum = Nbr[0];
   for (int i = 0; i < Total; i++)
      if (Minimum > Nbr[i])
         Minimum = Nbr[i];
   return Minimum;
}
double Max(const double *Nbr, const int Total) {
   double Maximum = Nbr[0];
   for (int i = 0; i < Total; i++)
      if (Maximum < Nbr[i])
         Maximum = Nbr[i];
   return Maximum;
}
double Sum(const double *Nbr, const int Total) {
   double S = 0;
   for (int i = 0; i < Total; i++)
      S += Nbr[i];
   return S;
}
double Average(const double *Nbr, const int Total){
   double avg, S = 0;
   for (int i = 0; i < Total; i++)
      S += Nbr[i];
   avg = S / Total;
   return avg;
}
long GreatestCommonDivisor(long Nbr1, long Nbr2) {
   while (true) {
      Nbr1 = Nbr1 % Nbr2;
      if (Nbr1 == 0)
         return Nbr2;
      Nbr2 = Nbr2 % Nbr1;
      if (Nbr2 == 0)
         return Nbr1;
   }
}

Step 6 - मुख्य मेनू पर DLL बनाने के लिए, क्लिक करें Build > Build MFCDynamicLib मुख्य मेनू से।

Step 7 - DLL के सफलतापूर्वक बन जाने के बाद, आपको आउटपुट विंडो में एमेज़ेज डिस्प्ले दिखाई देगा।

Step 8 - ओपन विंडोज एक्सप्लोरर और फिर वर्तमान परियोजना के डिबग फ़ोल्डर।

Step 9 - ध्यान दें कि dll एक्सटेंशन वाली एक फाइल और दूसरी फाइल जिसमें lib एक्सटेंशन है, बनाई गई है।

Step 10 - इस फाइल को dll एक्सटेंशन के साथ टेस्ट करने के लिए, हमें फाइल → न्यू → प्रोजेक्ट से एक नया MFC डायलॉग आधारित एप्लिकेशन बनाना होगा।

Step 11 - MFCD DynamicsicLib \ Debug फ़ोल्डर में जाएं और *। Dll और * .lib फ़ाइलों को MFCLibTest प्रोजेक्ट में कॉपी करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

Step 12 - डीएलएल को वर्तमान प्रोजेक्ट में जोड़ने के लिए, मुख्य मेनू पर, प्रोजेक्ट → मौजूदा आइटम जोड़ें पर क्लिक करें और फिर, एमएफसीडीडायरेक्टलिब.लिब फ़ाइल चुनें।

Step 13 - अपने संवाद बॉक्स को डिज़ाइन करें जैसा कि निम्नलिखित स्नैपशॉट में दिखाया गया है।

Step 14 - मूल्य प्रकार डबल के दोनों संपादन नियंत्रण के लिए मूल्य चर जोड़ें।

Step 15 - स्टेटिक टेक्स्ट कंट्रोल के लिए वैल्यू वैरिएबल जोड़ें, जो डायलॉग बॉक्स के अंत में है।

Step 16 - गणना बटन के लिए घटना हैंडलर जोड़ें।

Step 17 - DLL का उपयोग कर रहे प्रोजेक्ट में, प्रत्येक फ़ंक्शन जो एक्सेस किया जाएगा उसे _declspec (dllimport) संशोधक का उपयोग करके घोषित किया जाना चाहिए।

Step 18 - MFCLibTestDlg.cpp फ़ाइल में निम्न फ़ंक्शन घोषणा जोड़ें।

extern "C" _declspec(dllimport) double Min(const double *Numbers, const int Count);
extern "C" _declspec(dllimport) double Max(const double *Numbers, const int Count);
extern "C" _declspec(dllimport) double Sum(const double *Numbers, const int Count);
extern "C" _declspec(dllimport) double Average(const double *Numbers, const int Count);
extern "C" _declspec(dllimport) long GreatestCommonDivisor(long Nbr1, long Nbr2);

Step 19 - यहां बटन ईवेंट हैंडलर का कार्यान्वयन है।

void CMFCLibTestDlg::OnBnClickedButtonCal() {

   // TODO: Add your control notification handler code here
   UpdateData(TRUE);

   CString strTemp;
   double numbers[2];
   numbers[0] = m_Num1;
   numbers[1] = m_Num2;

   strTemp.Format(L"%.2f", Max(numbers,2));
   m_strText.Append(L"Max is:\t" + strTemp);

   strTemp.Format(L"%.2f", Min(numbers, 2));
   m_strText.Append(L"\nMin is:\t" + strTemp);

   strTemp.Format(L"%.2f", Sum(numbers, 2));
   m_strText.Append(L"\nSum is:\t" + strTemp);

   strTemp.Format(L"%.2f", Average(numbers, 2));
   m_strText.Append(L"\nAverage is:\t" + strTemp);

   strTemp.Format(L"%d", GreatestCommonDivisor(m_Num1, m_Num2));
   m_strText.Append(L"\nGDC is:\t" + strTemp);
 
   UpdateData(FALSE);
}

Step 20 - जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो आपको निम्न आउटपुट दिखाई देगा।

Step 21- संपादन फ़ील्ड में दो मान दर्ज करें और गणना पर क्लिक करें। अब आप DLL से गणना करने के बाद परिणाम देखेंगे।