상세 컨텐츠

본문 제목

(안드로이드 미션) TextWatcher 글자 수 실시간 표시하기

Android

by choiDev 2019. 1. 28. 15:24

본문

글자 수 실시간 표시하기


안녕하세요 초이 입니다~


오늘은 글자 수를 입력 시 마다, 실시간으로 갱신 되면서 

현재 입력된 문자의 수를 세는 문제를 풀어보려고 합니다.

실제로 SMS에서 문자의 내용 수를 세고 전송하는 경우가 있죠?

그 경우에 대비해서 이런 문제도 풀어보는 것이 어떨까요!  ^^

그럼 바로 시작하겠습니다~


문제내용

- EditText, TextView, Button 이 3가지 뷰를 사용한 xml 생성

- EditText에 작성되는 글에 따라 TextView에 글자 수를 표시

- Button을 누르면 키보드를 감추기


문제힌트

 - addTextChangedListener() 메소드를 활용해라



layout 예상 그림


문제 정답

  [activity_main.xml] 작성 소스

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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"
android:orientation="vertical"
tools:context=".MainActivity">

<EditText
android:id="@+id/editText"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/border"
android:gravity="top"
android:padding="8dp"
android:layout_weight="8"
android:ems="9"
android:inputType="textPersonName"
android:hint = "글자를 입력 해 주세요"
/>
<TextView
android:id="@+id/textView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_weight="0.5"
android:layout_marginTop="5dp"
android:layout_gravity="right"
android:hint="글자 수가 표시될 자리 입니다."/>

<Button
android:id="@+id/button"
android:layout_width="100dp"
android:layout_height="20dp"
android:layout_weight="1"
android:layout_gravity="right"
android:text="닫기" />


</LinearLayout>

  [MainActivity.java] 작성 소스

import android.content.Context;
import android.content.res.AssetManager;
import android.content.res.Resources;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.drawable.BitmapDrawable;
import android.graphics.drawable.Drawable;
import android.os.Bundle;
import android.support.v7.app.AppCompatActivity;
import android.text.Editable;
import android.text.TextWatcher;
import android.util.Log;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.view.inputmethod.InputMethodManager;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.TextView;
import android.widget.Toast;

import org.w3c.dom.Text;

import java.io.InputStream;

public class MainActivity extends AppCompatActivity {
EditText
editText;
TextView textView;
Button button;

@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);

/**
* View들의 findViewById
* */
editText = (EditText) findViewById(R.id.editText);
textView = (TextView) findViewById(R.id.textView);
button= (Button) findViewById(R.id.button);

/**
* button 클릭 리스너
* */
button.setOnClickListener(new View.OnClickListener(){
@Override
public void onClick(View v) {
InputMethodManager imm = (InputMethodManager)getSystemService(Context.
INPUT_METHOD_SERVICE);
imm.hideSoftInputFromWindow(editText.getWindowToken(),0);
}
})
;

editText.addTextChangedListener(new TextWatcher() {
@Override
public void beforeTextChanged(CharSequence s, int start, int count, int after) {

}

@Override
public void onTextChanged(CharSequence s, int start, int before, int count) {
String input =
editText.getText().toString();
textView.setText(input.length()+" / 80 글자 수");
}

@Override
public void afterTextChanged(Editable s) {

}
})
;
}

}


관련글 더보기