Android切近實戰(二)

上篇文章咱們的那個登錄界面比較簡陋,這篇文章稍微對這塊進行了修改,以下java

wKioL1Mm_n-harSXAAD_6gTtzXk653.jpg

看到那個文本框中的圖片和文本框中的文字了嗎android

<EditText android:id="@+id/txtUserName"
            android:hint="@string/hintInputUserNo"
            android:layout_width="fill_parent"
            android:drawableLeft="@drawable/user"
            android:layout_height="wrap_content"
            android:singleLine="true">
            </EditText>

圖片就是上面代碼中的drawableLeft這個屬性來設置,而文字則是經過android:hint來設置web

其文字是設置在string.xml中
c#

wKioL1Mm_2mhb9kAAAEKDR5zvfs774.jpg

內容以下app

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="app_name">我的理財</string>
    <string name="app_LoginName">用戶登陸</string>
    <string name="labUserName">用戶名:</string>
    <string name="labPwd">密    碼:</string>
    <string name="labRePwd">重複密碼:</string>
    <string name="labRole">角色:</string>
    <string name="labAdmin">管理員</string>
    <string name="btnLoginText">登  錄</string>
    <string name="hintInputUserNo">請輸入您的用戶名</string>
    <string name="hintInputUserPwd">請輸入您的密碼</string>
    <string name="hintInputUserRePwd">請再次輸入您的密碼</string>
    <string name="labColrLogin">#fff000</string>
    <string name="btnCancelText">取消</string>
    <string name="btnSure">肯定</string>
    <string name="btnUserReg">用戶註冊</string>
    <string name="btnSysCode">系統參數</string>
    <string name="btnDataBackup">數據備份</string>
    <string name="labWelCome">歡迎您,</string>
    <string name="chkDisplayPwd">顯示密碼</string>
    <string name="WarningMsgTitle">提示</string>
    <string name="UserNoIsEmpty">用戶名不能爲空!</string>
    <string name="UserPWdIsEmpty">密碼不能爲空!</string>
    <string name="UserRepwdIsNotCorrect">重複密碼和密碼不一致!</string>
    <string name="SaveSuccess">保存成功!</string>
    <string name="PwdLengthIsNotCorrect">密碼長度必須介於6到15位!</string>
</resources>

OK,經過設置android:hint="@string/hintInputUserNo"就能夠實現水印效果。ide


OK,今天來看一下登陸成功的界面以及功能佈局

wKiom1MnADvQoT1OAAD7C4Uu-kQ407.jpg

首先是登陸成功後,會將登陸用戶的用戶名傳遞給上面的界面。ui

public class index extends Activity {
    TextView labUser;
    ImageButton imgBtnUserRegister;
    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.index);
        labUser = (TextView) this.findViewById(R.id.labUser);
        imgBtnUserRegister=(ImageButton)this.findViewById(R.id.imgBtnUserRegister);
        imgBtnUserRegister.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                Intent intent = new Intent();
                intent.setClass(index.this,userregister.class);
                startActivityForResult(intent, 0);
            }
        });
        Init();
    }
    private void Init() {
        Bundle bundle = getIntent().getExtras();
        String userNo = bundle.getString("userNo");
        labUser.setText(userNo);
    }
}

在初始化Init方法中,接收到登錄界面傳遞過來的userNo,顯示在TextView中。Index界面的代碼以下this

<?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:padding="5dp" android:orientation="vertical">
    <LinearLayout android:orientation="horizontal"
        android:layout_width="fill_parent" android:layout_height="wrap_content">
        <TextView android:id="@+id/labWelCome" android:layout_width="wrap_content"
            android:text="@string/labWelCome" android:layout_height="fill_parent"
            android:textColor="@color/yellow">
        </TextView>
        <TextView android:id="@+id/labUser" android:layout_width="wrap_content"
            android:layout_height="fill_parent" android:textColor="@color/red"
            android:textStyle="bold"></TextView>
    </LinearLayout>
    <View android:layout_height="1px" android:background="#FFFFFF"
        android:layout_width="fill_parent" android:paddingBottom="10dp"></View>
    <TableLayout android:id="@+id/tabMain"
        android:layout_width="fill_parent" android:layout_height="wrap_content"
        android:stretchColumns="*" android:padding="3dip">
        <TableRow>
            <ImageButton android:id="@+id/imgBtnUserRegister"
                android:src="@drawable/userregister" />
            <ImageButton android:id="@+id/p_w_picpathBtnSystemCode"
                android:src="@drawable/main_system_code" />
        </TableRow>
        <TableRow>
            <ImageButton android:id="@+id/imgBtnUserInfo"
                android:src="@drawable/main_user_info" />
            <ImageButton android:id="@+id/p_w_picpathBtnModifyPwd"
                android:src="@drawable/main_modify_pwd" />
        </TableRow>
        <TableRow>
            <ImageButton android:id="@+id/imgBtnEnter"
android:src="@drawable/main_enter_mng" />
            <ImageButton android:id="@+id/imgBtnQuit" android:src="@drawable/main_quit_mng" />
        </TableRow>
    </TableLayout>
</LinearLayout>

本界面採用TabelLayout佈局。咱們點擊imgBtnUserRegister按鈕,跳轉到用戶註冊界面spa

wKiom1MnBTii6NnTAAEZZQV3GRo900.jpg

Intent intent = new Intent();
                intent.setClass(index.this,userregister.class);
                startActivityForResult(intent, 0);

界面UI代碼以下

<?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:padding="5dp" android:orientation="vertical">
    <TableLayout android:id="@+id/tabMain"
        android:layout_width="fill_parent" android:layout_height="wrap_content"
        android:padding="3dip" android:stretchColumns="1">
        <TableRow>
            <TextView android:text="@string/labUserName"
                android:textSize="8pt" android:gravity="right" />
            <EditText android:id="@+id/txtUserName" android:maxLength="25"
                android:hint="@string/hintInputUserNo" android:singleLine="true"></EditText>
        </TableRow>
        <TableRow>
            <TextView android:text="@string/labPwd" android:textSize="8pt"
                android:gravity="right" />
            <EditText android:id="@+id/txtPwd" android:maxLength="50"
                android:singleLine="true" android:hint="@string/hintInputUserPwd"
                android:password="true"></EditText>
        </TableRow>
        <TableRow>
            <TextView android:text="@string/labRePwd" android:textSize="8pt"
                android:gravity="right" />
            <EditText android:id="@+id/txtRePwd" android:singleLine="true"
                android:hint="@string/hintInputUserRePwd" android:password="true"></EditText>
        </TableRow>
        <TableRow>
            <TextView android:text="@string/labRole" android:textSize="8pt"
                android:gravity="right" />
            <CheckBox android:id="@+id/chkRole" android:layout_width="wrap_content"
                android:layout_height="wrap_content" android:checked="false"
                android:text="@string/labAdmin" android:textColor="@color/yellow"
                android:textSize="8pt"></CheckBox>
        </TableRow>
    </TableLayout>
    <LinearLayout android:orientation="horizontal"
        android:gravity="center_horizontal" android:layout_width="fill_parent"
        android:layout_height="fill_parent">
        <Button android:id="@+id/btnSure" android:layout_width="110dp"
            android:layout_height="45dp" android:layout_gravity="center_horizontal"
            android:text="@string/btnSure" android:textStyle="bold"
            android:textColor="@color/blue"></Button>
        <Button android:id="@+id/btnCancel" android:layout_width="110dp"
            android:layout_gravity="center_horizontal" android:layout_height="45dp"
            android:text="@string/btnCancelText" android:textStyle="bold"
            android:textColor="@color/blue"></Button>
    </LinearLayout>
</LinearLayout>

點擊肯定按鈕,註冊用戶。

btnSure.setOnClickListener(new OnClickListener() {
            public void onClick(View v) {
                String userName = txtUserName.getText().toString().trim();
                String pwd = txtPwd.getText().toString().trim();
                String rePwd = txtRePwd.getText().toString().trim();
                String isAdmin = chkRole.isChecked() ? "1" : "0";
                if (!CheckInput(userName, pwd, rePwd))
                    return;
                SoapObject response = GetServerResponse(userName, pwd, isAdmin);
                Boolean isSuccess = Boolean.valueOf(response.getProperty(
                        "IsSuccess").toString());
                if (isSuccess) {
                    ShowMessage(R.string.SaveSuccess);
                } else {
                    String errorMsg = response.getProperty("ErrorMessage")
                            .toString();
                    new AlertDialog.Builder(owner).setTitle(
                            R.string.WarningMsgTitle).setMessage(errorMsg)
                            .setIcon(R.drawable.info).setPositiveButton("肯定",
                                    new DialogInterface.OnClickListener() {
                                        public void onClick(
                                                DialogInterface dialoginterface,
                                                int i) {
                                            txtUserName.setText("");
                                            txtPwd.setText("");
                                            txtRePwd.setText("");
                                            chkRole.setChecked(false);
                                        }
                                    }).show();
                }
            }
        });

首先先Check輸入的用戶名和密碼等

private Boolean CheckInput(String userName, String pwd, String rePwd) {
        if (userName == null || userName.equals("")) {
            new AlertDialog.Builder(this).setTitle(R.string.WarningMsgTitle)
                    .setMessage(R.string.UserNoIsEmpty)
                    .setIcon(R.drawable.info).setPositiveButton("肯定",
                            new DialogInterface.OnClickListener() {
                                public void onClick(
                                        DialogInterface dialoginterface, int i) {
                                    txtUserName.requestFocus();
                                }
                            }).show();
            return false;
        } 此處省略部分代碼

以下都是一些Check。

wKioL1MnBrij2bYgAAE2yxweeD8886.jpgwKiom1MnBySyrnVsAAFhvLjDkmY327.jpg

wKiom1MnB26R2hxyAAFiNKrgs_Q207.jpgwKiom1MnB82xvVO8AAEusxpaSGo146.jpg

wKioL1MnB-KyhZDfAAFQgIq5jP4391.jpg

OK,到此一個用戶就註冊成功了。咱們先看一下.net webservice端。

namespace GRLC.WebService
{
    /// <summary>
    /// UserInfoMng 的摘要說明
    /// </summary>
    [WebService(Namespace = "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo = WsiProfiles.BasicProfile1_1)]
    [System.ComponentModel.ToolboxItem(false)]
    // 若要容許使用 ASP.NET AJAX 從腳本中調用此 Web 服務,請取消註釋如下行。
    // [System.Web.Script.Services.ScriptService]
    public class UserInfoMng : System.Web.Services.WebService
    {
        [WebMethod]
        public CommonResponse UserInfoAdd(UserEntity userInfo)
        {
            return UserInfoBiz.GetInstance().AddUserInfo(userInfo);
        }
    }
}

下面是Biz層代碼

namespace GRLC.Biz
{
    public class UserInfoBiz
    {
        static UserInfoBiz userInfoBiz = new UserInfoBiz();
        private UserInfoBiz()
        { }
        public static UserInfoBiz GetInstance()
        {
            return userInfoBiz;
        }
        const string moduleName = "UserInfoModule";
        private string GetMessageByName(string msgName)
        {
            return CommonFunction.GetMessageByModuleAndName(moduleName, msgName);
        }
        private string AddFaild
        {
            get
            {
                return this.GetMessageByName("AddFailed");
            }
        }
        private string UserHasExists
        {
            get
            {
                return this.GetMessageByName("UserHasExists");
            }
        }
        public CommonResponse AddUserInfo(UserEntity userEntity)
        {
            if (UserInfoMngDAL.GetInstance().IsUserInfoExists(userEntity.UseNo))
            {
                return new CommonResponse() { IsSuccess = false, ErrorMessage = UserHasExists };
            }
            User user = new User();
            user.UseNo = userEntity.UseNo;
            user.Pwd = Cryptor.Encrypt(userEntity.Pwd);
            user.IsAdmin = userEntity.IsAdmin;
            int suc = UserInfoMngDAL.GetInstance().AddUserInfo(user);
            if (suc > 0)
            {
                return new CommonResponse() { IsSuccess = true };
            }
            return new CommonResponse() { IsSuccess = false, ErrorMessage = AddFaild };
        }
    }
}

其中UserInfoMngDAL的定義以下

namespace GRLC.DAL
{
    public class UserInfoMngDAL
    {
        static UserInfoMngDAL userInfoMngDAL = new UserInfoMngDAL();
        private UserInfoMngDAL()
        { }
        public static UserInfoMngDAL GetInstance()
        {
            return userInfoMngDAL;
        }
        public int AddUserInfo(User user)
        {
            using(BonusEntities bonusEntities=new BonusEntities())
            {
                bonusEntities.User.Add(user);
                return bonusEntities.SaveChanges();
            }
        }
        public bool IsUserInfoExists(string userNo)
        {
            using (BonusEntities bonusEntities = new BonusEntities())
            {
                return bonusEntities.User.Any(u => u.UseNo == userNo);
            }
        }
    }
}

其中UserEntity的定義以下

namespace GRLC.Model.DTO
{
    public class UserEntity
    {
        public string UseNo { get; set; }
        public string Pwd { get; set; }
        public string IsAdmin { get; set; }
    }
}

到時候這個實體須要和Android那邊傳遞的實體保持一致

wKiom1MnC2vhqdy0AAFaGxySiz0105.jpg

Ok,咱們接下來看看Android是如何調用的。

private SoapObject GetServerResponse(String userName, String pwd,
            String isAdmin) {
        SoapObject request = new SoapObject(NAMESPACE, METHOD_NAME);
        UserEntity userEntity = new UserEntity();
        userEntity.setProperty(0, userName);
        userEntity.setProperty(1, pwd);
        userEntity.setProperty(2, isAdmin);
        PropertyInfo pi = new PropertyInfo();
        pi.setName("userInfo");
        pi.setValue(userEntity);
        pi.setType(userEntity.getClass());
        request.addProperty(pi);// 將自定參數加入請求對象中
        SoapSerializationEnvelope soapEnvelope = new SoapSerializationEnvelope(
                SoapEnvelope.VER11);
        soapEnvelope.dotNet = true;
        soapEnvelope.setOutputSoapObject(request);
        HttpTransportSE httpTS = new HttpTransportSE(URL);
        soapEnvelope.bodyOut = httpTS;
        soapEnvelope.setOutputSoapObject(request);// 設置請求參數
        soapEnvelope.addMapping(NAMESPACE, "UserEntity", userEntity.getClass());
        try {
            httpTS.call(SOAP_ACTION, soapEnvelope);
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (XmlPullParserException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        SoapObject result = null;
        try {
            result = (SoapObject) soapEnvelope.getResponse();
        } catch (SoapFault e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        return result;
    }

OK,調用只要將數據對象傳遞正確,就不會調用失敗。android中定義的UserEntity以下

package bruce.grlc.model.Entity;
import java.util.Hashtable;
import org.ksoap2.serialization.KvmSerializable;
import org.ksoap2.serialization.PropertyInfo;
public class UserEntity implements KvmSerializable {
    private String UseNo;
    private String Pwd;
    private String IsAdmin;
    @Override
    public Object getProperty(int arg0) {
        // TODO Auto-generated method stub
        Object property = null;
        switch (arg0) {
        case 0:
            property = this.UseNo;
            break;
        case 1:
            property = this.Pwd;
            break;
        case 2:
            property = this.IsAdmin;
        default:
            break;
        }
        return property;
    }
    @Override
    public int getPropertyCount() {
        // TODO Auto-generated method stub
        return 3;
    }
    @Override
    public void getPropertyInfo(int arg0, Hashtable arg1, PropertyInfo arg2) {
        // TODO Auto-generated method stub
        switch (arg0) {
        case 0:
            arg2.type = PropertyInfo.STRING_CLASS;
            arg2.name = "UseNo";
            break;
        case 1:
            arg2.type = PropertyInfo.STRING_CLASS;
            arg2.name = "Pwd";
            break;
        case 2:
            arg2.type = PropertyInfo.STRING_CLASS;
            arg2.name = "IsAdmin";
        default:
            break;
        }
    }
    @Override
    public void setProperty(int arg0, Object arg1) {
        // TODO Auto-generated method stub
        if (arg1 == null)
            return;
        switch (arg0) {
        case 0:
            this.UseNo = arg1.toString();
            break;
        case 1:
            this.Pwd = arg1.toString();
            break;
        case 2:
            this.IsAdmin = arg1.toString();
            break;
        default:
            break;
        }
    }
}

必須繼承KvmSerializable這個抽象接口,並實現它的抽象方法。

public abstract interface org.ksoap2.serialization.KvmSerializable {
                                                           
  // Method descriptor #4 (I)Ljava/lang/Object;
  public abstract java.lang.Object getProperty(int arg0);
                                                           
  // Method descriptor #6 ()I
  public abstract int getPropertyCount();
                                                           
  // Method descriptor #8 (ILjava/lang/Object;)V
  public abstract void setProperty(int arg0, java.lang.Object arg1);
                                                           
  // Method descriptor #10 (ILjava/util/Hashtable;Lorg/ksoap2/serialization/PropertyInfo;)V
  public abstract void getPropertyInfo(int arg0, java.util.Hashtable arg1, org.ksoap2.serialization.PropertyInfo arg2);
}

OK,調用就是這麼簡單。最後,在界面操做的時候,當焦點在文本框中時,老是會彈出輸入法,遮擋按鈕,爲了解決這一問題,須要採起兩種方法

第一種,在AndroidManifest.xml中增長android:windowSoftInputMode="adjustResiz

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="bruce.grlc" android:versionCode="1" android:versionName="1.0">
    <uses-sdk android:minSdkVersion="8" />
    <application android:icon="@drawable/app" android:label="@string/app_name">
        <activity android:name=".main"
        android:label="@string/app_LoginName"
        android:windowSoftInputMode="adjustResize">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name=".index" android:label="@string/app_name">
        </activity>
        <activity android:name=".userregister" android:label="@string/btnUserReg">
        </activity>
    </application>
    <uses-permission android:name="android.permission.INTERNET"></uses-permission>
</manifest>

這句的意思是當輸入法出現時,界面自適應,可是有時候界面上的控件比較多時,依然會遮住某些控件。因此以下

第二種解決方案,在觸摸屏幕其餘地方時,自動關閉輸入法

public boolean onTouchEvent(MotionEvent event) {
        InputMethodManager im = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
        im.hideSoftInputFromWindow(getCurrentFocus()
                .getApplicationWindowToken(),
                InputMethodManager.HIDE_NOT_ALWAYS);
        return super.onTouchEvent(event);
    }

OK,本篇到此結束。

相關文章
相關標籤/搜索