12

新しいレコードを表示する (新しいデータをロードする) ために、Android でフリング ジェスチャをサポートする必要がある webview コントロールがあります。これは、Activity を拡張するクラスで発生しています。私が見たすべての例は、テキストビューのジェスチャサポートを実装する方法を示していますが、Web ビューには何もありません。

左フリングと右フリングの両方で異なるアクションを実行する必要があります。これは完全に困惑しているので、コードの助けをいただければ幸いです。

これが私の基本的なonCreateと私のクラスです

import android.app.Activity;
import android.content.Intent;
import android.database.Cursor;
import android.database.SQLException;
import android.os.Bundle;
import android.text.Html;
import android.view.Menu;
import android.view.MenuItem;
import android.view.View;
import android.view.Window;

import android.webkit.WebView;

public class ArticleActivity extends Activity   {

public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);



    Window  w = getWindow();

     w.requestFeature(Window.FEATURE_LEFT_ICON);

     WebView webview = new WebView(this);
     setContentView(webview); 



     w.setFeatureDrawableResource(Window.FEATURE_LEFT_ICON,
     R.drawable.gq);




    setDefaultKeyMode(DEFAULT_KEYS_SEARCH_LOCAL);
    populateFields();
    webview.loadData(question + answer, "text/html", "utf-8");



  //   
}
private void populateFields() {

....


}

}
4

3 に答える 3

12

GestureListener と GestureDetector を作成します。Webview の onTouchEvent をオーバーライドして、GestureDetector.onTouchEvent を呼び出します。

Activity onTouchEvent をオーバーライドすることもできます。必要に応じてコードを投稿できます。

編集:要求されたコード。

public class Main extends Activity {

    /** Called when the activity is first created. */
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        MyWebView webview = new MyWebView(this);
        setContentView(webview);
    }

    class MyWebView extends WebView {
        Context context;
        GestureDetector gd;

        public MyWebView(Context context) {
            super(context);

            this.context = context;
            gd = new GestureDetector(context, sogl);
        }

        @Override
        public boolean onTouchEvent(MotionEvent event) {
            return gd.onTouchEvent(event);
        }

        GestureDetector.SimpleOnGestureListener sogl = new GestureDetector.SimpleOnGestureListener() {
            public boolean onDown(MotionEvent event) {
                return true;
            }

            public boolean onFling(MotionEvent event1, MotionEvent event2, float velocityX, float velocityY) {
                if (event1.getRawX() > event2.getRawX()) {
                    show_toast("swipe left");
                } else {
                    show_toast("swipe right");
                }
                return true;
            }
        };

        void show_toast(final String text) {
            Toast t = Toast.makeText(context, text, Toast.LENGTH_SHORT);
            t.show();
        }
    }
}

@littleFluffyKitty。デフォルトでは、ズームコントロールなどを表示するときの WebView タッチイベントを想定していますか? 私はそれをテストしませんでした。独自のジェスチャ検出の実装が最適であることがわかりました (ただし、WebView で最適に機能するかどうかはわかりません)。タッチ イベントを 3 つの異なるコンポーネントとして見る必要があります。プレス ダウン、動き (ある場合)、およびプレス リリースは、プレス ダウン、移動、リリースとして常に発生します。

onDown で return false を実行すると、アクションは WebView タッチ イベント ハンドラに渡されるはずですが、iirc は後続のイベントが GestureDetector に渡されるのを停止します。これが、Android ソースに基づいた独自の実装を行う理由の半分です。iirc 市場からダウンロードできる Sony Ericsson Tutorials からアイデアを得ました。これは、コードを示す 3D リストであり、非常に簡単に適応できます。

于 2010-11-19T21:09:04.933 に答える
7

コードを更新しました。これにより、ユーザーがフリングしなかった場合にネイティブイベントハンドラーを呼び出すことができるようになります

import android.content.Context;
import android.util.AttributeSet;
import android.util.Log;
import android.view.GestureDetector;
import android.view.MotionEvent;
import android.webkit.WebView;

public class MyWebView extends WebView {
    private boolean flinged;

    private static final int SWIPE_MIN_DISTANCE = 320;
    private static final int SWIPE_MAX_OFF_PATH = 250;
    private static final int SWIPE_THRESHOLD_VELOCITY = 200;

    public MyWebView(Context context, AttributeSet attrs) {
        super(context, attrs);
        gd = new GestureDetector(context, sogl);
    }

    GestureDetector gd;


    @Override
    public boolean onTouchEvent(MotionEvent event) {
         gd.onTouchEvent(event);
         if (flinged) {
             flinged = false;
             return true;
         } else {
             return super.onTouchEvent(event);
         }
    }

    GestureDetector.SimpleOnGestureListener sogl = new GestureDetector.SimpleOnGestureListener() {
    // your fling code here
        public boolean onFling(MotionEvent event1, MotionEvent event2, float velocityX, float velocityY) {
            if (event1.getX() < 1200 && event1.getX() > 80) {
                return false;
            }
            if (Math.abs(event1.getY() - event1.getY()) > SWIPE_MAX_OFF_PATH)
                return false;
            if(event1.getX() - event2.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
                loadUrl("javascript:changePage('LEFT')");
                Log.i("Swiped","swipe left");
                flinged = true;
            } else if (event2.getX() - event1.getX() > SWIPE_MIN_DISTANCE && Math.abs(velocityX) > SWIPE_THRESHOLD_VELOCITY) {
                loadUrl("javascript:changePage('RIGHT')");
                Log.i("Swiped","swipe right");
                flinged = true;
            }
            return true;
        }
    };
}
于 2011-11-25T09:43:10.483 に答える