Добавление pull для обновления в веб-просмотре для обновления

Я добавлю pull для обновления моего веб-просмотра, чтобы он обновил мой веб-просмотр. Я видел все вопросы на этой странице, но я не могу найти хороший способ добавить тягу, чтобы обновить ...

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>

Я надеюсь, что кто-нибудь может помочь мне и решить эту проблему для меня.

Ответы на вопрос(5)

если вы хотите просто потянуть, чтобы обновить

    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

 Hessel13 июн. 2016 г., 10:16
У меня есть RelativeLayout
 Hessel12 июн. 2016 г., 16:41
Могу ли я обновить свой веб-просмотр с этим?
 Hessel12 июн. 2016 г., 19:19
дадим мне ошибку
 Yash Jain12 июн. 2016 г., 16:46
Да, вы можете снова поставить loadURL (<YOUR URL>) снова с некоторым запросом после MotionEvent.ACTION _DOWN, и если вы хотите еще несколько типов движения, обратитесьdeveloper.android.com/reference/android/view/MotionEvent.html
 Yash Jain12 июн. 2016 г., 19:45
@Hessel Найдите функцию, чтобы получить все как ваш линейный макет
Решение Вопроса

Вы можете обернуть веб-просмотр в макет Swipe refesh, как это

<?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>

В яве

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();
    }
    }
    );

}

}
 jitinsharma13 июн. 2016 г., 11:43
проверьте обновленный ответ.
 Chamnap07 дек. 2016 г., 11:19
@jitinsharma, зачем нужен NestedScrollView?
 Hessel13 июн. 2016 г., 11:17
У меня есть 2 ошибки: «mySwipeRefreshLayout» не может разрешить символ, а LOG_TAG выдает ошибку, не может разрешить символ, и если я вставлю webview.reload (), в этой строке появится ошибка. Может, я смогу обновить свой вопрос? "
 Hessel13 июн. 2016 г., 13:18
Оно работает! Большое спасибо! Только проблема в том, что круг остается на моем экране, как на этом рисунке:i-cdn.phonearena.com/images/articles/162782-thumb/chrome.png
 jitinsharma13 июн. 2016 г., 13:23
Hmm..trymySwipeRefreshLayout.setRefreshing(false); внутриonRefresh после функции reload ().
 Hessel13 июн. 2016 г., 13:31
Это работает :) Спасибо!
 jitinsharma13 июн. 2016 г., 11:11
Можете ли вы разработать проблему?
 jitinsharma13 июн. 2016 г., 12:44
поместите это ниже</android.support.v4.widget.NestedScrollView>  Проверьте обновленный ответ
 jitinsharma08 дек. 2016 г., 11:50
Вы также можете использовать scrollview.
 Hessel13 июн. 2016 г., 10:20
И когда я вставляю webview.reload (), это дает мне ошибку в этой строке.
 Hessel13 июн. 2016 г., 11:10
не работает для меня ...
 jitinsharma13 июн. 2016 г., 11:00
Вы должны определить веб-просмотр в onCreate ()Webview webview = (WebView)findViewById(R.id.web_view) а затем позвонитеwebview.loadUrl("your url") внутри onCreate для первоначальной загрузки wbeview. Тогда позвониwebview.reload() внутри слушателя.
 Hessel13 июн. 2016 г., 12:19
У меня нет ошибок, но мне не хватает </android.support.v4.widget.SwipeRefreshLayout>, где я могу разместить это на content_main? Если я помещу это позади <android.support.v4.widget.SwipeRefreshLayout, я не могу тянуть, чтобы обновить.
 Bhavik Mehta05 февр. 2018 г., 12:58
Это не работает для меня вообще, он показывает чистый белый пустой экран. потому что nestedscrollview ведет себя грубо
 Emre Tekin16 дек. 2016 г., 11:20
Это wokrs Спасибо! Но вы должны сделать onPageFinished {swRefreshLayout.setRefreshing (false); }

Я думаю, что лучшим решением является использованиеSwipeRefreshLayout но безNestedScrollView внутри него какjitinsharma описано, потому что эта возможная проблема:Высота веб-просмотра растет неопределенно внутри nestedScrollView.Но есть другое решение проблемы прокрутки, как описаноВизз, чтобы реализоватьViewTreeObserver.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);

                    }
                });
 UdayaLakmal24 сент. 2018 г., 07:55
Да, только это решение обеспечивает плавную загрузку, android.support.v4.widget.NestedScrollView переносит веб-просмотр при загрузке, и загрузка не очень приятна.

wipeRefreshLayout.

<?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));

                            }
                        }
                );
 11m015 июн. 2018 г., 17:00
Вам не нужно добавлять эту строку, потому что она установлена ​​вLOAD_DEFAULT режим по умолчаниюmWebview.getSettings().setCacheMode(WebSettings.LOAD_DEFAULT);

https://developer.android.com/training/swipe/add-swipe-interface.html

Вы можете использовать макет Swipe-to-Refresh, он прост в использовании и позаботится об обновлении анимации.

Вы можете добавить OnRefreshListener, чтобы обновить ваш веб-просмотр

Ваш ответ на вопрос