1.Activity布局activity_main
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
tools:context="hjk.signalchoice.activity.MainActivity" >
<ListView
android:id="@+id/listView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"></ListView>
</RelativeLayout>
2.Activity代码 MainActivity
package hjk.signalchoice.activity;
import hjk.signalchoice.R;
import hjk.signalchoice.adapter.SignalAdapter;
import java.util.ArrayList;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.widget.ListView;
public class MainActivity extends Activity {
private Context mContext;
private ListView mListView;
private SignalAdapter mSignalAdapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
initView();
loadData();
}
private void initView() {
mContext = MainActivity.this;
mListView = (ListView) this.findViewById(R.id.listView);
}
private void loadData() {
List<String> datas = getDatas();
mSignalAdapter = new SignalAdapter(mContext, datas);
mListView.setAdapter(mSignalAdapter);
}
private List<String> getDatas() {
List<String> datas = new ArrayList<String>();
for (int i = 0; i < 10; i++) {
datas.add("测试"+i);
}
return datas;
}
}
3.item布局item_signal
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center_horizontal"
android:orientation="vertical" >
<TextView
android:id="@+id/textView"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:padding="15dp"
/>
<View
android:layout_width="match_parent"
android:layout_height="0.3dp"
android:background="@android:color/black"/>
<ImageView
android:id="@+id/imageView"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:contentDescription="@string/imageView"
android:src="@drawable/ic_launcher"/>
</LinearLayout>
4.Adapter代码 SignalAdapter
package hjk.signalchoice.adapter;
import hjk.signalchoice.R;
import java.util.List;
import android.annotation.SuppressLint;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.ImageView;
import android.widget.TextView;
@SuppressLint("InflateParams")
public class SignalAdapter extends BaseAdapter {
private Context mContext;
private List<String> mDatas;
private int mLastPosition = -1;//最后选中的项
public SignalAdapter(Context context, List<String> datas) {
this.mContext = context;
this.mDatas = datas;
}
@Override
public int getCount() {
return mDatas==null?0:mDatas.size();
}
@Override
public Object getItem(int position) {
return mDatas==null?null:mDatas.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(final int position, View convertView, ViewGroup parent) {
CheckHolder holder;
if(convertView == null) {
convertView = LayoutInflater.from(mContext).inflate(R.layout.item_signal, null);
holder = new CheckHolder();
holder.textView = (TextView) convertView.findViewById(R.id.textView);
holder.imageView = (ImageView) convertView.findViewById(R.id.imageView);
convertView.setTag(holder);
} else {
holder = (CheckHolder) convertView.getTag();
}
String text = (String) getItem(position);
holder.textView.setText(text);
if(position == mLastPosition) {
holder.imageView.setVisibility(View.VISIBLE);
} else {
holder.imageView.setVisibility(View.GONE);
}
holder.textView.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View v) {
changeItemVisibility(position);
}
});
return convertView;
}
class CheckHolder {
TextView textView;
ImageView imageView;
}
private void changeItemVisibility(int position) {
if(position == mLastPosition) {
mLastPosition = -1;
} else {
mLastPosition = position;
}
notifyDataSetChanged();
}
}
这就是整理的单一View展开的示例