Android - शैलियाँ और विषय-वस्तु
ए styleसंसाधन प्रारूप को परिभाषित करता है और UI की तलाश करता है। एक शैली एक व्यक्तिगत दृश्य (एक लेआउट फ़ाइल के भीतर से) या संपूर्ण गतिविधि या एप्लिकेशन (प्रकट फ़ाइल के भीतर से) पर लागू की जा सकती है।
शैलियों को परिभाषित करना
एक शैली को XML संसाधन में परिभाषित किया गया है जो लेआउट को निर्दिष्ट करने वाले XML से अलग है। यह XML फ़ाइल के अंतर्गत रहता हैres/values/ आपके प्रोजेक्ट की निर्देशिका और आपके पास होगी <resources>रूट नोड के रूप में जो शैली फ़ाइल के लिए अनिवार्य है। XML फ़ाइल का नाम मनमाना है, लेकिन इसे .xml एक्सटेंशन का उपयोग करना होगा।
आप प्रति फ़ाइल का उपयोग करके कई शैलियों को परिभाषित कर सकते हैं <style>टैग लेकिन प्रत्येक शैली का अपना नाम होगा जो विशिष्ट रूप से शैली की पहचान करता है। एंड्रॉइड स्टाइल विशेषताओं का उपयोग करके सेट किया गया है<item> नीचे दिखाए अनुसार टैग -
<?xml version="1.0" encoding="utf-8"?>
<resources>
<style name="CustomFontStyle">
<item name="android:layout_width">fill_parent</item>
<item name="android:layout_height">wrap_content</item>
<item name="android:capitalize">characters</item>
<item name="android:typeface">monospace</item>
<item name="android:textSize">12pt</item>
<item name="android:textColor">#00FF00</item>/>
</style>
</resources>
<आइटम> का मान एक कीवर्ड स्ट्रिंग, एक हेक्स रंग, किसी अन्य संसाधन प्रकार का संदर्भ या शैली की संपत्ति के आधार पर अन्य मान हो सकता है।
शैलियों का उपयोग करना
एक बार आपकी शैली परिभाषित हो जाने के बाद, आप इसे अपने XML लेआउट फ़ाइल में उपयोग कर सकते हैं style विशेषता इस प्रकार है -
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<TextView
android:id="@+id/text_id"
style="@style/CustomFontStyle"
android:text="@string/hello_world" />
</LinearLayout>
एंड्रॉइड स्टाइल से संबंधित अवधारणा को समझने के लिए, आप स्टाइल डेमो उदाहरण की जांच कर सकते हैं ।
स्टाइल इनहेरिटेंस
एंड्रॉइड वेब डिज़ाइन में कैस्केडिंग स्टाइल शीट के रूप में बहुत समान तरीके से स्टाइल इनहेरिटेंस का समर्थन करता है। आप मौजूदा शैली से गुणों को प्राप्त करने के लिए इसका उपयोग कर सकते हैं और फिर केवल उन गुणों को परिभाषित कर सकते हैं जिन्हें आप बदलना या जोड़ना चाहते हैं।
एक कस्टम थीम लागू करने के लिए MyAndroidApp / res / values / themes.xml बनाएं या संपादित करें और निम्नलिखित जोड़ें -
<resources>
...
<style name="MyCustomTheme" parent="android:style/Theme">
<item name="android:textColorPrimary">#ffff0000</item>
</style>
...
</resources>
अपने AndroidManifest.xml में उन गतिविधियों के विषय को लागू करें जिन्हें आप स्टाइल करना चाहते हैं -
<activity
android:name="com.myapp.MyActivity"
...
android:theme="@style/MyCustomTheme"
/>
आपकी नई थीम को आपकी गतिविधि पर लागू किया जाएगा, और पाठ अब चमकदार लाल है।
थीम विशेषताओं में रंग लागू करना
आपके रंग संसाधन को कुछ थीम विशेषताओं पर लागू किया जा सकता है, जैसे कि विंडो पृष्ठभूमि और प्राथमिक पाठ रंग, आपके कस्टम थीम में <आइटम> तत्व जोड़कर। ये विशेषताएँ आपकी शैलियों में परिभाषित की गई हैं। xml फ़ाइल। उदाहरण के लिए, विंडो बैकग्राउंड में कस्टम रंग लागू करने के लिए, अपने कस्टम थीम में निम्नलिखित दो <आइटम> तत्व जोड़ें, जो MyAndroidApp / Res / मान / स्टाइल / xml फ़ाइल में परिभाषित है -
<resources>
...
<style name="MyCustomTheme" ...>
<item name="android:windowBackground">@color/my_custom_color</item>
<item name="android:colorBackgroundCacheHint">@color/my_custom_color</item>
</style>
...
</resources>
बटन के साथ एक कस्टम नौ पैच का उपयोग करना
एक नौ-पैच ड्रॉबल एक विशेष प्रकार की छवि है जिसे अपनी दृश्य अखंडता को बनाए रखते हुए चौड़ाई और ऊंचाई में बढ़ाया जा सकता है। एंड्रॉइड बटन की उपस्थिति को निर्दिष्ट करने के लिए नौ-पैच सबसे आम तरीका है, हालांकि किसी भी प्रकार के ड्रॉबल प्रकार का उपयोग किया जा सकता है।
नौ-पैच बटन का एक नमूना
नौ-पैच बटन बनाने के लिए कदम
- इस बिटमैप को /res/drawable/my_nine_patch.9.png के रूप में सहेजें
- एक नई शैली को परिभाषित करें
- अपने कस्टम थीम के बटन स्टाइल विशेषता पर नई बटन शैली लागू करें
Define a new Style
<resources>
...
<style name="MyCustomButton" parent="android:Widget.Button">
<item name="android:background">@drawable/my_nine_patch</item>
</style>
...
</resources>
Apply the theme
<resources>
...
<style name="MyCustomTheme" parent=...>
...
<item name="android:buttonStyle">@style/MyCustomButton</item>
</style>
...
</resources>
Android थीम्स
आशा है कि आप शैली की अवधारणा को समझ गए हैं, तो अब आइए समझने की कोशिश करें कि क्या है Theme। एक विषय एक व्यक्तिगत दृश्य के बजाय एक संपूर्ण गतिविधि या अनुप्रयोग पर लागू Android शैली के अलावा कुछ भी नहीं है।
इस प्रकार, जब एक शैली को थीम के रूप में लागू किया जाता है, हर Viewगतिविधि या एप्लिकेशन में प्रत्येक शैली की संपत्ति लागू होगी जो उसका समर्थन करती है। उदाहरण के लिए, आप इसे लागू कर सकते हैंCustomFontStyle एक गतिविधि के लिए एक विषय के रूप में शैली और उसके बाद सभी पाठ Activity हरे रंग का मोनोस्पेस फ़ॉन्ट होगा।
अपने एप्लिकेशन की सभी गतिविधियों के लिए एक थीम सेट करने के लिए, खोलें AndroidManifest.xml फ़ाइल और संपादित करें <application> टैग शामिल करने के लिए android:themeशैली नाम के साथ विशेषता। उदाहरण के लिए -
<application android:theme="@style/CustomFontStyle">
लेकिन अगर आप अपने आवेदन में सिर्फ एक गतिविधि पर लागू एक विषय चाहते हैं, तो केवल <गतिविधि> टैग के लिए Android: थीम विशेषता जोड़ें। उदाहरण के लिए -
<activity android:theme="@style/CustomFontStyle">
एंड्रॉइड द्वारा परिभाषित डिफ़ॉल्ट थीम की संख्या है जिसे आप सीधे उपयोग कर सकते हैं या उनका उपयोग करके इनहेरिट कर सकते हैं parent विशेषता इस प्रकार है -
<style name="CustomTheme" parent="android:Theme.Light">
...
</style>
एंड्रॉइड थीम से संबंधित अवधारणा को समझने के लिए, आप थीम डेमो उदाहरण की जांच कर सकते हैं ।
कलर पैलेट को स्टाइल करना
लेआउट डिज़ाइन उन पर आधारित रंगों के आधार पर कार्यान्वित किया जा सकता है, उदाहरण के लिए निम्न डिज़ाइन को उनके रंग (नीला) के आधार पर डिज़ाइन किया गया है
ऊपर के लेआउट को style.xml फ़ाइल के आधार पर डिज़ाइन किया गया है, जिसने इसे रखा है res/values/
<resource>
<style name="AppTheme" parent="android:Theme.Material">
<item name ="android:color/primary">@color/primary</item>
<item name ="android:color/primaryDark">@color/primary_dark</item>
<item name ="android:colorAccent/primary">@color/accent</item>
</style>
<resource>
डिफ़ॉल्ट शैलियाँ और विषय-वस्तु
एंड्रॉइड प्लेटफ़ॉर्म शैलियों और विषयों का एक बड़ा संग्रह प्रदान करता है जिसे आप अपने अनुप्रयोगों में उपयोग कर सकते हैं। आप सभी उपलब्ध शैलियों का संदर्भ पा सकते हैंR.styleकक्षा। यहां सूचीबद्ध शैलियों का उपयोग करने के लिए, शैली के नाम में सभी अंडरस्कोर को एक अवधि के साथ बदलें। उदाहरण के लिए, आप "@android: style / Theme.NoTitleBar" के साथ Theme_NoTitleBar थीम लागू कर सकते हैं। आप Android शैलियों और विषयों के लिए निम्न स्रोत कोड देख सकते हैं -
Android शैलियाँ (styles.xml)
Android थीम्स (theme.xml)