Android開發的16條小經驗總結

cwf8 9年前發布 | 41K 次閱讀 Android Android開發 移動開發

Android開發的16條小經驗總結,希望對各位搞Android開發的朋友有所幫助。

1. TextView中的getTextSize返回值是以像素(px)為單位的,

而setTextSize()是以sp為單位的.

所以如果直接用返回的值來設置會出錯,解決辦法是用setTextSize()的另外一種形式,可以指定單位:

setTextSize(int unit, int size)   
TypedValue.COMPLEX_UNIT_PX : Pixels   
TypedValue.COMPLEX_UNIT_SP : Scaled Pixels   
TypedValue.COMPLEX_UNIT_DIP : Device Independent Pixels

2. 在繼承自View時,繪制bitmap時,需要將圖片放到新建的drawable-xdpi中,否則容易出現繪制大小發生改變

3. 在文字中加下劃線: textView.getPaint().setFlags(Paint.STRIKE_THRU_TEXT_FLAG);

4. scrollView是繼承自frameLayout,所以在使用LayoutParams時需要用frameLayout的

5.在Android中幾種網絡編程的方式:

(1)針對TCP/IP的Socket、ServerSocket
(2)針對UDP的DatagramSocket、DatagramPackage。這里需要注意的是,考慮到Android設備通常是手持終端,IP都是隨著上網進行分配的。不是固定的。因此開發也是有 一點與普通互聯網應用有所差異的。
(3)針對直接URL的HttpURLConnection
(4)Google集成了Apache HTTP客戶端,可使用HTTP進行網絡編程。針對HTTP,Google集成了Appache Http core和httpclient 4版本,因此特別注意Android不支持 httpclient 3.x系列,而且目前并不支持Multipart(MIME),需要自行添加httpmime.jar
(5)使用Web Service。Android可以通過開源包如Jackson去支持Xmlrpc和Jsonrpc,另外也可以用Ksoap2去實現Webservice
(6) 直接使用WebView視圖組件顯示網頁。基于WebView 進行開發,Google已經提供了一個基于chrome-lite的Web瀏覽器,直接就可以進行上網瀏覽網頁。

6. TranslateAnimation(float fromXDelta, float toXDelta, float fromYDelta, float toYDelta)

這個是我們最常用的一個構造方法,

float fromXDelta:這個參數表示動畫開始的點離當前View X坐標上的差值;

float toXDelta, 這個參數表示動畫結束的點離當前View X坐標上的差值;

float fromYDelta, 這個參數表示動畫開始的點離當前View Y坐標上的差值;

float toYDelta)這個參數表示動畫開始的點離當前View Y坐標上的差值;

如果view在A(x,y)點 那么動畫就是從B點(x+fromXDelta, y+fromYDelta)點移動到C 點 (x+toXDelta,y+toYDelta)點.

7.android提供了幾種在其他線程中訪問UI線程的方法。

Activity.runOnUiThread( Runnable ) 
View.post( Runnable ) 
View.postDelayed( Runnable, long )

從網上獲取一個網頁,在一個TextView中將其源代碼顯示出來

package org.unique.async;   
import java.io.ByteArrayOutputStream;   
import java.io.InputStream;   
import java.util.ArrayList;   

import org.apache.http.HttpEntity;    import org.apache.http.HttpResponse;    import org.apache.http.client.HttpClient;    import org.apache.http.client.methods.HttpGet;    import org.apache.http.impl.client.DefaultHttpClient;   

import android.app.Activity;    import android.app.ProgressDialog;    import android.content.Context;    import android.content.DialogInterface;    import android.os.AsyncTask;    import android.os.Bundle;    import android.os.Handler;    import android.os.Message;    import android.view.View;    import android.widget.Button;    import android.widget.EditText;    import android.widget.TextView;   

public class NetworkActivity extends Activity{        private TextView message;        private Button open;        private EditText url;   

    @Override        public void onCreate(Bundle savedInstanceState) {           super.onCreate(savedInstanceState);           setContentView(R.layout.network);           message= (TextView) findViewById(R.id.message);           url= (EditText) findViewById(R.id.url);           open= (Button) findViewById(R.id.open);           open.setOnClickListener(new View.OnClickListener() {               public void onClick(View arg0) {                  connect();               }           });   

    }   

    private void connect() {            PageTask task = new PageTask(this);            task.execute(url.getText().toString());        }   

    class PageTask extends AsyncTask<String, Integer, String> {            // 可變長的輸入參數,與AsyncTask.exucute()對應            ProgressDialog pdialog;            public PageTask(Context context){                pdialog = new ProgressDialog(context, 0);                   pdialog.setButton("cancel", new DialogInterface.OnClickListener() {                 public void onClick(DialogInterface dialog, int i) {                  dialog.cancel();                 }                });                pdialog.setOnCancelListener(new DialogInterface.OnCancelListener() {                 public void onCancel(DialogInterface dialog) {                  finish();                 }                });                pdialog.setCancelable(true);                pdialog.setMax(100);                pdialog.setProgressStyle(ProgressDialog.STYLE_HORIZONTAL);                pdialog.show();   

        }            @Override            protected String doInBackground(String... params) {   

            try{   

               HttpClient client = new DefaultHttpClient();                   // params[0]代表連接的url                   HttpGet get = new HttpGet(params[0]);                   HttpResponse response = client.execute(get);                   HttpEntity entity = response.getEntity();                   long length = entity.getContentLength();                   InputStream is = entity.getContent();                   String s = null;                   if(is != null) {                       ByteArrayOutputStream baos = new ByteArrayOutputStream();   

                   byte[] buf = new byte[128];   

                   int ch = -1;   

                   int count = 0;   

                   while((ch = is.read(buf)) != -1) {   

                      baos.write(buf, 0, ch);   

                      count += ch;   

                      if(length > 0) {                              // 如果知道響應的長度,調用publishProgress()更新進度                              publishProgress((int) ((count / (float) length) * 100));                          }   

                      // 讓線程休眠100ms                          Thread.sleep(100);                       }                       s = new String(baos.toByteArray());              }                   // 返回結果                   return s;                } catch(Exception e) {                   e.printStackTrace();   

            }   

            return null;   

        }   

        @Override            protected void onCancelled() {                super.onCancelled();            }   

        @Override            protected void onPostExecute(String result) {                // 返回HTML頁面的內容                message.setText(result);                pdialog.dismiss();             }   

        @Override            protected void onPreExecute() {                // 任務啟動,可以在這里顯示一個對話框,這里簡單處理                message.setText(R.string.task_started);            }   

        @Override            protected void onProgressUpdate(Integer... values) {                // 更新進度                  System.out.println(""+values[0]);                  message.setText(""+values[0]);                  pdialog.setProgress(values[0]);            }   

     }   

}</pre>

8.Spinner不能用在dialog和tabhost中的解決辦法

9. eclipse關聯JDK源碼

(1).點 “window”-> “Preferences” -> “Java” -> “Installed JRES”

(2).此時”Installed JRES”右邊是列表窗格,列出了系統中的 JRE 環境,選擇你的JRE,然后點邊上的 “Edit…”, 會出現一個窗口(Edit JRE)

(3).選中rt.jar文件的這一項:“c:\program files\java\jre_1.5.0_06\lib\rt.jar”點 左邊的“+” 號展開它,

(4).展開后,可以看到“Source Attachment:(none)”,點這一項,點右邊的按鈕“Source Attachment…”, 選擇你的JDK目錄下的 “src.zip”文件

10.Unable to open sync connection!

把設置里的USB調試重啟

11.EditText設置光標位置問題

EditText中有一些預置文本的時候,想把光標調到最前面,一開始是使用的setSelection(0),結果發現在三星P1000上面有問 題。經過研究發現需要先調用EditText.requestFocus(),再調用setSelection(0)。否則的話,在2.x的機器上有問 題,但3.x上面是好著的。

12.Android中Home鍵被系統保留,無法象監聽回退鍵一樣用onKeyDown,但是可以根據按下home鍵時會觸發的activity和view的一些事件來添加自己的處理代碼.網上有人說可以用onAttachWindow來攔截Home鍵,沒試過

13.在用surfaceView渲染時,如果要想在需要時其中出現其他View,可以將surfaceView和其他View放在layout中,平常時可以將其他view隱藏

14.使用android:imeOptinos可對Android自帶的軟鍵盤進行一些界面上的設置:

android:imeOptions="flagNoExtractUi"  //使軟鍵盤不全屏顯示,只占用一部分屏幕     
同時,這個屬性還能控件軟鍵盤右下角按鍵的顯示內容,默認情況下為回車鍵     
android:imeOptions="actionNone"  //輸入框右側不帶任何提示     
android:imeOptions="actionGo"    //右下角按鍵內容為'開始'     
android:imeOptions="actionSearch"  //右下角按鍵為放大鏡圖片,搜索     
android:imeOptions="actionSend"    //右下角按鍵內容為'發送'     
android:imeOptions="actionNext"   //右下角按鍵內容為'下一步'     
android:imeOptions="actionDone"  //右下角按鍵內容為'完成'

15.為TextView添加陰影

<style name="Overlay">      
    <item name="android:paddingLeft">2dip</item>      
    <item name="android:paddingBottom">2dip</item>      
    <item name="android:textColor">#ffffff</item>      
    <item name="android:textSize">12sp</item>      
    <item name="android:shadowColor">#00ff00</item>      
    <item name="android:shadowDx">5</item>      
    <item name="android:shadowDy">3</item>      
    <item name="android:shadowRadius">6</item>     
</style>     

<TextView android:id="@+id/test"              android:layout_width="fill_parent"              android:layout_height="wrap_content"              style="@style/<span style="background-color: rgb(250, 250, 250); font-family: Helvetica, Tahoma, Arial, sans-serif; ">Overlay</span>"              android:text="test"              android:gravity="center" /></pre>

16.如何將TextView中的中文設置成粗體? 

在xml文件中使用android:textStyle=”bold” 可以將英文設置成粗體,但是不能將中文設置成粗體,將中文設置成粗體的方法是:

TextView tv = (TextView)findViewById(R.id.TextView01); 
TextPaint tp = tv.getPaint(); 
tp.setFakeBoldText(true);
來源:博客園

 本文由用戶 cwf8 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
 轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
 本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!