Android - 只有一行的自定义ListView

时间:2016-08-25 07:08:22

标签: java android listview

我想要在下面的图像中显示的东西......如第3项,第4项和第7项具有拨动开关但是项目1,项目2,项目5,项目6没有。任何人都可以帮助我制作这种布局并使切换开关工作

我想要这个(用Photoshop制作)

enter image description here

我的Java文件

import android.content.*;
import android.view.*;
import android.widget.*;

class CustomSettingsAdapter extends ArrayAdapter<String> {

String[] settingItems = {
        "Themes",
        "Entry Tune",
        "Remember Last Location",
        "About Us",
        "Exit"
};


public CustomSettingsAdapter(Context context, String[] Items) {
    super(context, R.layout.main_settings_listview, Items);
}

@Override
public View getView(final int position, View convertView, ViewGroup parent) {
    LayoutInflater layoutInflater = LayoutInflater.from(getContext());
    View customView = layoutInflater.inflate(R.layout.main_settings_listview, parent, false);

    String itemName = getItem(position);
    TextView textView =(TextView) customView.findViewById(R.id.itemName);
    Switch mButton = (Switch) customView.findViewById(R.id.Switch);

    if (position == 1 || position == 2) {
        mButton.setVisibility(View.VISIBLE);
    }

    textView.setText(settingItems[position]);
    return customView;
}

}

** XML **

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

<RelativeLayout
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:padding="6dp"
    android:minHeight="48dp"
    android:id="@+id/mainActivityListBackground"
    >

   <TextView
       android:layout_width="wrap_content"
       android:layout_height="wrap_content"
       android:text="Item Number"
       android:id="@+id/itemName"
       android:layout_marginLeft="5dp"
       android:textSize="18sp"
       android:layout_centerVertical="true"
       />

    <Switch
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:id="@+id/Switch"
        android:visibility="invisible"
        android:layout_alignParentRight="true"
        />

</RelativeLayout>
</RelativeLayout>

2 个答案:

答案 0 :(得分:0)

您可以使用recycler视图。您可以通过为两个不同的设计创建两个xml来完成此操作,并且根据条件,您可以在布局inflater中设置视图。使用这些方法进行额外视图。

@Override
public int getViewTypeCount() {
    return VIEW_TYPE_COUNT;
}

@Override
public int getItemViewType(int position) {
    return position;
}

您还可以参考this link.

答案 1 :(得分:0)

使用此代码可以帮助您。

item.xml

   <?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/linear"
    android:layout_width="match_parent"
    android:layout_height="wrap_content"
    android:orientation="horizontal">

    <TextView
        android:id="@+id/code"
        android:layout_width="0dp"
        android:layout_height="wrap_content"
        android:layout_marginLeft="30dp"
        android:layout_weight="1"
        android:textSize="16dp" />


    <Switch
        android:id="@+id/toggleButton"
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:checked="true"
        android:gravity="center"
        android:text="Off"
        android:visibility="invisible" />

</LinearLayout>

并使用此适配器

public class PhoneAdapter extends BaseAdapter {
    private Context context;

    public PhoneAdapter(Context context) {
        this.context = context;
    }

    @Override
    public int getCount() {
        return 7;
    }

    @Override
    public Object getItem(int i) {
        return i;
    }

    @Override
    public long getItemId(int i) {
        return i;
    }

    @Override
    public View getView(final int i, View convertView, ViewGroup viewGroup) {

        convertView = View.inflate(context, R.layout.item, null);


        TextView mCode = (TextView) convertView.findViewById(R.id.code);

        Switch mButton = (Switch) convertView.findViewById(R.id.toggleButton);

        mCode.setText("item"+i+1);
        if (i == 2 || i == 3 || i == 6)
            mButton.setVisibility(View.VISIBLE);

        return convertView;
    }}

这是输出: -

o

随时可以询问您是否卡在两者之间。

编辑: - getView()用于标识点击了button,因此您不想关注它。在getView() i变量用于标识单击的项目。 只需在OnchangeListner内设置getView()即可解决问题。