繁体   English   中英

刷卡刷新android webView

[英]swipe refresh android webView

我的 android studio 应用程序上有 webView

    <WebView
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:layout_centerHorizontal="true"
    android:layout_alignParentTop="true"
    android:id="@+id/webView" />

    mywebview = (WebView) findViewById(R.id.webView);
    WebSettings webSettings = mywebview.getSettings();
    webSettings.setJavaScriptEnabled(true);
    mywebview.loadUrl("https://m.site.com/");
    mywebview.setWebViewClient(new WebViewClient());

我怎样才能让刷卡刷新呢?

看看这个: https : //stackoverflow.com/a/27916575/5627123 如您所见,您可以非常轻松地完成此操作。 只需将webview放在SwipeToRefreshLayout内,然后使用链接中的代码即可。

在下面,您可以找到一种简单的方法:[1]复制简单的OnTouchListener,[2]将OnTouchListener连接到Webview。 [3]“ this”表示您实现TouchListener()接口的方法。 因此,您可以通过onSwipeRight()和onSwipeLeft()方法实现“刷新”。

webView.setOnTouchListener( new OnSwipeWebviewTouchListener( getActivity(), this));

TouchListener可能像这样简单:

public interface TouchListener  {
    default void onSwipeLeft() {
        Logger.d( "Swipe left");
    }
    default void onSwipeRight() {
        Logger.d( "Swipe right");
    }
}

简单的OnTouchListener:

public class OnSwipeWebviewTouchListener implements View.OnTouchListener {
    private final GestureDetector gestureDetector;
    public OnSwipeWebviewTouchListener(Context ctx, TouchListener touchListener) {
        gestureDetector = new GestureDetector(ctx, new GestureListener(touchListener));
    }
    @Override
    public boolean onTouch(View v, MotionEvent event) {
        return gestureDetector.onTouchEvent(event);
    }
    private final class GestureListener extends GestureDetector.SimpleOnGestureListener {
        private TouchListener touchListener;
        GestureListener(TouchListener touchListener) {
            super();
            this.touchListener = touchListener;
        }
        @Override
        public boolean onDown(MotionEvent e) {
            return false;  // THIS does the trick
        }
        @Override
        public boolean onFling(MotionEvent e1, MotionEvent e2, float velocityX, float velocityY) {
            boolean result = false;
            try {
                float diffY = e2.getY() - e1.getY();
                float diffX = e2.getX() - e1.getX();
                if (Math.abs(diffX) > Math.abs(diffY)) {
                    // You can customize these settings, so 30 is an example
                    if (Math.abs(diffX) > 30 && Math.abs(velocityX) > 30) {
                        if (diffX > 0) {
                            touchListener.onSwipeRight();
                        } else {
                            touchListener.onSwipeLeft();
                        }
                        result = true;
                    }
                } else {
                    result = false;
                }
            } catch (Exception exception) {
                exception.printStackTrace();
            }
            return result;
        }
    }
}

德里克! 从 Z3r0byte 提到的https://stackoverflow.com/a/27916575/5627123是一种(非常好!)方法,您需要手动集成路径。 如果您使用 WebViewGold,您还可以在Config.java配置文件中将 ENABLE__PULL_REFRESH切换为 true。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM