Devahoy Logo
PublishedAt

Android

Day 16 - Autofix TextView

Day 16 - Autofix TextView

สวัสดีครับ บทความนี้เป็นบทความที่ 16 แล้วนะครับ ที่ผมจะมาเขียน ในซีรีย์ Learn 30 Android Libraries in 30 days

สำหรับบทความทั้งหมด อ่านได้จากด้านล่างครับ

สำหรับวันนี้ขอนำเสนอเรื่อง AutofitTextView Library ตัวนี้ไม่มีอะไรมาก เป็นเหมือน Custom TextView ที่เอาไว้จัด TextView และปรับขนาดของ TextView ให้เราอัตโนมัติตามความยาวของข้อความครับ ขอได้รับการขอบคุณจาก CVD International เอ้ย ไม่ใช่!! ต้องขอขอบคุณ คุณเอก ที่แนะนำมาครับ

AutofitTextView

Installation

ขั้นตอนการติดตั้ง ง่ายๆครับ เพิ่ม dependencies ลงไปที่ไฟล์ build.gradle

1
dependencies {
2
compile 'me.grantland:autofittextview:0.1.+'
3
}

กด Sync Project with Gradle File เป็นอันเรียบร้อย

Getting Started

การใช้งาน AutofitTextView ก็เหมือนกับการใช้ TextView ทั่วๆไปเลยครับ เพียงแค่เพิ่มแท็กลงไปในไฟล์เลเอาท์ xml ของเรา อย่างเช่น เวลาเราจะใช้ TextView ก็จะใช้แบบนี้

1
<TextView
2
android:id="@+id/text"
3
android:layout_width="match_parent"
4
android:layout_height="match_parent"
5
android:singleLine="false"/>

หากเป็น AutofitTextView ก็จะประกาศแบบนี้

1
<me.grantland.widget.AutofitTextView
2
android:layout_width="match_parent"
3
android:layout_height="wrap_content"
4
android:singleLine="true" />

มาเริ่มสร้างโปรเจ็คง่ายๆกันเลยครับ เริ่มที่เลเอาท์ ตั้งชื่อว่า activity_autofit.xml

1
<?xml version="1.0" encoding="utf-8"?>
2
3
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
4
android:orientation="vertical"
5
android:layout_width="match_parent"
6
android:layout_height="match_parent">
7
8
<EditText
9
android:id="@+id/edit_text"
10
android:hint="@string/edit_text_hint"
11
android:layout_width="wrap_content"
12
android:layout_height="wrap_content"
13
android:layout_marginBottom="32dp"/>
14
15
<me.grantland.widget.AutofitTextView
16
android:id="@+id/text_view"
17
android:textSize="32sp"
18
android:layout_width="match_parent"
19
android:layout_height="wrap_content"
20
android:maxLines="3" />
21
22
</LinearLayout>

จากเลเอาท์ด้านบน ผมใช้ AutofitTextView โดยกำหนด จำนวนแถวทั้งหมด 3 แถว ถ้าใครอยากใช้แค่แถวเดียวก้ใส่ android:singleLine="true" ไปครับ ส่วน EditText เอาไว้พิมพ์ข้อความ ข้อความก็จะมาแสดงใน AutofitTextView ครับ ส่วนไฟล์ strings.xml เพิ่ม นี้ลงไป

1
<string name="edit_text_hint">Input some text</string>

ต่อมาทำการสร้างคลาส AutofitActivity.java ขึ้นมา ทำการ setContentView() และ findViewById() ให้เรียบร้อย

1
package com.devahoy.learn30androidlibraries.day16;
2
3
import android.os.Bundle;
4
import android.support.v7.app.ActionBarActivity;
5
import android.text.Editable;
6
import android.widget.EditText;
7
8
import com.devahoy.learn30androidlibraries.R;
9
10
import me.grantland.widget.AutofitTextView;
11
12
public class AutoFitTextViewActivity extends ActionBarActivity {
13
14
AutofitTextView mTextView;
15
EditText mEditText;
16
17
@Override
18
protected void onCreate(Bundle savedInstanceState) {
19
super.onCreate(savedInstanceState);
20
setContentView(R.layout.day16_activity_autofit);
21
mTextView = (AutofitTextView) findViewById(R.id.text_view);
22
mEditText = (EditText) findViewById(R.id.edit_text);
23
}
24
}

ต่อไปก็ใช้ TextWatcher มาช่วย เพื่อให้เวลาที่เราใส่ข้อความลงบน EditText ก็จะไปทำการอัพเดทข้อความลงใน AutofitTextView

1
mEditText.addTextChangedListener(new TextWatcher() {
2
@Override
3
public void beforeTextChanged(CharSequence s, int start, int count, int after) {
4
5
}
6
7
@Override
8
public void onTextChanged(CharSequence s, int start, int before, int count) {
9
mTextView.setText(s);
10
}
11
12
@Override
13
public void afterTextChanged(Editable s) {
14
15
}
16
});

สุดท้าย ทดสอบรันโปรแกรม แล้วลองพิมพ์ข้อความดูครับ

Result Result2 Result3

อะ ทดสอบภาษาไทยซักหน่อยว่าได้มั้ย?

Thai Thai2

สรุป

ตัว AutofitTextView() มันก็เป็น Library แบบง่ายๆครับ หากดู source code จะเห็นว่ามีแค่คลาส AutofitTextView เท่านั้นครับ โดยคลาสที่ extends TextView อีกที เพื่อทำการ custom ครับ หากใครมีแอพที่ต้องใช้แสดงผล TextView เยอะๆ หรืออยากจัดหน้า จัดเรียงข้อความให้มันสวยๆ ก็ลองดู Library ตัวนี้นะครับ ใช้งานง่าย มีประสิทธิภาพครับ แถมภาษาไทยก็ไม่มีปัญหา แต่อาจจะมีตัดคำ ตัดตัวอักษรผิดไปบ้าง

Happy Coding :D

Source Code

References

Authors
avatar

Chai Phonbopit

เป็น Web Dev ในบริษัทแห่งหนึ่ง ทำงานมา 10 ปีกว่าๆ ด้วยภาษาและเทคโนโลยี เช่น JavaScript, Node.js, React, Vue และปัจจุบันกำลังสนใจในเรื่องของ Blockchain และ Crypto กำลังหัดเรียนภาษา Rust

Related Posts