> Java > java지도 시간 > 본문

안드로이드 개발을 위한 16가지 작은 경험 요약

伊谢尔伦
풀어 주다: 2016-11-26 13:42:17
원래의
1053명이 탐색했습니다.

16가지 안드로이드 개발 소소한 경험 요약, 안드로이드 개발에 종사하는 친구들에게 도움이 되었으면 좋겠습니다.

안드로이드 개발을 위한 16가지 작은 경험 요약

1. TextView의 getTextSize 반환 값은 픽셀(px) 단위이며,

및 setTextSize()는

따라서 반환된 값을 직접 사용하여 설정하면 오류가 발생합니다. 해결 방법은 단위를 지정할 수 있는 다른 형식의 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. Inherited from 보기 비트맵을 그릴 때 새로 생성된 drawable-xdpi에 그림을 넣어야 합니다. 그렇지 않으면 그리기 크기가 쉽게 변경됩니다.

3. 텍스트에 밑줄을 긋습니다: textView.getPaint().setFlags(Paint.STRIKE_THRU_TEXT_FLAG ) ;

4. scrollView는 FrameLayout에서 상속되므로 LayoutParams를 사용할 때 FrameLayout의

을 사용해야 합니다. 5. Android의 여러 네트워크 프로그래밍 방법:

1) Socket 및 ServerSocket TCP/IP

  (2) UDP용 DatagramSocket 및 DatagramPackage. 여기서 주목해야 할 점은 안드로이드 기기가 일반적으로 휴대용 단말기라는 점을 고려하면 인터넷 접속과 함께 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 ) 웹 서비스를 사용합니다. Android는 Jackson과 같은 오픈 소스 패키지를 통해 Xmlrpc 및 Jsonrpc를 지원할 수 있습니다. 또한 Ksoap2를 사용하여 Webservice를 구현할 수도 있습니다

 (6) WebView 보기 구성 요소를 직접 사용하여 웹 페이지를 표시합니다. WebView를 기반으로 개발된 Google은 웹을 직접 탐색할 수 있는 chrome-lite 기반의 웹 브라우저를 제공하고 있습니다.

6. TranslateAnimation(float from 애니메이션 시작점과 현재 뷰 X 좌표 사이의 차이;

float toXDelta, 이 매개변수는 애니메이션 끝점과 현재 뷰 X 사이의 차이를 나타냅니다. 좌표;

float fromYDelta, this 매개변수는 애니메이션 시작점과 현재 뷰 Y 좌표 간의 차이를 나타냅니다.

float toYDelta) 이 매개변수는 애니메이션 시작점과 뷰 Y 좌표 간의 차이를 나타냅니다. 현재 Y 좌표 보기

A 지점(x, y)에서 보는 경우 애니메이션은 B 지점(x+fromXDelta, y+fromYDelta)에서 C 지점(x+toXDelta, y+toYDelta)으로 이동합니다. ).

7. android는 다른 스레드에서 UI 스레드에 액세스할 수 있는 여러 가지 방법을 제공합니다. <… >

 9. Eclipse 관련 JDK 소스 코드

 (1) “창”-> “Java”-> “설치된 JRES” 클릭

(2 ) 이때 "설치된 JRES" 오른쪽에 시스템의 JRE 환경이 나열되는 목록 창이 있습니다. 그런 다음 옆에 있는 "편집..."을 클릭합니다. 창(JRE 편집)이 나타납니다

Activity.runOnUiThread( Runnable ) 
View.post( Runnable ) 
View.postDelayed( Runnable, long )
로그인 후 복사
(3) rt.jar 파일에서 "c:program filesjavajre_1.5.0_06librt.jar" 항목을 선택하고 왼쪽의 "+" 기호를 클릭하여 확장합니다.

(4) 확장하면 "Source Attachment:(none)"이 보입니다. 이 항목을 클릭한 후 오른쪽의 "Source Attachment..." 버튼을 클릭하고 "src. zip" 파일을 JDK 디렉토리
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]);   
        }   
     }   
}
로그인 후 복사

 10.동기화 연결을 열 수 없습니다!

설정에서 USB 디버깅을 다시 시작하세요

11. EditText에서 커서 위치 설정 문제

EditText에 미리 설정된 텍스트가 있는 경우 커서를 처음에는 setSelection(0)을 사용했는데 Samsung P1000에 문제가 있는 것을 발견했습니다. 연구 결과, EditText.requestFocus()를 먼저 호출한 다음 setSelection(0)을 호출해야 한다는 사실이 밝혀졌습니다. 그렇지 않으면 2.x 시스템에서는 문제가 발생하지만 3.x 시스템에서는 문제가 없습니다.

12. Android의 홈 버튼은 시스템에 의해 예약되어 있습니다. 뒤로 버튼을 모니터링할 수 있는 것처럼 onKeyDown을 사용할 수 없습니다. 그러나 일부 활동 이벤트를 기반으로 자체 처리 코드를 추가하고 이를 볼 수 있습니다. 인터넷의 누군가가 onAttachWindow를 사용하여 홈 버튼을 가로챌 수 있다고 했지만 저는 시도해 본 적이 없습니다.

13. SurfaceView로 렌더링할 때 다른 뷰를 원할 경우 필요한 경우 SurfaceView 및 기타 뷰를 레이아웃에 넣을 수 있습니다.

14. android:imeOptinos를 사용하여 Android와 함께 제공되는 소프트 키보드에 대한 일부 인터페이스 설정을 지정합니다.

android:imeOptions="flagNoExtractUi" //사용 소프트 키보드는 전체 화면으로 표시되지 않고 화면의 일부만 차지합니다.

동시에 이 속성을 사용하여 표시도 제어할 수 있습니다. 소프트 키보드 오른쪽 하단에 있는 키 내용은 기본적으로 Enter 키입니다.

15. TextView에 그림자 추가

16. TextView의 중국어를 굵게 설정하는 방법은 무엇입니까?

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

TextView tv = (TextView)findViewById(R.id.TextView01); 
TextPaint tp = tv.getPaint(); 
tp.setFakeBoldText(true);
로그인 후 복사


관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿
회사 소개 부인 성명 Sitemap
PHP 중국어 웹사이트:공공복지 온라인 PHP 교육,PHP 학습자의 빠른 성장을 도와주세요!