【问题标题】:How to show images efficiently in a list?如何在列表中有效地显示图像?
【发布时间】:2016-08-06 03:29:07
【问题描述】:

所以目前我有一个列表,在它旁边显示图像和文本,但显示图片时出现问题。我认为最好的方法是使用 JSOUP 解析,然后下载图像并使用 bitmapsFactory 对其进行解码但失败了,因为它仍然需要太多内存来显示图片。有没有办法在线显示图像而不占用空间?我考虑过使用 Webview,然后插入链接并显示图片,但这会起作用吗?我在列表中包含了我的 MainActivity、ListClass、ImageHandler 和 XML。

主要活动;

import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.support.design.widget.FloatingActionButton;
import android.support.design.widget.Snackbar;
import android.view.View;
import android.support.design.widget.NavigationView;
import android.support.v4.view.GravityCompat;
import android.support.v4.widget.DrawerLayout;
import android.support.v7.app.ActionBarDrawerToggle;
import android.support.v7.app.AppCompatActivity;
import android.support.v7.widget.Toolbar;
import android.view.Menu;
import android.view.MenuItem;
import android.widget.TextView;
import android.support.v4.app.FragmentTransaction;
import android.support.v4.app.FragmentManager;
import android.widget.FrameLayout;
import android.widget.Button;
import android.os.Bundle;
import android.view.View;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.Toast;
import android.app.Activity;
import android.graphics.BitmapFactory;
import android.graphics.drawable.Drawable;




public class MainActivity extends AppCompatActivity
        implements NavigationView.OnNavigationItemSelectedListener   {

    ListView list;
    imageHandler imagess = new imageHandler();

    String[] web = {"Egypt "};
    Drawable[] imageId = { imagess.LoadImageFromWebOperations("http://egyptianstreets.com/wp-content/uploads/2016/08/satelliteegypt-400x240.jpg")};

    Handler handler;
    Button button;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
        DrawerLayout drawer = (DrawerLayout) findViewById(R.id.drawer_layout);
        ActionBarDrawerToggle toggle = new ActionBarDrawerToggle(
                this, drawer, toolbar, R.string.navigation_drawer_open, R.string.navigation_drawer_close);
        drawer.setDrawerListener(toggle);
        toggle.syncState();
        NavigationView navigationView = (NavigationView) findViewById(R.id.nav_view);
        navigationView.setNavigationItemSelectedListener(this);
        listClass adapter = new
                listClass(MainActivity.this, web, imageId);
        list=(ListView)findViewById(R.id.list);
        list.setAdapter(adapter);

        list.setOnItemClickListener(new AdapterView.OnItemClickListener() {

            @Override
            public void onItemClick(AdapterView<?> parent, View view,
                                    int position, long id) {
                Toast.makeText(MainActivity.this, "You Clicked at " +web[+ position], Toast.LENGTH_SHORT).show();
            }
        });

    }

列表类;

import android.app.Activity;
import android.graphics.drawable.Drawable;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.ArrayAdapter;
import android.widget.ImageView;
import android.widget.TextView;

public class listClass extends ArrayAdapter<String>{



    //Next three lines introduces Variables to use in the class
    private final Activity context;
    private final String[] web;
    private final Drawable[] imageId;

    //Constructor to get Web, Image and context to set adapter
    public listClass(Activity context,  String[] web, Drawable[] imageId) {

            super(context, R.layout.list, web);
            this.context = context;
            this.web = web;
            this.imageId = imageId;

    }

    //Public method to ...
    @Override
    public View getView(int position, View view, ViewGroup parent) {
        LayoutInflater inflater = context.getLayoutInflater();
        View rowView= inflater.inflate(R.layout.list, null, true);

        TextView txtTitle = (TextView) rowView.findViewById(R.id.txt);
        ImageView imageView = (ImageView) rowView.findViewById(R.id.img);
        txtTitle.setText(web[position]);
        imageView.setImageDrawable(imageId[position]);
        return rowView;
    }
}

ImageHandler 使用 InputStream 但不起作用;

import android.media.Image;
import java.net.URL;
import android.graphics.BitmapFactory;
import java.io.InputStream;
import android.graphics.drawable.Drawable;




public class imageHandler {

    Image picture;


    public static Drawable LoadImageFromWebOperations(String url) {
        try {
            InputStream is = (InputStream) new URL(url).getContent();
            Drawable d = Drawable.createFromStream(is, "earthdownload");
            return d;
        } catch (Exception e) {
            return null;
        }
    }
}

用于列表的 XML;;

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

    <ImageView
        android:id="@+id/img"
        android:layout_width="150dp"
        android:layout_height="100dp" />

    <TextView
        android:id="@+id/txt"
        android:paddingRight="16dp"
        android:textSize="15dp"
        android:layout_alignLeft="@+id/img"
        android:layout_marginLeft="150dp"
        android:layout_width="wrap_content"
        android:layout_height="100dp"
        android:layout_weight="1"
        android:ellipsize="none"
        android:maxLines="100"
        android:scrollHorizontally="false"/>

</RelativeLayout>

【问题讨论】:

  • 试试安卓毕加索库。
  • @Razgriz 我考虑过或使用 Glide 库,但有人告诉我那些库将图像下载到手机上效率低下。
  • glide 或 picasso 不要下载他们缓存的图像。这是非常有效的方式。您也可以关闭缓存。 Glide

标签: android listview android-studio bitmapsource


【解决方案1】:

如果您使用的是图像、文本组合,我建议您查看回收站视图。它们对图像的效率要高得多。不过,使用列表视图并没有什么坏处。

要加载图像,请使用 Picasso 库。 http://square.github.io/picasso/

您只需一行代码即可将图像加载到图像视图中。希望这会有所帮助。

【讨论】:

    【解决方案2】:

    按照 Nikhil 的建议,尝试使用 Picasso 库。它易于实施且高效。

    您所要做的就是输入一行来加载图像。您可以在适配器的 getView 方法中执行此操作

    Picasso.with(context).load(imageURI/path/file).fit().error(R.id.error_img) //an image that gets displayed in case of error
    .into(R.id.img_container, new Callback() {
       void onSuccess() {}
       void onError() {}
    })
    

    希望这会有所帮助!

    【讨论】:

      【解决方案3】:

      使用 Volley 库加载图片 并使用该类加载图像。

      public class LruBitmapCache extends LruCache<String, Bitmap> implements
          ImageCache {
      public static int getDefaultLruCacheSize() {
          final int maxMemory = (int) (Runtime.getRuntime().maxMemory() / 1024);
          final int cacheSize = maxMemory / 8;
      
          return cacheSize;
      }
      
      public LruBitmapCache() {
          this(getDefaultLruCacheSize());
      }
      
      public LruBitmapCache(int sizeInKiloBytes) {
          super(sizeInKiloBytes);
      }
      
      @Override
      protected int sizeOf(String key, Bitmap value) {
          return value.getRowBytes() * value.getHeight() / 1024;
      }
      
      @Override
      public Bitmap getBitmap(String url) {
          return get(url);
      }
      
      @Override
      public void putBitmap(String url, Bitmap bitmap) {
          put(url, bitmap);
      }
      

      }

      为 ImageView 添加这个 XML

       <!-- Thumbnail Image -->
      <com.android.volley.toolbox.NetworkImageView
          android:id="@+id/thumbnail"
          android:layout_width="80dp"
          android:layout_height="80dp"
          android:layout_alignParentLeft="true"
          android:layout_marginRight="8dp" />
      

      在适配器中设置

      if (imageLoader == null)
              imageLoader = AppController.getInstance().getImageLoader();
          NetworkImageView thumbNail = (NetworkImageView) convertView
                  .findViewById(R.id.thumbnail);
      

      欲了解更多信息,你可以去here

      【讨论】:

        猜你喜欢
        • 1970-01-01
        • 1970-01-01
        • 1970-01-01
        • 2011-01-31
        • 1970-01-01
        • 2017-09-26
        • 1970-01-01
        • 2018-09-27
        • 1970-01-01
        相关资源
        最近更新 更多