728x90
- 앱의 기능 설명
- 1. 로그인 기능
- 2. 메모장
- 3. 달력
- 4. 연락처
- 5. 그림판
- 6. 미니게임
- 7. 계산기
- 8. 스톱워치
- 9. 가계부
- 스톱워치
- 스톱워치 xml 코드
더보기
<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context=".MainActivity"
android:background="#25E9FD35">
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical">
<TextView
android:id="@+id/timeView"
android:layout_width="match_parent"
android:layout_height="100dp"
android:background="@drawable/bg_index"
android:gravity="center"
android:text="00:00:00:00"
android:textColor="#FFD000"
android:textSize="35dp"
android:textStyle="bold" />
<RelativeLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="15dp"
android:layout_marginRight="15dp"
android:layout_marginTop="20dp">
<Button
android:id="@+id/btn_start"
android:layout_width="match_parent"
android:layout_height="70dp"
android:background="#00897B"
android:text="시작"
android:textColor="#FDD835"
android:textStyle="bold" />
<LinearLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="horizontal">
<Button
android:id="@+id/btn_record"
android:layout_width="0dp"
android:layout_height="70dp"
android:layout_marginRight="3dp"
android:layout_weight="1"
android:background="@drawable/bg_index"
android:text="기록"
android:textColor="#FDD835"
android:textStyle="bold"
android:visibility="invisible" />
<Button
android:id="@+id/btn_pause"
android:layout_width="0dp"
android:layout_height="70dp"
android:layout_marginRight="3dp"
android:layout_weight="1"
android:background="@drawable/bg_index"
android:text="일시정지"
android:textColor="#FDD835"
android:textStyle="bold"
android:visibility="invisible" />
<Button
android:id="@+id/btn_stop"
android:layout_width="0dp"
android:layout_height="70dp"
android:layout_weight="1"
android:background="@drawable/bg_index"
android:text="중지"
android:textColor="#FDD835"
android:textStyle="bold"
android:visibility="invisible" />
</LinearLayout>
</RelativeLayout>
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="15dp"
android:layout_marginTop="20dp"
android:text="기록"
android:textColor="#000000"
android:textSize="22dp" />
<View
android:layout_width="match_parent"
android:layout_height="1dp"
android:layout_marginLeft="15dp"
android:layout_marginTop="5dp"
android:layout_marginRight="15dp"
android:background="#1E88E5">
</View>
<TextView
android:id="@+id/recordView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_marginLeft="15dp"
android:layout_marginTop="15dp"
android:text=""
android:textColor="#000000"
android:textSize="22dp" />
</LinearLayout>
</ScrollView>
- Scrollview, LinearLayout, RelativeLayout을 응용.
- 스톱워치에 필요한, 다양한 버튼들과, 시간 초가 보이는 textView를 생성
- visibility를 이용하여, 뷰들을 보이도록, 안보이도록 설정.
- 스톱워치 java 코드
더보기
public class Activity9 extends AppCompatActivity {
private Button mStartBtn, mStopBtn, mRecordBtn, mPauseBtn;
private TextView mTimeTextView, mRecordTextView;
private Thread timeThread = null;
private Boolean isRunning = true;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.layout9);
if (Build.VERSION.SDK_INT >= 21) {
getWindow().setStatusBarColor(Color.parseColor("#4ea1d3"));
}
mStartBtn = (Button) findViewById(R.id.btn_start);
mStopBtn = (Button) findViewById(R.id.btn_stop);
mRecordBtn = (Button) findViewById(R.id.btn_record);
mPauseBtn = (Button) findViewById(R.id.btn_pause);
mTimeTextView = (TextView) findViewById(R.id.timeView);
mRecordTextView = (TextView) findViewById(R.id.recordView);
mStartBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
v.setVisibility(View.GONE);
mStopBtn.setVisibility(View.VISIBLE);
mRecordBtn.setVisibility(View.VISIBLE);
mPauseBtn.setVisibility(View.VISIBLE);
timeThread = new Thread(new timeThread());
timeThread.start();
}
});
mStopBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
v.setVisibility(View.GONE);
mRecordBtn.setVisibility(View.GONE);
mStartBtn.setVisibility(View.VISIBLE);
mPauseBtn.setVisibility(View.GONE);
mRecordTextView.setText("");
timeThread.interrupt();
}
});
mRecordBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
mRecordTextView.setText(mRecordTextView.getText() + mTimeTextView.getText().toString() + "\n");
}
});
mPauseBtn.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
isRunning = !isRunning;
if (isRunning) {
mPauseBtn.setText("일시정지");
} else {
mPauseBtn.setText("시작");
}
}
});
}
@SuppressLint("HandlerLeak")
Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
int mSec = msg.arg1 % 100;
int sec = (msg.arg1 / 100) % 60;
int min = (msg.arg1 / 100) / 60;
int hour = (msg.arg1 / 100) / 360;
//1000이 1초 1000*60 은 1분 1000*60*10은 10분 1000*60*60은 한시간
@SuppressLint("DefaultLocale") String result = String.format("%02d:%02d:%02d:%02d", hour, min, sec, mSec);
if (result.equals("00:01:15:00")) {
Toast.makeText(Activity9.this, "1분 15초가 지났습니다.", Toast.LENGTH_SHORT).show();
}
mTimeTextView.setText(result);
}
};
public class timeThread implements Runnable {
@Override
public void run() {
int i = 0;
while (true) {
while (isRunning) { //일시정지를 누르면 멈춤
Message msg = new Message();
msg.arg1 = i++;
handler.sendMessage(msg);
try {
Thread.sleep(10);
} catch (InterruptedException e) {
e.printStackTrace();
runOnUiThread(new Runnable(){
@Override
public void run() {
mTimeTextView.setText("");
mTimeTextView.setText("00:00:00:00");
}
});
return; // 인터럽트 받을 경우 return
}
}
}
}
}
}
- mStartBtn이 클릭 되면, stop, Record, Pause 버튼이 보이도록 함.
- timeThread를 상속 받아, timeThread를 시작
- mStopBtn이 클릭 되면, timeThread가 인터럽트 되도록함.
- mRecordBtn이 클릭 되면, 해당 RecordTextView에 있는 사항을 가져와 mRecordTextView에 저장
- mPauseBtn이 클릭 되면, 일시 정지가 된다.
- handler를 통해 몇분 몇초가 지났는지 toast메시지를 통해 알림이 가도록 한다.
728x90
'안드로이드' 카테고리의 다른 글
안드로이드 프로그래밍 - 다용도 앱 만들기 10 (1) | 2023.01.18 |
---|---|
안드로이드 프로그래밍 - 다용도 앱 만들기 8 (0) | 2023.01.18 |
안드로이드 프로그래밍 - 다용도 앱 만들기 7 (0) | 2023.01.18 |
안드로이드 프로그래밍 - 다용도 앱 만들기 6 (0) | 2023.01.18 |
안드로이드 프로그래밍 - 다용도 앱 만들기 5 (0) | 2023.01.18 |