码迷,mamicode.com
首页 > 移动开发 > 详细

Android控件之WebView

时间:2015-02-28 21:27:57      阅读:234      评论:0      收藏:0      [点我收藏+]

标签:

  如何在Android应用中打开Web网站呢?谷歌为我们提供了解决方案,现在就让我们一起看一下WebView控件吧。

  为了方便总结,就以实现下面这个效果为主线,进行总结:

技术分享

  首先我们先看一下它的布局文件吧,整个界面分为上下两个部分,上部是一个类似于标题栏的效果,它是由两个Button按钮和一个TextView组成的,下部是一个WebView控件,通过AndroidManifest.xml去除系统的标题(如有不懂,请查阅我的上一遍博客:Android常用属性),已达到上图效果。为方便大家自学,下面奉上代码:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical"
    tools:context=".MainActivity">

    <LinearLayout
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:weightSum="1">
        <Button
            android:id="@+id/quit"
            android:layout_gravity="left"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="返回"/>
        <TextView
            android:id="@+id/web"
            android:layout_gravity="center"
            android:gravity="center"
            android:layout_width="222dp"
            android:layout_height="wrap_content"
            android:layout_weight="1.13" />
        <Button
            android:id="@+id/news"
            android:layout_gravity="right"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="刷新"/>
    </LinearLayout>
    <WebView
        android:id="@+id/webView"
        android:layout_width="fill_parent"
        android:layout_height="fill_parent"/>

</LinearLayout>

  最后我们开始编写我们MainActivity.java:

public class MainActivity extends Activity {
    private TextView mTextView;
    private WebView mWebView;
    private Button mbreak;
    private Button mnews;
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        init();
    }
    public void init(){
        mTextView = (TextView)findViewById(R.id.web);
        mWebView = (WebView)findViewById(R.id.webView);
        mbreak = (Button)findViewById(R.id.quit);
        mnews = (Button)findViewById(R.id.news);
        mbreak.setOnClickListener(new myListener());
        mnews.setOnClickListener(new myListener());
        mWebView.loadUrl("http://www.baidu.com/");//设置打开的网址

        mWebView.setWebChromeClient(new WebChromeClient(){
            @Override
            public void onReceivedTitle(WebView view, String title) {
                super.onReceivedTitle(view, title);
                mTextView.setText(title);//显示打开的网址信息
            }
        });

        mWebView.setWebViewClient(new WebViewClient(){
            @Override
            public boolean shouldOverrideUrlLoading(WebView view, String url) {
                view.loadUrl(url);
                return super.shouldOverrideUrlLoading(view, url);
            }
        });
    }

    //按钮点击事件监听
    class myListener implements View.OnClickListener{
        @Override
        public void onClick(View view) {
            switch (view.getId()){
                case R.id.quit :
                    finish();
                    break;
                case R.id.news :
                    mWebView.reload();
                    break;
            }
        }
    }

  最后不要忘在AndroidManifest.xml中添加使用网络声明:<uses-permission android:name="android.permission.INTERNET"/>

  大功告成,我们的WebView初步介绍到此结束。

 

<uses-permission android:name="android.permission.INTERNET"/>

Android控件之WebView

标签:

原文地址:http://www.cnblogs.com/AndroidJotting/p/4306181.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!