android开发小经验

原文地址:http://www.2cto.com/kf/201203/122483.html

1. TextView中的getTextSize返回值是以像素(px)为单位的, 
而setTextSize()是以sp为单位的.
所以如果直接用返回的值来设置会出错,解决办法是
用setTextSize()的另外一种形式,可以指定单位:
[java]
<span style="font-size:16px;">setTextSize(int unit, int size) 
TypedValue.COMPLEX_UNIT_PX : Pixels 
TypedValue.COMPLEX_UNIT_SP : Scaled Pixels 
TypedValue.COMPLEX_UNIT_DIP : Device Independent Pixels</span> 
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 )
Hanlder
AsyncTask(推荐使用)
[java]
从网上获取一个网页,在一个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中的解决办法http://www.2cto.com/kf/201203/122480.html 

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自带的软键盘进行一些界面上的设置:
[html]
android:imeOptions="flagNoExtractUi"  //使软键盘不全屏显示,只占用一部分屏幕   
同时,这个属性还能控件软键盘右下角按键的显示内容,默认情况下为回车键   
android:imeOptions="actionNone"  //输入框右侧不带任何提示   
android:imeOptions="actionGo"    //右下角按键内容为'开始'   
android:imeOptions="actionSearch"  //右下角按键为放大镜图片,搜索   
android:imeOptions="actionSend"    //右下角按键内容为'发送'   
android:imeOptions="actionNext"   //右下角按键内容为'下一步'   
android:imeOptions="actionDone"  //右下角按键内容为'完成'  

15.为TextView添加阴影
[html]
<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);  

 

 

1.TextView的ellipsize
我们都知道当在TextView中设定ellipsize时,显示的结果会是缩略显示,但是比较不好的是
Google默认只会显示倆行,如果自己想多显示的话就必须自定义TextView,为了减少开发
过程中的重复工作,我把最近做的项目中的这部分代码贴出来,如下:
[java]
package com.hustunique.Fuubo.View; 
 
import android.content.Context; 
import android.util.AttributeSet; 
import android.widget.TextView; 
 
public class WeiboContentText extends TextView{ 
    private String mText; 
 
    public WeiboContentText(Context context, AttributeSet attrs) { 
        super(context, attrs); 
        // TODO Auto-generated constructor stub 
    } 
 
    public WeiboContentText(Context context) { 
        super(context); 
        // TODO Auto-generated constructor stub 
    } 
 
    @Override 
    public CharSequence getText() { 
        // TODO Auto-generated method stub 
        return mText; 
    } 
 
    @Override 
    public void setText(CharSequence text, BufferType type) { 
        // TODO Auto-generated method stub 
        mText = (String) text; 
        if (mText.length()>22) { 
            StringBuffer subTextBuffer = new StringBuffer(mText.substring(0, 19)); 
            subTextBuffer.append("..."); 
            text = subTextBuffer; 
        }  
        super.setText(text, type); 
    } 

比较低级,但是感觉还是比较实用
2.设置输入法弹出后的布局问题可以试下以下系列方法:
[java]
getWindow().setSoftInputMode(WindowManager.LayoutParams.xxxx); 

3.TextView实现多行本文滚动
  <TextView 
    android:id="@+id/xxx" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:scrollbars="vertical"   <!--垂直滚动条 -->
    android:singleLine="false"       <!--实现多行 -->
    android:maxLines="12"            <!--最多不超过12行 -->
    android:textColor="#ffffff"
    />
   当然我们为了让TextView动起来,还需要用到TextView的setMovementMethod方法设置一个滚动实例,代码如下
TextView tv = (TextView)findViewById(R.id.tvCWJ);  
tv.setMovementMethod(ScrollingMovementMethod.getInstance());

4.EditText中setInputType的妙用
使用该方法我们可以实现诸如隐藏/显示输入内容,隐藏键盘等等 



 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值