스레드에서 UI 업데이트 하는 방법 1. handler.post(); 이용
작업 스레드에서 변경(UI)된 내용: 메인 스레드에 화면 갱신 요청
Hanler 클래스: 작업 스레드와 메인 스레드간 매게체 역할(main 스레드와 통신 제공)
1. 레이아웃
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context="com.progdv.currenttime.MainActivity">
<LinearLayout
android:orientation="horizontal"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/linearLayout">
<Button
android:id="@+id/btnStart"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="시작"
/>
<Button
android:id="@+id/btnStop"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="1"
android:text="중지"
/>
</LinearLayout>
<TextView
android:id="@+id/txtTime"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:text="현재 시간"
android:layout_below="@+id/linearLayout"
android:layout_alignParentLeft="true"
android:layout_alignParentStart="true"
android:layout_margin="25sp"/>
</RelativeLayout>
2. 메인 액티비티
package com.progdv.handler;
import android.os.Bundle;
import android.os.Handler;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import java.util.Date;
public class MainActivity extends AppCompatActivity {
TextView txtTime;
boolean flag = true;
Handler handler = new Handler();
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
txtTime = (TextView)findViewById(R.id.txtTime);
Button btnStart = (Button)findViewById(R.id.btnStart);
Button btnStop = (Button)findViewById(R.id.btnStop);
btnStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
while(flag) {
try {
Date d = new Date();
final String currentTime = "현재 시간은: "+d.toString();
handler.post(new Runnable() {
@Override
public void run() {
txtTime.setText(currentTime);
}
});
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
});
thread.start();
}
});
btnStop.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
flag = false;
}
});
}
}
시작을 눌러도 에러 없이 현재 시간이 출력된다.
스레드 안에서 UI 관련 작업을 할 때에는 handler.post를 이용해야 한다.
스레드에서 UI 업데이트 하는 방법 2. handler.sendMessage(); 이용
UI스레드에게 메시지를 전달하는 형태
2-1) 메인 액티비티
package com.progdv.handler;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import java.util.Date;
public class MainActivity extends AppCompatActivity {
TextView txtTime;
boolean flag = true;
// 방법1: hanlder.post();
// Handler handler = new Handler();
// 방법2: hanlder.sendMessage();
Handler handler = new Handler(new Handler.Callback(){
@Override
public boolean handleMessage(Message msg) {
if(msg.what == 1) {
String time = (String)msg.obj;
txtTime.setText(time);
}
return true;
}
});
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
txtTime = (TextView)findViewById(R.id.txtTime);
Button btnStart = (Button)findViewById(R.id.btnStart);
Button btnStop = (Button)findViewById(R.id.btnStop);
btnStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
while(flag) {
try {
Date d = new Date();
final String currentTime = "현재 시간은: "+d.toString();
// 방법1: handler.post();
// handler.post(new Runnable() {
// @Override
// public void run() {
// txtTime.setText(currentTime);
// }
// });
// 방법2: handler.setndMessage();
Message message = Message.obtain();
message.obj = currentTime;
message.what = 1;
handler.sendMessage(message);
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
});
thread.start();
}
});
btnStop.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
flag = false;
}
});
}
}
스레드에서 UI 업데이트 하는 방법 3. handler.sendEmptyMessage(); 이용
작업 스레드와 UI스레드 사이의 요청을 메시지로 전달
2-2) 메인 액티비티
package com.progdv.handler;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.v7.app.AppCompatActivity;
import android.view.View;
import android.widget.Button;
import android.widget.TextView;
import java.util.Date;
public class MainActivity extends AppCompatActivity {
TextView txtTime;
boolean flag = true;
// 방법1: hanlder.post();
// Handler handler = new Handler();
// 방법2, 3: hanlder.sendMessage();, handler.sendEmptyMessage();
Handler handler = new Handler(new Handler.Callback(){
@Override
public boolean handleMessage(Message msg) {
if(msg.what == 1) {
// 방법2
/*String time = (String)msg.obj;
txtTime.setText(time);*/
// 방법3
Date d = new Date();
final String currentTime = "현재 시간은: "+d.toString();
txtTime.setText(currentTime);
}
return true;
}
});
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
txtTime = (TextView)findViewById(R.id.txtTime);
Button btnStart = (Button)findViewById(R.id.btnStart);
Button btnStop = (Button)findViewById(R.id.btnStop);
btnStart.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
while(flag) {
try {
/* Date d = new Date();
final String currentTime = "현재 시간은: "+d.toString();*/
// 방법1: handler.post();
// handler.post(new Runnable() {
// @Override
// public void run() {
// txtTime.setText(currentTime);
// }
// });
// 방법2: handler.setndMessage();
// Message message = Message.obtain();
// message.obj = currentTime;
// message.what = 1;
// handler.sendMessage(message);
// 방법3: handler.sendEmptyMessage();
handler.sendEmptyMessage(1);
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
}
});
thread.start();
}
});
btnStop.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
flag = false;
}
});
}
}
'안드로이드' 카테고리의 다른 글
XML 파서: DOM파서, SAX파서 (0) | 2016.05.03 |
---|---|
Asyncask 클래스 (0) | 2016.05.03 |
작업스레드 만들기 (0) | 2016.05.03 |
Thread를 이용한 Progress Dialog 일정 시간 후 종료시키기 (0) | 2016.05.03 |
안드로이드 스레드(Thread) (0) | 2016.05.02 |