Tips - แนะนำ 20 Short Key ที่ควรรู้บน Android Studio

Published on
Android
2014/07/20-tips-keyboard-shortcut-on-android-studio
Discord

สวัสดีครับ บทความนี้ผมจะมาแนะนำ Tip และ เทคนิค บน Android Studio ที่จะช่วยให้ทุกท่าน เขียนโค๊ดได้ไวขึ้น ทำงานได้ไวขึ้น รวมถึงประโยชน์หลายๆอย่างของ Keyboard Short Cut แต่ละตัว แน่นอนว่า ส่วนใหญ่ Tip พวกนี้ มันมีอยู่ในหน้า Tip of a Day อยู่แล้ว ผมแค่ยกตัวอย่าง ที่คิดว่าน่าจะมีประโยชน์มาแชร์กันครับ

สำหรับเวอร์ชั่น Mac OS X สามารถดูได้ที่นี่ Tips : แนะนำ 20 Short Key ที่ควรรู้บน Android Studio (Mac OS X)

เนื่องจากว่า Android Studio มันพัฒนามาจาก Intelij IDEA Community ทำให้ Short Key หรือฟังค์ชันทุกๆ อย่างเหมือนกับ Intelij IDEA เลย ใครที่อยากรู้รายละเอียด Short Key เพิ่มเติม หรือ Features อะไรบ้าง ที่มีใน Intelij IDEA ก็สามารถอ่านเพิ่มเติมได้จากลิงค์ด้านล่างนี้

Table of Content

Tip 1 : Code Complete

Ctrl + Spacebar

ตัวช่วยพื้นฐานเลยก็ว่าได้ มันจะคอยแนะนำ ตัวแปร เมธอด ต่างๆ หรือแม้แต่ชื่อตัวแปรให้เราเช่น

private AdapterView.OnItemClickListener

แล้วกด Ctrl + Space มันก็จะแนะนำ ควรจะตั้งตัวแปรชื่ออะไรให้เรา

Tip 1

Tip 2 : Show Parameters

Ctrl + P

Tip นี้เชื่อว่าน่าจะเป็น short key ที่นิยมใช้เป็นลำดับต้นๆแน่นอน เพราะมันช่วยให้เรารู้ว่า เมธอดนี้ มี parameter อะไรบ้าง โดยการกด ctrl + p ระหว่างปีกกา เช่น

Tip 2

Tip 3 : Live Template

Ctrl + J

เป็นหนึ่งใน feature ของ Intelij IDEA ที่มีประโยชน์มากๆครับ คือเราแค่พิมพ์คำสั้นๆ มันก็จะออโต้ให้เรา อย่างเช่น พิมพ์แค่ psfs แล้วกด Tab มันจะกลายเป็น

public static final String

sout แล้วกด Tab ก็จะกลายเป็น System.out.println();

หรือ พิมพ์แค่ itar แล้วกด Tab มันจะ gen for loop ให้เราแบบนี้

for (int i = 0; i < FOCUSED_STATE_SET.length; i++) {
    int i1 = FOCUSED_STATE_SET[i];

}

หากใครลืมว่ามี live Template อะไรบ้าง ก็สามารถกดดูได้ด้วยคำสั่ง Ctrl + J

Tip 3

Tip 3 - 2

Tip 4 : Recent Files

Ctrl + E

เราสามารถเรียกดูไฟล์ที่เราเปิดล่าสุด ได้ด้วย short key นี้เลย

Tip 4

Tip 5 : Recend Change

Alt + Shift + C

อันนี้คล้ายๆกับ ด้านบน แต่ว่าเป็นการดูว่าเราได้แก้ไขอะไรไปบ้าง แบบนี้

Tip 5

Tip 6 : Next/Previous method

Alt + Up หรือ Alt + Down

สำหรับกดเลื่อนไขเมธอดขั้นไป หรือเมธอดก่อนหน้า ได้ง่ายๆ ในหน้าโค๊ดได้เลย ทำให้เราไม่ต้องเสียเวลา เอามือไปเลื่อนเมาท์ เพิ่มความเร็วในการเขียนโค๊ดแน่นอน

Tip 7 : Copy to Clipboard

Ctrl + Shift + V

สำหรับ paste สิ่งที่เราก็อปปี้ได้ ต่างจาก Ctrl + V ตรงที่เราสามารถเลือกได้ว่า เราเคย Copy อะไรไปแล้วบ้าง เพราะ Ctrl + V จะ paste เฉพาะ ที่ copy ล่าสุดเท่านั้น (ภาษาไทยก็ก็อปได้)

Tip 7

Tip 8 : Type Hierarchy

Ctrl + H

เราสามารถดู Type Hierarchy ได้ว่าเมธอด หรือคลาสนี้ สืบทอดมาจากคลาสอะไรบ้าง โดยเลือกไปที่คลาสๆนั้น แล้วก็กด Ctrl + H ครับ อย่างในรูป ผมกดดู ActionBarActivity แถมมันรู้ด้วยว่า มีคลาสอะไรที่ผม extends ActionBarActivity อยู่

Tip 8

Tip 9 : Open Documentation

Ctrl + Q

เราสามารถกดโชว์ Dialog เพื่อดู Document ของคลาสนั้นๆได้ โดยการเลือกไปที่คลาสนั้น แล้วกด Ctrl + Q จะมี Popup เด้งขึ้นมา หรือจริงๆ เราแค่เอาเมาท์ไปชี้ แล้วค้างไว้ในระยะเวลาหนึ่ง (ซึ่งเรากำหนดได้ว่าจะให้เป็นเท่าไหร่)

Tip 9

วิธีการกำหนดระยะเวลา ว่าให้เอาเมาท์ไปชี้ที่ variable นั้นๆ แล้วเด้ง Document ขึ้นมา ทำได้โดยเข้าไปที่ Settings -> Editor -> ติ๊กถูกที่ช่อง Show quick doc on mouse move Delay(ms) แล้วก็ใส่เวลาที่ต้องการ (มิลลิวินาที)

Tip 10 : Rename Variable

Shift + F6

เราสามารถเปลี่ยนตัวแปร ได้ง่ายๆ เช่นเราตั้งชื่อว่า String myName; แล้วจะเปลี่ยนเป็นชื่ออื่น แต่ว่า ดันเรียกใช้ myName ไว้เป็นสิบๆแห่งเลย จะเปลี่ยนก็้ต้องมานั่งเลือกเปลี่ยน ทีละตัว ซึ่งมันลำบากมาก วิธีที่ง่าย ก็คือ เลือกที่ตัวแปรตัวหนึ่ง แล้วกด Shift + F6 ก็สามารถเปลี่ยนตัวแปรทีเดียว ทั้งคลาสเลย สะดวกมาก

Tip 10

Tip 11 : Auto Cast

Ctrl + Shift + Spacebar

โดยปกติ ส่วนใหญ่แล้ว เวลาเขียนแอพแอนดรอยส์ต้องเจอ การ Cast บ่อยๆ แน่นอน เช่น findViewById() ปกติเราต้องพิมพ์ (TextView) ด้วยทุกครั้ง

TextView textView = (TextView) findViewById(R.id.textview);

เราสามารถย่อให้ไวขึ้นได้ โดยการพิมพ์

TextView textView = (

เมื่อลูกศร (cursor) อยู่หลังวงเล็บเปิด ก็ให้กด Ctrl + Shift + Spacebar มันก็จะ กลายเป็น

TextView textView = (TextView)

สะดวกและรวดเร็วขึ้นมาอีกนิด

Tip 12 : Find class name

Ctrl + N

Tip นี้มีประโยชน์มาก ในกรณีที่เรามีคลาสๆ เยอะๆ เราสามารถกดแล้วเลือกค้นหาคลาส จากชื่อได้เลย

Tip 12

Tip 13 : Find file name

Ctrl + Shift + N

Tip นี้คล้ายๆกับ การหาคลาสแบบด้านบนเลย ต่างกันที่อันนี้ไม่ได้หาแต่คลาส แต่ว่าหาไฟล์อื่นๆ ได้อีกด้วย เช่นไฟล์ xml ไฟล์ใน res ต่างๆ

Tip 13

Tip 14 : Show Image

Ctrl + Shift + I

อันนี้เอาไว้ใช้ในหน้า layout ครับ เช่นเวลาเราใส่ background ให้มัน แต่ว่าอยากดูว่ารูปนี้เป็นรูปอะไร ก็กดง่ายๆเลย แบบนี้

Tip 14

Tip 15 : Auto Generate

Alt + Insert

อันนี้เอาไว้ให้มัน auto generate ให้เองครับ เช่นพวก การทำ Constructor หรือจะให้มันสร้าง Getter และ Setter ให้เอง

Tip 15

Tip 16 : Show override method

Ctrl + O

เอาไว้กดดูว่าในคลาสนี้อะ มีเมธอดอะไรให้เราใช้ได้บ้าง อย่างกรณีกดดูในคลาสที่ extends ActionBarActivity

Tip 16

Tip 17 : Implement Method

Ctrl + I

ในกรณีที่เราต้องการ implement method Interface ที่เราทำการ implement มา เราสามารถกด Key นี้ได้แบบง่ายๆเลย เช่นเมื่อเรา implement OnItemClickListener หรือว่า BaseAdapter เป็นต้นครับ

Tip 17

Tip 18 : Reformat Code

Ctrl + Alt + L

อันนี้เอาไว้ให้มันจัด format โค๊ดให้เราครับ เช่นบางทีจัดเรียงหน้า เว้นวรรค ตัดคำ ตัดโค๊ดที่มีความยาวเกิน หรือแท็ป ระหว่างบรรทัด ครับ

จากรูป

Tip 18

เมือกด Ctrl + Alt + L เพื่อ Reformat โค๊ด

Tip 18 - 2

การตั้งค่า Reformat Code สามารถปรับแต่งเพิ่มเติมได้ โดยเ้ข้าไปที่ Settings -> Code Style -> ภาษา จากนั้นก็จะมีให้ปรับพวก Tab, Indent, Space หรือการ Wrapping Brace ต่างๆครับ

Tip 19 : Multiple Selection

Shift + Alt + Mouse Click

อันนี้คือเราสามารถเลือก Select ได้หลายๆ ตัว และสามารถแก้ค่า value ได้ทีละหลายๆค่าได้เลย หากใครเคยใช้ Sublime Text จะคุ้นๆมากครับ ส่วนนี้ Intelij IDEA ก็เอาไอเดียมาจาก Sublime Text ครับ แถมปัจจุบัน Chrome Dev Tools ก็มี feature นี้เหมือนกัน เรียกได้ว่า มันเป็น feature ยอดฮิตเลยก็ว่าได้

Multiple Selection

วิธีการคือ กด Shift + Alt จากนั้นก็ใช้เมาท์คลิกไปยังตำแหน่งที่ต้องการ กด esc เพื่อกดออกจาก feature

Tip 20 : Comment/Uncomment

Ctrl + / และ Ctrl + Shift + /

คีย์นี้เอาไว้ใช้ในกรณีที่ต้องการ คอมเม้นโค๊ดครับ เพียงแค่กด Ctrl + / ก็จะคอมเม้นโค๊ดบรรทัดนั้นๆ หากกดอีกที ก็จะเป็นการ เอาคอมเม้นออก หรือหากต้องการคอมเม้นหลายๆบรรทัด ก็กด Ctrl + Shift + /

Bonus 1 : Auto Import

Ctrl + Alt + O

อันนี้คือการ Optimize Import ครับ สำหรับ import class ต่างๆ ใน Eclipse ก็เหมือนกับการกด Ctrl + Shift + I ครับ

อีกอย่าง หากไม่ต้องการกด Import ทุกครั้ง เราสามารถให้มัน import อัตโนมัติได้ครับ ซึ่งใน Intelij IDEA เรียกมันว่า import on the fly ครับ วิธีการ ก็เข้าไป Settings -> Editor -> Auto Import แล้วเลือก Optimize import on the fly ที่นี้เวลาเราเรียกคลาสอะไรมา มันก็จะ import ให้เองเลย

Bonus 1

Bonus 2 : Menu

ที่จริงๆพวก Shortcut Key เหล่านี้ หากเราไม่กดด้วย Keyboard มันก็มีวิธีเรียกอีกวิธีนึงนะครับ นั่นก็คือเลือกที่เมนู แต่ละหัวข้อเลย เช่น เมนู View, Navigate, Code และก็ต่อๆมาครับ

Bonus 2

Bonus 3 : Parameter Popup

ผมเคยถามบางคน ทำไมไม่ชอบ Android Studio หรอ เค้าบอกว่า มันไม่มี Popup มาให้ดูว่าใช้ parameter อะไรบ้าง บางทีก็ช้า บางทีก็ต้องมานั่งกดเอง ไม่เหมือน Eclipse

ผมเลยบอกกลับไป ก็ไปตั้งค่าให้มันซิ แค่เข้าไปที่ Settings -> Editor -> Code Completion ติ๊กถูกที่ Autopopup in (ms) แล้วก็ใส่เวลาที่ต้องการซะ อยากให้มันโชว์เร็วๆ ก็ใส่ซัก 1 มิิลลิวินาทีไปเลย

Bonus 4 : Speed up Gradle!

อันนี้เป็น Tip เล็กๆน้อยๆครับ พอดีไปเจอในกรุ๊ปหนึ่ง เห็นว่ามีปัญหาเกี่ยวกับ Speed ของ Gradle ครับ ปกติ Android Studio มันใช้ทรัพยากรเครื่่่องมากกว่า Eclipse อยู่แล้ว ยิ่งถ้าเป็นตอนที่เริ่มสร้างโปรเจ็ค แล้วทำการ generate file, Build Task แล้วก็โหลด library จาก Maven ในกรณีที่เครื่องไม่ได้เซฟ repository ไว้

แถมถ้าเกิดมันทำการเช็คเวอร์ชันใหม่ หรือว่าอัพเดท Maven นี่ยิ่งช้าเข้าไปใหญ่เลย CPU รัน 100%

Update Maven Repo

วิธีแก้ Settings -> Gradle -> เลือก Offline Work เพื่อไม่ต้องเช็คเวอร์ชันล่าสุดบ่อยๆ

อีกที่คือไฟล์ gradle.properties ในโปรเจ็ค ให้เพิ่ม นี่ลงไป

org.gradle.daemon=true

Reference : Building and running app via Gradle and Android Studio is slower than via Eclipse

Bonus 5 : Move Line Up/Down

อันนี้เพิ่มเติมนะครับ เนื่องจากเพิ่งเห็นจาก Google+ มา ก็เลยนำมาแชร์กันเลยครับ สำหรับอันนี้จะเป็นการเลื่อน ทั้งบรรทัดเลยครับ รายละเอียดตามรูปเลย

Move Lines


หมดละครับ สำหรับ 20 Short Key บน Android Studio (Intelij IDEA) มีแถมเพิ่ม เนื่องจากเพิ่งนึกขึ้นได้ จะให้เขียน 30 ไปเลย ก็ขี้เกียจ ฮา~

หากใครมีเทคนิคอะไรอยากจะแนะนำเพิ่มเติม ก็แนะนำมาได้นะครับ หวังว่าคงจะมีประโยชน์และช่วยให้การเขียนโค๊ดได้เร็วและมีประสิทธิภาพมากขึ้นนะครับ

บทความต่อไปผมจะมาแนะนำ 10 Features ดีๆที่คุณจะต้องหลงรัก Android Studio คอยติดตามอ่านนะครับ :D

Buy Me A Coffee
Authors
Discord