2011-12-11 12 views
1

私は2つのテキストビューを持つカスタムリストビューを持っています。私はエミュレータのD - パッドを使用する場合、すべて正常に動作し、行が選択されていますが、エミュレータ上の項目をクリックして(または電話で選択しようとすると)何も選択されません。Android - リストビュー項目を選択できない

addresslist.xml: 
    <?xml version="1.0" encoding="utf-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:layout_width="fill_parent" android:layout_height="wrap_content" 
    android:orientation="horizontal" android:paddingBottom="6dip" 
    android:paddingTop="4dip"> 

    <TextView android:id="@+id/DENUMIRE_CELL" 
     android:layout_width="50dp" android:layout_height="wrap_content" 
     android:layout_weight="1.03" /> 

    <TextView android:id="@+id/ADRESA_CELL" android:layout_width="50dp" 
     android:layout_height="wrap_content" android:layout_weight="0.84" /> 
</LinearLayout> 
clienti.xml: 

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

    <TableRow android:id="@+id/tableRow1" android:layout_width="fill_parent" 
     android:layout_height="wrap_content"> 

     <LinearLayout android:orientation="horizontal" 
      android:focusable="true" android:focusableInTouchMode="true"> 
      <EditText android:id="@+id/editTextCauta" 
       android:layout_width="100dp" android:layout_height="wrap_content" 
       android:layout_weight="0.04" /> 

      <Button android:id="@+id/buttonCauta" android:layout_width="70dp" 
       android:layout_height="wrap_content" android:text="Cauta" /> 
     </LinearLayout> 

    </TableRow> 
    <TableRow android:id="@+id/tableRowHeader" 
     android:layout_width="fill_parent" android:layout_height="wrap_content" 
     android:background="#000000"> 

     <LinearLayout android:orientation="horizontal"> 
      <TextView android:id="@+id/textView1" android:layout_width="159dp" 
       android:layout_height="wrap_content" android:text="Denumire" 
       android:textAppearance="?android:attr/textAppearanceLarge" 
       android:textColor="#BBBBBB" android:textSize="15sp" /> 
      <TextView android:id="@+id/textView2" android:layout_width="159dp" 
       android:layout_height="wrap_content" android:text="Adresa" 
       android:textAppearance="?android:attr/textAppearanceLarge" 
       android:textColor="#BBBBBB" android:textSize="15sp" /> 

     </LinearLayout> 

    </TableRow> 
    <TableRow android:id="@+id/tableRow2" android:layout_width="wrap_content" 
     android:layout_height="wrap_content" android:baselineAligned="false"> 


     <ListView android:id="@+id/adresslist" android:layout_width="wrap_content" 
      android:choiceMode="singleChoice" android:layout_height="wrap_content" 
      android:scrollbars="horizontal|vertical" /> 

    </TableRow> 


</TableLayout> 

コード:

public void adresalistBind() 
     { 
      listview = (ListView) findViewById(R.id.adresslist); 

      ArrayList<HashMap<String, String>> mylist = new ArrayList<HashMap<String, String>>(); 
      ArrayList<ClientClass> clientlist=new ArrayList<ClientClass>(); 

      ClientClass.setClientContextForDB(this); 

      clientlist=ClientClass.ClientiGet(); 

      listaAll=clientlist; 


      HashMap<String, String> map; 

      for(int i=0;i<clientlist.size();i++) 
      { 
       map = new HashMap<String, String>(); 
       map.put("denumire", clientlist.get(i).getDenumire()); 
       map.put("adresa", clientlist.get(i).getAdresa()); 
       map.put("clientid", String.valueOf(clientlist.get(i).getClientID())); 
       mylist.add(map); 
      } 

      SimpleAdapter mAdapter = new SimpleAdapter(this, mylist, R.layout.addresslist, 
         new String[] {"denumire", "adresa"}, new int[] {R.id.DENUMIRE_CELL, R.id.ADRESA_CELL}); 
      listview.setAdapter(mAdapter); 
      listview.setChoiceMode(ListView.CHOICE_MODE_SINGLE); 
      listview.setSelection(1); 
      listview.setOnItemSelectedListener(new OnItemSelectedListener() 
      { 
       public void onItemSelected(AdapterView<?> adaptview, View clickedview, int position, 
         long id) 
       { 
        //adaptview.setSelected(true); 
        listview.setSelection(position); 
       } 

       public void onNothingSelected(AdapterView<?> arg0) 
       { 
       } 

      }); 

      listview.setOnItemClickListener(new OnItemClickListener() 
      { 
       public void onItemClick(AdapterView<?> adaptview, View arg1, 
         int position, long arg3) 
       { 
        //adaptview.setSelected(true); 
        // View rowview = (View) adaptview.getChildAt(position); 
        // rowview.setSelected(true); 
        listview.setSelection(position); 

        //Toast.makeText(ClientiForm.this, (String) listview.getItemAtPosition(position).toString(), 10000).show(); 
       } 
      }); 

      listview.setOnItemLongClickListener(new OnItemLongClickListener() 
      { 

       public boolean onItemLongClick(AdapterView<?> arg0, View arg1, 
         int position, long arg3) 
       { 
        listview.setSelection(position); 
        openOptionsMenu(); 

        Toast.makeText(ClientiForm.this, (String) listview.getItemAtPosition(position).toString(), 10000).show(); 
        return false; 
       } 
      }); 
     } 

答えて

6

アイテムを「チェック可能」にするには、アイテムの上面図にCheckableインターフェイスを実装する必要があります。この場合に限り、ListViewの範囲内で「チェック済み」/「未チェック」の状態になります。

「選択可能」と「チェック可能」の項目は異なる意味を持つことに注意してください。あなたの場合は、 "チェック可能な"アイテムを意味します。 「選択可能」ではありません。あなたはあなたのアイテムを "チェック"する必要がありますが、ListViewは一度にチェックされるアイテムが最大でもCHOICE_MODE_SINGLEであることを確認します。 「選択済み」アイテムは現在アクティブなアイテムです(これは主にアクセシビリティのニーズに使用されます)。

LinearLayoutCheckBoxビューに置き換えて確認できます。 ListViewは自動的に "チェックされた"状態の処理を開始するはずです。


あなたがLinearLayoutを使用して、まだ「確認」/「未チェック」状態をサポートすることができるようにしたい場合は、LinearLayoutを拡張し、Checkableインタフェースを実装するカスタムレイアウトを実装する必要があります。

public class CheckableLinearLayout extends LinearLayout implements Checkable { 

    private boolean mChecked; 

    private static final int[] CHECKED_STATE_SET = { 
     android.R.attr.state_checked 
    }; 

    public CheckableLinearLayout(Context context) { 
     this(context, null); 
     init(); 
    } 

    public CheckableLinearLayout(Context context, AttributeSet attrs) { 
     super(context, attrs); 
     init(); 
    } 

    private void init() {  
     setClickable(true); 
    } 

    /**********************/ 
    /** Handle clicks **/ 
    /**********************/ 

    @Override 
    public boolean performClick() { 
     toggle(); 
     return super.performClick(); 
    } 

    @Override 
    public boolean onInterceptTouchEvent(MotionEvent ev) { 
     return onTouchEvent(ev); 
    } 

    /**************************/ 
    /**  Checkable  **/ 
    /**************************/ 

    public void toggle() { 
     setChecked(!mChecked); 
    } 

    public boolean isChecked() { 
     return mChecked; 
    } 

    public void setChecked(boolean checked) { 
     if (mChecked != checked) { 
      mChecked = checked; 
      refreshDrawableState(); 
      setCheckedRecursive(this, checked); 
     } 
    } 

    private void setCheckedRecursive(ViewGroup parent, boolean checked) { 
     int count = parent.getChildCount(); 
     for(int i = 0; i < count; i++) { 
      View v = parent.getChildAt(i); 
      if(v instanceof Checkable) { 
       ((Checkable) v).setChecked(checked); 
      } 

      if(v instanceof ViewGroup) { 
       setCheckedRecursive((ViewGroup)v, checked); 
      } 
     } 
    } 

    /**************************/ 
    /** Drawable States **/ 
    /**************************/ 

    @Override 
    protected int[] onCreateDrawableState(int extraSpace) { 
     final int[] drawableState = super.onCreateDrawableState(extraSpace + 1); 
     if (isChecked()) { 
      mergeDrawableStates(drawableState, CHECKED_STATE_SET); 
     } 
     return drawableState; 
    } 

    @Override 
    protected void drawableStateChanged() { 
     super.drawableStateChanged(); 

     Drawable drawable = getBackground(); 
     if (drawable != null) { 
      int[] myDrawableState = getDrawableState(); 
      drawable.setState(myDrawableState); 
      invalidate(); 
     } 
    } 

    /**************************/ 
    /** State persistency **/ 
    /**************************/ 

    static class SavedState extends BaseSavedState { 
     boolean checked; 

     SavedState(Parcelable superState) { 
      super(superState); 
     } 

     private SavedState(Parcel in) { 
      super(in); 
      checked = (Boolean)in.readValue(null); 
     } 

     @Override 
     public void writeToParcel(Parcel out, int flags) { 
      super.writeToParcel(out, flags); 
      out.writeValue(checked); 
     } 

     @Override 
     public String toString() { 
      return "CheckableLinearLayout.SavedState{" 
        + Integer.toHexString(System.identityHashCode(this)) 
        + " checked=" + checked + "}"; 
     } 

     public static final Parcelable.Creator<SavedState> CREATOR 
       = new Parcelable.Creator<SavedState>() { 
      public SavedState createFromParcel(Parcel in) { 
       return new SavedState(in); 
      } 

      public SavedState[] newArray(int size) { 
       return new SavedState[size]; 
      } 
     }; 
    } 

    @Override 
    public Parcelable onSaveInstanceState() { 
     // Force our ancestor class to save its state 
     Parcelable superState = super.onSaveInstanceState(); 
     SavedState ss = new SavedState(superState); 

     ss.checked = isChecked(); 
     return ss; 
    } 

    @Override 
    public void onRestoreInstanceState(Parcelable state) { 
     SavedState ss = (SavedState) state; 

     super.onRestoreInstanceState(ss.getSuperState()); 
     setChecked(ss.checked); 
     requestLayout(); 
    } 
} 

あなたの項目のレイアウトのようなものになります:

<com.your.pkg.CheckableLinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
    android:id="@+id/linearLayout1" 
    android:layout_width="fill_parent" 
    android:layout_height="wrap_content" 
    android:background="@drawable/checkable_item"> 

     <TextView 
      android:id="@+id/name" 
      android:layout_width="wrap_content" 
      android:layout_height="wrap_content" 
      android:text="Large Text" 
      android:textAppearance="?android:attr/textAppearanceLarge" /> 
</com.your.pkg.CheckableLinearLayout> 

をそして "描画可能/ checakble_item" ことに注意してください。ここ

は、この実装の私のバージョンが何であるかです。異なる状態を処理する必要があります。私の例では、次のようになります。drawable/item_presseddrawable/item_checkeddrawable/item_uncheckedは私のカスタムのドローアブルある

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

    <item android:state_pressed="true" android:drawable="@drawable/item_pressed" /> 
    <item android:state_checked="true" android:drawable="@drawable/item_checked"/> 
    <item android:drawable="@drawable/item_unchecked" /> 

</selector> 

最後のノート:あなたのAdaptergetView()であなたはCheckableLinearLayoutによってListViewとしないことによって処理されるようにチェック可能な状態のためview.setClickable(false);を呼び出す必要があります。

+0

あなたのコードは動作していますが、複数の項目をチェックするので、一度に1つだけチェックしたいと思います。私は現在の項目をチェックretriveしようとしたが、それはこのように働いていない:(listview.getCheckedItemPosition()> = 0) \t \t場合(listaAll.size()> 0) \t \t \t { \t \t \t \t場合\t \t { \t \t \t \t \t Clientid = listaAll.get(listview.getCheckedItemPosition())。getClientID(); \t \t \t \t \t startActivity(新しいインテント(ClientiForm.this、ClientiDetaliiForm.class)); \t \t \t \t} \t \t \t他\t \t \t \t \t { \t \t \t \t \t Toast.makeText(ClientiForm.this、 "Alegeti国連クライアント!"、10000).SHOW(); \t \t \t \t} \t \t \t \t \t \t \t} –

+0

あなたが追加したことを確認してください 'view.setClickable(偽)'アダプタの 'getViewメソッドで()'。または 'CheckableLinearLayout'から' setClickable(true) 'を削除してください。 – inazaruk

+0

addresslist.xmlのCheckableLinearLayoutにandroid:clickable = "false"を追加しましたが、複数の項目をチェックします –

0

あなたはthis linkであなたの解決策を見つけることができます。プログラムでレイアウトの外観を変更する必要があります。

関連する問題