Проблемы с утилизацией в ArrayAdapter с использованием ImageFetcher

1

В настоящее время я использую (или, по крайней мере, пытаюсь использовать) Droidparts ImageFetcher в своем приложении. Существует пример кода, показывающий, как он работает с CursorAdapter, но я не смог все понять и реплицировать его с помощью ArrayAdapter. Я думаю, что я понимаю, как работает материал InjectDependency, но если это может быть объяснено или не включено в ответ, я был бы благодарен.

В любом случае, мой вопрос заключается в том, как остановить мой ImageViews от загрузки с неправильными изображениями после их повторного использования? Я попытался привязать ImageHolder как тег к представлению, но он не сработал, и я не вижу его логики...

Здесь мой код:

@Override
public View getView( int position, View view, ViewGroup parent )
{
    if( view == null )
    {
        LayoutInflater inflater = ( LayoutInflater ) m_context.getSystemService( Context.LAYOUT_INFLATER_SERVICE );
        view = inflater.inflate( m_resourceId, parent, false );
    }

    TextView titleView = ( TextView ) view.findViewById( R.id.title );
    if( titleView != null ) titleView.setText( m_values.get( position ).title );

    ImageView imageView = ( ImageView ) view.findViewById( R.id.image );
    if( imageView != null )
    {
        imageView.setImageDrawable( null );

        ViewHolder holder = new ViewHolder();
        holder.imageView = imageView;

        m_imageFetcher = new ImageFetcher( m_context );
        m_imageFetcher.attachImage(m_values.get( position ).imageUrl, holder.imageView, null, 10, null);

        view.setTag(holder);
    }

    return view;
}

Любой указатель или пример будут очень благодарны, спасибо!

Теги:
droidparts

1 ответ

1
Лучший ответ

Я бы рекомендовал вам продлить org.droidparts.adapter.widget.ArrayAdapter, который уже содержит экземпляр LayoutInflater.

Если вы это сделаете, здесь код, логика должна быть легко следовать:

public class MyArrayAdapter extends ArrayAdapter<MyModel> {

    private final ImageFetcher imageFetcher;

    public MyArrayAdapter(Context ctx, List<MyModel> list) {
        super(ctx, list);
        imageFetcher = new ImageFetcher(ctx);
    }

    @Override
    public View getView(int position, View view, ViewGroup parent) {
        if (view == null) {
            view = layoutInflater.inflate(m_resourceId, null);
            ViewHolder holder = new ViewHolder();
            holder.titleView = ViewUtils.findViewById(view, R.id.title);
            holder.iconView = ViewUtils.findViewById(view, R.id.image);
            view.setTag(holder);
        }
        ViewHolder holder = (ViewHolder) view.getTag();
        holder.iconView.setImageDrawable(null);
        MyModel item = getItem(position);
        holder.titleView.setText(item.title);
        imageFetcher.attachImage(item.iconUrl, holder.iconView);
        return view;
    }

    private static class ViewHolder {
        TextView titleView;
        ImageView iconView;
    }

}

Также проверьте метод setContent(...) как альтернативу предоставлению списка объектов в конструкторе. И, конечно же, убедитесь, что вы объявили <uses-permission android:name="android.permission.INTERNET" />.

  • 0
    Работает отлично, спасибо =] Также очень люблю вашу библиотеку. Полный удивительных вещей, и это многому меня учит, так что спасибо еще раз!

Ещё вопросы

Сообщество Overcoder
Наверх
Меню