Devahoy Logo
PublishedAt

Android

Day 6 - Holo Color Picker

Day 6 - Holo Color Picker

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

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

สำหรับวันนี้ขอนำเสนอเรื่อง Holo Color Picker

Holo Color Picker คืออะไร?

Holo Color Picker เป็น Library ที่เอาไว้โชว์ Dialog สำหรับเลือกสี ใช้ได้กับ View ทุกอย่าง ตั้้งแต่ TextView, Button ยัน Layout จุดเด่นของมันคือ ไม่ได้เลือกสีอย่างเดียว สามารถปรับแต่ง Opacity ได้ สำหรับ Document อ่านได้จากหน้า Github ของ Library ได้เลย Holo Color Picker on Github

Holo Color Picker

Installaton

ในส่วนขั้นตอนการติดตั้ง เปิดไฟล์ build.gradle เพิ่ม dependency นี้ลงไป

1
dependencies {
2
compile 'com.larswerkman:HoloColorPicker:1.4'
3
}

Getting Started

ก่อนเริ่มโปรเจ็ค หากใครได้อ่าน Document หน้าเว็บ ก็จะเจอตัวอย่าง และวิธีการใช้ ซึ่งมันไม่มีอะไรซับซ้อนเลย แค่สร้างไฟล์ Layout และก็เรียกใช้จากคลาส เหมือนการ findViewById() View อื่นๆ

ส่วน Listener ของมันจะมีด้วยกันคือ

  • OnValueChangeListener : สำหรับ Listener เมื่อ color มีการเปลี่ยนค่า
  • OnOpacityChangeListener : สำหรับ Listener เมื่อ Opacity (ค่าความโปร่งใส) มีการเปลี่ยนค่า
  • OnSaturationChangeListener : สำหรับ Listener เมื่อ Saturation (ความบริสุทธิ์ของสี)

เริ่มสร้างโปรเจ็คเลย โดย ผมจะใช้ 3 ไฟล์คือ HoloColorPickerActivity.java, activity_holo_color.xml และไฟล์ dialog.xml สำหรับเอาไว้แสดง Dialog ให้เลือก Color เมื่อกดปุ่ม Button

สำหรับตัวอย่าง เป็นแบบง่ายๆคือ สามารถเปลี่ยนพื้นหลัง Background ของแอพ โดยการเลือก Holo Color Picker

ขั้นแรก ก็เพิ่ม xml สำหรับไฟล์ acitivty_holo_color.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:id="@+id/linear_layout"
6
android:gravity="center"
7
android:layout_width="match_parent"
8
android:layout_height="match_parent">
9
10
<Button
11
android:id="@+id/button_pick_color"
12
android:layout_width="wrap_content"
13
android:layout_height="wrap_content"
14
android:padding="24dp"
15
android:text="@string/pick_color"/>
16
17
18
</LinearLayout>

ส่วนไฟล์ dialog.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:gravity="center"
6
android:layout_width="match_parent"
7
android:layout_height="match_parent">
8
9
<com.larswerkman.holocolorpicker.ColorPicker
10
android:id="@+id/picker"
11
android:layout_width="wrap_content"
12
android:layout_height="wrap_content"/>
13
14
<com.larswerkman.holocolorpicker.SVBar
15
android:id="@+id/svbar"
16
android:layout_width="wrap_content"
17
android:layout_height="wrap_content"/>
18
19
<com.larswerkman.holocolorpicker.OpacityBar
20
android:id="@+id/opacitybar"
21
android:layout_width="wrap_content"
22
android:layout_height="wrap_content"/>
23
24
</LinearLayout>

และไฟล์ HoloColorPicker.java มีแค่นี้ (มีแค่ setContentView() อย่างเดียว)

1
package com.devahoy.learn30androidlibraries.day6;
2
3
import android.os.Bundle;
4
import android.support.v7.app.ActionBarActivity;
5
6
import com.devahoy.learn30androidlibraries.R;
7
8
public class HoloColorPickerActivity extends ActionBarActivity {
9
10
@Override
11
protected void onCreate(Bundle savedInstanceState) {
12
super.onCreate(savedInstanceState);
13
setContentView(R.layout.day6_activity_holo_color);
14
}
15
}

จากนั้น setListener() ให้กับ Button ซะ เพื่อเปิด Dialog ดังนี้

1
button.setOnClickListener(new View.OnClickListener() {
2
@Override
3
public void onClick(View v) {
4
openDialog();
5
}
6
});

และเพิ่มเมธอด openDialog()

1
private void openDialog() {
2
AlertDialog.Builder builder =
3
new AlertDialog.Builder(this);
4
LayoutInflater inflater = getLayoutInflater();
5
6
final View view = inflater.inflate(R.layout.day6_dialog, null);
7
builder.setView(view);
8
9
// Color picker go here.
10
11
builder.setPositiveButton("OK", new DialogInterface.OnClickListener() {
12
@Override
13
public void onClick(DialogInterface dialog, int which) {
14
15
}
16
});
17
builder.setNegativeButton("Cancel", null);
18
builder.show();
19
}

ทดสอบรันโปรแกรม แล้วลองเปิด Dialog ดู ได้ดังภาพ (จะเห็นว่าเลือก Color อะไรได้แล้ว แต่ว่าเรายังไม่ได้ setListener ให้มัน ทำให้มันยังไม่สมบูรณ์)

Result

ต่อมา ได้เวลาทำ Listener กันแล้ว เริ่มเขียนโค๊ด ที่ผมคอมเม้นไว้นะครับ // Color picker go here.

1
final ColorPicker picker = (ColorPicker) view.findViewById(R.id.picker);
2
SVBar svBar = (SVBar) view.findViewById(R.id.svbar);
3
OpacityBar opacityBar = (OpacityBar) view.findViewById(R.id.opacitybar);
4
5
picker.addOpacityBar(opacityBar);
6
picker.addSVBar(svBar);
7
8
picker.setOnColorChangedListener(new ColorPicker.OnColorChangedListener() {
9
@Override
10
public void onColorChanged(int i) {
11
mLinearLayout.setBackgroundColor(picker.getColor());
12
}
13
});

ด้านบนเป็นแค่การเชื่อม View ที่ประกาศไว้ใน xml จากนั้นก็ใช้ ColorPicker ทำการ addSVBar() และ addOpacityBar() เพื่อทำการ setOnColorChangedListener() ทีเดียวครับ ไม่อย่างงั้นก็ต้องสั่ง setListener() แยกต่างหาก

เมื่อมีการเปลี่ยนสีของ color picker ก็ให้ setBackgroundColor() เป็นสีที่เลือกครับ ส่วน mLinearLayout ได้มาจาก

1
private LinearLayout mLinearLayout;
2
3
@Override
4
protected void onCreate(Bundle savedInstanceState) {
5
...
6
mLinearLayout = (LinearLayout) findViewById(R.id.linear_layout);
7
...
8
}

สุดท้ายลองรันโปรแกรม แล้วลองเปลี่ยนสี Color Picker ไปเรื่อยๆ สีของ Linear Layout ก็จะเปลี่ยนตามครับ

Result

จบละครับ สำหรับ Library อันนี้ ไม่รู้จะเขียนอะไรต่อ เพราะมันก็มีแค่นี้จริงๆ เอาไว้แค่ Color Picker ก็จะได้ค่าสีเป็น int แล้วจะเอาไปทำอะไรก็ตามสะดวกครับ

Authors
avatar

Chai Phonbopit

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

Related Posts