web-dev-qa-db-ja.com

更新のためにWebViewで更新するプルを追加する

プルを追加してウェブビューを更新し、ウェブビューを更新します。私はこのページですべての質問を見ましたが、更新にプルを追加する良い方法を見つけることができません...

Mainactivity.Java

package com.vvhvb.hesselfeenstra.vvheerenveenseboys;

import Android.os.Bundle;
import Android.support.v7.app.AppCompatActivity;
import Android.webkit.WebView;
import Android.webkit.WebViewClient;

public class MainActivity extends AppCompatActivity {

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        String url ="http://heerenveenseboys.nl/";
        WebView view=(WebView) this.findViewById(R.id.webView);
        view.getSettings().setJavaScriptEnabled(true);
        view.getSettings().setBuiltInZoomControls(true);
        view.getSettings().setDisplayZoomControls(false);
        view.setWebViewClient(new WebViewClient());
        view.loadUrl(url);

    }

}

content_main.xml

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:app="http://schemas.Android.com/apk/res-auto"
    xmlns:tools="http://schemas.Android.com/tools"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent"
    Android:paddingBottom="@dimen/activity_vertical_margin"
    Android:paddingLeft="@dimen/activity_horizontal_margin"
    Android:paddingRight="@dimen/activity_horizontal_margin"
    Android:paddingTop="@dimen/activity_vertical_margin"
    app:layout_behavior="@string/appbar_scrolling_view_behavior"
    tools:context="com.vvhvb.hesselfeenstra.vvheerenveenseboys.MainActivity"
    tools:showIn="@layout/activity_main">

    <WebView
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:id="@+id/webView"
        Android:layout_alignParentBottom="true"
        Android:layout_alignParentRight="true"
        Android:layout_alignParentEnd="true"
        Android:layout_alignParentTop="true"
        Android:layout_alignParentLeft="true"
        Android:layout_alignParentStart="true" />
</RelativeLayout>

誰もが私を助け、私のためにこの問題を解決できることを願っています。

14
Hessel

このようにスワイプ更新レイアウトでウェブビューをラップすることができます

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
xmlns:app="http://schemas.Android.com/apk/res-auto"
xmlns:tools="http://schemas.Android.com/tools"
Android:layout_width="match_parent"
Android:layout_height="match_parent"
Android:paddingBottom="@dimen/activity_vertical_margin"
Android:paddingLeft="@dimen/activity_horizontal_margin"
Android:paddingRight="@dimen/activity_horizontal_margin"
Android:paddingTop="@dimen/activity_vertical_margin"
app:layout_behavior="@string/appbar_scrolling_view_behavior"
tools:context="com.vvhvb.hesselfeenstra.vvheerenveenseboys.MainActivity"
tools:showIn="@layout/activity_main">

<Android.support.v4.widget.SwipeRefreshLayout
    Android:id="@+id/swipeContainer"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent"
    app:layout_behavior="@string/appbar_scrolling_view_behavior">

<Android.support.v4.widget.NestedScrollView
    Android:layout_width="match_parent"
    Android:layout_height="match_parent">

    <WebView
        Android:id="@+id/webView"
        Android:layout_width="wrap_content"
        Android:layout_height="wrap_content"
        Android:layout_alignParentBottom="true"
        Android:layout_alignParentEnd="true"
        Android:layout_alignParentLeft="true"
        Android:layout_alignParentRight="true"
        Android:layout_alignParentStart="true"
        Android:layout_alignParentTop="true" />

</Android.support.v4.widget.NestedScrollView>
</Android.support.v4.widget.SwipeRefreshLayout>
</RelativeLayout>

Javaで

package com.vvhvb.hesselfeenstra.vvheerenveenseboys;

import Android.os.Bundle;
import Android.support.v7.app.AppCompatActivity;
import Android.webkit.WebView;
import Android.webkit.WebViewClient;

public class MainActivity extends AppCompatActivity {
WebView view;
SwipeRefreshLayout mySwipeRefreshLayout;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    mySwipeRefreshLayout = (SwipeRefreshLayout)this.findViewById(R.id.swipeContainer);
    String url ="http://heerenveenseboys.nl/";
    view=(WebView) this.findViewById(R.id.webView);
    view.getSettings().setJavaScriptEnabled(true);
    view.getSettings().setBuiltInZoomControls(true);
    view.getSettings().setDisplayZoomControls(false);
    view.setWebViewClient(new WebViewClient());
    view.loadUrl(url);

    mySwipeRefreshLayout.setOnRefreshListener(
    new SwipeRefreshLayout.OnRefreshListener() {
    @Override
    public void onRefresh() {
        view.reload();
    }
    }
    );

}

}
28
jitinsharma

最善の解決策はSwipeRefreshLayoutを使用することですが、 jitinsharma のようにNestedScrollViewを使用しないことです。 : webviewの高さは、nestedScrollView 内で無限に成長しますが、 vizZViewTreeObserver.OnScrollChangedListenerを実装するには、次のような作業ソリューションが必要です。

<Android.support.v4.widget.SwipeRefreshLayout
        Android:id="@+id/swipeContainer"
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"
        app:layout_behavior="@string/appbar_scrolling_view_behavior">

        <RelativeLayout
            Android:id="@+id/nonVideoLayout"
            Android:layout_width="match_parent"
            Android:layout_height="match_parent"
            Android:windowSoftInputMode="adjustResize">

            <WebView
                Android:id="@+id/main_web_view"
                Android:layout_width="match_parent"
                Android:layout_height="match_parent"
                Android:layout_marginTop="5dp"
                Android:windowSoftInputMode="adjustResize"
                app:layout_constraintDimensionRatio="1" />

        </RelativeLayout>


    </Android.support.v4.widget.SwipeRefreshLayout>

アクティビティパラメータ:

private WebView mWebView;
private SwipeRefreshLayout mySwipeRefreshLayout;
private ViewTreeObserver.OnScrollChangedListener mOnScrollChangedListener;   

アクティビティonCreate

mWebView = (WebView) findViewById(R.id.main_web_view);
mySwipeRefreshLayout = (SwipeRefreshLayout)this.findViewById(R.id.swipeContainer);

        mySwipeRefreshLayout.setOnRefreshListener(
                new SwipeRefreshLayout.OnRefreshListener() {
                    @Override
                    public void onRefresh() {
                        mWebView.reload();
                    }
                }
        );

アクティビティの実装:implements AdvancedWebView.Listener

アクティビティonStopで:

mySwipeRefreshLayout.getViewTreeObserver().removeOnScrollChangedListener(mOnScrollChangedListener);

およびアクティビティonStart

 mySwipeRefreshLayout.getViewTreeObserver().addOnScrollChangedListener(mOnScrollChangedListener =
                new ViewTreeObserver.OnScrollChangedListener() {
                    @Override
                    public void onScrollChanged() {
                        if (mWebView.getScrollY() == 0)
                            mySwipeRefreshLayout.setEnabled(true);
                        else
                            mySwipeRefreshLayout.setEnabled(false);

                    }
                });
12
Mihuilk

https://developer.Android.com/training/swipe/add-swipe-in​​terface.html

スワイプして更新するレイアウトを使用できます。使いやすく、更新アニメーションを処理します。

OnRefreshListenerを追加して、Webビューを更新できます。

1
Vaibhav

プルしてリフレッシュしたい場合はこれを試してください

    ll = (LinearLayout)findViewById(R.id.CategorySelect_lLayout_noID);
ll.setOnTouchListener(new OnTouchListener() {

    public boolean onTouch(View v, MotionEvent event) {

        if(event.getAction() == MotionEvent.ACTION_DOWN){
            Toast.makeText(CategorySelect.this, "action DOWN called", Toast.LENGTH_SHORT).show();
            return true;
        } 

        return false;
    }
});
    return true;
}

または、アイコンまたはクロムのようなものが必要な場合

https://github.com/liaohuqiu/Android-Ultra-Pull-To-Refresh

0
Yash Jain

これは完全に機能するはずです!レイアウトファイルで、SwipeRefreshLayoutでWebビューをラップします。

_<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:Android="http://schemas.Android.com/apk/res/Android"
    xmlns:tools="http://schemas.Android.com/tools"
    Android:id="@+id/activity_main"
    Android:layout_width="match_parent"
    Android:layout_height="match_parent"
    >
    <Android.support.v4.widget.SwipeRefreshLayout
        Android:id="@+id/swipeContainer"
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"
    >
    <WebView
        Android:layout_width="match_parent"
        Android:layout_height="match_parent"
        Android:layout_alignParentTop="true"
        Android:layout_alignParentLeft="true"
        Android:layout_alignParentStart="true"
        Android:id="@+id/webView"
       />
    </Android.support.v4.widget.SwipeRefreshLayout>
</RelativeLayout>
_

Javaファイルで、クラス外で_SwipeRefreshLayout mySwipeRefreshLayout;_を宣言します。次に、これをonCreate()メソッドに追加します。

_    mySwipeRefreshLayout = (SwipeRefreshLayout)this.findViewById(R.id.swipeContainer);

        mySwipeRefreshLayout.setOnRefreshListener(
                        new SwipeRefreshLayout.OnRefreshListener() {
                            @Override
                            public void onRefresh() {
                                    mWebview.reload();
        mWebview.getSettings().setCacheMode(WebSettings.LOAD_DEFAULT);
// This is important as it forces webview to load from the instead of reloading from cache

        mWebview .loadUrl(getString(R.string.app_link));

                            }
                        }
                );
_
0
Rahul Suresh