글자 수 실시간 표시하기
안녕하세요 초이 입니다~
오늘은 글자 수를 입력 시 마다, 실시간으로 갱신 되면서
현재 입력된 문자의 수를 세는 문제를 풀어보려고 합니다.
실제로 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) {
}
});
}
}
(안드로이드) 콘텐츠 프로바이더 (Content Provider) (0) | 2019.01.28 |
---|---|
(안드로이드) 레이아웃 인플레이션 및 인플레이터 (layout Inflation & inflator) (2) | 2019.01.28 |
(안드로이드 미션) 이미지 이동하기 (0) | 2019.01.28 |
(안드로이드) 애플리케이션 다국어화 예제 (0) | 2019.01.28 |
(안드로이드) 문자열 리소스 (안드로이드 string.xml) (0) | 2019.01.28 |