Android開發的16條小經驗總結

部落格園發表於2015-03-25

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]);   
        }   

     }   

}

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"  //使軟鍵盤不全屏顯示,只佔用一部分螢幕     
同時,這個屬性還能控制元件軟鍵盤右下角按鍵的顯示內容,預設情況下為Enter鍵     
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" />

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

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

TextView tv = (TextView)findViewById(R.id.TextView01); 
TextPaint tp = tv.getPaint(); 
tp.setFakeBoldText(true);

相關文章