Nano Hash - криптовалюты, майнинг, программирование

Найти положение кнопки внутри списка

У меня есть представление списка, в котором я заполняю строки через базу данных mysql.

Это вид того, что я сделал:

введите здесь описание изображения

Эти имена, которые вы видели, взяты из моей базы данных, а PLAY ImageView — из моего списка макетов, который появляется в каждой строке (когда я добавляю имя в свою базу данных).

Теперь моя проблема заключается в том, что когда я устанавливаю прослушиватель кликов на эту кнопку воспроизведения (цель - переключить ее на паузу, ImageView и т. д.), он также изменяет другие кнопки воспроизведения из других строк, но не все из них. Следовательно, я думаю, что я не получаю эту должность, верно? Можете ли вы помочь мне с этим, пожалуйста!

Это мой фрагмент:

public class XXXUpdatesFragment extends Fragment implements AsyncResponse
,AdapterView.OnItemClickListener{

    View view ;
    private ArrayList<Product> productList;
    private ListView lvProduct;
    private FunDapter<Product> adapter;


    @Nullable
    @Override
    public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
        view = inflater.inflate(R.layout.xxx_updates_layout, container, false);
        ImageLoader.getInstance().init(UILConfig.config(getActivity()));

        lvProduct = (ListView)view.findViewById(R.id.lvProduct);

        PostResponseAsyncTask taskRead = new PostResponseAsyncTask(getActivity(), this);

        taskRead.execute("http://symphonyrecords.6te.net/product.php");

        return view;
    } //onCreate


    @Override
    public void  processFinish(String s) {
        productList = new JsonConverter<Product>().toArrayList(s, Product.class);

        BindDictionary<Product> dict = new BindDictionary<Product>();
        dict.addStringField(R.id.tvName, new StringExtractor<Product>() {
            @Override
            public String getStringValue(Product product, int position) {
                return product.name;
            }
        });

        dict.addStringField(R.id.tvDescription, new StringExtractor<Product>() {
            @Override
            public String getStringValue(Product product, int position) {
                return product.description;   
            }
        });

        dict.addStringField(R.id.tvQty, new StringExtractor<Product>() {
            @Override
            public String getStringValue(Product product, int position) {
                return "" + product.qty;
            }
        });


        adapter = new FunDapter<>(getActivity(), productList, R.layout.d_layout_list_d, dict);


        lvProduct.setAdapter(adapter);
        lvProduct.setOnItemClickListener(this);

    }

    @Override
    public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
        Product selectedProduct = productList.get(position);
        Toast.makeText(getActivity(),selectedProduct.name+"", Toast.LENGTH_SHORT).show();
       }


    }

Это мой класс товаров:

public class Product implements Serializable {
@SerializedName("pid")
public int pid;

@SerializedName("name")
public String name;

@SerializedName("qty")
public int qty;

@SerializedName("price")
public String description;
}

А это мой адаптер:

public class FunDapter<T> extends BaseAdapter implements Filterable {



private boolean paused = true;


protected List<T> mDataItems;
protected List<T> mOrigDataItems;
protected LongExtractor<T> idExtractor;
protected final Context mContext;
private final int mLayoutResource;
private final BindDictionary<T> mBindDictionary;
private int oddColorRes;
private int evenColorRes;
private FunDapterFilter<T> funDapterFilter;
private Filter mFilter;


public FunDapter(Context context, List<T> dataItems, int layoutResource,
                 BindDictionary<T> dictionary) {
  this(context, dataItems, layoutResource, null, dictionary);
}

public FunDapter(Context context, List<T> dataItems, int layoutResource,
                 LongExtractor<T> idExtractor, BindDictionary<T> dictionary) {
    this.mContext = context;
    this.mDataItems = dataItems;
    this.mOrigDataItems = dataItems;
    this.mLayoutResource = layoutResource;
    this.idExtractor = idExtractor;
    this.mBindDictionary = dictionary;

}

public void updateData(List<T> dataItems) {
    this.mDataItems = dataItems;
    this.mOrigDataItems = dataItems;
    notifyDataSetChanged();
}

@Override
public int getCount() {
    if (mDataItems == null || mBindDictionary == null) return 0;

    return mDataItems.size();
}

@Override
public T getItem(int position) {
    return mDataItems.get(position);
}

@Override
public boolean hasStableIds() {
    if(idExtractor == null) return super.hasStableIds();
    else return true;
}

@Override
public long getItemId(int position) {
    if(idExtractor == null) return position;
    else return idExtractor.getLongValue(getItem(position), position);
}

@Override
public View getView(final int position, View convertView, ViewGroup parent) {
    View v = convertView;
    final GenericViewHolder holder;
    if (null == v) {
        LayoutInflater vi =
                (LayoutInflater) mContext.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        v = vi.inflate(mLayoutResource, null);
        holder = new GenericViewHolder();
        holder.root = v;


        holder.playPause=(ImageView)v.findViewById(R.id.playPause); 
        holder.playPause.setOnClickListener(new View.OnClickListener() {

            @Override
            public void onClick(View arg0) {

                        if (paused) {
                            holder.playPause.setImageResource(R.drawable.ic_pause);
                            paused=false;
                        }
                        else {
                            paused = true;
                            holder.playPause.setImageResource(R.drawable.ic_play);
                        }

            }});



        FunDapterUtils.initViews(v, holder, mBindDictionary);

        v.setTag(holder);


    } else {
        holder = (GenericViewHolder) v.getTag();
    }

    final T item = getItem(position);
    showData(item, holder, position);

    return v;
}


private void showData(T item, GenericViewHolder holder, int position) {

    if (oddColorRes > 0 && evenColorRes > 0) {
        if (position % 2 == 0) {
            holder.root.setBackgroundColor(mContext.getResources().getColor(evenColorRes));
        } else {
            holder.root.setBackgroundColor(mContext.getResources().getColor(oddColorRes));
        }
    }

    FunDapterUtils.showData(item, holder, position, mBindDictionary);
}

public FunDapter<T> setAlternatingBackground(int oddColorRes, int evenColorRes) {

    if (oddColorRes <= 0 || evenColorRes <= 0) {
        throw new IllegalArgumentException("Color parameters are illegal");
    }

    this.oddColorRes = oddColorRes;
    this.evenColorRes = evenColorRes;

    return this;
}

public void setIdExtractor(LongExtractor<T> idExtractor) {
    this.idExtractor = idExtractor;
}

@Override
public Filter getFilter() {
    return mFilter;
}

public void initFilter(FunDapterFilter<T> filter) {

    if (filter == null)
        throw new IllegalArgumentException("Cannot pass a null filter to FunDapter");

    this.funDapterFilter = filter;

    mFilter = new Filter() {

        @Override
        protected void publishResults(CharSequence constraint, FilterResults results) {

            List<T> list = (List<T>) results.values;

            if (results.count == 0) {
                resetData();
            } else {
                mDataItems = list;
            }

            notifyDataSetChanged();
        }

        @Override
        protected FilterResults performFiltering(CharSequence constraint) {

            FilterResults results = new FilterResults();
            if (constraint == null || constraint.length() == 0) {

                results.values = mOrigDataItems;
                results.count = mOrigDataItems.size();
            } else {

                List<T> filter =
                        funDapterFilter.filter(constraint.toString(), mOrigDataItems);

                results.count = filter.size();
                results.values = filter;

            }

            return results;
          }
      };
  }

  public void resetData() {
      mDataItems = mOrigDataItems;
     }

  }

Я уже неделю борюсь с этим, буду очень признателен, если вы поможете мне с этим.


Ответы:


1

Используйте RecyclerView, в вашем коде в блоке getView все в порядке, но я не знаю, в чем проблема

11.02.2017
  • Я меньше знаю о RecyclerView, но не могли бы вы подробнее объяснить, почему я должен использовать его вместо Listview и чего я достигну, если сделаю это? потому что я должен изменить много вещей тогда 11.02.2017
  • Потому что у меня были те же проблемы с использованием списка, но вот почему 11.02.2017
  • Новые материалы

    Кластеризация: более глубокий взгляд
    Кластеризация — это метод обучения без учителя, в котором мы пытаемся найти группы в наборе данных на основе некоторых известных или неизвестных свойств, которые могут существовать. Независимо от..

    Как написать эффективное резюме
    Предложения по дизайну и макету, чтобы представить себя профессионально Вам не позвонили на собеседование после того, как вы несколько раз подали заявку на работу своей мечты? У вас может..

    Частный метод Python: улучшение инкапсуляции и безопасности
    Введение Python — универсальный и мощный язык программирования, известный своей простотой и удобством использования. Одной из ключевых особенностей, отличающих Python от других языков, является..

    Как я автоматизирую тестирование с помощью Jest
    Шутка для победы, когда дело касается автоматизации тестирования Одной очень важной частью разработки программного обеспечения является автоматизация тестирования, поскольку она создает..

    Работа с векторными символическими архитектурами, часть 4 (искусственный интеллект)
    Hyperseed: неконтролируемое обучение с векторными символическими архитектурами (arXiv) Автор: Евгений Осипов , Сачин Кахавала , Диланта Хапутантри , Тимал Кемпития , Дасвин Де Сильва ,..

    Понимание расстояния Вассерштейна: мощная метрика в машинном обучении
    В обширной области машинного обучения часто возникает необходимость сравнивать и измерять различия между распределениями вероятностей. Традиционные метрики расстояния, такие как евклидово..

    Обеспечение масштабируемости LLM: облачный анализ с помощью AWS Fargate и Copilot
    В динамичной области искусственного интеллекта все большее распространение получают модели больших языков (LLM). Они жизненно важны для различных приложений, таких как интеллектуальные..