खोज…


परिचय

TextInputLayout को EditText पर फ्लोटिंग लेबल प्रदर्शित करने के लिए पेश किया गया था। फ्लोटिंग लेबल को प्रदर्शित करने के लिए TextInputLayout द्वारा EditText को लपेटना होगा।

टिप्पणियों

TextInputLayout एक लेआउट है जो उपयोगकर्ता इनपुट पाठ के कारण संकेत छिपा होने पर फ्लोटिंग लेबल दिखाने के लिए एक EditText (या वंशज) को लपेटता है। Additonally TextInputLayout आपको EditText नीचे एक त्रुटि संदेश प्रदर्शित करने में सक्षम बनाता है।

सुनिश्चित करें कि निम्न निर्भरता आपके ऐप की build.gradle फ़ाइल में निर्भरता के तहत build.gradle गई है:

compile 'com.android.support:design:25.3.1'

मूल उपयोग

यह TextInputLayout का मूल उपयोग है।
टिप्पणी अनुभाग में वर्णित build.gradle . build.gradle फ़ाइल में निर्भरता जोड़ना सुनिश्चित करें।

उदाहरण:

 <android.support.design.widget.TextInputLayout
         android:layout_width="match_parent"
         android:layout_height="wrap_content">

     <EditText
             android:layout_width="match_parent"
             android:layout_height="wrap_content"
             android:hint="@string/username"/>
 
 </android.support.design.widget.TextInputLayout>

त्रुटियों को संभालना

आप उपयोग कर सकते हैं TextInputLayout के अनुसार त्रुटि संदेश प्रदर्शित करने के लिए सामग्री डिजाइन दिशा निर्देशों का उपयोग कर setError और setErrorEnabled तरीकों।

EditText उपयोग के नीचे त्रुटि दिखाने के लिए:

TextInputLayout til = (TextInputLayout) findViewById(R.id.username);
til.setErrorEnabled(true);
til.setError("You need to enter a name");

TextInputLayout में त्रुटि को सक्षम करने के लिए आप app:errorEnabled="true" उपयोग कर सकते हैं app:errorEnabled="true" in xml या til.setErrorEnabled(true); ऊपर दिखाये अनुसार।

आप प्राप्त करेंगे:

यहाँ छवि विवरण दर्ज करें

कैरेक्टर काउंटिंग जोड़ना

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

बस setCounterEnabled() और setCounterMaxLength विधियों का उपयोग करें:

TextInputLayout til = (TextInputLayout) findViewById(R.id.username);
til.setCounterEnabled(true);
til.setCounterMaxLength(15);

या app:counterEnabled और app:counterMaxLength xml में app:counterMaxLength विशेषताएँ।

<android.support.design.widget.TextInputLayout
    app:counterEnabled="true"
    app:counterMaxLength="15">

    <EditText/>

</android.support.design.widget.TextInputLayout>

पासवर्ड दृश्यता टॉगल

एक इनपुट पासवर्ड प्रकार के साथ, आप भी कर सकते हैं एक आइकन पता चलता है कि या छुपा सकते हैं सक्षम का उपयोग करते हुए पूरे पाठ passwordToggleEnabled विशेषता।

आप इन विशेषताओं का उपयोग करके समान डिफ़ॉल्ट को भी अनुकूलित कर सकते हैं:

  • passwordToggleDrawable : डिफ़ॉल्ट आई आइकन को बदलने के लिए
  • passwordToggleTint : ड्रा करने योग्य टॉगल करने के लिए पासवर्ड दृश्यता के लिए एक टिंट लागू करने के लिए।
  • passwordToggleTintMode : पृष्ठभूमि टिंट को लागू करने के लिए उपयोग किए जाने वाले सम्मिश्रण मोड को निर्दिष्ट करने के लिए।

उदाहरण:

<android.support.design.widget.TextInputLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        app:passwordToggleContentDescription="@string/description"
        app:passwordToggleDrawable="@drawable/another_toggle_drawable"
        app:passwordToggleEnabled="true">

            <EditText/>

</android.support.design.widget.TextInputLayout>

TextInputEditText

TextInputEditText IME में एक संकेत प्रदर्शित करने के लिए एक अतिरिक्त फिक्स के साथ एक EditText है, जब 'निकालें' मोड में

एक्स्ट्रेक्ट मोड वह मोड है जो कीबोर्ड एडिटर स्विच करने पर होता है जब आप एडिटटेक्स्ट पर क्लिक करते हैं जब स्पेस बहुत छोटा होता है (उदाहरण के लिए स्मार्टफोन पर लैंडस्केप)।
इस मामले में, जब आप पाठ को संपादित कर रहे हैं तो एक EditText का उपयोग करके आप देख सकते हैं कि IME आपको जो संपादन कर रहा है उसका संकेत नहीं देता है।

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

उदाहरण:

<android.support.design.widget.TextInputLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:hint="Description"
    >
    <android.support.design.widget.TextInputEditText
        android:id="@+id/description"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"/>

</android.support.design.widget.TextInputLayout>

TextInputLayout की उपस्थिति को अनुकूलित करना

आप अपनी शैलियों में कस्टम शैलियों को परिभाषित करके TextInputLayout और इसके एम्बेडेड EditText की उपस्थिति को कस्टमाइज़ कर सकते हैं। styles.xml । परिभाषित शैलियों को आपके TextInputLayout या तो शैलियों या थीम के रूप में जोड़ा जा सकता है।

संकेत स्वरूप को अनुकूलित करने के लिए उदाहरण:

styles.xml :

<!--Floating label text style-->  
<style name="MyHintStyle" parent="TextAppearance.AppCompat.Small">  
    <item name="android:textColor">@color/black</item>
</style>

<!--Input field style-->  
<style name="MyEditText" parent="Theme.AppCompat.Light">  
    <item name="colorControlNormal">@color/indigo</item>
    <item name="colorControlActivated">@color/pink</item>
</style>  

स्टाइल लागू करने के लिए अपने TextInputLayout और EditText को निम्नानुसार अपडेट करें

<android.support.design.widget.TextInputLayout  
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    app:hintTextAppearance="@style/MyHintStyle">

    <EditText
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:hint="@string/Title"
        android:theme="@style/MyEditText" />

</android.support.design.widget.TextInputLayout>  

TextInputLayout के उच्चारण रंग को अनुकूलित करने के लिए उदाहरण। उच्चारण का रंग EditText की आधार रेखा के रंग और फ्लोटिंग हिंट टेक्स्ट के टेक्स्ट कलर को प्रभावित करता है:

styles.xml :

<style name="TextInputLayoutWithPrimaryColor" parent="Widget.Design.TextInputLayout">
    <item name="colorAccent">@color/primary</item>
</style> 

लेआउट फ़ाइल:

<android.support.design.widget.TextInputLayout
            android:id="@+id/textInputLayout_password"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:theme="@style/TextInputLayoutWithPrimaryColor">

            <android.support.design.widget.TextInputEditText
                android:id="@+id/textInputEditText_password"
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:hint="@string/login_hint_password"
                android:inputType="textPassword" />

</android.support.design.widget.TextInputLayout>


Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow