lifecaresciencelab android seminar 3 rd class

Post on 24-Feb-2016

43 Views

Category:

Documents

0 Downloads

Preview:

Click to see full reader

DESCRIPTION

아주대학교. LifecareScienceLAB Android Seminar 3 rd class. Android Software Development 2011/05/04 – p.m. 06:00 – 팔달관 409 호. Review. User Interface Button, TextView , EditText LinearLayout Software Design Tool. Widget. TextView , Button, EditText 를 이용하여 버튼을 누르면 편집한 문자열이 출력되는 예제 - PowerPoint PPT Presentation

TRANSCRIPT

아주대학교

LifecareScienceLABAndroid Seminar 3rd class

• Android• Software Development

2011/05/04 – p.m. 06:00 – 팔달관 409 호

아주대학교

Review User Interface

Button, TextView, EditText LinearLayout

Software Design Tool

Widget TextView, But-

ton, EditText 를 이용하여 버튼을 누르면 편집한 문자열이 출력되는 예제main.xml→

Widget↓ Activity Class

State Diagram

Not Playing,At the begin-

ning

Playing

Paused

Play

Play

Play

PauseStop

Stop

Pause

PauseStop

Structure Chart

main

process

Input

ouput

sub process 2

sub process 1

sub process 3

print

Flow Chart

i <= 0

Turn on All LED

Output Data in Array[i]

to LED

i++ False

True

Add Random Value to Ar-

ray

Array Size + 1

START

i <= 0

i < Array Size?Turn on All LED

Input Data from But-

ton

False

True

Array[i] == Input?True

i++

Clear ArrayArray Size

<= 0

False

i <= 0

i < Array Size?

New Stage

LED Output

Button Input

Class DiagramClass

ExplainBuilder

문서를 구성하기 위한 메소드를결정하는 추상 클래스

Director

한 개의 문서를 만드는 클래스TextBuilder

일반 텍스트 ( 보통의 문자열 ) 를이용해서 문서를 만드는 클래스

HTMLBuilder

HTML 파일을 이용해서문서를 만드는 클래스

Main

동작 테스트용 클래스

Builder

makeTitlemakeStringmakeItemsclose

TextBuilder

buffer

makeTitlemakeStringmakeItemsclosegetResult

makeTitlemakeStringmakeItemsclosegetResult

HTMLBuilder

Director

builderconstruct

filenamewriter

Uses▲

MainUses▶

Uses▲

Sequence Diagram:Client :Server :Device

work open

print

close

write

Contents List

Android• Activity• Toast• Log

Software Development• Design Presentation

아주대학교

ANDROID

• Activity• Toast• Log

Activity 프로그램에서의 “화면 하나” 반드시 “ View” 나 “ View Group” 를 가져야 한다 . 액티비티는 서로 중첩되지 않으며 독립적이다 .

(View 는 중첩된다 .)

Activity LifeCycle

Activity 추가MainActivity.-

javaActivity

SubActivity.javaActivity

mainactivity.xmlView

subactivity.xmlView

프로젝트 생성

Create Activity :

MainActivity →

main.xml 파일 이름 바꾸기

main.xml 파일 이름 바꾸기

SubActivity Class 추가하기

SubActivity Class 추가하기

subactivity xml 파일 추가하기

subactivity xml 파일 추가하기

AndroidManifest 파일에 등록하기

AndroidManifest 파일에 등록하기

AndroidManifest 파일에 등록하기

AndroidManifest 파일에 등록하기

AndroidManifest 파일에 등록하기

AndroidManifest 파일에 등록하기

AndroidManifest 파일에 등록하기

AndroidManifest 파일에 등록하기

MainActivity.javaimport android.app.Activity;import android.content.Intent;import android.os.Bundle;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;

public class MainActivity extends Activity {/** Called when the activity is first created. */@Overridepublic void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);setContentView(R.layout.mainactivity);

Button btnCall = (Button)findViewById(R.id.call);btnCall.setOnClickListener(new OnClickListener(){

public void onClick(View v){Intent intent = new Intent(MainActivity.this, SubActivity.class);startActivity(intent);

}});

}}

mainactivity.xml<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"

android:orientation="vertical"android:layout_width="fill_parent"android:layout_height="fill_parent"><TextView

android:layout_width="fill_parent" android:layout_height="wrap_content" android:text=" 메인 엑티비티입니다 ." android:textSize="30dp" android:textColor="#FF0000"></TextView>

<Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/call" android:text="Call"></Button>

</LinearLayout>

SubActivity.javaimport android.app.Activity;import android.os.Bundle;import android.view.View;import android.view.View.OnClickListener;import android.widget.Button;

public class SubActivity extends Activity {/** Called when the activity is first created. */@Overridepublic void onCreate(Bundle savedInstanceState) {

super.onCreate(savedInstanceState);setContentView(R.layout.subactivity);

Button btnClose = (Button)findViewById(R.id.close);btnClose.setOnClickListener(new OnClickListener(){

public void onClick(View v){finish();

}});

}}

subactivity.xml<?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:orientation="vertical"><TextView

android:layout_height="wrap_content" android:layout_width="fill_parent" android:text=" 메인에서 호출한 서브입니다 ." android:textSize="20dp" android:textColor="#00FF00"></TextView>

<Button android:layout_width="wrap_content" android:layout_height="wrap_content" android:id="@+id/close"android:text="Close"></Button>

</LinearLayout>

Activity 간의 통신 인텐트는 액티비티간에 인수와 리턴값을 전달하는 도구로도 사용된다 . 값을 저장하는 Method

Intent putExtra(String name, int value) Intent putExtra(String name, String value) Intent putExtra(String name, boolean value)

저장된 값을 꺼내오는 Method int getIntExtra(String name, int defaultValue) String getStringExtra(String name) boolean getBooleanExtra(String name, boolean defaultValue)

리턴값을 돌려받기 위해 누가 호출했는지 알려주는 Method public void startActivityForResult(Intent intent, int request-

Code) 리턴값을 돌려받는 Method

Protected void onActivityResult(int requestCode, int result-Code, Intent data)

Activity 간의 통신CommActivity.-

javaActivity

ActEdit.javaActivity

main.xmlView

sub.xmlView

CommActivity.java import android.app.*; import android.content.*; import android.os.*; import android.view.*; import android.widget.*;

public class CommActivity extends Activity { TextView mText; final static int ACT_EDIT = 0;

public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main);

mText = (TextView)findViewById(R.id.textView);

Button btnEdit=(Button)findViewById(R.id.buttonNEXT); btnEdit.setOnClickListener(new Button.OnClickListener() { public void onClick(View v) { Intent intent = new Intent(CommActivity.this, ActEdit.class); intent.putExtra("TextIn", mText.getText().toString()); startActivityForResult(intent,ACT_EDIT); } }); } protected void onActivityResult (int requestCode, int resultCode, Intent data) { switch (requestCode) { case ACT_EDIT: if (resultCode == RESULT_OK) { mText.setText(data.getStringExtra("TextOut")); } break; } } }

main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <TextView android:text="TextView" android:layout_height="wrap_content" android:id="@+id/textView" android:textSize="30dp" android:layout_width="fill_parent" ></TextView> <Button android:layout_height="wrap_content" android:id="@+id/buttonNEXT" android:text="EDIT" android:layout_width="fill_parent" android:textSize="20dp" ></Button> </LinearLayout>

ActEdit.java import android.app.*; import android.content.*; import android.os.*; import android.view.*; import android.widget.*;

public class ActEdit extends Activity { EditText mEdit;

public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.sub);

mEdit = (EditText)findViewById(R.id.editText);

Intent intent = getIntent(); mEdit.setText(intent.getStringExtra("TextIn"));

Button btnOK=(Button)findViewById(R.id.buttonOK); btnOK.setOnClickListener(new Button.OnClickListener() { public void onClick(View v) { Intent intent = new Intent(); intent.putExtra("TextOut", mEdit.getText().toString()); setResult(RESULT_OK,intent); finish(); } });

Button btnCancel=(Button)findViewById(R.id.buttonCANCEL); btnCancel.setOnClickListener(new Button.OnClickListener() { public void onClick(View v) { setResult(RESULT_CANCELED); finish(); } }); } }

sub.xml <?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:orientation="vertical"> <EditText android:text="EditText" android:layout_height="wrap_content" android:id="@+id/editText" android:layout_width="fill_parent" android:textSize="30dp" ></EditText> <Button android:layout_height="wrap_content" android:id="@+id/buttonOK" android:text="OK" android:layout_width="fill_parent" android:textSize="20dp" ></Button> <Button android:layout_height="wrap_content" android:id="@+id/buttonCANCEL" android:text="CANCEL" android:layout_width="fill_parent" android:textSize="20dp" ></Button> </LinearLayout>

Activity 간의 통신CommActivity.java

ActivityActEdit.java

Activity

new intent+Caller, +Callee getIntent

putExtra+TextIn

startActivityForRe-sult

getStringExtraTextIn

new intent

putExtra+TextOut

setResut

onActivityResult

getStringExtraTextOut

TextIn

TextOut

Toast 작은 팝업 대화상자 초보자들에게 디버깅용 , 학습용으로 아주 용이한 출력 방법

변수 값을 수시로 찍어볼 때 등

Toast 생성 Method

static Toast makeToast(Context context, int resId, int duration) context : 메시지를 출력하는 주체

MainActivity.this resId : 출력할 문자열의 ID

R.String.name duration : 메시지 출력 지속시간

LENGTH_SHORT, LENGTH_LONG static Toast makeToast(Context context, CharSequence text, int duration)

text : 출력할 메시지 “LifecareScienceLAB”

옵션 Method void setGravity(int gravity, int, xOffset, int yOffset) void setMargin(float horizonMargin, float verticalMargin) void setText(CharSequence s) void setDuration(int duration) void setView(View view)

메시지를 보이거나 숨기는 Method void show() void cancel()

ToastTest.java import android.app.*; import android.os.*; import android.view.*; import android.widget.*; import exam.AndroidExam.*;

public class ToastTest extends Activity { Toast mToast = null; int count; String str;

public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main);

findViewById(R.id.shortmsg).setOnClickListener(mClickListener); findViewById(R.id.longmsg).setOnClickListener(mClickListener); findViewById(R.id.count1).setOnClickListener(mClickListener); findViewById(R.id.count2).setOnClickListener(mClickListener); findViewById(R.id.customview).setOnClickListener(mClickListener); }

Button.OnClickListener mClickListener = new Button.OnClickListener() { public void onClick(View v) { switch (v.getId()) { case R.id.shortmsg: Toast.makeText(ToastTest.this, " 잠시 나타나는 메시지 ", Toast.LENGTH_SHORT).show(); break; case R.id.longmsg: Toast.makeText(ToastTest.this, " 조금 길게 나타나는 메시지 ", Toast.LENGTH_LONG).show(); break; case R.id.count1: str = " 현재 카운트 = " + count++; if (mToast != null) { mToast.cancel(); } mToast = Toast.makeText(ToastTest.this, str, Toast.LENGTH_SHORT); mToast.show(); break; case R.id.count2: str = " 현재 카운트 = " + count++; if (mToast == null) { mToast = Toast.makeText(ToastTest.this, str, Toast.LENGTH_SHORT); } else { mToast.setText(str); } mToast.show(); break; case R.id.customview: LinearLayout linear = (LinearLayout)View.inflate(ToastTest.this, R.layout.output_toast, null); Toast t2 = new Toast(ToastTest.this); t2.setView(linear); t2.show(); break; } } }; }

main.xml <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:orientation="vertical" android:layout_width="fill_parent" android:layout_height="fill_parent" > <Button android:id="@+id/shortmsg" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="짧은 메시지" /> <Button android:id="@+id/longmsg" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="긴 메시지" /> <Button android:id="@+id/count1" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="카운트 연속 출력" /> <Button android:id="@+id/count2" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="카운트 연속 출력2" /> <Button android:id="@+id/customview" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="커스텀 뷰 표시" /> </LinearLayout>

Log 개발자를 위한 디버깅용 메시지 Eclipse 를 통해서만 확인 가능

LogCat 을 이용하여 확인 할 수 있다 . 다양한 메시지 필터

Log.v : verbose Log.i : information Log.w : warning Log.e : error Log.d : debugging

Log.x(String tag, String msg) tag : 사용자 정의 메시지 분류 msg : 출력할 메시지

아주대학교

SOFTWARE DEVELOP-MENT

• Design Presentation

top related