फ्लेक्स - त्वरित गाइड

फ्लेक्स क्या है?

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

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

फ्लेक्स यूजर इंटरफेस (यूआई) या वेब एप्लिकेशन के क्लाइंट-साइड कार्यक्षमता का ख्याल रखता है। सर्वर-साइड कार्यक्षमता एक पारंपरिक स्क्रिप्टिंग भाषा (जावा / पीएचपी आदि) में लिखे गए सर्वर-साइड घटकों पर निर्भर है।

एक फ्लेक्स आधारित एप्लिकेशन वास्तव में एक SWF फ़ाइल के रूप में दिया जाता है और यह पारंपरिक वेब एप्लिकेशन के HTML / जावास्क्रिप्ट हिस्से के समान है।

फ्लेक्स एप्लिकेशन को एसडब्ल्यूएफ फाइल (एस) और एक एचटीएमएल रैपर, सीएसएस फाइल (एस) और किसी भी सर्वर-साइड स्क्रिप्ट फाइल (यानी जावा, .CFM, .PHP, आदि) के रूप में सर्वर पर तैनात किया जाता है। पारंपरिक वेब अनुप्रयोगों की तरह।

ये संसाधन एक सर्वर से क्लाइंट के ब्राउजर में कस्टमरी HTTP रिक्वेस्ट / रिस्पांस फैशन और फ्लैश प्लेयर के उपयोग से दिए जाते हैं, जो एक ब्राउजर में एप्लिकेशन चलाता है।

फ्लेक्स के लाभ

  • फ्लेक्स एप्लिकेशन आमतौर पर फ्लैश प्लेयर आधारित होते हैं जो जीपीएस, कैमरा, स्थानीय डेटाबेस, ग्राफिक्स एक्सेलेरोमीटर जैसी डिवाइस क्षमताओं तक पहुंच सकते हैं।

  • फ्लेक्स एप्लिकेशन एंड्रॉइड, ब्लैकबेरी टैबलेट ओएस और आईओएस डिवाइस पर चल सकते हैं।

  • फ्लेक्स एप्लिकेशन ब्राउज़रों के साथ-साथ डेस्कटॉप पर भी चल सकते हैं।

  • फ्लेक्स एप्लिकेशन प्लेटफ़ॉर्म स्वतंत्र हैं। यूआई प्लेटफॉर्म के लिए मूल हो सकता है या प्रत्येक प्लेटफॉर्म पर समान बनाया जा सकता है।

  • फ्लेक्स एप्लिकेशन जावा, स्प्रिंग, हाइबरनेट, पीएचपी, रूबी, .NET, एडोब कोल्डफ्यूज़न और एसएपी जैसे सभी प्रमुख सर्वर साइड तकनीकों के साथ सर्वर के साथ बातचीत कर सकते हैं, जैसे उद्योग मानकों जैसे कि REST, SOAP, JSON, JMS और AMF का उपयोग करना।

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

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

  • फ्लेक्स एप्लिकेशन सर्वर पर लोड को काफी हद तक कम कर देता है क्योंकि उपयोगकर्ता द्वारा विचार बदलने पर हर बार एक नए पृष्ठ के बजाय केवल एक बार आवेदन को वापस करना आवश्यक होता है।

फ्लेक्स के नुकसान

  • फ्लेक्स एप्लिकेशन सिंगल थ्रेडेड एप्लिकेशन हैं लेकिन फ्लेक्स इस चिंता को कम करने के लिए एक अतुल्यकालिक प्रोग्रामिंग मॉडल प्रदान करता है।

  • फ्लेक्स एक्शनस्क्रिप्ट और एक्सएमएल आधारित है। इन दोनों को सीखना फ्लेक्स में काम करना जरूरी है।

यह ट्यूटोरियल आपको Adobe Flex फ्रेमवर्क के साथ अपना काम शुरू करने के लिए विकास का माहौल तैयार करने के बारे में मार्गदर्शन करेगा। यह ट्यूटोरियल आपको फ्लेक्स फ्रेमवर्क सेटअप करने से पहले अपनी मशीन पर JDK और एडोब फ्लैश बिल्डर सेटअप करने का तरीका भी सिखाएगा।

व्यवस्था की आवश्यकता

फ्लेक्स को JDK 1.4 या उच्चतर की आवश्यकता होती है, इसलिए बहुत पहली आवश्यकता है JDK को आपके मशीन में स्थापित करना।

JDK 1.4 या ऊपर।
याद कोई न्यूनतम आवश्यकता नहीं।
डिस्क में जगह कोई न्यूनतम आवश्यकता नहीं।
ऑपरेटिंग सिस्टम कोई न्यूनतम आवश्यकता नहीं।

फ्लेक्स अनुप्रयोग विकास के साथ शुरू करने के लिए अपने वातावरण को सेटअप करने के लिए दिए गए चरणों का पालन करें।

चरण 1 - अपनी मशीन पर जावा इंस्टॉलेशन सत्यापित करें

अब कंसोल खोलें और निम्नलिखित को निष्पादित करें java आदेश।

ओएस टास्क आदेश
खिड़कियाँ कमांड कंसोल खोलें c: \> java -version
लिनक्स कमांड टर्मिनल खोलें $ जावा -अविवर्तन
मैक टर्मिनल खोलें मशीन: ~ joseph $ java -version

आइए सभी ऑपरेटिंग सिस्टम के लिए आउटपुट को सत्यापित करें -

ओएस उत्पन्न उत्पादन
खिड़कियाँ

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b07)

जावा हॉटस्पॉट (टीएम) क्लाइंट वीएम (बिल्ड 17.0-b17, मिश्रित मोड, साझाकरण)

लिनक्स

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b07)

जावा हॉटस्पॉट (टीएम) क्लाइंट वीएम (बिल्ड 17.0-b17, मिश्रित मोड, साझाकरण)

मैक

जावा संस्करण "1.6.0_21"

जावा (TM) एसई रनटाइम एनवायरनमेंट (बिल्ड 1.6.0_21-b07)

जावा हॉटस्पॉट (TM) 64-बिट सर्वर VM (बिल्ड 17.0-b17, मिश्रित मोड, साझाकरण)

चरण 2 - सेटअप जावा डेवलपमेंट किट (JDK)

यदि आपके पास जावा स्थापित नहीं है, तो आप ओरेकल के जावा साइट जावा एसई डाउनलोड से जावा सॉफ्टवेयर डेवलपमेंट किट (एसडीके) स्थापित कर सकते हैं । आपको डाउनलोड की गई फ़ाइलों में जेडीके स्थापित करने के लिए निर्देश मिलेंगे, फिर सेटअप को स्थापित करने और कॉन्फ़िगर करने के लिए दिए गए निर्देशों का पालन करें। अंत में PATH और JAVA_HOME वातावरण चर को उस निर्देशिका के संदर्भ में सेट करें जिसमें क्रमशः java और javac शामिल हैं, आमतौर पर java_install_dir / bin और java_install_dir।

ठीक JAVA_HOMEवातावरण चर आधार निर्देशिका स्थान पर इंगित करने के लिए जहां जावा आपकी मशीन पर स्थापित है। उदाहरण के लिए -

ओएस उत्पादन
खिड़कियाँ पर्यावरण चर JAVA_HOME को C: \ Program Files \ Java \ jdk1.6.0_21 पर सेट करें
लिनक्स निर्यात JAVA_HOME = / usr / स्थानीय / जावा-वर्तमान
मैक निर्यात JAVA_HOME = / लाइब्रेरी / जावा / होम

जावा कंपाइलर लोकेशन को सिस्टम पाथ में जोड़ें।

ओएस उत्पादन
खिड़कियाँ सिस्टम चर के अंत में स्ट्रिंग,% JAVA_HOME% \ बिन को भेजें।
लिनक्स निर्यात पथ =$PATH:$JAVA_HOME / bin /
मैक आवश्यक नहीं

चरण 3 - सेटअप एडोब फ्लैश बिल्डर 4.5

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

एडोब फ्लैश बिल्डर आईडीई स्थापित करने के लिए, नवीनतम एडोब फ्लैश बिल्डर बायनेरी डाउनलोड करें https://www.adobe.com/in/products/flash-builder.html। एक बार जब आप इंस्टॉलेशन डाउनलोड कर लेते हैं, तो बाइनरी वितरण को सुविधाजनक स्थान पर अनपैक कर दें। उदाहरण के लिए, विंडोज़ पर C: \ फ़्लैश-बिल्डर में, या लिनक्स / यूनिक्स पर / usr / स्थानीय / फ्लैश-बिल्डर और अंत में उचित रूप से पथ परिवर्तन सेट करें।

फ़्लैश बिल्डर शुरू होगा, जब आप विंडोज़ मशीन पर निम्न कमांड निष्पादित करते हैं, या जब आप बस FlashBucktern.net पर डबल क्लिक कर सकते हैं

%C:\flash-builder\FlashBuilder.exe

फ्लैश बिल्डर को यूनिक्स (सोलारिस, लिनक्स, आदि) मशीन पर निम्नलिखित आदेशों को निष्पादित करके शुरू किया जा सकता है।

$/usr/local/flash-builder/FlashBuilder

एडोब फ्लैश बिल्डर ट्रायल संस्करण का उपयोग 60 दिनों के लिए किया जा सकता है। बस नियम और शर्तों को स्वीकार करें, और आईडीई के साथ जारी रखने के लिए प्रारंभिक पंजीकरण चरणों को छोड़ दें। हमारी समझ के लिए, हम शिक्षण उद्देश्य के लिए परीक्षण संस्करण का उपयोग कर रहे हैं।

एक सफल स्टार्टअप के बाद, यदि सब कुछ ठीक है, तो उसे निम्नलिखित परिणाम प्रदर्शित करने चाहिए -

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

चरण 4 - सेटअप अपाचे टॉमकैट

आप Tomcat के नवीनतम संस्करण को डाउनलोड कर सकते हैं https://tomcat.apache.org/। एक बार, आपने इंस्टॉलेशन डाउनलोड कर लिया, बाइनरी वितरण को सुविधाजनक स्थान पर अनपैक कर दिया। उदाहरण के लिए, विंडोज़ पर C: \ apache-tomcat-6.0.33, या लिनक्स / यूनिक्स पर /usr/local/apache-tomcat-6.0.33 और CATALINA_HOME पर्यावरण चर को संस्थापन स्थानों पर इंगित करते हुए सेट करें।

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

%CATALINA_HOME%\bin\startup.bat 
or 
C:\apache-tomcat-6.0.33\bin\startup.bat

UNIX (Solaris, Linux, आदि) मशीन पर निम्नलिखित आदेशों को निष्पादित करके टॉमकैट शुरू किया जा सकता है -

$CATALINA_HOME/bin/startup.sh 
Or 
/usr/local/apache-tomcat-6.0.33/bin/startup.sh

एक सफल स्टार्टअप के बाद, टॉमकैट के साथ शामिल डिफ़ॉल्ट वेब एप्लिकेशन पर जाकर उपलब्ध होंगे http://localhost:8080/। यदि सब कुछ ठीक है, तो इसे निम्नलिखित परिणाम प्रदर्शित करना चाहिए -

टॉमकैट को कॉन्फ़िगर करने और चलाने के बारे में अधिक जानकारी यहाँ शामिल प्रलेखन में पाई जा सकती है, साथ ही टॉमकैट वेब साइट पर भी: http://tomcat.apache.org

विन्डोज़ मशीन पर निम्नलिखित कमांड निष्पादित करके टॉमकैट को रोका जा सकता है -

%CATALINA_HOME%\bin\shutdown
Or
C:\apache-tomcat-5.5.29\bin\shutdown

UNIX (Solaris, Linux, इत्यादि) मशीन पर निम्नलिखित आदेशों को निष्पादित करके टॉमकैट को रोका जा सकता है -

$CATALINA_HOME/bin/shutdown.sh
Or
/usr/local/apache-tomcat-5.5.29/bin/shutdown.sh

इससे पहले कि हम फ्लैश बिल्डर का उपयोग करके वास्तविक "हैलोवर्ल्ड" एप्लिकेशन बनाना शुरू करें, आइए देखें कि फ्लेक्स एप्लिकेशन के वास्तविक हिस्से क्या हैं -

एक फ्लेक्स एप्लिकेशन में निम्नलिखित चार महत्वपूर्ण भाग होते हैं, जिनमें से अंतिम भाग वैकल्पिक होता है लेकिन पहले तीन भाग अनिवार्य होते हैं।

  • फ्लेक्स फ्रेमवर्क लाइब्रेरी
  • क्लाइंट-साइड कोड
  • सार्वजनिक संसाधन (HTML / JS / CSS)
  • सर्वर-साइड कोड

एक सामान्य फ्लेक्स एप्लिकेशन के विभिन्न भागों जैसे हैलोवर्ल्ड के नमूना स्थानों को नीचे दिखाया गया है -

नाम स्थान
प्रोजेक्ट रूट नमस्ते दुनिया/
फ्लेक्स फ्रेमवर्क लाइब्रेरी पथ का निर्माण
सार्वजनिक संसाधन एचटीएमएल-टेम्पलेट
क्लाइंट-साइड कोड टेबल टेबल-बॉर्डर / कॉम / ट्यूटोरियलस्पॉट / क्लाइंट
सर्वर-साइड कोड टेबल टेबल-बॉर्डर / कॉम / ट्यूटोरियलस्पॉट / सर्वर

आवेदन का निर्माण प्रक्रिया

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

जब हम फ्लैश बिल्डर का उपयोग करके अपना कोड बनाते हैं, तो फ्लैश बिल्डर निम्नलिखित कार्य करेगा -

  • HelloWorld.swf फ़ाइल के स्रोत कोड को संकलित करता है।

  • एक फ़ाइल index.template.html HTML- टेम्पलेट फ़ोल्डर में संग्रहीत से एक HelloWorld.html (swf फ़ाइल के लिए एक आवरण फ़ाइल) संकलित करता है

  • लक्ष्य फ़ोल्डर, बिन-डिबग में HelloWorld.swf और HelloWorld.html फ़ाइलों की प्रतियां।

  • प्रतिलिपि swfobject.js, लक्ष्य फ़ोल्डर, बिन-डिबग में HelloWorld.html में गतिशील रूप से swf फ़ाइल लोड करने के लिए जिम्मेदार एक जावास्क्रिप्ट कोड

  • लक्ष्य फ़ोल्डर, बिन-डिबग में फ्रेमवर्क_xxx.swf नाम की swf फ़ाइल के रूप में फ्रेमवर्क लाइब्रेरी की प्रतिलिपि बनाता है

  • लक्ष्य फ़ोल्डर में अन्य फ्लेक्स मॉड्यूल (.swf फाइलें जैसे स्पार्कस्किन_xxx.swf, textLayout_xxx.swf) की प्रतिलिपि बनाता है।

एप्लिकेशन लॉन्च प्रक्रिया

  • किसी भी वेब-ब्राउज़र में \ HelloWorld \ bin-debug फ़ोल्डर में उपलब्ध HelloWorld.html फ़ाइल खोलें।

  • HelloWorld.swf अपने आप लोड हो जाएगा और एप्लिकेशन चलना शुरू हो जाएगा।

फ्लेक्स फ्रेमवर्क लाइब्रेरी

कुछ महत्वपूर्ण रूपरेखा पुस्तकालयों के बारे में संक्षिप्त विवरण निम्नलिखित है। कृपया ध्यान दें कि, फ्लेक्स पुस्तकालयों को .swc नोटेशन के उपयोग से दर्शाया जाता है

अनु क्रमांक नोड्स और विवरण
1

playerglobal.swc

यह लाइब्रेरी आपकी मशीन पर स्थापित FlashPayer के लिए विशिष्ट है और इसमें फ़्लैश प्लेयर द्वारा समर्थित देशी तरीके हैं।

2

textlayout.swc

यह लाइब्रेरी टेक्स्ट लेआउट संबंधित सुविधाओं का समर्थन करती है।

3

framework.swc

यह फ्लेक्स फ्रेमवर्क लाइब्रेरी में फ्लेक्स की मुख्य विशेषताएं हैं।

4

mx.swc

यह लाइब्रेरी mx UI नियंत्रण की परिभाषा को संग्रहीत करती है।

5

charts.swc

यह पुस्तकालय चार्टिंग नियंत्रणों का समर्थन करता है।

6

spark.swc

यह लाइब्रेरी स्पार्क यूआई नियंत्रण की परिभाषाओं को संग्रहीत करती है।

7

sparkskins.swc

यह लाइब्रेरी स्पार्क यूआई नियंत्रण की स्किनिंग का समर्थन करती है।

क्लाइंट-साइड कोड

फ्लेक्स एप्लिकेशन कोड में लिखा जा सकता है MXML साथ ही साथ ActionScript

अनु क्रमांक टाइप और विवरण
1

MXML

एमएक्सएमएल एक XML मार्कअप भाषा है जिसका उपयोग हम उपयोगकर्ता इंटरफ़ेस घटकों को बिछाने के लिए करेंगे। MXML बिल्ड प्रक्रिया के दौरान ActionScript में संकलित किया जाता है।

2

ActionScript

ActionScript एक ऑब्जेक्ट-ओरिएंटेड प्रक्रियात्मक प्रोग्रामिंग भाषा है और यह ECMAScript (ECMA-262) संस्करण 4 ड्राफ्ट भाषा विनिर्देश पर आधारित है।

फ्लेक्स में, हम निम्नलिखित करने के लिए ActionScript और MXML को मिला सकते हैं -

  • MXML टैग का उपयोग करके लेआउट यूजर इंटरफेस घटक

  • एमएक्सएमएल का उपयोग किसी एप्लिकेशन के गैर-प्रासंगिक पहलुओं को घोषित करने के लिए करें, जैसे कि सर्वर पर डेटा स्रोतों तक पहुंच

  • सर्वर पर उपयोगकर्ता इंटरफ़ेस घटकों और डेटा स्रोतों के बीच डेटा बाइंडिंग बनाने के लिए MXML का उपयोग करें।

  • MXML ईवेंट विशेषताओं के अंदर ईवेंट श्रोताओं को परिभाषित करने के लिए एक्शनस्क्रिप्ट का उपयोग करें।

  • का उपयोग कर स्क्रिप्ट ब्लॉक जोड़ें टैग।

  • बाहरी ActionScript फ़ाइलों को शामिल करें।

  • एक्शनस्क्रिप्ट क्लासेस आयात करें।

  • एक्शनस्क्रिप्ट घटक बनाएँ।

सार्वजनिक संसाधन

ये फ्लेक्स एप्लिकेशन द्वारा संदर्भित फाइलें हैं, जैसे होस्ट HTML पेज, सीएसएस या HTML-टेम्पलेट फ़ोल्डर के तहत स्थित छवियां। इसमें निम्न फ़ाइलें हैं -

अनु क्रमांक फ़ाइल का नाम और विवरण
1

index.template.html

स्थान धारकों के साथ होस्ट HTML पृष्ठ। Flash बिल्डर इस टेम्पलेट का उपयोग वास्तविक पेज HelloWorld.html को HelloWorld.swf फ़ाइल बनाने के लिए करता है।

2

playerProductInstall.swf

यह फ़्लैश प्लेयर को एक्सप्रेस मोड में स्थापित करने के लिए एक फ्लैश उपयोगिता है।

3

swfobject.js

यह स्थापित फ़्लैश प्लेयर के संस्करण की जांच करने और HelloWorld.html पृष्ठ में HelloWorld.swf को लोड करने के लिए जावास्क्रिप्ट जिम्मेदार है।

4

html-template/history

इस फ़ोल्डर में एप्लिकेशन के इतिहास प्रबंधन के लिए संसाधन हैं।

HelloWorld.mxml

यह वास्तविक एमएमएमएल / एएस (एक्शनस्क्रिप्ट) कोड है जो एप्लिकेशन के व्यापार तर्क को लागू करने के लिए लिखा गया है और यह कि फ्लेक्स कंपाइलर एसडब्ल्यूएफ फ़ाइल में अनुवाद करता है जिसे ब्राउज़र में फ्लैश प्लेयर द्वारा निष्पादित किया जाएगा।

एक नमस्कार HelloWorld प्रवेश वर्ग निम्नानुसार होगा -

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%"
   minWidth = "500" minHeight = "500" 
   initialize = "application_initializeHandler(event)">

   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            Alert.show("Hello World!");				
         }

         protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "My Hello World Application";				
         }
      ]]>
   </fx:Script>
   
   <s:VGroup horizontalAlign = "center" width = "100%" height = "100%" 
      paddingTop = "100" gap = "50">
      <s:Label id = "lblHeader" fontSize = "40" color = "0x777777" />
      <s:Button label = "Click Me!" id = "btnClickMe" 
         click = "btnClickMe_clickHandler(event)" />
   </s:VGroup>	
</s:Application>

निम्न तालिका उपरोक्त कोड स्क्रिप्ट में उपयोग किए गए सभी टैग का विवरण देती है।

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

Application

एप्लिकेशन कंटेनर को परिभाषित करता है जो हमेशा एक फ्लेक्स एप्लिकेशन का रूट टैग होता है।

2

Script

ActionScript भाषा में व्यावसायिक तर्क समाहित करता है।

3

VGroup

एक वर्टिकल ग्रुपिंग कंटेनर को परिभाषित करता है जिसमें वर्टिकल फैशन में फ्लेक्स UI कंट्रोल हो सकते हैं।

4

Label

एक लेबल नियंत्रण का प्रतिनिधित्व करता है, एक बहुत ही सरल उपयोगकर्ता इंटरफ़ेस घटक जो पाठ प्रदर्शित करता है।

5

Button

एक बटन नियंत्रण का प्रतिनिधित्व करता है, जिसे कुछ कार्रवाई करने के लिए क्लिक किया जा सकता है।

सर्वर-साइड कोड

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

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

फ्लेक्स एप्लिकेशन बनाने के लिए हम फ़्लैश बिल्डर 4.5 का उपयोग करेंगे। एक सरल से शुरू करते हैंHelloWorld आवेदन।

चरण 1 - प्रोजेक्ट बनाएं

पहला कदम फ्लैश बिल्डर आईडीई का उपयोग करके एक साधारण फ्लेक्स प्रोजेक्ट बनाना है। विकल्प का उपयोग करके प्रोजेक्ट विज़ार्ड लॉन्च करेंFile > New > Flex Project। अब के रूप में अपनी परियोजना का नाम HelloWorld इस प्रकार विज़ार्ड विंडो का उपयोग कर -

एप्लिकेशन प्रकार का चयन करें Web (runs in Adobe Flash Player)। हालाँकि, यदि यह चयनित नहीं है, तो अन्य डिफ़ॉल्ट मानों को ऐसे ही छोड़ दें और फिनिश बटन पर क्लिक करें। एक बार जब आपकी परियोजना सफलतापूर्वक बन जाती है, तो आपके पास अपने प्रोजेक्ट एक्सप्लोरर में निम्नलिखित सामग्री होगी -

यहाँ सभी महत्वपूर्ण फ़ोल्डरों का संक्षिप्त विवरण दिया गया है -

फ़ोल्डर स्थान
टेबल टेबल-बॉर्डर

सोर्स कोड (mxml / as classes) फाइलें।

हमने ग्राहक UI प्रदर्शन के लिए जिम्मेदार क्लाइंट-साइड विशिष्ट जावा कक्षाओं वाले कॉम / ट्यूटोरियलस्पॉट / क्लाइंट फ़ोल्डर संरचना बनाई है।

बिन-डिबग

यह आउटपुट भाग है, यह वास्तविक परिनियोज्य वेब अनुप्रयोग का प्रतिनिधित्व करता है।

इतिहास फ़ोल्डर में फ्लेक्स एप्लिकेशन के इतिहास प्रबंधन के लिए समर्थन फाइलें शामिल हैं।

flex_xxx.swf, फ्लेक्स फ्रेमवर्क फ़ाइलों का उपयोग फ्लेक्स एप्लिकेशन द्वारा किया जाना चाहिए।

नमस्कार अनुप्रयोग के लिए HelloWorld.html, आवरण / होस्ट HTML फ़ाइल।

HelloWorld.swf, हमारे फ्लेक्स आधारित अनुप्रयोग।

playerProductInstall.swf, फ़्लैश प्लेयर एक्सप्रेस इंस्टॉलर।

स्पार्क_xxx.swf, स्पार्क घटक समर्थन के लिए पुस्तकालय।

swfobject.js, HelloWorld.html में HelloWorld.swf को लोड करने के लिए उत्तरदायी जावास्क्रिप्ट। यह फ़्लैश प्लेयर संस्करण की जाँच करता है और HelloWorld.swf फ़ाइल में इनिशियलाइज़ेशन पैरामीटर पास करता है।

textLayout_xxx.swf, पाठ घटक समर्थन के लिए पुस्तकालय।

एचटीएमएल-टेम्पलेट

यह कॉन्फ़िगर करने योग्य वेब एप्लिकेशन का प्रतिनिधित्व करता है। फ़्लैश बिल्डर html-टेम्पलेट से बिन-डिबग फ़ोल्डर में फ़ाइलों को संकलित करता है।

इतिहास फ़ोल्डर में फ्लेक्स एप्लिकेशन के इतिहास प्रबंधन के लिए समर्थन फाइलें शामिल हैं।

index.template.html, फ्लेक्स एप्लिकेशन के लिए रैपर / होस्ट HTML फ़ाइल, फ्लैश बिल्डर विशिष्ट कॉन्फ़िगरेशन के लिए स्थान धारक हैं। बिल्ड के दौरान बिन-डिबग फ़ोल्डर में HelloWorld.html पर संकलित किया जाता है।

playerProductInstall.swf, फ़्लैश प्लेयर एक्सप्रेस इंस्टॉलर निर्माण के दौरान बिन-डिबग फ़ोल्डर में कॉपी हो जाता है।

swfobject.js, HelloWorld.html में HelloWorld.swf को लोड करने के लिए उत्तरदायी जावास्क्रिप्ट। यह फ़्लैश प्लेयर संस्करण की जाँच करता है और HelloWorld.swf फ़ाइल के लिए इनिशियलाइज़ेशन पैरामीटर पास करता है जो बिल्ड के दौरान बाइंडबग फ़ोल्डर में कॉपी हो जाता है।

चरण 2 - बाहरी सीएसएस फ़ाइल बनाएँ

CSS फ़ाइल बनाएं styles.css Wrapper HTML पेज के लिए html-template फ़ोल्डर।

html, body { 
   height:100%;
}

body { 
   margin:0; 
   padding:0; 
   overflow:auto; 
   text-align:center;		
}   

object:focus { 
   outline:none; 
}

#flashContent { 
   display:none;	
}

.pluginHeader {
   font-family:Arial, Helvetica, sans-serif;
   font-size:14px;
   color:#9b1204;
   text-decoration:none;
   font-weight:bold;
}

.pluginInstallText {
   font-family:Arial, Helvetica, sans-serif;
   font-size:12px;
   color:#000000;
   line-height:18px;
   font-style:normal;
}

.pluginText { 
   font-family:Arial, Helvetica, sans-serif;
   font-size:12px;
   color:#000000;
   line-height:18px;
   font-style:normal;
}

चरण 3 - Wrapper HTML पेज टेम्पलेट को संशोधित करें

Wrapper HTML पेज टेम्पलेट को संशोधित करें index.template.html में htmltemplateफ़ोल्डर। फ्लैश बिल्डर एक डिफ़ॉल्ट रैपर एचटीएमएल पेज टेम्प्लेट HTML- टेम्पलेट / index.template.html बनाएगा , जो HelloWorld.html पर संकलित किया जाएगा।

इस फ़ाइल में प्लेसहोल्डर हैं, जो फ़्लैश बिल्डर संकलन प्रक्रिया के दौरान बदलता है। उदाहरण के लिए, फ़्लैश प्लेयर संस्करण, एप्लिकेशन का नाम, आदि।

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

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns = "http://www.w3.org/1999/xhtml" lang = "en" xml:lang = "en">
   
   <head>
      <title>${title}</title>
      <meta name = "google" value = "notranslate" />
      <meta http-equiv = "Content-Type" content = "text/html; charset = utf-8" />
      <link rel = "stylesheet" href = "styles.css" type = "text/css"></link>
      <link rel = "stylesheet" type = "text/css" href = "history/history.css" />
      <script type = "text/javascript" table table-bordered = "history/history.js">
      </script>
      <script type = "text/javascript" table table-bordered = "swfobject.js"></script>
      
      <script type = "text/javascript">
         // For version detection, set to min. required Flash Player version,
         //or 0 (or 0.0.0), for no version detection.
         var swfVersionStr = "${version_major}.${version_minor}.${version_revision}"; // To use express install, set to playerProductInstall.swf, //otherwise the empty string. var xiSwfUrlStr = "${expressInstallSwf}";
         var flashvars = {};
         var params = {};
         params.quality = "high";
         params.bgcolor = "${bgcolor}"; params.allowscriptaccess = "sameDomain"; params.allowfullscreen = "true"; var attributes = {}; attributes.id = "${application}";
         attributes.name = "${application}"; attributes.align = "middle"; swfobject.embedSWF ( "${swf}.swf", "flashContent",
            "${width}", "${height}",
            swfVersionStr, xiSwfUrlStr,
            flashvars, params, attributes);

         // JavaScript enabled so display the flashContent div in case
         //it is not replaced with a swf object.
         swfobject.createCSS("#flashContent", "display:block;text-align:left;");
      </script>
   </head>
   
   <body>
      <div id = "flashContent">
         <p style = "margin:100px;">

            <table width = "700" cellpadding = "10" cellspacing = "2" border = "0">
               <tr>
                  <td class = "pluginHeader">Flash Player Required</td>
               </tr>
               
               <tr>
                  <td class = "pluginText">The Adobe Flash Player version
                     10.2.0 or greater is required.</td>
               </tr>
               
               <tr>
                  <td class = "pluginInstallText" align = "left">
               
                  <table border = "0" width = "100%">
                     <tr class = "pluginInstallText" >
                        <td>Click here to download and install Adobe Flash Player:</td>
                        <td> </td>
                        <td align = "right">
                           <script type = "text/javascript">
                              var pageHost
                                 = ((document.location.protocol == "https:") ? "https://" : "http://");
                              document.write("<a target = '_blank'"
                                 +" href = 'http://get.adobe.com/flashplayer/'><"
                                 +"img style = 'border-style: none' table table-bordered = '"
                                 +pageHost
                                 +"www.adobe.com/images/shared/download_buttons/get_flash_player.gif'"
                                 +" alt = 'Get Adobe Flash player' /></a>" );
                           </script>
                        </td>
                     </tr>
                  </table>
               </tr>
            </table>
         </p>
      </div>
      
      <noscript>
         <object classid = "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"
            width = "${width}" height = "${height}" id = "${application}"> <param name = "movie" value = "${swf}.swf" />
            <param name = "quality" value = "high" />
            <param name = "bgcolor" value = "${bgcolor}" /> <param name = "allowScriptAccess" value = "sameDomain" /> <param name = "allowFullScreen" value = "true" /> <!--[if !IE]>--> <object type = "application/x-shockwave-flash" data = "${swf}.swf"
               width = "${width}" height = "${height}">
               <param name = "quality" value = "high" />
               <param name = "bgcolor" value = "${bgcolor}" />
               <param name = "allowScriptAccess" value = "sameDomain" />
               <param name = "allowFullScreen" value = "true" />
            <!--<![endif]-->
         
            <!--[if gte IE 6]>-->
               <p>
                  <p style = "margin:100px;">
                     <table width = "700" cellpadding = "10" cellspacing = "2" 
                        border = "0">
                        <tr>
                           <td class = "pluginHeader">Flash Player Required</td>
                        </tr>
                        
                        <tr>
                           <td class = "pluginText">The Adobe Flash Player version
                           10.2.0 or greater is required.</td>
                        </tr>
                        
                        <tr>
                           <td class = "pluginInstallText" align = "left">

                           <table border = "0" width = "100%">
                              <tr class = "pluginInstallText" >
                                 <td>Click here to download and install Adobe Flash 
                                    Player:</td>
                                 <td> </td>
                                 <td align = "right">
                                    <script type = "text/javascript">
                                       var pageHost
                                          = ((document.location.protocol == "https:") ? "https://" : "http://");
                                       document.write("<a target = '_blank'"
                                          +" href = 'http://get.adobe.com/flashplayer/'><"
                                          +"img style = 'border-style: none' table table-bordered = '"
                                          +pageHost
                                          +"www.adobe.com/images/shared/download_buttons/get_flash_player.gif'"
                                          +" alt = 'Get Adobe Flash player' /></a>" );
                                    </script>
                                 </td>
                              </tr>
                           </table>
                        </tr>
                     </table>
                  </p>
               </p>
            <!--<![endif]-->
         
            <p style = "margin:100px;">
               <table width = "700" cellpadding = "10" cellspacing = "2" border = "0">
                  <tr><td class = "pluginHeader">Flash Player Required</td></tr>
                  <tr><td class = "pluginText">The Adobe Flash Player version
                     10.2.0 or greater is required.</td></tr>
                  <tr>
                     <td class = "pluginInstallText" align = "left">
                        <table border = "0" width = "100%">
                           <tr class = "pluginInstallText" >
                              <td>Click here to download and install Adobe Flash 
                                 Player:</td>
                              <td> </td>
                              <td align = "right">
                                 <script type = "text/javascript">
                                    var pageHost
                                       = ((document.location.protocol == "https:") ? "https://" : "http://");
                                    document.write("<a target = '_blank'"
                                       +" href = 'http://get.adobe.com/flashplayer/'><"
                                       +"img style = 'border-style: none' table table-bordered = '"
                                       +pageHost
                                       +"www.adobe.com/images/shared/download_buttons/get_flash_player.gif'"
                                       +" alt = 'Get Adobe Flash player' /></a>" );
                                 </script>
                              </td>
                           </tr>
                        </table>
                     </td>
                  </tr>
               </table>
            </p>
         <!--[if !IE]>-->
         </object>
         <!--<![endif]-->
         </object>
      </noscript>
   </body>
</html>

चरण 4 - आंतरिक सीएसएस फ़ाइल बनाएँ

CSS फ़ाइल बनाएं Style.css के लिये HelloWorld.mxml में table tablebordered/com/tutorialspointफ़ोल्डर। फ्लेक्स अपने यूआई नियंत्रणों के लिए समान सीएसएस शैली प्रदान करता है क्योंकि एचटीएमएल यूआई नियंत्रणों के लिए सीएसएस शैलियों हैं।

/* CSS file */
@namespace s "library://ns.adobe.com/flex/spark";
@namespace mx "library://ns.adobe.com/flex/mx";

.heading {
   fontFamily: Arial, Helvetica, sans-serif;
   fontSize: 17px;
   color: #9b1204;
   textDecoration:none;
   fontWeight:normal;
}

.button {
   fontWeight: bold;			
}

.container {
   cornerRadius :10;
   horizontalCenter :0;	
   borderColor: #777777;
   verticalCenter:0;
   backgroundColor: #efefef;
}

चरण 5 - प्रवेश स्तर कक्षा को संशोधित करें

फ़्लैश बिल्डर एक डिफ़ॉल्ट mxml फ़ाइल टेबल टेबलबॉर्डेड / com.tutorialspoint / HelloWorld.mxml बनाएगा , जिसमें रूट टैग <एप्लिकेशन> कंटेनर के लिए एप्लिकेशन हो रहा है। हमें "हैलो, वर्ल्ड!" -

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%"
      minWidth = "500" minHeight = "500"
      initialize = "application_initializeHandler(event)">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            Alert.show("Hello World!");
         }

         protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "My Hello World Application";
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "500" height = "500" id = "mainContainer"
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50" horizontalAlign = "center"
         verticalAlign = "middle">
         <s:Label id = "lblHeader" fontSize = "40" color = "0x777777"
            styleName = "heading" />
         <s:Button label = "Click Me!" id = "btnClickMe"
            click = "btnClickMe_clickHandler(event)" styleName = "button" />
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

आप या तो नए एप्लिकेशन को परिभाषित करने या हेल्पर रूटीन को परिभाषित करने के लिए एक ही सोर्स डायरेक्टरी में अधिक mxml या एक्शनस्क्रिप्ट फाइल बना सकते हैं।

चरण 6 - अनुप्रयोग बनाएँ

फ्लैश बिल्डर है Build Automaticallyडिफ़ॉल्ट रूप से जाँच की गई। बस जाँच करेंProblemsदेखें कि क्या कोई त्रुटि है। एक बार जब आप परिवर्तनों के साथ किए जाते हैं, तो आपको कोई त्रुटि नहीं दिखाई देगी।

चरण 7 - रन एप्लिकेशन

अब

Run एप्लीकेशन मेनू पर क्लिक करें और सेलेक्ट करेंHelloWorld आवेदन चलाने के लिए आवेदन।

यदि सब कुछ ठीक है, तो आपको ब्राउज़र को पॉप अप, एप्लिकेशन अप और रनिंग देखना होगा। यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

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

बधाई हो! आपने अपना पहला आवेदन प्रयोग करके लागू किया हैFlex

यह ट्यूटोरियल आपको समझाएगा कि एप्लिकेशन कैसे बनाएं war फ़ाइल और कैसे Apache Tomcat वेब सर्वर रूट में तैनात करने के लिए।

यदि आप इस सरल उदाहरण को समझ गए हैं तो आप उसी चरणों के बाद एक जटिल फ्लेक्स एप्लिकेशन को भी तैनात कर पाएंगे।

हमें एक फ्लेक्स एप्लिकेशन बनाने के लिए निम्नलिखित चरणों का पालन करना चाहिए -

कदम विवरण
1 एक पैकेजकॉम के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं। Flexspoint.client फ्लेक्स में बताया गया है - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

फ्लेक्स एप्लिकेशन की रिलीज़ बिल्ड बनाने के लिए नीचे दिए गए चरणों का पालन करें और फिर इसे टोमैट सर्वर पर तैनात करें -

पहला कदम फ्लैश बिल्डर आईडीई का उपयोग करके रिलीज़ बिल्ड बनाना है। विकल्प का उपयोग करते हुए रिलीज़ रिलीज़ बिल्ड विज़ार्डFile > Export > Flash Builder > Release Build

निम्नानुसार विज़ार्ड विंडो का उपयोग करके हैलोवर्ल्ड के रूप में प्रोजेक्ट का चयन करें

अन्य डिफ़ॉल्ट मानों को ऐसे ही छोड़ दें और फिनिश बटन पर क्लिक करें। अब, फ़्लैश बिल्डर एक बिन-रिलीज़ फ़ोल्डर बनाएगा जिसमें प्रोजेक्ट का रिलीज़ बिल्ड होगा।

अब हमारी रिलीज़ बिल्ड तैयार है, आइए एक फ्लेक्स एप्लिकेशन को तैनात करने के लिए निम्नलिखित चरणों का पालन करें -

कदम विवरण
1 HelloWorld.war फ़ाइल के रूप में एप्लिकेशन के बिन-रिलीज़ फ़ोल्डर की सामग्री को ज़िप करें और इसे Apache Tomcat Webserver में तैनात करें।
2 अंतिम चरण में नीचे बताए अनुसार उपयुक्त URL का उपयोग करके अपना वेब एप्लिकेशन लॉन्च करें।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है table table-bordered/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%"
   minWidth = "500" minHeight = "500" 
   initialize = "application_initializeHandler(event)">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            Alert.show("Hello World!");				
         }

         protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "My Hello World Application";				
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "500" height = "500" id = "mainContainer" 
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50" horizontalAlign = "center" 
         verticalAlign = "middle">
         <s:Label id = "lblHeader" fontSize = "40" color = "0x777777" 
            styleName = "heading" />
         <s:Button label = "Click Me!" id = "btnClickMe" 
            click = "btnClickMe_clickHandler(event)" styleName = "button" />
      </s:VGroup>	
   </s:BorderContainer>	
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

WAR फ़ाइल बनाएँ

अब हमारा आवेदन ठीक काम कर रहा है और हम इसे युद्ध फाइल के रूप में निर्यात करने के लिए तैयार हैं। निम्नलिखित चरणों का पालन करें -

  • अपनी परियोजना के बिन-रिलीज़ निर्देशिका C: \ workspace \ HelloWorld \ binrelease में जाएं

  • बिन-रिलीज़ निर्देशिका के अंदर उपलब्ध सभी फ़ाइलों और फ़ोल्डरों का चयन करें।

  • HelloWorld.zip नामक फ़ाइल में सभी चयनित फ़ाइलों और फ़ोल्डरों को ज़िप करें ।

  • HelloWorld.zip का नाम HelloWorld.war पर रखें।

WAR फ़ाइल परिनियोजित करें

टॉमकैट सर्वर बंद करो।

  • HelloWorld.war फ़ाइल को tomcat संस्थापन निर्देशिका> webapps फ़ोल्डर में कॉपी करें।

  • टॉमकैट सर्वर शुरू करें।

  • Webapps निर्देशिका के अंदर देखें, एक फ़ोल्डर होना चाहिए HelloWorld बनाया गया।

  • अब HelloWorld.war को टॉमकैट वेबसर्वर रूट में सफलतापूर्वक तैनात किया गया है।

अनुप्रयोग चलाएँ

वेब ब्राउज़र में URL दर्ज करें -

http: // localhost: 8080 / HelloWorld / HelloWorld.html एप्लिकेशन लॉन्च करने के लिए।

सर्वर नाम (लोकलहोस्ट) और पोर्ट (8080) आपके टॉमकैट कॉन्फ़िगरेशन के अनुसार भिन्न हो सकते हैं।

फ्लेक्स एप्लीकेशन का जीवन चक्र

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

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

जब हम किसी ब्राउज़र में फ्लेक्स एप्लिकेशन लोड करते हैं, तो फ्लेक्स एप्लिकेशन के जीवनचक्र के दौरान निम्न घटनाएं होती हैं।

विभिन्न फ्लेक्स जीवन चक्र घटनाओं के बारे में संक्षिप्त विवरण निम्नलिखित है।

अनु क्रमांक घटना विवरण
1

preInitialize: mx.core.UIComponent.preinitialize

इवेंट प्रकार: mx.events.FlexEvent.PREINITIALIZE

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

जब फ्लेक्स प्री-इनिशियल इवेंट को भेजता है, तो एक घटक के सभी आंतरिक बच्चों सहित बच्चों को अभी तक नहीं बनाया गया है।

2

initialize: mx.core.UIComponent.initialize

इवेंट प्रकार: mx.events.FlexEvent.INITIALIZE

यह घटना पूर्व-प्रारंभिक चरण के बाद भेजी जाती है। फ्लेक्स फ्रेमवर्क इस चरण के दौरान इस घटक की आंतरिक संरचना को आरंभ करता है। जब घटक को माता-पिता में जोड़ा जाता है, तो यह घटना अपने आप आग जाती है।

आपको आमतौर पर इनिशियलाइज़ () कॉल करने की आवश्यकता नहीं है।

3

सृष्टि निर्माण: mx.core.UIComponent.creationComplete

इवेंट प्रकार: mx.events.FlexEvent.CREATION_COMPLETE

इस घटना को तब भेजा जाता है जब घटक ने अपना निर्माण, संपत्ति प्रसंस्करण, माप, लेआउट और ड्राइंग समाप्त कर लिया हो।

इस बिंदु पर, इसकी दृश्यमान संपत्ति के आधार पर, घटक दिखाई नहीं देता है, भले ही इसे खींचा गया हो।

4

applicationComplete: spark.computers.Application.applicationComplete

घटना का प्रकार: mx.events.FlexEvent.APPLICATION_COMPLETE

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

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

फ्लेक्स जीवन चक्र उदाहरण

आइए हम एक परीक्षण एप्लिकेशन बनाकर एक फ्लेक्स एप्लिकेशन के परीक्षण जीवन चक्र को समझने के लिए चरणों का पालन करें -

कदम विवरण
1 एक पैकेजकॉम के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं। Flexspoint.client फ्लेक्स में बताया गया है - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%" minWidth = "500" minHeight = "500"
   initialize = "reportEvent(event)"
   preinitialize = "reportEvent(event)"
   creationComplete = "reportEvent(event)"
   applicationComplete = "reportEvent(event)">	
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
   
         [Bindable]
         private var report:String = "";

         private function reportEvent(event:FlexEvent):void {
            report += "\n" + (event.type + " event occured at: " 
            + getTimer() + " ms" + "\n");
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "500" height = "500" id = "mainContainer" 
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50" 
         horizontalAlign = "center" verticalAlign = "middle">
         <s:Label textAlign = "center" width="100%" id = "lblHeader"
         fontSize = "40" color = "0x777777" styleName = "heading" 
         text = "Life Cycle Events Demonstration" />
         <s:TextArea id = "reportText" text = "{report}" editable = "false" 
         width = "300" height = "200">				
         </s:TextArea>			
      </s:VGroup>	
   </s:BorderContainer>	
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

फ्लेक्स अपने यूआई नियंत्रणों को उसी तरह लागू करने के लिए सीएसएस सिंटैक्स और शैलियों के उपयोग का समर्थन करता है जैसे सीएसएस से HTML घटकों के लिए।

रास्ता # 1: बाहरी शैली शीट फ़ाइल का उपयोग करना

आप आवेदन के वर्ग पथ में उपलब्ध शैली पत्रक का उल्लेख कर सकते हैं। उदाहरण के लिए Style.css फ़ाइल पर विचार करेंcom/tutorialspoint/client folder जहाँ HelloWorld.mxml फ़ाइल भी निहित है।

/* CSS file */
@namespace s "library://ns.adobe.com/flex/spark";
@namespace mx "library://ns.adobe.com/flex/mx";
...
.container {
   cornerRadius :10;
   horizontalCenter :0;	
   borderColor: #777777;
   verticalCenter:0;
   backgroundColor: #efefef;
}

फिर कोड स्निपेट का पालन करके सीएसएस फाइल को संदर्भित किया जा सकता है

<fx:Style source = "/com/tutorialspoint/client/Style.css" />

शैली के नाम संपत्ति का उपयोग करके UI घटक को शैलियों को असाइन करें

<s:BorderContainer width = "500" height = "500" id = "mainContainer" 
   styleName = "container"> 
   ...
</s:BorderContainer>

वे # 2: यूआई कंटेनर घटक के भीतर शैलियों का उपयोग करना

आप <fx: स्टाइल> टैग का उपयोग करके यूआई कंटेनर घटक के भीतर शैलियों को परिभाषित कर सकते हैं

क्लास लेवल सेलेक्टर

<fx:Style>
   @namespace s "library://ns.adobe.com/flex/spark";
   @namespace mx "library://ns.adobe.com/flex/mx";

   /* class level selector  */
   .errorLabel {
      color: red;
   }		
</fx:Style>

शैली के नाम संपत्ति का उपयोग करके UI घटक को शैलियों को असाइन करें।

<s:Label id = "errorMsg" text = "This is an error message" styleName = "errorLabel" />

आईडी स्तर चयनकर्ता

आईडी चयनकर्ता का उपयोग करते हुए स्टाइल यूआई घटक।

<fx:Style> 
   /* id level selector  */ 
   #msgLabel { 
      color: gray; 
   } 
</fx:Style>

<s:Label id = "msgLabel" text = "This is a normal message" />

प्रकार स्तर चयनकर्ता

एक GO में एक प्रकार का UI घटक शैली।

<fx:Style> 
   /* style applied on all buttons  */ 
   s|Button {  
      fontSize: 15; 
      color: #9933FF; 
   } 
</fx:Style>

<s:Button label = "Click Me!" id = "btnClickMe"
   click = "btnClickMe_clickHandler(event)" />

सीएसएस उदाहरण के साथ फ्लेक्स स्टाइल

आइए, टेस्ट एप्लिकेशन बनाकर फ्लेक्स एप्लिकेशन की CSS स्टाइलिंग की जाँच करने के लिए निम्नलिखित चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार Style.css, HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित सीएसएस फ़ाइल की सामग्री है src/com.tutorialspoint/Style.css

/* CSS file */
@namespace s "library://ns.adobe.com/flex/spark";
@namespace mx "library://ns.adobe.com/flex/mx";

.heading
{
   fontFamily: Arial, Helvetica, sans-serif;
   fontSize: 17px;
   color: #9b1204;
   textDecoration:none;
   fontWeight:normal;
}

.button {
   fontWeight: bold;			
}

.container {
   cornerRadius :10;
   horizontalCenter :0;	
   borderColor: #777777;
   verticalCenter:0;
   backgroundColor: #efefef;
}

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%" minWidth = "500" minHeight = "500"
   initialize = "application_initializeHandler(event)">
   
   <!--Add reference to style sheet -->
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />

   <!--Using styles within mxml file -->
   <fx:Style>
      @namespace s "library://ns.adobe.com/flex/spark";
      @namespace mx "library://ns.adobe.com/flex/mx";

      /* class level selector  */
      .errorLabel {
         color: red;
      }

      /* id level selector  */
      #msgLabel {
         color: gray;
      }

      /* style applied on all buttons  */
      s|Button {
         fontSize: 15;
         color: #9933FF;
      }
   </fx:Style>

   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            Alert.show("Hello World!");
         }

         protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "CSS Demonstrating Application";
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "560" height = "500" id = "mainContainer"
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50"
         horizontalAlign = "center" verticalAlign = "middle">
         <s:Label width = "100%" id = "lblHeader" fontSize = "40"
            color = "0x777777" styleName = "heading" />
         <s:Button label = "Click Me!" id = "btnClickMe"
            click = "btnClickMe_clickHandler(event)"  />
         <s:Label id = "errorMsg"
            text = "This is an error message" styleName = "errorLabel" />
         <s:Label id = "msgLabel" text = "This is a normal message" />
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

स्किनिंग क्या है?

  • फ्लेक्स में स्किनिंग, यूआई कंपोनेंट के लुक और फील को पूरी तरह से कस्टमाइज़ करने की एक प्रक्रिया है।

  • एक त्वचा एक घटक के पाठ, छवि, फिल्टर, संक्रमण और राज्यों को परिभाषित कर सकती है।

  • एक अलग mxml या ActionScript घटक के रूप में एक त्वचा बनाई जा सकती है।

  • त्वचा का उपयोग करके, हम UI घटक के सभी दृश्य पहलुओं को नियंत्रित कर सकते हैं।

  • सभी UI घटक के लिए त्वचा को परिभाषित करने की प्रक्रिया समान है।

चरण 1 - एक त्वचा बनाएँ

विकल्प का उपयोग करके एमएक्सएमएल स्किन विज़ार्ड बनाएं File > New > MXML Skin

पैकेज के रूप में दर्ज करें com.tutorialspoint.skin, नाम के रूप में GradientBackgroundSkin और मौजूदा फ्लेक्स बॉर्डर कॉर्नर कंट्रोल के रूप में होस्ट घटक चुनेंspark.component.BorderContainer

अब आपने एक बॉर्डरकोर्टर के लिए स्किन बनाई है। Mxml त्वचा फ़ाइल की सामग्री को संशोधित करेंsrc/com.tutorialspoint/skin/GradientBackgroundSkin.mxml

अद्यतन भरण परत निम्नानुसार है -

<!-- fill -->
<s:Rect id = "backgroundRect" left = "0" right = "0" height = "100%" top = "0">
   <s:fill>
      <s:LinearGradient rotation = "90">
         <s:GradientEntry color = "0x888888" ratio = "0.2" />
         <s:GradientEntry color = "0x111111" ratio = "1" />
      </s:LinearGradient>
   </s:fill>
</s:Rect>

चरण 2: त्वचा को लागू करें

आप दो तरीकों से एक घटक पर त्वचा को लागू कर सकते हैं -

MXML स्क्रिप्ट में त्वचा को लागू करें (सांख्यिकीय रूप से)

लागू GradientBackgroundSkin आईडी के साथ एक BorderContainer के लिए mainContainer इसका उपयोग कर रहा है skinClass विशेषता।

<s:BorderContainer width = "560" height = "500" id = "mainContainer" 
   styleName = "container">
   <s:VGroup width = "100%" height = "100%" gap = "50" 
      horizontalAlign = "center" verticalAlign = "middle" 
      skinClass = "com.tutorialspoint.skin.GradientBackgroundSkin">

ActionScript (गतिशील रूप से) में त्वचा को लागू करें

लागू GradientBackgroundSkin आईडी के साथ एक BorderContainer के लिए mainContainer इसका उपयोग कर रहा है skinClass संपत्ति।

protected function gradientBackground_clickHandler(event:MouseEvent):void {
   mainContainer.setStyle("skinClass", GradientBackgroundSkin);
}

फ्लेक्स स्टाइल विद स्किन उदाहरण

आइए, एक परीक्षण एप्लिकेशन बनाकर एक फ्लेक्स एप्लिकेशन में कार्रवाई करने के लिए निम्नलिखित चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 जैसा कि ऊपर बताया गया है, एक पैकेज com.tutorialspoint.skin के तहत स्किन ग्रेडिएंटबेकग्राउंडस्किन . mxml बनाएं । बाकी फाइलों को अपरिवर्तित रखें।
3 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
4 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित GradientBackgroundSkin.mxml फ़ाइल की सामग्री है src/com/tutorialspoint/skin/GradientBackg roundSkin.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Skin xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx">
   
   <!-- host component -->
   <fx:Metadata>
      [HostComponent("spark.components.BorderContainer")]
   </fx:Metadata> 

   <!-- states -->
   <s:states>
      <s:State name = "disabled" />
      <s:State name = "disabled" />
      <s:State name = "normal" />
   </s:states>

   <!-- SkinParts
   name = contentGroup, type = spark.components.Group, required = false
   -->
   
   <!-- fill -->
   <s:Rect id = "backgroundRect" left = "0" right = "0" height = "100%" top = "0">
      <s:fill>
         <s:LinearGradient rotation = "90">
            <s:GradientEntry color = "0x111111" ratio = "0.2" />
            <s:GradientEntry color = "0x888888" ratio = "1" />
         </s:LinearGradient>
      </s:fill>
   </s:Rect>	
   
   <!-- must specify this for the host component --> 
   <s:Group id = "contentGroup" left = "0" right = "0" top = "0" bottom = "0" />
</s:Skin>

निम्नलिखित संशोधित HelloWorld.mxml की सामग्री है filesrc/com/tutorialspoint/client/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%" minWidth = "500" minHeight = "500"
   initialize = "application_initializeHandler(event)">

   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import com.tutorialspoint.skin.GradientBackgroundSkin;
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         import spark.skins.spark.BorderContainerSkin;			

         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            Alert.show("Hello World!");				
         }

         protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "My Hello World Application";				
         }

         protected function gradientBackground_clickHandler(event:MouseEvent):void {
            mainContainer.setStyle("skinClass", GradientBackgroundSkin );
         }

         protected function standardBackground_clickHandler(event:MouseEvent):void {
            mainContainer.setStyle("skinClass", BorderContainerSkin );
         }
      ]]>
   </fx:Script>
   
   <fx:Declarations>
      <s:RadioButtonGroup id = "selectorGroup" />
   </fx:Declarations>
   
   <s:BorderContainer width = "500" height = "500" id = "mainContainer"
      skinClass = "spark.skins.spark.BorderContainerSkin" 
      horizontalCenter = "0" verticalCenter = "0" cornerRadius = "10">
      
      <s:VGroup width = "100%" height = "100%" gap = "50" horizontalAlign = "center"
         verticalAlign = "middle">
         <s:Label id = "lblHeader" fontSize = "40" color = "green" 
            styleName = "heading" />
         <s:Button label = "Click Me!" id = "btnClickMe" 
            click = "btnClickMe_clickHandler(event)" />
         <s:RadioButton color = "gray" fontWeight = "bold" 
            group = "{selectorGroup}" label = "Standard Background" 
            click = "standardBackground_clickHandler(event)" selected = "true" />
         <s:RadioButton color = "gray" fontWeight = "bold" 
            group = "{selectorGroup}" label = "Gradient Background" 
            click = "gradientBackground_clickHandler(event)" />			
      </s:VGroup>			
   </s:BorderContainer>	
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

डेटा बाइंडिंग क्या है?

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

फ्लेक्स डेटा बाइंडिंग को नीचे करने के तीन तरीके प्रदान करता है

  • MXML स्क्रिप्ट ({}) में कर्ली ब्रेस सिंटैक्स
  • <fx: MXML में बाध्यकारी> टैग
  • ActionScript में बंधन

डेटा बाइंडिंग - एमएक्सएमएल में घुंघराले ब्रेस का उपयोग करना

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

<s:TextInput id = "txtInput1" />
<s:TextInput id = "txtInput2" text = "{txtInput1.text}" />

डेटा बाइंडिंग - एमएक्सएमएल में <fx: बाइंडिंग> टैग का उपयोग करना

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

<fx:Binding source = "txtInput1.text" destination = "txtInput2.text" />
<s:TextInput id = "txtInput1" />
<s:TextInput id = "txtInput2" />

डेटा बाइंडिंग - एक्शनस्क्रिप्ट में बाइंडिंग यूटिल्स का उपयोग करना

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

<fx:Script>
   <![CDATA[
      import mx.binding.utils.BindingUtils;
      import mx.events.FlexEvent;

      protected function txtInput2_preinitializeHandler(event:FlexEvent):void {
         BindingUtils.bindProperty(txtInput2,"text",txtInput1, "text");
      }      
   ]]>
</fx:Script>

<s:TextInput id = "txtInput1" />
<s:TextInput id = "txtInput2" 
   preinitialize = "txtInput2_preinitializeHandler(event)" />

फ्लेक्स डेटा बाइंडिंग उदाहरण

आइए, एक परीक्षण एप्लिकेशन बनाकर एक फ्लेक्स एप्लिकेशन में कार्रवाई करने के लिए नीचे दिए गए चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित HelloWorld.mxml फ़ाइल की सामग्री हैsrc/com/tutorialspoint/client/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%" minWidth = "500" minHeight = "500">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.binding.utils.BindingUtils;   
         import mx.events.FlexEvent;

         protected function txtInput6_preinitializeHandler(event:FlexEvent):void {
            BindingUtils.bindProperty(txtInput6,"text",txtInput5, "text");
         }
      ]]>
   </fx:Script>
   
   <fx:Binding source = "txtInput3.text" destination = "txtInput4.text" />
   <s:BorderContainer width = "500" height = "550" id = "mainContainer" 
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50" horizontalAlign = "center" 
         verticalAlign = "middle">
         <s:Label id = "lblHeader" text = "Data Binding Demonstration"
            fontSize = "40" color = "0x777777" styleName = "heading" />
         <s:Panel title = "Example #1 (Using Curly Braces,\{\})" width = "400" 
            height = "100" >
            <s:layout>
               <s:VerticalLayout paddingTop = "10" paddingLeft = "10" />
            </s:layout>
            
            <s:HGroup >
               <s:Label text = "Type here: " width = "100" paddingTop = "6" />
               <s:TextInput id = "txtInput1" />	
            </s:HGroup>
            
            <s:HGroup >
               <s:Label text = "Copied text: " width = "100" paddingTop = "6" />
               <s:TextInput id = "txtInput2" text = "{txtInput1.text}" />
            </s:HGroup>						
         </s:Panel>
         
         <s:Panel title = "Example #2 (Using &lt;fx:Binding&gt;)" width = "400" 
            height = "100" >
            <s:layout>
               <s:VerticalLayout paddingTop = "10" paddingLeft = "10" />
            </s:layout>
            
            <s:HGroup >
               <s:Label text = "Type here: " width = "100" paddingTop = "6" />
               <s:TextInput id = "txtInput3" />	
            </s:HGroup>
            
            <s:HGroup >
               <s:Label text = "Copied text: " width = "100" paddingTop = "6" />
               <s:Label id = "txtInput4" />
            </s:HGroup>						
         </s:Panel>
         
         <s:Panel title = "Example #3 (Using BindingUtils)" width = "400" 
            height = "100" >
            <s:layout>
               <s:VerticalLayout paddingTop = "10" paddingLeft = "10" />
            </s:layout>
            
            <s:HGroup >
               <s:Label text = "Type here: " width = "100" paddingTop = "6" />
               <s:TextInput id = "txtInput5" />	
            </s:HGroup>
            
            <s:HGroup >
               <s:Label text = "Copied text: " width = "100" paddingTop = "6" />
               <s:TextInput enabled = "false" id = "txtInput6" 
                  preinitialize = "txtInput6_preinitializeHandler(event)" />
            </s:HGroup>						
         </s:Panel>
      </s:VGroup>	 
   </s:BorderContainer>	
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

प्रत्येक उपयोगकर्ता इंटरफ़ेस निम्नलिखित तीन मुख्य पहलुओं पर विचार करता है -

  • UI Elements- ये मुख्य दृश्य तत्व हैं जो उपयोगकर्ता अंततः देखता है और साथ बातचीत करता है। फ्लेक्स व्यापक रूप से उपयोग किए जाने वाले व्यापक और सामान्य तत्वों की एक विशाल सूची प्रदान करता है, जिसे हम इस ट्यूटोरियल में शामिल करेंगे।

  • Layouts- वे परिभाषित करते हैं कि कैसे यूआई तत्वों को स्क्रीन पर व्यवस्थित किया जाना चाहिए और जीयूआई (ग्राफिकल यूजर इंटरफेस) को एक अंतिम रूप और अनुभव प्रदान करना चाहिए। यह भाग लेआउट चैप्टर में कवर किया जाएगा।

  • Behavior- ये घटनाएं तब होती हैं जब उपयोगकर्ता UI तत्वों के साथ इंटरैक्ट करता है। यह हिस्सा इवेंट हैंडलिंग चैप्टर में कवर किया जाएगा।

फ्लेक्स UI तत्वों

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

प्रत्येक बेसिक UI नियंत्रण UI घटक वर्ग से गुण प्राप्त करता है जो बदले में EventDispatcher और अन्य शीर्ष स्तर की कक्षाओं से गुण प्राप्त करता है।

अनु क्रमांक नियंत्रण और विवरण
1 फ्लेक्स EventDispatcher वर्ग

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

2 फ्लेक्स UIComponent

UIComponent class सभी विजुअल घटकों के लिए आधार वर्ग है, दोनों इंटरैक्टिव और गैर-इंटरैक्टिव।

बुनियादी नियंत्रण

निम्नलिखित कुछ महत्वपूर्ण बुनियादी नियंत्रण हैं -

अनु क्रमांक नियंत्रण और विवरण
1 लेबल

लेबल एक निम्न-स्तरीय UIComponent है जो समान रूप से स्वरूपित पाठ की एक या अधिक पंक्तियों को प्रस्तुत कर सकता है।

2 टेक्स्ट

पाठ नियंत्रण आपको अपने एप्लिकेशन में HTML सामग्री और साथ ही सामान्य पाठ प्रदर्शित करने देता है।

3 छवि

छवि नियंत्रण आपको रनटाइम पर JPEG, PNG, GIF और SWF फ़ाइलों को आयात करने देता है।

4 LinkButton

LinkButton नियंत्रण एक सीमा रहित बटन नियंत्रण है जिसकी सामग्री को तब उजागर किया जाता है जब कोई उपयोगकर्ता इस पर माउस ले जाता है।

प्रपत्र नियंत्रण उपयोगकर्ताओं को डेटा इनपुट करने की अनुमति देता है और उन्हें एप्लिकेशन के साथ सहभागिता क्षमता प्रदान करता है। प्रत्येक फॉर्म UI नियंत्रित करता है और UIComponent वर्ग से गुण प्राप्त करता है, जो बदले में EventDispatcher और अन्य शीर्ष स्तर की कक्षाओं से गुण प्राप्त करता है।

अनु क्रमांक नियंत्रण और विवरण
1 फ्लेक्स EventDispatcher वर्ग

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

2 फ्लेक्स UIComponent

UIComponent class सभी विजुअल घटकों के लिए आधार वर्ग है, दोनों इंटरैक्टिव और नॉनएक्टिव।

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

निम्नलिखित कुछ महत्वपूर्ण नियंत्रण हैं -

अनु क्रमांक नियंत्रण और विवरण
1 बटन

बटन घटक आमतौर पर इस्तेमाल किया जाने वाला आयताकार बटन है।

2 टॉगल बटन

ToggleButton घटक टॉगल बटन को परिभाषित करता है।

3 चेक बॉक्स

चेकबॉक्स घटक में एक वैकल्पिक लेबल और एक छोटा बॉक्स होता है जिसमें चेक मार्क हो सकता है या नहीं।

4 रंग चयनकर्ता

ColorPicker नियंत्रण उपयोगकर्ता को एक स्वैच सूची से रंग चुनने का एक तरीका प्रदान करता है।

5 सम्मिश्रण पटी

ComboBox नियंत्रण DropDownListBase नियंत्रण का एक बच्चा वर्ग है।

6 DateChooser

DateChooser नियंत्रण सप्ताह के दिन के लिए लेबल किए गए कॉलम के साथ महीने, वर्ष और महीने के दिनों का एक ग्रिड का नाम प्रदर्शित करता है।

7 रेडियो बटन

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

8 पाठ क्षेत्र

TextArea एक पाठ-प्रवेश नियंत्रण है जो उपयोगकर्ताओं को स्वरूपित पाठ की कई पंक्तियों को दर्ज करने और संपादित करने देता है।

9 पाठ इनपुट

TextInput एक पाठ-प्रवेश नियंत्रण है जो उपयोगकर्ताओं को समान रूप से स्वरूपित पाठ की एक पंक्ति में प्रवेश करने और संपादित करने देता है।

10 ड्राॅप डाउन लिस्ट

DropDownList नियंत्रण में एक ड्रॉप-डाउन सूची है जिसमें से उपयोगकर्ता एकल मान का चयन कर सकता है।

1 1 NumericStepper

NumericStepper नियंत्रण आपको एक सेट क्रम से संख्या का चयन करने देता है।

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

अनु क्रमांक नियंत्रण और विवरण
1 फ्लेक्स EventDispatcher वर्ग

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

2 फ्लेक्स UIComponent

UIComponent class सभी विजुअल घटकों के लिए आधार वर्ग है, दोनों इंटरैक्टिव और नॉनएक्टिव।

जटिल नियंत्रण

निम्नलिखित कुछ महत्वपूर्ण जटिल नियंत्रण हैं -

अनु क्रमांक नियंत्रण और विवरण
1 डेटा ग्रिड

DataGrid नियंत्रण स्क्रॉल शीर्ष ग्रिड के ऊपर स्तंभ शीर्षों की एक पंक्ति प्रदर्शित करता है।

2 AdvancedDataGrid

AdvancedDataGrid डेटा विज़ुअलाइज़ेशन सुविधाओं को जोड़ने के लिए मानक DataGrid नियंत्रण में कुछ अतिरिक्त कार्यक्षमता जोड़ता है।

3 मेन्यू

मेनू नियंत्रण व्यक्तिगत रूप से चयन करने योग्य विकल्पों का एक पॉप-अप मेनू बनाता है।

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

ProgressBar नियंत्रण समय के साथ किसी कार्य की प्रगति का एक दृश्य प्रतिनिधित्व प्रदान करता है।

5 रिच टेक्स्ट एडिटर

RichTextEditor नियंत्रण उपयोगकर्ताओं को पाठ दर्ज करने और प्रारूपित करने देता है।

6 TileList

द टाइललिस्ट नियंत्रण टाइलिस्ट नियंत्रण टाइलों में रखी गई कई वस्तुओं को प्रदर्शित करता है।

7 पेड़

ट्री कंट्रोल उपयोगकर्ता को एक विस्तार योग्य पेड़ के रूप में व्यवस्थित पदानुक्रम डेटा को देखने देता है।

8 वीडियो प्लेयर

VideoPlayer नियंत्रण एक स्किनेबल वीडियो प्लेयर है जो प्रगतिशील डाउनलोड, मल्टी-बिटरेट स्ट्रीमिंग और स्ट्रीमिंग वीडियो का समर्थन करता है।

9 अकॉर्डियन

एकॉर्डियन कंट्रोल में बच्चे एमएक्स कंटेनर या स्पार्क नेविगेटरकंटेंट कंटेनर का संग्रह होता है, लेकिन एक समय में उनमें से केवल एक ही दिखाई देता है।

10 TabNavigator

TabNavigator नियंत्रण में अपने बच्चे के कंटेनरों के बीच नेविगेट करने के लिए एक TabBar कंटेनर शामिल है।

1 1 ToggleButtonBar

ToggleButtonBar नियंत्रण बटन के एक क्षैतिज या ऊर्ध्वाधर समूह को परिभाषित करता है जो उनकी चयनित या अचयनित स्थिति को बनाए रखता है।

लेआउट पैनल नियंत्रण उपयोगकर्ताओं को पृष्ठ पर UI नियंत्रण व्यवस्थित करने के लिए प्रदान करता है। प्रत्येक लेआउट नियंत्रण UIComponent वर्ग के गुणों को विरासत में देता है जो बदले में EventDispatcher और अन्य शीर्ष स्तर की कक्षाओं से गुण प्राप्त करता है।

अनु क्रमांक नियंत्रण और विवरण
1 फ्लेक्स EventDispatcher वर्ग

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

2 फ्लेक्स UIComponent

UIComponent class सभी विजुअल घटकों के लिए आधार वर्ग है, दोनों इंटरैक्टिव और नॉनएक्टिव।

लेआउट पैनल्स

निम्नलिखित कुछ महत्वपूर्ण लेआउट पैनल हैं -

अनु क्रमांक पैनल और विवरण
1 BorderContainer

BorderContainer वर्ग CSS शैलियों का एक सेट प्रदान करता है जो बॉर्डर और कंटेनर के बैकग्राउंड फिल की उपस्थिति को नियंत्रित करता है।

2 प्रपत्र

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

3 VGroup

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

4 HGroup

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

5 पैनल

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

6 SkinnableContainer

SkinnableContainer वर्ग स्किनेबल कंटेनरों के लिए आधार वर्ग है जो दृश्य सामग्री प्रदान करता है।

7 टैब पट्टी

टैबबार समान टैब का एक सेट प्रदर्शित करता है।

8 TitleWindow

TitleWindow एक विस्तृत बटन और चाल क्षेत्र शामिल करने के लिए पैनल का विस्तार करता है।

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

प्रत्येक प्रभाव गुण वर्ग से गुण प्राप्त करता है जो बदले में EventDispatcher और अन्य शीर्ष स्तर की कक्षाओं से गुण प्राप्त करता है।

अनु क्रमांक प्रभाव और विवरण
1 फ्लेक्स इफेक्ट क्लास

प्रभाव वर्ग एक सार आधार वर्ग है जो सभी फ्लेक्स प्रभावों की मूल कार्यक्षमता को परिभाषित करता है। यह वर्ग सभी प्रभावों के लिए आधार कारखाना वर्ग को परिभाषित करता है।

मूल प्रभाव

निम्नलिखित कुछ महत्वपूर्ण बेसिक विजुअल इफेक्ट्स हैं -

अनु क्रमांक प्रभाव और विवरण
1 मुरझाना

फीका प्रभाव एक घटक की अल्फा संपत्ति को दर्शाता है।

2 WipeLeft

WipeLeft वर्ग एक पोंछे प्रभाव को परिभाषित करता है।

3 WipeRight

WipeRight वर्ग एक पोंछ सही प्रभाव को परिभाषित करता है।

4 Move3D

Move3D वर्ग x, y और z आयामों में लक्ष्य ऑब्जेक्ट को ले जाता है।

5 Scale3D

स्केल 3 डी वर्ग रूपांतरण केंद्र के चारों ओर तीन आयामों में लक्ष्य वस्तु को मापता है।

6 Rotate3D

Rotate3D वर्ग x, y, या z axes के चारों ओर तीन आयामों में लक्ष्य वस्तु को घुमाता है।

7 चेतन

यह चेतन प्रभाव मानों के बीच गुणों के एक मनमाने सेट को दर्शाता है। गति गुण सेट करके गुणों और मूल्यों को चेतन करने के लिए निर्दिष्ट करें।

फ्लेक्स अनुप्रयोग के भीतर स्थिति या उपयोगकर्ता इंटरैक्शन के आधार पर डेटा को एक वस्तु से दूसरी वस्तु में पारित करने के लिए घटना की अवधारणा का उपयोग करता है।

ActionScript में एक जेनेरिक है Eventघटनाओं के साथ काम करने के लिए आवश्यक कार्यक्षमता को परिभाषित करने वाला वर्ग। जब भी कोई घटना फ्लेक्स एप्लिकेशन के भीतर होती है, तो इवेंट क्लास पदानुक्रम से तीन प्रकार की वस्तुएँ बनाई जाती हैं।

घटना में निम्नलिखित तीन प्रमुख गुण हैं

अनु क्रमांक संपत्ति विवरण
1

Type

typeइस बारे में बताता है कि किस तरह की घटना हुई। यह क्लिक, इनिशियलाइज़, माउसओवर, परिवर्तन आदि हो सकता है। वास्तविक मानों को माउसइवेंट.क्लिक जैसे स्थिरांक द्वारा दर्शाया जाएगा।

2

Target

target ईवेंट की संपत्ति उस घटक के लिए एक ऑब्जेक्ट संदर्भ है, जिसने ईवेंट उत्पन्न किया है। यदि आप क्लिक बटन पर क्लिक करते हैं, तो क्लिक करेंबटन, उस क्लिक इवेंट का लक्ष्य क्लिकबटन होगा

3

CurrentTarget

currentTargetसंपत्ति कंटेनर पदानुक्रम बदलती है। यह मुख्य रूप से घटनाओं के प्रवाह से संबंधित है।

घटना प्रवाह चरण

ईवेंट हैंडलर की तलाश में एक घटना तीन चरणों से गुजरती है।

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

Capture

कैप्चर चरण में, कार्यक्रम बाहरी (या शीर्ष) माता-पिता से सबसे अंतरतम तक घटना संचालकों की तलाश शुरू करेगा। कैप्चर चरण ऑब्जेक्ट के माता-पिता पर रुक जाता है जिसने घटना को ट्रिगर किया।

2

Target

लक्ष्य चरण में, इवेंट को ट्रिगर करने वाले घटक को इवेंट हैंडलर के लिए चेक किया जाता है।

3

Bubble

बबल चरण कैप्चर चरण के पीछे है, संरचना के माध्यम से वापस काम कर रहा है, लक्ष्य घटक के माता-पिता से।

निम्नलिखित आवेदन कोड पर विचार करें -

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%" minWidth = "500" minHeight = "500" >
   
   <s:Panel>
      <s:Button id = "clickMeButton" label = "Click Me!" click = "doAction( );" />
   </s:Panel>   
</s:Application>

जब उपयोगकर्ता बटन पर क्लिक करता है, तो वह पैनल या एप्लिकेशन पर भी क्लिक करता है।

ईवेंट हैंडलर असाइनमेंट की तलाश में घटना तीन चरणों से गुजरती है।

आइए हम फ्लेक्स एप्लिकेशन में ईवेंट हैंडिंग का परीक्षण करने के लिए नीचे दिए गए चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009"
   xmlns:s = "library://ns.adobe.com/flex/spark"
   xmlns:mx = "library://ns.adobe.com/flex/mx
   width = "100%" height = "100%" minWidth = "500" minHeight = "500">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         protected function reportEvent(event:MouseEvent):void {
            var target:String = event.target.id;
            var currentTarget:String = event.target.id;
            var eventPhase: String;

            if(event.target is Button) {
               var button:Button = event.target as Button;
               target = button.label + " Button";
            } else if(event.target is HGroup) {
               var hGroup:HGroup = event.target as HGroup;
               target = hGroup.id + " HGroup";
            } else if(event.target is Panel) {
               var panel:Panel = event.target as Panel;
               target = panel.id + " Panel";
            }

            if(event.currentTarget is Button) {
               var button1:Button = event.currentTarget as Button;
               currentTarget = button1.label + " Button";
            } else if(event.currentTarget is HGroup) {
               var hGroup1:HGroup = event.currentTarget as HGroup;
               currentTarget = hGroup1.id + " HGroup";
            } else if(event.currentTarget is Panel) {
               var panel1:Panel = event.currentTarget as Panel;
               currentTarget = panel1.id + " Panel";
            }

            var eventPhaseInt:uint = event.eventPhase;

            if(eventPhaseInt == EventPhase.AT_TARGET) {
               eventPhase = "Target";
            } else if(eventPhaseInt == EventPhase.BUBBLING_PHASE) {
               eventPhase = "Bubbling";
            } else if(eventPhaseInt == EventPhase.CAPTURING_PHASE) {
               eventPhase = "Capturing";
            }
            
            reports.text += " Target: " + target + "\n currentTarget: " +
               currentTarget + "\n Phase: " + eventPhase + "\n----------\n";
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "630" height = "480" id = "mainContainer"
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "10"
         horizontalAlign = "center" verticalAlign = "middle">
         <s:Label id = "lblHeader" text = "Event Handling Demonstration"
            fontSize = "40" color = "0x777777" styleName = "heading" />

         <s:Panel id = "parentPanel" title = "Main Parent"
            click = "reportEvent(event)" width = "500"
            height = "100" includeInLayout = "true" visible = "true">
            <s:layout>
               <s:VerticalLayout  gap = "10" verticalAlign = "middle"
                  horizontalAlign = "center" />
            </s:layout>
            
            <s:HGroup id = "mainHGroup" click = "reportEvent(event)">
               <s:Button label = "Click Me" click = "reportEvent(event)" />
            </s:HGroup>
         </s:Panel>

         <s:Panel id = "reportPanel" title = "Events" width = "500" height = "230">
            <mx:Text id = "reports" />
         </s:Panel>
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

कस्टम घटक बनाने के लिए फ्लेक्स दो तरीके प्रदान करता है।

  • एक्शनस्क्रिप्ट का उपयोग करना
  • MXML का उपयोग करना

एक्शनस्क्रिप्ट का उपयोग करना

आप मौजूदा घटक का विस्तार करके एक घटक बना सकते हैं। फ्लैश बिल्डर का उपयोग करके एक घटक बनाने के लिए, पर क्लिक करेंFile > New > ActionScript Class

नीचे दिखाए अनुसार विवरण दर्ज करें -

फ्लैश बिल्डर निम्नलिखित CustomButton.as फ़ाइल बनाएगा।

package com.tutorialspoint.client {
   import spark.components.Button;

   public class CustomButton extends Button {
      public function CustomButton() {
         super();
      }
   }
}

MXML का उपयोग करना

आप मौजूदा घटक का विस्तार करके एक घटक बना सकते हैं। फ्लैश बिल्डर का उपयोग करके एक घटक बनाने के लिए, पर क्लिक करेंFile > New > MXML Component

नीचे दिखाए अनुसार विवरण दर्ज करें।

फ्लैश बिल्डर निम्नलिखित CustomLogin.mxml फ़ाइल बनाएगा।

<?xml version = "1.0" encoding = "utf-8"?>
<s:Group xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx" 
   width = "400" height = "300">
</s:Group>

फ्लेक्स एप्लिकेशन में कस्टम नियंत्रण का परीक्षण करने के लिए निम्नलिखित चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 ऊपर बताए अनुसार CustomLogin.mxml और CustomButton.as घटक बनाएं । इन फाइलों को नीचे बताए अनुसार संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
4 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/client/CustomLogin.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Group xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx" width = "400" height = "300">
   
   <s:Form>
      <s:FormItem label = "UserName:">
         <s:TextInput width = "200" />
      </s:FormItem>
      
      <s:FormItem label = "Password:">
         <s:TextInput width = "200" displayAsPassword = "true" />
      </s:FormItem>
      
      <s:FormItem>
         <s:Button label = "Login" />
      </s:FormItem>		
   </s:Form>
</s:Group>

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/client/CustomButton.as

package com.tutorialspoint.client {
   import spark.components.Button;

   public class CustomButton extends Button {
      
      public function CustomButton() {
         super();
         this.setStyle("color","green");
         this.label = "Submit";
      }
   }
}

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/client/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx" 
   xmlns:client = "com.tutorialspoint.client.*"
   initialize = "application_initializeHandler(event)">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
        import mx.events.FlexEvent;

        protected function application_initializeHandler(event:FlexEvent):void {
           //create a new custom button
           var customButton: CustomButton = new CustomButton();
           asPanel.addElement(customButton);
        }

      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "630" height = "480" id = "mainContainer" 
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "10" 
         horizontalAlign = "center" verticalAlign = "middle">
         <s:Label id = "lblHeader" text = "Custom Controls Demonstration" 
            fontSize = "40" color = "0x777777" styleName = "heading" />

         <s:Panel title = "Using MXML Component" width = "400" height = "200">
            <client:CustomLogin>			
            </client:CustomLogin>		
         </s:Panel>
         
         <s:Panel  title = "Using AS Component" width = "400" height = "100">
            <s:VGroup id = "asPanel" width = "100%" height = "100%" gap = "10" 
               horizontalAlign = "center" verticalAlign = "middle">
            </s:VGroup>
         </s:Panel>
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

फ्लेक्स ग्राहक पक्ष को सर्वर साइड डेटा प्रदान करने के लिए आरपीसी सेवाएं प्रदान करता है। फ्लेक्स सर्वर साइड डेटा पर उचित मात्रा में नियंत्रण प्रदान करता है।

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

  • फ्लेक्स RPC Sservices को किसी भी सर्वर साइड प्रौद्योगिकियों के साथ एकीकृत किया जा सकता है।

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

फ्लेक्स निम्नलिखित तीन प्रकार की RPC सेवाएँ प्रदान करता है

अनु क्रमांक RPC सेवा और विवरण
1

HttpService

<mx: MXT फ़ाइल में HTTPService ऑब्जेक्ट का प्रतिनिधित्व करने के लिए HTTPService> टैग का उपयोग किया जाता है। जब आप HTTPService ऑब्जेक्ट के भेजने () विधि के लिए कॉल करते हैं, तो यह निर्दिष्ट URL के लिए एक HTTP अनुरोध करता है, और एक HTTP प्रतिक्रिया दी जाती है। आप HTTP HEAD, विकल्प, TRACE और DELETE विधियों का भी उपयोग कर सकते हैं।

2

WebService

<Mx: WebService> का उपयोग SOAP-आज्ञाकारी वेब सेवाओं के संचालन के लिए किया जाता है।

3

RemoteObject

<Mx: RemoteObject> टैग का उपयोग MXML फ़ाइल में HTTPService ऑब्जेक्ट का प्रतिनिधित्व करने के लिए किया जाता है। यह टैग आपको एक्शन मैसेज फॉर्मेट (एएमएफ) एन्कोडिंग का उपयोग करके जावा ऑब्जेक्ट के तरीकों तक पहुंच प्रदान करता है।

हम HTTP सेवा पर विस्तार से चर्चा करने जा रहे हैं। हम सर्वर पर रखी एक XML स्रोत फ़ाइल का उपयोग करेंगे और इसे HTTP सेवा के माध्यम से क्लाइंट साइड में एक्सेस करेंगे।

Items.xml

<items>
   <item name = "Book" description = "History of France"></item>
   <item name = "Pen" description = "Parker Pen"></item>
   <item name = "Pencil" description = "Stationary"></item>
<items>

HTTPService घोषणा

अब एक HTTPService की घोषणा करें और इसे उपरोक्त फ़ाइल का url पास करें

<fx:Declarations>
   <mx:HTTPService id = "itemRequest" 
   url = "http://www.tutorialspoint.com/flex/Items.xml" />
</fx:Declarations>

आरपीसी कॉल

ItemRequest.send () विधि पर कॉल करें और आइटम के अंतिम ऑब्जेक्ट से आइटम को हटा दें। Flex UI घटक कोRequest webservice की ऑब्जेक्ट।

...
itemRequest.send();
...
<mx:DataGrid id = "dgItems" height = "80%" width = "75%" 
   dataProvider = "{itemRequest.lastResult.items.item}">
   <mx:columns>
      <mx:DataGridColumn headerText = "Name" dataField = "name" />
      <mx:DataGridColumn headerText = "Description" dataField = "description" />
   </mx:columns>
</mx:DataGrid>

RPC सेवा कॉल उदाहरण

अब, फ्लेक्स एप्लिकेशन में RPC सेवाओं के परीक्षण के लिए निम्नलिखित चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx" 
   minWidth = "500" minHeight = "500" creationComplete = "init(event)">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.events.FlexEvent;
         import mx.rpc.events.FaultEvent;
         import mx.rpc.events.ResultEvent;

         protected function init(event:FlexEvent):void {
            itemRequest.send();				
         }
      ]]>
   </fx:Script>
   
   <fx:Declarations>
      <mx:HTTPService id = "itemRequest" 
         url = "http://www.tutorialspoint.com/flex/Items.xml" />
   </fx:Declarations>
   
   <s:BorderContainer width = "630" height = "480" id = "mainContainer" 
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "10" 
         horizontalAlign = "center" verticalAlign = "middle">
         <s:Label id = "lblHeader" text = "RPC Service Demonstration" 
            fontSize = "40" color = "0x777777" styleName = "heading" />
         
         <s:Panel id = "parentPanel" title = "Using RPC Services"  
            width = "500" height = "200" >
            <s:layout>
               <s:VerticalLayout  gap = "10" 
                  verticalAlign = "middle" horizontalAlign = "center" />
            </s:layout>						
            
            <mx:DataGrid id = "dgItems" height = "80%" width = "75%" 
               dataProvider = "{itemRequest.lastResult.items.item}">
               
               <mx:columns>
                  <mx:DataGridColumn headerText = "Name" dataField = "name" />
                  <mx:DataGridColumn headerText = "Description" 
                     dataField = "description" />
               </mx:columns>
            </mx:DataGrid>
         </s:Panel>	
      </s:VGroup>	 
   </s:BorderContainer>	
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

फ्लैश बिल्डर 4 में फ्लेक्स डेवलपमेंट साइकल में FlexUnit एकीकरण के लिए एक उत्कृष्ट इनबिल्ट सपोर्ट है।

टेस्ट केस क्लास बनाएं

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

फ़्लैश बिल्डर का उपयोग करके टेस्ट केस क्लास बनाने के लिए, पर क्लिक करें File > New > Test Case Class। नीचे दिखाए अनुसार विवरण दर्ज करें।

फ्लैश बिल्डर निम्नलिखित TestClass1.as एक फ़ाइल बनाएगा।

package com.tutorialspoint.client {
   public class TestClass1 {		
      [Before]
      public function setUp():void {}

      [After]
      public function tearDown():void {}

      [BeforeClass]
      public static function setUpBeforeClass():void {}

      [AfterClass]
      public static function tearDownAfterClass():void {}	
   }
}

FlexUnit एकीकरण उदाहरण

अब, एक फ्लेक्स एप्लिकेशन में FlexUnit इंटीग्रेशन का परीक्षण करने के लिए चरणों का पालन करें -

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 ऊपर वर्णित के अनुसार TestClass1.as परीक्षण केस बनाएँ और नीचे बताए अनुसार TestClass1.as संशोधित करें।
4 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

फ़ाइल के रूप में संशोधित सामग्री निम्नलिखित है src/com.tutorialspoint/client/TestClass1.as

package com.tutorialspoint.client {
   import org.flexunit.asserts.assertEquals;

   public class TestClass1 {		
      private var counter: int = 1;

      [Before]
      public function setUp():void {
         //this code will run before every test case execution
      }

      [After]
      public function tearDown():void {
         //this code will run after every test case execution
      }

      [BeforeClass]
      public static function setUpBeforeClass():void {
         //this code will run once when test cases start execution
      }

      [AfterClass]
      public static function tearDownAfterClass():void {
         //this code will run once when test cases ends execution
      }      

      [Test]  
      public function testCounter():void { 
         assertEquals(counter, 1);
      }
   }
}

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx" 
   minWidth = "500" minHeight = "500">
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाते हैं, तो हमें सामान्य मोड में संकलित करें जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन एप्लिकेशन बनाएं ।

चल रहे टेस्ट केस

अब पैकेज एक्सप्लोरर में TestClass1 पर राइट क्लिक करें और चुनें Run As > FlexUnit Tests। आपको फ़्लैश बिल्डर परीक्षण विंडो में निम्न आउटपुट दिखाई देगा।

फ़्लैश बिल्डर ब्राउज़र में परीक्षा परिणाम भी दिखाता है।

फ्लेक्स डिबगिंग की उत्कृष्ट क्षमता प्रदान करता है फ्लेक्स कोड और फ्लैश बिल्डर 4 में एक उत्कृष्ट अंतर्निहित डिबगर और डिबगिंग परिप्रेक्ष्य समर्थन है।

  • डिबग मोड के दौरान, फ्लेक्स एप्लिकेशन फ्लैश बिल्डर 4 में निर्मित फ़्लैश प्लेयर डीबगर संस्करण पर चलता है जो डिबगिंग क्षमता का समर्थन करता है।

  • तो डेवलपर्स को फ्लैश बिल्डर में एक आसान और इनबिल्ट डिबगिंग कॉन्फ़िगरेशन मिलता है

इस लेख में, हम फ़्लैश बिल्डर का उपयोग करके फ्लेक्स क्लाइंट कोड को डीबग करने का उपयोग प्रदर्शित करेंगे। हम निम्नलिखित कार्य करेंगे

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

डिबगिंग उदाहरण

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%"
   minWidth = "500" minHeight = "500" 
   initialize = "application_initializeHandler(event)">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            Alert.show("Hello World!");
         }

         protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "My Hello World Application";
         }
      ]]>
   </fx:Script>

   <s:BorderContainer width = "500" height = "500" id = "mainContainer"
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50" horizontalAlign = "center"
         verticalAlign = "middle">
         <s:Label id = "lblHeader" fontSize = "40" color = "0x777777"
            styleName = "heading" />
         <s:Button label = "Click Me!" id = "btnClickMe"
            click = "btnClickMe_clickHandler(event)" styleName = "button" />
      </s:VGroup>
   </s:BorderContainer>
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाते हैं, तो हमें सामान्य मोड में संकलित करें जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन एप्लिकेशन बनाएं ।

चरण 1 - ब्रेकपॉइंट्स रखें

HelloWorld.mxml के हैंडलर को इनिशियलाइज़ करने की पहली लाइन पर एक ब्रेकपॉइंट रखें

चरण 2 - डिबग आवेदन

अब

डिबग एप्लिकेशन मेनू पर क्लिक करें और चयन करेंHelloWorld आवेदन डिबग करने के लिए आवेदन।

यदि सब कुछ ठीक है, तो एप्लिकेशन ब्राउज़र में लॉन्च होगा और आपको फ़्लैश बिल्डर कंसोल में डीबग लॉग के बाद दिखाई देगा।

[SWF] \HelloWorld\bin-debug\HelloWorld.swf 
- 181,509 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\1 
- 763,122 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\2 
- 1,221,837 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\3 
- 1,136,788 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\4 
- 2,019,570 bytes after decompression
[SWF] \HelloWorld\bin-debug\HelloWorld.swf\[[DYNAMIC]]\5 
- 318,334 bytes after decompression

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

आप निलंबित धागे के लिए स्टैकट्रेस देख सकते हैं।

आप भावों के मान देख सकते हैं।

आप विराम बिंदुओं की सूची देख सकते हैं।

अब F6 को तब तक दबाए रखें जब तक आप application_initializeHandler () विधि की अंतिम पंक्ति तक नहीं पहुंच जाते। फ़ंक्शन कुंजियों के संदर्भ के रूप में, F6 लाइन द्वारा कोड लाइन का निरीक्षण करता है, आगे और F8 के अंदर F5 चरण फिर से शुरू होंगे। अब आप application_initializeHandler () विधि के सभी चर के मूल्यों की सूची देख सकते हैं।

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

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

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

Compile Time Internationalization

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

2

Run Time Internationalization

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

एक फ्लेक्स अनुप्रयोग के अंतर्राष्ट्रीयकरण का वर्कफ़्लो

चरण 1 - फ़ोल्डर संरचना बनाएं

फ्लेक्स प्रोजेक्ट के src फोल्डर के अंतर्गत एक लोकेल फोल्डर बनाएँ। यह उन सभी लोकेशन फाइल्स के लिए पेरेंट डायरेक्टरी होगी, जो एप्लीकेशन सपोर्ट करेगी। स्थानीय फ़ोल्डर के अंदर, सबफ़ोल्डर्स बनाएं, जो अनुप्रयोग के प्रत्येक स्थान के लिए समर्थित हो। एक स्थानीय नामकरण के लिए सम्मेलन है

{language}_{country code}

उदाहरण के लिए, en_US संयुक्त राज्य अमेरिका की अंग्रेजी का प्रतिनिधित्व करता है। स्थानीय de_DE जर्मन का प्रतिनिधित्व करता है। नमूना आवेदन दो सामान्य भाषाओं का समर्थन करेगा: अंग्रेजी, और जर्मन।

चरण 2 - गुण फ़ाइलें बनाएँ

एप्लिकेशन में उपयोग किए जाने वाले संदेशों के साथ गुण फ़ाइल बनाएं। हमने एक बनाया हैHelloWorldMessages.properties के तहत दर्ज करें src > locale > en_US हमारे उदाहरण में फ़ोल्डर।

enterName = Enter your name
clickMe = Click Me
applicationTitle = Application Internationalization Demonstration
greeting = Hello {0}

अनुवादित मानों के लिए विशिष्ट मान वाले गुण फ़ाइलें बनाएँ। हमने एक बनाया हैHelloWorldMessages.properties के तहत दर्ज करें src > locale > de_DEहमारे उदाहरण में फ़ोल्डर। इस फ़ाइल में जर्मन भाषा में अनुवाद हैं। _de जर्मन लोकेल को निर्दिष्ट करता है और हम अपने एप्लिकेशन में जर्मन भाषा का समर्थन करने जा रहे हैं।

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

enterName = Geben Sie Ihren Namen
clickMe = Klick mich
applicationTitle = Anwendung Internationalisierung Demonstration
greeting = Hallo {0}

चरण 3 - कंपाइलर विकल्प निर्दिष्ट करें

  • अपनी परियोजना पर राइट-क्लिक करें और गुण चुनें।

  • फ्लेक्स कम्पाइलर का चयन करें, और अतिरिक्त कंपाइलर तर्क सेटिंग्स में निम्न जोड़ें -

-locale en_US de_DE
  • अपनी परियोजना पर राइट-क्लिक करें और गुण चुनें।

  • फ्लेक्स बिल्ड पथ का चयन करें, और निम्न स्रोत पथ सेटिंग्स में जोड़ें -

src\locale\{locale}

आंतरिककरण उदाहरण

अब एक फ्लेक्स एप्लिकेशन में इंटरनलिज़ेशन तकनीक का परीक्षण करने के लिए निम्नलिखित चरणों का पालन करें

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
   <s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx" 
   minWidth = "500" minHeight = "500">
   
   <fx:Metadata>
      [ResourceBundle("HelloWorldMessages")]
   </fx:Metadata> 
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
      <![CDATA[
         import mx.controls.Alert;
         [Bindable]
         private var locales:Array =  [{label:"English", locale:"en_US"},
            {label:"German", locale:"de_DE"}];

         private function comboChangeHandler():void {
           resourceManager.localeChain = [localeComboBox.selectedItem.locale];
         }

         protected function clickMe_clickHandler(event:MouseEvent):void {
            var name:String = txtName.text;
            var inputArray:Array = new Array();
            inputArray.push(name);
            Alert.show(resourceManager.getString('HelloWorldMessages'
               ,'greeting',inputArray));
         }
      ]]>
   </fx:Script>
   
   <s:BorderContainer width = "500" height = "500" id = "mainContainer" 
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50" 
	  horizontalAlign = "center" verticalAlign = "middle">
         
         <s:Label id = "lblHeader" fontSize = "40" 
            color = "0x777777" 
            text  = "{resourceManager.getString('HelloWorldMessages','applicationTitle')}"
            styleName = "heading" width = "90%" height = "150" />
         
         <s:Panel width = "300" height = "150">
            <s:layout>
               <s:VerticalLayout paddingTop = "10" paddingLeft = "10" />
            </s:layout>
            
            <s:HGroup >
               <s:Label text = "{resourceManager.getString('HelloWorldMessages','enterName')}"
                  paddingTop = "2" />			
               <s:TextInput id = "txtName" />
            </s:HGroup>
            
            <s:Button 
               label = "{resourceManager.getString('HelloWorldMessages','clickMe')}" 
               click = "clickMe_clickHandler(event)" right = "10" />	
         </s:Panel>
         
         <mx:ComboBox id = "localeComboBox" dataProvider = "{locales}"
            change = "comboChangeHandler()" />
      </s:VGroup>	
   </s:BorderContainer>	
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

भाषा का उपयोग करके भाषा को नीचे छोड़ें और परिणाम देखें।

फ्लेक्स एक विशेष वर्ग प्रदान करता है FlexPrintJob फ्लेक्स वस्तुओं को मुद्रित करने के लिए।

  • FlexPrintJob का उपयोग एक या एक से अधिक फ्लेक्स ऑब्जेक्ट्स को प्रिंट करने के लिए किया जा सकता है, जैसे कि फॉर्म या VBox कंटेनर।

  • FlexPrintJob ऑब्जेक्ट और इसमें मौजूद सभी ऑब्जेक्ट्स को प्रिंट करता है।

  • ऑब्जेक्ट सभी या प्रदर्शित इंटरफ़ेस का हिस्सा हो सकते हैं।

  • ऑब्जेक्ट घटक हो सकते हैं जो विशेष रूप से मुद्रण के लिए डेटा को प्रारूपित करते हैं।

  • FlexPrintJob वर्ग आपको पृष्ठ को फिट करने के लिए आउटपुट को स्केल करने देता है।

  • FlexPrintJob वर्ग किसी ऑब्जेक्ट को प्रिंट करने के लिए स्वचालित रूप से कई पृष्ठों का उपयोग करता है जो एक पृष्ठ पर फिट नहीं होता है।

  • FlexPrintJob वर्ग ऑपरेटिंग सिस्टम को प्रिंट संवाद बॉक्स प्रदर्शित करने का कारण बनता है। आप कुछ उपयोगकर्ता कार्रवाई के बिना प्रिंट नहीं कर सकते।

प्रिंट कार्य तैयार करें और भेजें

आप प्रिंट कार्य तैयार करके और भेजकर आउटपुट प्रिंट करते हैं। चलो FlexPrintJob वर्ग का एक उदाहरण बनाते हैं

var printJob:FlexPrintJob = new FlexPrintJob();

प्रिंट कार्य शुरू करें

printJob.start();

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

printJob.addObject(myObject, FlexPrintJobScaleType.MATCH_WIDTH);

प्रत्येक वस्तु एक नए पृष्ठ पर शुरू होती है। प्रिंट कार्य को प्रिंटर पर भेजें

printJob.send();

मुद्रण उदाहरण

कदम विवरण
1 फ्लेक्स में बताए अनुसार एक पैकेज com.tutorialspoint.client के तहत एक नाम HelloWorld के साथ एक परियोजना बनाएं - एप्लिकेशन अध्याय बनाएं
2 नीचे दिए गए अनुसार HelloWorld.mxml को संशोधित करें। बाकी फाइलों को अपरिवर्तित रखें।
3 यह सुनिश्चित करने के लिए एप्लिकेशन को संकलित करें और चलाएं कि व्यावसायिक तर्क आवश्यकताओं के अनुसार काम कर रहा है।

निम्नलिखित संशोधित mxml फ़ाइल की सामग्री है src/com.tutorialspoint/HelloWorld.mxml

<?xml version = "1.0" encoding = "utf-8"?>
<s:Application xmlns:fx = "http://ns.adobe.com/mxml/2009" 
   xmlns:s = "library://ns.adobe.com/flex/spark" 
   xmlns:mx = "library://ns.adobe.com/flex/mx"
   width = "100%" height = "100%"
   minWidth = "500" minHeight = "500" 
   initialize = "application_initializeHandler(event)">
   
   <fx:Style source = "/com/tutorialspoint/client/Style.css" />
   <fx:Script>
     <![CDATA[
         import mx.controls.Alert;
         import mx.events.FlexEvent;
         import mx.printing.FlexPrintJob;
         import mx.printing.FlexPrintJobScaleType;
         
         protected function btnClickMe_clickHandler(event:MouseEvent):void {
            
            // Create an instance of the FlexPrintJob class.
            var printJob:FlexPrintJob = new FlexPrintJob();
         
            // Start the print job.
            if (printJob.start() != true) return;

            // Add the object to print. Do not scale it.
            printJob.addObject(myDataGrid, FlexPrintJobScaleType.NONE);

            // Send the job to the printer.
            printJob.send();
        }

        protected function application_initializeHandler(event:FlexEvent):void {
            lblHeader.text = "My Hello World Application";				
        }
     ]]>
   </fx:Script>
   
   <s:BorderContainer width = "500" height = "500" id = "mainContainer" 
      styleName = "container">
      <s:VGroup width = "100%" height = "100%" gap = "50"
         horizontalAlign = "center" 
         verticalAlign = "middle">
         <s:Label id = "lblHeader" fontSize = "40" color = "0x777777" 
            styleName = "heading" />
         
         <mx:DataGrid id = "myDataGrid" width = "300">
            <mx:dataProvider>
               <fx:Object Product = "Flex" Code = "1000" />
               <fx:Object Product = "GWT" Code = "2000" />
               <fx:Object Product = "JAVA" Code = "3000" />
               <fx:Object Product = "JUnit" Code = "4000" />
            </mx:dataProvider>
         </mx:DataGrid>
         
         <s:Button label = "Print Me!" id = "btnClickMe" 
            click = "btnClickMe_clickHandler(event)" 
            styleName = "button" />
      </s:VGroup>	
   </s:BorderContainer>	
</s:Application>

एक बार जब आप किए गए सभी परिवर्तनों के साथ तैयार हो जाएं, तो हमें एप्लिकेशन को सामान्य मोड में संकलित करें और चलाएं जैसा कि हमने फ्लेक्स में किया था - एप्लिकेशन अध्याय बनाएं । यदि आपके आवेदन में सब कुछ ठीक है, तो यह निम्नलिखित परिणाम देगा: [ इसे ऑनलाइन आज़माएं ]

प्रिंट मी बटन पर क्लिक करें और आप नीचे दिखाए गए डेटा ग्रिड का प्रिंटआउट देख सकते हैं।