Android實現QQ登入介面遇到問題及解決方案_Android

來源:互聯網
上載者:User

先給大家炫下效果圖:

首先過程中碰到的幾個問題:

1、對 EditText 進行自訂背景

2、運行時自動 EditText 自動獲得焦點

3、在獲得焦點時即清空 hint ,而不是輸入後清空

4、清空按鈕的出現時機(在得到焦點並且有輸入內容時)

  .........

--- 這些問題都有一一解決 ---

以下是代碼:

布局 fragment_main(問題2)

<!-- android:focusable="true"   android:focusableInTouchMode="true"   把EditText預設的行為截斷了! --><RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" android:layout_height="match_parent" android:background="#ECEDF1" android:focusable="true" android:focusableInTouchMode="true" tools:context="com.dragon.android.qqlogin.MainActivity$PlaceholderFragment" > <ImageView  android:id="@+id/imageView1"  android:layout_width="70dp"  android:layout_height="70dp"  android:layout_centerHorizontal="true"  android:layout_marginBottom="5dp"  android:layout_marginTop="40dp"  android:src="@drawable/a" />   <EditText  android:id="@+id/editText1"  android:layout_width="match_parent"  android:layout_height="wrap_content"  android:layout_below="@id/imageView1"  android:ems="10"  android:background="@drawable/bg_edittext"  android:inputType="textPersonName"  android:gravity="center"  android:textColor="#6A6A6C"  android:hint="@string/inaccount"  android:textColorHint="#ECEDDD"> </EditText> <EditText  android:id="@+id/editText2"  android:layout_width="match_parent"  android:layout_height="wrap_content"  android:layout_below="@id/editText1"  android:ems="10"  android:background="@drawable/bg_edittext"  android:inputType="textPassword"  android:gravity="center"  android:textColor="#6A6A6C"  android:hint="@string/inpwd"  android:textColorHint="#ECEDDD" > </EditText> <Button  android:id="@+id/button1"  android:layout_width="match_parent"  android:layout_height="40dp"  android:layout_below="@id/editText2"  android:layout_marginLeft="20dp"  android:layout_marginRight="20dp"  android:layout_marginTop="10dp"  android:background="@drawable/bg_button"  android:text="@string/button"  android:gravity="center"  android:textColor="#F9FAFB" /> <LinearLayout  android:layout_width="match_parent"  android:layout_height="wrap_content"  android:layout_alignParentBottom="true"  android:padding="10dp" >  <TextView   android:id="@+id/textView2"   android:layout_width="wrap_content"   android:layout_height="wrap_content"   android:gravity="center"   android:text="@string/faillogin"   android:textColor="#0EB1EF" />  <TextView   android:id="@+id/textView3"   android:layout_width="match_parent"   android:layout_height="wrap_content"   android:gravity="right"   android:text="@string/regist"   android:textColor="#0EB1EF" />  </LinearLayout> <Button  android:id="@+id/button2"  android:layout_width="16dp"  android:layout_height="16dp"  android:layout_alignTop="@id/editText1"  android:layout_marginTop="15dp"  android:layout_alignParentRight="true"  android:layout_marginRight="10dp"  android:background="@drawable/clear"  android:visibility="invisible" /> <Button  android:id="@+id/button3"  android:layout_width="16dp"  android:layout_height="16dp"  android:layout_alignTop="@id/editText2"  android:layout_marginTop="15dp"  android:layout_alignLeft="@+id/button2"  android:background="@drawable/clear"  android:visibility="invisible" /></RelativeLayout>fragment_main

Button 和 EditText 的背景(問題1)

<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android" > <stroke android:width="1px" android:color="#00ACED" /> <solid android:color="#00ACED" /> <corners android:radius="10dp" /></shape>bg_button
<?xml version="1.0" encoding="utf-8"?><shape xmlns:android="http://schemas.android.com/apk/res/android" > <stroke android:width="1px" android:color="#ECEDF1" /> <solid android:color="#F9FAFB" /> <corners android:radius="10dp" /> <padding   android:top="10dp"   android:bottom="10dp"/></shape>bg_edittext
<?xml version="1.0" encoding="utf-8"?><resources> <string name="app_name">qqloginnew</string> <string name="action_settings">Settings</string> <string name="button">登入</string> <string name="faillogin">無法登入?</string> <string name="regist">新使用者註冊</string> <string name="inaccount">QQ號/手機號/郵箱</string> <string name="inpwd">密碼</string> <string name="sucess">登入成功</string></resources>strings

MainActivity (問題3、4.....)

package com.dragon.android.qqloginnew;import android.app.Activity;import android.os.Bundle;import android.text.Editable;import android.text.TextWatcher;import android.view.View;import android.view.View.OnClickListener;import android.view.View.OnFocusChangeListener;import android.widget.Button;import android.widget.EditText;public class MainActivity extends Activity {private EditText editText1;private EditText editText2;// private Button button;private Button clearButton1;private Button clearButton2;// 得到strings中的屬性// private String string2 = getResources().getString(R.string.inaccount);@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.fragment_main);editText1 = (EditText) findViewById(R.id.editText1);editText2 = (EditText) findViewById(R.id.editText2);// button = (Button) findViewById(R.id.button1);clearButton1 = (Button) findViewById(R.id.button2);clearButton2 = (Button) findViewById(R.id.button3);// 對EditText進行焦點變更監聽editText1.setOnFocusChangeListener(new EditTextListener(clearButton1));editText2.setOnFocusChangeListener(new EditTextListener(clearButton2));// 對清空按鈕進行點擊監聽clearButton1.setOnClickListener(new ClearButtonListener());clearButton2.setOnClickListener(new ClearButtonListener());// 對EditText進行編輯監聽editText1.addTextChangedListener(new MyEditTextWatcher(editText1));editText2.addTextChangedListener(new MyEditTextWatcher(editText2));}/*** 對EditText的內容進行即時監控* * @author Auser* */class MyEditTextWatcher implements TextWatcher {private CharSequence temp;private EditText editText;public MyEditTextWatcher(EditText editText) {this.editText = editText;}@Override// int start開始的位置, int count被改變的舊內容數, int after改變後的內容數量public void beforeTextChanged(CharSequence s, int start, int count,int after) {// 這裡的s表示改變之前的內容,通常start和count組合,可以在s中讀取本次改變欄位中被改變的內容。而after表示改變後新的內容的數量。}@Override// int start開始的位置, int before改變前的內容數量, int count新增量public void onTextChanged(CharSequence s, int start, int before,int count) {// 這裡的s表示改變之後的內容,通常start和count組合,可以在s中讀取本次改變欄位中新的內容。而before表示被改變的內容的數量。temp = s;}@Override// 表示最終內容public void afterTextChanged(Editable s) {if (temp.length() > 0) {// 設定清空按鈕為可見if (editText == editText1) {clearButton1.setVisibility(View.VISIBLE);} else if (editText == editText2) {clearButton2.setVisibility(View.VISIBLE);}} else {// 設定清空按鈕不可見if (editText == editText1) {clearButton1.setVisibility(View.INVISIBLE);} else if (editText == editText2) {clearButton2.setVisibility(View.INVISIBLE);}}}}/*** 清空按鈕點擊事件* * @author* */class ClearButtonListener implements OnClickListener {@Overridepublic void onClick(View view) {if (view == clearButton1) {editText1.setText("");} else if (view == clearButton2) {editText2.setText("");}}}/*** 焦點變更事件* * @author Auser* */class EditTextListener implements OnFocusChangeListener {private Button clear;public EditTextListener(Button clear) {this.clear = clear;}@Overridepublic void onFocusChange(View v, boolean hasFocus) {EditText textView = (EditText) v;String hint;if (hasFocus) {// 當擷取焦點時如果內容不為空白則清空按鈕可見if (!textView.getText().toString().equals("")) {clear.setVisibility(View.VISIBLE);}// if (textView == editText2) {// // 設定輸入格式為不可見的密碼格式// textView.setInputType(InputType.TYPE_CLASS_TEXT// | InputType.TYPE_TEXT_VARIATION_PASSWORD);// }hint = textView.getHint().toString();// 給TextView添加額外的資料textView.setTag(hint);textView.setHint("");} else {// 當失去焦點時清空按鈕不可見clear.setVisibility(View.INVISIBLE);// if (textView == editText2) {// // 設定輸入格式為可見的密碼格式// textView.setInputType(InputType.TYPE_CLASS_TEXT// | InputType.TYPE_TEXT_VARIATION_VISIBLE_PASSWORD);// }// 取出之前添加的額外資料hint = textView.getTag().toString();textView.setHint(hint);}}}}

下篇文章給大家介紹Android實現QQ新使用者註冊介面遇到問題及解決方案,感興趣的朋友可以參考下。

以上所述是小編給大家介紹的Android實現QQ登入介面遇到問題及解決方案,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.