GestureOverlayView - Android Widgets Example |
GestureOverlayView - Android Widgets สำหรับ GestureOverlayView เป็น Widget ใช้สำหรับ ในการออกแบบเหตุการณ์ที่เกิดขึ้นบนหน้าจอในรูปแบบต่าง ๆ เช่นการ Slide ไปยังหน้าจอ หรือการวาดสัญลักษณ์บนหน้าจอ โดยเราสามารถเขียนเงื่อนไขว่าถ้ามีการกระทำแบบนั้น ๆ จะให้เกิดเหตุการณ์อะไร และทำอะไร ซึ่งปกติแล้วใน Android จะมี Library ที่เกี่ยวกับ Gesture อยู่เช่น GestureDetector ซึ่งถ้าใช้ตัวนี้เราจะต้องทำการตรวจสอบเหตุการณ์ต่าง ๆ ขึ้นมาเองได้ เช่น onDown, onFling, onLongPress, onScroll, onShowPress และ onSingleTapUp
ตัวอย่างการใช้ GestureDetector
แต่ถ้าจะง่ายกว่านั้นเราสามารถใช้ GestureOverlayView โดย Widgets ตัวนี้จะอ่านรูปแบบจากรูปแบบ Gesture ที่มีอยู่แล้ว ว่าเหตุการณ์ที่เกิดขึ้นนั้นมีรูปแบบที่คล้ายคลึงกับเหตุการณ์ที่เราได้ออกแบบไว้หรือไม่ และเราจะต้องทำการออกแบบ Gesture Template ไว้ ซึ่งใน Android ก็มีฟีเจอร์นี้ไว้อยู่แล้วเช่นเดียวกัน
data:image/s3,"s3://crabby-images/06acc/06acc731a9ef0090888d3fdffd6af411ec4ff14c" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
XML Syntax
<GestureOverlayView
android:id="@+id/gestureOverlayView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
Example 1 การสร้าง Gesture Template และการเรียกใช้และตรวจสอบรุปแบบ Gesture ด้วย GestureOverlayView
data:image/s3,"s3://crabby-images/63670/63670beb0349bc89302c9d7a7b394599a60509ed" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ไปที่ Show App บนหน้าจอของ Android ให้เลือก Gestures Building
data:image/s3,"s3://crabby-images/749ce/749ce891c1d465d2b518007943dcf9af410ee5b5" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
สังเกตุว่าตอนนี้ยังไม่มี Gestures ให้เลือก Add gesture
data:image/s3,"s3://crabby-images/d1f2a/d1f2a3ab33bf7764a14a8f64226baa275cda0793" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
กำหนดชื่อ Guesture เช่น Slide to up (ไม่ควรตั้งยาวจนเกินไป เพราะจะต้องมีการอ้างอิงถึงชื่อ)
data:image/s3,"s3://crabby-images/d7c51/d7c5135673069f6e7e2535e88066fe444b6b6468" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
จากนั้นก็สร้างรูปแบบของ Gesture ซึ่งตัวแรกเรากำหนดว่า Slide to up ก็ให้ Slide ขึ้นข้างบน หลังจกาเสร็จแล้วก็ให้เลือก Done
data:image/s3,"s3://crabby-images/5100d/5100d0b2e955231e95646ab2c75cac25da92eede" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
สังเกตุว่าไฟล์ของ Gesture จะถูกจัดเก็บไว้ที่ /mnt/sdcard/guesture บน SD Card
Android ทำการ Copy ไฟล์ไปยัง SD Card ของ Emulator การเรียกใช้งานไฟล์บน SD Card
data:image/s3,"s3://crabby-images/9b3a0/9b3a047bfac45c5411a44e7bb79ddc2b440a8457" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
สร้าง Gesture อื่น ๆ ตามที่ต้องการ ในตัวอย่างจะมีอยู่ 4 รายการ คือ
- Slide to left
- Slide to right
- Slide to up
- Slide to down
การนำ Gesture มาใช้งานกับ App ของเรา
เปิด Eclipse และ App ของเรา
data:image/s3,"s3://crabby-images/2ca48/2ca48caf27779f542d027d4a968b22b12c2c2a89" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ไปที่เมนู
Window -> Open Perspective -> DDMS
data:image/s3,"s3://crabby-images/57dde/57ddea586ac2ced5494caf1b0076554194bce48b" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ไฟล์ของ Gesture ถูกเก็บไว้ที่ /mnt/sdcard/guesture ให้เลือก Pull a file from the device
data:image/s3,"s3://crabby-images/733ab/733abe193320e0eba9efa85683a86bd4ae5ba783" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ให้จัดเก็บไฟว็ guesture ไว้ที่ /res/raw/ (กรณีที่ไม่มีโฟเดอร์ให้สร้างขึ้นมาใหม่)
data:image/s3,"s3://crabby-images/88635/886351540443e1f341995e8b2ffa9ff6e2cbf0ee" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
กลับไปยังหน่้าจอของ Java Android
Window -> Open Perspective -> Java
data:image/s3,"s3://crabby-images/71d3f/71d3fd4494554a43ce411e7b791970661eef431e" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ให้เลือก Project -> Clean เพื่อ Refresh ครั้งหนึ่ง
data:image/s3,"s3://crabby-images/69bc3/69bc3a43710a2d2b0cd05625a72e5d81e5de5ce9" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
จะเห็นว่าในโฟเดอร์ /res/raw/ มีไฟล์ guesture ที่เรา Export มาจาก SD Card ของ Android
Code ที่เป็น XML และ Java
activity_main.xml (XML Layout)
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<android.gesture.GestureOverlayView
android:id="@+id/gestures1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gestureStrokeType="multiple"
android:eventsInterceptionEnabled="true"/>
</RelativeLayout>
MainActivity.java (Java Code)
package com.myapp;
import java.util.ArrayList;
import android.os.Bundle;
import android.app.Activity;
import android.gesture.Gesture;
import android.gesture.GestureLibraries;
import android.gesture.GestureLibrary;
import android.gesture.GestureOverlayView;
import android.gesture.GestureOverlayView.OnGesturePerformedListener;
import android.gesture.Prediction;
import android.view.Menu;
import android.widget.Toast;
public class MainActivity extends Activity {
private GestureLibrary gestureLib;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
GestureOverlayView gest1 = (GestureOverlayView) findViewById(R.id.gestures1);
gestureLib = GestureLibraries.fromRawResource(this, R.raw.gestures);
if (!gestureLib.load()) {
finish();
}
gest1.addOnGesturePerformedListener(handleGestureListener);
}
private OnGesturePerformedListener handleGestureListener = new OnGesturePerformedListener() {
public void onGesturePerformed(GestureOverlayView gestureView,
Gesture gesture) {
ArrayList<Prediction> predictions = gestureLib.recognize(gesture);
if (predictions.size() > 0) {
Prediction prediction = predictions.get(0);
if (prediction.score > 1.0) {
Toast.makeText(MainActivity.this, "Your Command : " +prediction.name,
Toast.LENGTH_SHORT).show();
}
}
}
};
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
Code ของ Java
data:image/s3,"s3://crabby-images/212d8/212d86542d854e076766c946a9040cc72db3ff31" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
จะสังเกตุเห็นว่า
gestureLib = GestureLibraries.fromRawResource(this, R.raw.gestures);
จะเห็นว่ามีการเรียกใช้ไฟล์ gestures ที่เป็น Template ที่มาจาก SD Card
if (predictions.size() > 0) {
Prediction prediction = predictions.get(0);
if (prediction.score > 1.0) {
Toast.makeText(MainActivity.this, "Your Command : " +prediction.name,
Toast.LENGTH_SHORT).show();
}
}
ตรวจสอบเหตุการณ์ที่เกิดขึ้นว่าไปตรงกับรูปแบบ Gestures ที่ได้ออกแบบไว้ตัวไหน
Screenshot
data:image/s3,"s3://crabby-images/8a71e/8a71e5cc19ccde99973d20238de8a38f74ed0743" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ถ้าตรงกับรูปแบบที่ออกแบบไว้ก็จะแสดงเหตุการณ์นั้น ๆ ให้เราทราบ
data:image/s3,"s3://crabby-images/1ea6e/1ea6eecea2d6a275ca559104486877412fe577f0" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ถ้าตรงกับรูปแบบที่ออกแบบไว้ก็จะแสดงเหตุการณ์นั้น ๆ ให้เราทราบ
Example 2 ตัวอย่างการทำ GestureOverlayView ใช้ร่วมกับเหตุการณ์อื่น ๆ
ในตตัวอย่างนี้เราจะใช้ GestureOverlayView ทำงานร่วมกับ ViewFlipper เพื่อควบคุมการ Slide ซ้าย และ Slide ขวา เพื่อเปลี่ยนรูปภาพ
ViewFlipper - Android Widgets Example
data:image/s3,"s3://crabby-images/54b0d/54b0d0004add2cc2600dccb8ad2a5ac5cd859e70" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ออกแบบหน้าจอ GraphicalLayout ด้วย Widget ตามรูป
activity_main.xml (XML Layout)
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent" >
<android.gesture.GestureOverlayView
android:id="@+id/gestures1"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gestureStrokeType="multiple"
android:eventsInterceptionEnabled="true"/>
<LinearLayout
android:id="@+id/LinearLayout1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_marginTop="75dp" >
<ViewFlipper
android:id="@+id/ViewFlipper01"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
<ImageView
android:id="@+id/imageView1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/pic_a" />
<ImageView
android:id="@+id/imageView2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/pic_b" />
<ImageView
android:id="@+id/imageView3"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/pic_c" />
<ImageView
android:id="@+id/imageView4"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:src="@drawable/pic_d" />
</ViewFlipper>
</LinearLayout>
</RelativeLayout>
MainActivity.java (Java Code)
package com.myapp;
import java.util.ArrayList;
import android.os.Bundle;
import android.app.Activity;
import android.gesture.Gesture;
import android.gesture.GestureLibraries;
import android.gesture.GestureLibrary;
import android.gesture.GestureOverlayView;
import android.gesture.GestureOverlayView.OnGesturePerformedListener;
import android.gesture.Prediction;
import android.util.Log;
import android.view.Menu;
import android.widget.Toast;
import android.widget.ViewFlipper;
public class MainActivity extends Activity {
private GestureLibrary gestureLib;
ViewFlipper vf;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// Gesture Event
GestureOverlayView gest1 = (GestureOverlayView) findViewById(R.id.gestures1);
gestureLib = GestureLibraries.fromRawResource(this, R.raw.gestures);
if (!gestureLib.load()) {
finish();
}
gest1.addOnGesturePerformedListener(handleGestureListener);
// ViewFlipper Slide Show Images
vf = (ViewFlipper) findViewById(R.id.ViewFlipper01);
vf.setInAnimation(this,android.R.anim.fade_in);
vf.setOutAnimation(this, android.R.anim.fade_out);
}
private OnGesturePerformedListener handleGestureListener = new OnGesturePerformedListener() {
public void onGesturePerformed(GestureOverlayView gestureView,
Gesture gesture) {
ArrayList<Prediction> predictions = gestureLib.recognize(gesture);
if (predictions.size() > 0) {
Prediction prediction = predictions.get(0);
if (prediction.score > 1.0) {
String action = predictions.get(0).name;
if ("Slide to left".equals(action)) {
vf.showPrevious();
Toast.makeText(MainActivity.this, prediction.name + " : Show Next Picture" ,
Toast.LENGTH_SHORT).show();
} else if ("Slide to right".equals(action)) {
vf.showPrevious();
vf.showPrevious();
Toast.makeText(MainActivity.this, prediction.name + " : Show Previous Picture" ,
Toast.LENGTH_SHORT).show();
}
}
}
}
};
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.activity_main, menu);
return true;
}
}
จาก Code ที่เป็น Java
if (predictions.size() > 0) {
Prediction prediction = predictions.get(0);
if (prediction.score > 1.0) {
String action = predictions.get(0).name;
if ("Slide to left".equals(action)) {
vf.showPrevious();
Toast.makeText(MainActivity.this, prediction.name + " : Show Next Picture" ,
Toast.LENGTH_SHORT).show();
} else if ("Slide to right".equals(action)) {
vf.showPrevious();
vf.showPrevious();
Toast.makeText(MainActivity.this, prediction.name + " : Show Previous Picture" ,
Toast.LENGTH_SHORT).show();
}
}
}
จะเห็นว่ามีการเขียนเงื่อนไขว่า Slide to left ให้ vf.showPrevious(); และ Slide to right ให้ vf.showPrevious();
Screenshot
data:image/s3,"s3://crabby-images/17dd3/17dd315f43ece8c755dcea2a314d86533ece1433" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ผลลัพธ์ที่ได้เมื่อ Slide to right
data:image/s3,"s3://crabby-images/e926a/e926a6d618a8ec7b56dd77a57113a75a8355c966" alt="GestureOverlayView - Android Widgets GestureOverlayView - Android Widgets"
ผลลัพธ์ที่ได้เมื่อ Slide to left
data:image/s3,"s3://crabby-images/fb383/fb38346e31d9bb4f28f9550c882abb3d761cac7e" alt=""
Property & Method (Others Related) |
|
ช่วยกันสนับสนุนรักษาเว็บไซต์ความรู้แห่งนี้ไว้ด้วยการสนับสนุน Source Code 2.0 ของทีมงานไทยครีเอท
|
|
|
By : |
ThaiCreate.Com Team (บทความเป็นลิขสิทธิ์ของเว็บไทยครีเอทห้ามนำเผยแพร่ ณ เว็บไซต์อื่น ๆ) |
|
Score Rating : |
data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" data:image/s3,"s3://crabby-images/fa28a/fa28a4ccb73eccec48000d688830fff77ebecb87" alt="" |
|
|
Create/Update Date : |
2012-07-01 16:30:32 /
2012-07-15 07:49:03 |
|
Download : |
No files |
|
Sponsored Links / Related |
|
|
|
|
|
|
|