显示效果:
代码实现:
package com.example.tuhuadmin.testlistview;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.CountDownTimer;
import android.support.v7.app.AppCompatActivity;
import android.view.Display;
import android.view.View;
import android.view.Window;
import android.view.WindowManager;
import android.widget.AdapterView;
import android.widget.ListView;
import android.widget.TextView;
import java.util.ArrayList;
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//准备要传入的数据
ArrayList<String> mData = new ArrayList<>();
for (int i = 0; i < 100; i++) {
mData.add("crs" + i);
}
ListView lv = (ListView) findViewById(R.id.lv);
final MyAdapter myAdapter = new MyAdapter(this, mData);
myAdapter.selectedItemPosition(0);
lv.setAdapter(myAdapter);
//条目监听事件
lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
myAdapter.selectedItemPosition(i);
//相当于调用getView()重新绘制条目
myAdapter.notifyDataSetChanged();
ShowDialog(MainActivity.this, "已经加入购物车");
}
});
}
public void ShowDialog(Context context, String text) {
//控制Dialog显示的大小
WindowManager wm = (WindowManager) this.getSystemService(Context.WINDOW_SERVICE);
Display defaultDisplay = wm.getDefaultDisplay();
int width = defaultDisplay.getWidth();
final BaseDialog baseDialog = new BaseDialog(context, R.layout.show_dialog);
//获取对话框所在的窗口
Window dialogWindow = baseDialog.getWindow();
//获取对话框窗口的布局参数
WindowManager.LayoutParams p = dialogWindow.getAttributes();
p.height = (int) (width * 0.5);
p.width = (int) (width * 0.5);
//当Window的Attributes改变时系统会调用此函数 setAttributes()
dialogWindow.setAttributes(p);
//为对话框设置文字
((TextView) baseDialog.getView().findViewById(R.id.show_text)).setText(text);
//触摸外面不能够取消
baseDialog.setCanceledOnTouchOutside(false);
baseDialog.show();
CountDownTimer timer = new CountDownTimer(2000, 2000) {
@Override
public void onTick(long millisUntilFinished) {
}
@Override
public void onFinish() {
//定时器类 2秒后自动消失
baseDialog.dismiss();
}
};
timer.cancel();
//定时器开始执行
timer.start();
}
}
适配器:
package com.example.tuhuadmin.testlistview;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.BaseAdapter;
import android.widget.LinearLayout;
import android.widget.TextView;
import java.util.ArrayList;
/**
* Created on 2016/7/29.
* Author:crs
* Description:XXX
*/
public class MyAdapter extends BaseAdapter {
private int selectedPosition;
private Context mContext;
private ArrayList<String> mData;
private final LayoutInflater mInflate;
public MyAdapter(Context context, ArrayList<String> mData) {
this.mContext = context;
this.mData = mData;
mInflate = LayoutInflater.from(context);
}
@Override
public int getCount() {
return mData.size();
}
@Override
public Object getItem(int i) {
return mData.get(i);
}
@Override
public long getItemId(int i) {
return 0;
}
@Override
public View getView(int i, View view, ViewGroup viewGroup) {
ViewHolder holder;
if (view == null) {
view = mInflate.inflate(R.layout.item, null);
holder = new ViewHolder();
holder.tv = (TextView) view.findViewById(R.id.tv_name);
holder.bg = (LinearLayout) view.findViewById(R.id.bg);
view.setTag(holder);
} else {
holder = (ViewHolder) view.getTag();
}
//赋值
holder.tv.setText(mData.get(i));
//被选中和未被选中的显示样式
if (selectedPosition == i) {
holder.bg.setBackgroundColor(mContext.getResources().getColor(R.color.car_item_list_bg_selected));
holder.tv.setTextColor(mContext.getResources().getColor(R.color.car_item_list_item_text_selected));
} else {
holder.bg.setBackgroundColor(mContext.getResources().getColor(R.color.car_item_list_bg_normal));
holder.tv.setTextColor(mContext.getResources().getColor(R.color.fontColorce));
}
return view;
}
public void selectedItemPosition(int position) {
this.selectedPosition = position;
}
static class ViewHolder {
TextView tv;
LinearLayout bg;
}
}自定义Dilaog:
package com.example.tuhuadmin.testlistview;
import android.app.Dialog;
import android.content.Context;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
/**
* Created on 2016/7/29.
* Author:crs
* Description:XXX
*/
public class BaseDialog extends Dialog {
private View view;
//构造函数
public BaseDialog(Context context, int layout) {
super(context, R.style.Dialog);
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = inflater.inflate(layout, null);
this.addContentView(view, new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));
this.setContentView(view);
}
public View getView() {
return view;
}
public void setView(View view) {
this.view = view;
}
public void closewindow() {
this.dismiss();
}
}布局文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout 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="match_parent"
android:background="@drawable/show_dialog"
android:id="@+id/show_layout"
android:layout_gravity="center">
<LinearLayout
android:orientation="vertical"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerInParent="true"
android:padding="20dp">
<ImageView
android:layout_width="40dp"
android:layout_height="40dp"
android:id="@+id/v"
android:layout_gravity="center_horizontal"
android:background="@drawable/show_success" />
<TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/show_text"
android:textColor="#ffffff"
android:textSize="15sp"
android:layout_marginTop="10dp" />
</LinearLayout>
</RelativeLayout>
</LinearLayout>样式:
<style name="Dialog" parent="android:style/Theme.Dialog">
<item name="android:background">#00000000</item>
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:windowNoTitle">true</item>
<item name="android:windowIsFloating">true</item>
</style>
本文介绍了一个使用Android实现ListView自定义条目选中效果的案例,包括如何通过自定义Adapter设置条目的选中状态及样式变化,并展示了如何在条目点击时弹出自定义的提示Dialog。
895

被折叠的 条评论
为什么被折叠?



