Android ListView с элементами onClick

Я новый программист и новичок в Android. Я использую этот пример http://www.androidhive.info/2012/09/android-adding-search-functionality-to-listview/, и это прекрасно работает.

Теперь я хочу, чтобы элементы (Dell, Samsung Galaxy S3 и т. д.) вызывали функцию для открытия нового действия с различной информацией.

Например:

Если я коснусь Dell, появится новое действие, показывающее мне информацию о Dell. Если я коснусь Samsung, то же самое.

Я гуглил, но ничего полезного не нашел, какой-нибудь намек? Я думаю, что это основное, но я новичок, поэтому я действительно не знаю, с чего начать.


person Agustín    schedule 22.01.2014    source источник


Ответы (7)


В вашей деятельности, где вы определили свой список

ты пишешь

listview.setOnItemClickListener(new OnItemClickListener(){   
    @Override
    public void onItemClick(AdapterView<?>adapter,View v, int position){
        ItemClicked item = adapter.getItemAtPosition(position);

        Intent intent = new Intent(Activity.this,destinationActivity.class);
        //based on item add info to intent
        startActivity(intent);
    }
});

в getItem вашего адаптера вы пишете

public ItemClicked getItem(int position){
    return items.get(position);
}
person Lena Bru    schedule 22.01.2014

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

http://developer.android.com/reference/android/os/Parcelable.html

Здесь у меня есть onItemClick. Я создаю намерение и добавляю в него дополнительный класс. В классе, который я отправляю, реализована возможность разделения. Совет: вам нужно реализовать анализируемый объект только по сравнению с тем, что минимально необходимо для воссоздания класса. То есть, может быть, имя файла или что-то простое, например строка, которую конструктор может использовать для создания класса. Новое действие может позже получитьExtras и, по сути, создает копию класса с помощью метода конструктора.

Здесь я запускаю класс kmlreader моего приложения, когда я получить щелчок в списке.

Примечание: ниже сводка представляет собой список классов, которые я передаю, поэтому get(position) возвращает класс, фактически это тот же список, который заполняет список

List<KmlSummary> summary = null;
...

public final static String EXTRA_KMLSUMMARY = "com.gosylvester.bestrides.util.KmlSummary";

...

@Override
public void onItemClick(AdapterView<?> parent, View view, int position,
        long id) {
    lastshownitem = position;
    Intent intent = new Intent(context, KmlReader.class);
    intent.putExtra(ImageTextListViewActivity.EXTRA_KMLSUMMARY,
            summary.get(position));
    startActivity(intent);
}

позже в новом действии я вытаскиваю анализируемый класс с помощью

kmlSummary = intent.getExtras().getParcelable(
                ImageTextListViewActivity.EXTRA_KMLSUMMARY);

//note:
//KmlSummary implements parcelable.
//there is a constructor method for parcel in
// and a overridden writetoparcel method
// these are really easy to setup.

public KmlSummary(Parcel in) {
    this._id = in.readInt();
    this._description = in.readString();
    this._name = in.readString();
    this.set_bounds(in.readDouble(), in.readDouble(), in.readDouble(),
    in.readDouble());
    this._resrawid = in.readInt();
    this._resdrawableid = in.readInt();
     this._pathstring = in.readString();
    String s = in.readString();
    this.set_isThumbCreated(Boolean.parseBoolean(s));
}

@Override
public void writeToParcel(Parcel arg0, int arg1) {
    arg0.writeInt(this._id);
    arg0.writeString(this._description);
    arg0.writeString(this._name);
    arg0.writeDouble(this.get_bounds().southwest.latitude);
    arg0.writeDouble(this.get_bounds().southwest.longitude);
    arg0.writeDouble(this.get_bounds().northeast.latitude);
    arg0.writeDouble(this.get_bounds().northeast.longitude);
    arg0.writeInt(this._resrawid);
    arg0.writeInt(this._resdrawableid);
    arg0.writeString(this.get_pathstring());
    String s = Boolean.toString(this.isThumbCreated());
    arg0.writeString(s);
}

Удачи Дэнни117

person danny117    schedule 22.01.2014

Вы обязательно должны расширить ArrayListAdapter и реализовать это в своем методе getView(). Второй параметр (View) должен быть увеличен, если его значение равно null, воспользуйтесь этим и установите для него значение onClickListener() сразу после увеличения.

Предположим, что ваш второй параметр getView() называется convertView:

convertView.setOnClickListener(new View.OnClickListener() {
  public void onClick(final View v) {
    if (isSamsung) {
      final Intent intent = new Intent(this, SamsungInfo.class);
      startActivity(intent);
    }
    else if (...) {
      ...
    }
  }
}

Если вам нужна информация о том, как расширить ArrayListAdapter, я рекомендую этот ссылка.

person nKn    schedule 22.01.2014

ну, в вашем onitemClick вы отправите выбранное значение, например deal, и отправите его в своем намерении при открытии нового действия, а в новом действии получите отправленные данные, и связанные с выбранным элементом отобразят ваши данные

чтобы получить имя от list

String item = yourData.get(position).getName(); 

установить данные в намерении

intent.putExtra("Key", item);

чтобы получить данные во втором действии

getIntent().getExtras().getString("Key")
person mohammed momn    schedule 22.01.2014

для какого черта внедрять Parcelable?

он переходит к адаптеру String[] поэтому

  • получить элемент (строка) в позиции
  • создать намерение
  • поставь как лишнее
  • начать деятельность
  • в активности получить доп.

для хранения списка продуктов вы можете использовать здесь HashMap (например, как СТАТИЧЕСКИЙ объект)

пример класса, описывающего продукт:

public class Product {
    private String _name;
    private String _description;
    private int _id

    public Product(String name, String description,int id) {
        _name = name;
        _desctription = description;
        _id = id;
    }

    public String getName() {
        return _name;
    }

    public String getDescription() {
        return _description;
    }
}

Product dell = new Product("dell","this is dell",1);

HashMap<String,Product> _hashMap = new HashMap<>();
_hashMap.put(dell.getName(),dell);

затем вы переходите к набору ключей адаптера как:

String[] productNames =  _hashMap.keySet().toArray(new String[_hashMap.size()]);

когда в адаптере вы возвращаете представление, вы устанавливаете слушателя, например, так:

 @Override
 public View getView(int position, View convertView, ViewGroup parent) {

     Context context = parent.getContext(); 

     String itemName = getItem(position)

     someView.setOnClikListener(new MyOnClickListener(context, itemName));

 }


 private class MyOnClickListener implements View.OnClickListener { 

     private  String _itemName; 
     private  Context _context

     public MyOnClickListener(Context context, String itemName) {
         _context = context;
         _itemName = itemName; 
     }

     @Override 
     public void onClick(View view) {
         //------listener onClick example method body ------
         Intent intent = new Intent(_context, SomeClassToHandleData.class);
         intent.putExtra(key_to_product_name,_itemName);
         _context.startActivity(intent);
     }
 }

затем в другой деятельности:

@Override 
public void onCreate(Bundle) {

    String productName = getIntent().getExtra(key_to_product_name);
    Product product = _hashMap.get(productName);

}

*key_to_product_name — общедоступная статическая строка, которая служит ключом для дополнительных

пс. извините за опечатку я торопился :) ps2. это должно дать вам представление о том, как это сделать ps3. когда у меня будет больше времени я добавлю подробное описание

МОЙ КОММЕНТАРИЙ:

  • НЕ ИСПОЛЬЗУЙТЕ УТВЕРЖДЕНИЕ ПЕРЕКЛЮЧЕНИЯ
  • НЕ СОЗДАВАЙТЕ ОТДЕЛЬНЫЕ ДЕЙСТВИЯ ДЛЯ КАЖДОГО ПРОДУКТА (ТРЕБУЕТСЯ ТОЛЬКО ОДИН)
person ceph3us    schedule 11.07.2015

Я смог обойти все это, заменив контекстную ссылку с this или Context.this на getapplicationcontext.

person kenyan_ian    schedule 06.10.2015

person    schedule
comment
Этот ответ оказался в очереди на проверку низкого качества, предположительно потому, что вы не предоставили никаких объяснений кода. Если этот код отвечает на вопрос, рассмотрите возможность добавления текста, поясняющего код в вашем ответе. Таким образом, у вас гораздо больше шансов получить больше голосов и помочь спрашивающему узнать что-то новое. - person lmo; 07.09.2016