在webview应用程序之前显示的异步启动画面

时间:2015-01-07 11:22:09

标签: android android-webview splash-screen

我正在制作一个运行全屏webview的android,但问题是索引页面在2秒延迟后出现,所以我想实现一个启动画面,直到webview在后台加载网站。如果你我可以使用这个启动画面的完整代码,因为我对它完全陌生。

主要活动是:

public class MainActivity extends Activity  {

WebView网站;

@Override
protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);

    setContentView(R.layout.activity_main);
    website = (WebView) findViewById(R.id.website);
    website.setWebViewClient(new WebViewClient());
    WebSettings webSettings = website.getSettings();
    webSettings.setJavaScriptEnabled(true);
    website.loadUrl("http://www.fitanity.com/index2.jsp");

}


@Override
public boolean onCreateOptionsMenu(Menu menu) {
    // Inflate the menu; this adds items to the action bar if it is present.
    getMenuInflater().inflate(R.menu.menu_main, menu);
    return true;
}

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here. The action bar will
    // automatically handle clicks on the Home/Up button, so long
    // as you specify a parent activity in AndroidManifest.xml.
    int id = item.getItemId();

    //noinspection SimplifiableIfStatement
    if (id == R.id.action_settings) {
        return true;
    }

    return super.onOptionsItemSelected(item);
}

@Override
public boolean onKeyDown(int keyCode, KeyEvent event) {
    if ((keyCode == KeyEvent.KEYCODE_BACK) && website.canGoBack()) {
        website.goBack();
        return true;
    }
    else
    {
        finish();
    }
    return super.onKeyDown(keyCode, event);
}

}

3 个答案:

答案 0 :(得分:1)

你最初可以显示ImageView,一旦webview加载到public void onPageFinished()中,就会改变它们的可见性。

public class MainActivity1 extends Activity {

WebView website;
ImageView imgLoading;

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

    setContentView(R.layout.activity_main);
    website = (WebView) findViewById(R.id.website);
    imgLoading = (ImageView)findViewById(R.id.imgloader);
    WebSettings webSettings = website.getSettings();
    webSettings.setJavaScriptEnabled(true);
    website.setWebViewClient(new WebViewClient() {

        @Override
        public void onPageFinished(WebView view, String url) {
            //hide loading image
            imgLoading.setVisibility(View.GONE);
            //show webview
            website.setVisibility(View.VISIBLE);
        }

    });     

    website.loadUrl("http://www.fitanity.com/index2.jsp");

}

您的xml将如下所示:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" >

<ImageView
    android:id="@+id/imgloader"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:src="@drawable/loader"
    android:visibility="visible" />

<WebView
    android:id="@+id/website"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:visibility="gone" />

</LinearLayout>

答案 1 :(得分:0)

为此,您必须创建一个扩展WebViewClient类的类。

在这个课程中,有一些方法你可以或你必须覆盖,

1.onPageStarted - 这将在webview开始加载页面时调用。 (显示你的SPALSH) 2.shouldOverrideUrlLoading - 您必须覆盖此方法 3.onPageFinished - 这将在webview停止加载页面时调用。 (隐藏你的身份)

现在进入webview,使用你自己的Webview类,

    web.setWebViewClient(new mywebclient());

希望它能帮助你,

干杯

-Aman

答案 2 :(得分:0)

Dhwanik的解决方案也适用于我,但我想用backgrount显示文本并将gif作为启动画面加载,所以我用新布局替换了图像并将所有内容放入其中。

以下链接可能对像我这样需要相同的人有用 http://www.codewithasp.net/2016/01/show-splash-screen-while-android.html