zoukankan      html  css  js  c++  java
  • Android 本地加载网页与显示网络图片

    有时候需要在应用程序里展示一些网页,但是需求里又明确指出,不允许打开系统浏览器,显然也不可能去编写一个浏览器出来,这时就需要使用 WebView控件,借助它我们就可以在自己的应用程序里嵌入一个浏览器,从而非常轻松地展示各种各样的网页。

    由于程序用到了网络功能,而访问网络是需要声明权限的,因此首先得修改 AndroidManifest.xml 文件,并加入声明权限:

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

    然后修改 activity_main.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/image_view"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </LinearLayout>
    activity_main.xml

    最后修改 MainActivity 中的代码,如下所示:

    public class MainActivity extends AppCompatActivity {
        private WebView webView;
        private ImageView imageView;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.web_image);
    
            setContentView(R.layout.activity_main);
            webView = (WebView) findViewById(R.id.web_view);
            //调用setJavaScriptEnabled()方法让WebView支持JS脚本
            webView.getSettings().setJavaScriptEnabled(true);
            //跳转网页仍然在当前WebView中显示
            webView.setWebViewClient(new WebViewClient());
            webView.loadUrl("https://www.baidu.com");
    
        }
    }

    调用 WebView 的 loadUrl() 方法,并将网址传入,即可展示相应的网页内容,这里就让我们看一看百度的首页的加载情况。

    ----------------------------动态加载网络图片-------------------------------

    显示网络图片也非常简单,大概思路是首先获得图片地址,再通过网络访问图片,然后把图片文件流转换成位图对象,最后将它显示出来。

    但是需要注意,获取网络图片的过程需要放在一个子线程中运行,否则就很容易出现程序无响应(Application Not Responding)的情况。

      首先,新建一个 LoadImagesTask 类,继承自 AsyncTask,代码如下:

    import android.graphics.Bitmap;
    import android.graphics.BitmapFactory;
    import android.os.AsyncTask;
    import android.widget.ImageView;
    
    import java.io.IOException;
    import java.io.InputStream;
    import java.net.HttpURLConnection;
    import java.net.MalformedURLException;
    import java.net.URL;
    
    public class LoadImagesTask extends AsyncTask<String, Void, Bitmap> {
        private ImageView imageView;
    
        public LoadImagesTask(ImageView imageView) {
            this.imageView = imageView;
        }
    
        @Override
        protected Bitmap doInBackground(String... params) {
            URL imageUrl = null;
            Bitmap bitmap = null;
            InputStream inputStream = null;
            try {
                imageUrl = new URL(params[0]);
                HttpURLConnection conn = (HttpURLConnection) imageUrl.openConnection();
                conn.setDoInput(true);
                conn.connect();
                inputStream = conn.getInputStream();
                bitmap = BitmapFactory.decodeStream(inputStream);
                inputStream.close();
    
            } catch (MalformedURLException e) {
                e.printStackTrace();
            } catch (IOException e) {
                e.printStackTrace();
            }
            return bitmap;
        }
    
        @Override
        protected void onPostExecute(Bitmap bitmap) {
            imageView.setImageBitmap(bitmap);
        }
    }
    LoadImagesTask.java

      布局代码中只包含一个ImageView,代码略。

      最后在 MainActivity 中进行测试:

    public class MainActivity extends AppCompatActivity {private ImageView imageView;
    
        @Override
        protected void onCreate(Bundle savedInstanceState) {
            super.onCreate(savedInstanceState);
            setContentView(R.layout.web_image);
    
            String http = "https://www.baidu.com/img/bd_logo1.png";
            ImageView imageView = (ImageView) findViewById(R.id.image_view);
            //启动异步处理
            new LoadImagesTask(imageView).execute(http);
    
        }
    }

    获取网络图片并不难,反而是异步处理比较难以理解,如果看不懂的可以参考:Android 异步消息处理机制解析

    现在让我们看一下图片的加载情况,截图如下:

  • 相关阅读:
    Servlet_note
    J2SE学习历程
    ASP.NET Core搭建多层网站架构【0-前言】
    使用oh-my-posh美化powershell
    Linux使用整理
    Ubuntu18.04国内源安装MySQL8.0
    Visual Studio Code 个人配置备份
    ASP.NET Core搭建多层网站架构【15-扩展之使用Obfuscar混淆加密保护代码】
    ASP.NET Core搭建多层网站架构【14-扩展之部署到IIS】
    ASP.NET Core搭建多层网站架构【13-扩展之支持全球化和本地化多语言】
  • 原文地址:https://www.cnblogs.com/woider/p/5178889.html
Copyright © 2011-2022 走看看