如何在加载webview中的新页面时滚动到滚动视图的顶部

时间:2013-06-10 19:30:33

标签: android webview

我在scrollview中设置了一个webview。当我最初向下滚动到屏幕底部并单击webview内的链接时,加载的页面在页面中间可见。如何自动滚动到我的滚动视图的顶部。我用谷歌搜索但没有答案。 iOS自动执行此操作,但android并没有我所见。任何见解将不胜感激。我设置了smoothscroll(0,0)但它在移动到下一页之前滚动到顶部。也许这就是我可以使用的全部内容。任何其他解决方案将不胜感激。

if(isConnectingToInternet()){
        WebProducts.setVisibility(View.VISIBLE);
        TextNoInternet.setVisibility(View.GONE);
        WebProducts.getSettings().setLoadWithOverviewMode(true);
        WebProducts.getSettings().setUseWideViewPort(true);
        WebProducts.getSettings().setSupportZoom(false);
        WebProducts.loadUrl("http://www.healthfitnessenergy.com/productpages/products.php");
    }
    else{
        WebProducts.setVisibility(View.GONE);
        TextNoInternet.setVisibility(View.VISIBLE);
    }
    WebProducts.setWebViewClient(new WebViewClient() {
        @Override
        public boolean shouldOverrideUrlLoading(WebView view, String url) {
            view.loadUrl(url);
            ScrollView1.smoothScrollTo(0,0);
            return false;
        }
    });

<ScrollView xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/scrollView1"
android:layout_width="fill_parent"
android:layout_height="fill_parent" >
<LinearLayout
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:paddingBottom="30dp"
    android:gravity="center_horizontal|center_vertical"
    android:orientation="vertical" >
    <TextView
        android:id="@+id/products_title"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_marginLeft="5dp"
        android:layout_marginTop="15dp"
        android:layout_marginBottom="8dp"
        android:gravity="center_vertical"
        android:text="@string/product_qs2_products"
        style="@style/Bold_Black_20" />
    <WebView
        android:id="@+id/wvProducts"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"
        android:layout_gravity="center"
        android:background="@drawable/gradient_background"
        android:orientation="vertical" >
    </WebView>
    <TextView
        android:id="@+id/ifnointernet"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:layout_gravity="center"
        android:paddingLeft="25dp"
        android:gravity="center_vertical"
        android:text="Product Menu will be available when cell/wifi service is available"
        android:textColor="#333333"
        android:textSize="18sp"
        android:textStyle="bold"
        android:visibility="gone" />
</LinearLayout>

3 个答案:

答案 0 :(得分:1)

将“scrollview.pageScroll(View.FOCUS_UP);”在某些倾听者的帮助下?

答案 1 :(得分:1)

尝试在OnPageStarted()onPageFinished()内使用setVisibility()方法来完成这项工作。基本上删除现有视图。

@Override
public void onPageStarted(WebView view, String url, Bitmap favicon) {
    webView.setVisibility(View.GONE);
    super.onPageStarted(view, url, favicon);
}

@Override
public void onPageFinished(WebView view, String url) {
    webView.setVisibility(View.VISIBLE);
    super.onPageFinished(view, url);
}

答案 2 :(得分:0)

@Kevin M你可以通过覆盖onPageStarted和onPageFinished这两个方法来解决你的问题,正如@Htet Will所回答的那样。 而你的另一个问题是“不确定如何在网页上设置按钮以便在应用程序内部工作”可以通过JS Bridge解决。因为在ios中你必须知道js桥接的概念,它在android中也是类似的。

第1 - 你必须启用webview for javascript interface。

webview.getSettings().setJavaScriptEnabled(true);

第二 - 制作一个javascript界面​​

@Keep
    private class JavaScriptInterface {

        private JavaScriptInterface() {
        }
        @JavascriptInterface
        public void methodName(){

            getActivity().runOnUiThread(new Runnable() {
                @Override
                public void run() {
                    //do what you want in your java class
                }
            });
        }
    }

3rd - 将JavaScriptInterface分配给webview

webView.addJavascriptInterface(new JavaScriptInterface(), "jsSolutionInterface");

4th - 在html按钮中添加一个on click方法让我们说open()。在名为open的方法中你可以调用javascript接口方法。例如js方法:

function open()
{jsSolutionInterface.methodName();}

通过这种方式,您可以桥接js和java方法。希望这对您有帮助。