点击按钮弹框显示ListView,点击ListView某一项做出相应

最近在做上面描述的功能,网上找了个几个例子,拼拼凑凑整出来了效果,首先多谢http://www.cnblogs.com/miya2012/archive/2012/08/23/2652224.html,  代码实现差不多,特地做了个例子。附在最后?

不多说,先看效果图哈.

    

好了,上代码

MainActivity.java

public class MainActivity extends Activity {
	private Button btn;
	private List<String> list = new ArrayList<String>();
	private AlertDialog.Builder builder;
	private AlertDialog alertDialog;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		this.requestWindowFeature(Window.FEATURE_NO_TITLE);
		setContentView(R.layout.activity_main);

		list = initData();

		btn = (Button) findViewById(R.id.btn_list);

		btn.setOnClickListener(new OnClickListener() {

			@Override
			public void onClick(View v) {
				ShowDialog();//弹框操作
			}
		});
	}
	//初始化数据
	private ArrayList<String> initData() {
           ArrayList<String> list = new ArrayList<String>();
           for(int i = 0;i < 15;i++){
        	String name = "布丁布丁"+i;
            list.add(name);
           }
          return list;
	}
	public void ShowDialog() {
	     Context context = MainActivity.this;
             LayoutInflater inflater = (LayoutInflater) context.getSystemService(LAYOUT_INFLATER_SERVICE);
             View layout = inflater.inflate(R.layout.formcommonlist, null);
             ListView myListView = (ListView) layout.findViewById(R.id.formcustomspinner_list);
	     MyAdapter adapter = new MyAdapter(context, list);
             myListView.setAdapter(adapter);
             myListView.setOnItemClickListener(new OnItemClickListener() {

		@Override
		public void onItemClick(AdapterView<?> arg0, View arg1, int positon, long id) {
		    //在这里面就是执行点击后要进行的操作,这里只是做一个显示
		   Toast.makeText(MainActivity.this, "您点击的是"+list.get(positon).toString(), 0).show();
		   if (alertDialog != null) {
			alertDialog.dismiss();
		   }
		}
             });
             builder = new AlertDialog.Builder(context);
             builder.setView(layout);
             alertDialog = builder.create();
             alertDialog.show();
	}
    //自定义的适配器
   class MyAdapter extends BaseAdapter {
	private List<String> mlist;
	private Context mContext;

	public MyAdapter(Context context, List<String> list) {
		this.mContext = context;
		mlist = new ArrayList<String>();
		this.mlist = list;
	}

	@Override
	public int getCount() {
		return mlist.size();
	}

	@Override
	public Object getItem(int position) {
		return mlist.get(position);
	}

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

	@Override
	public View getView(int position, View convertView, ViewGroup parent) {
		Person person = null;
		if (convertView == null) {
		    LayoutInflater inflater = LayoutInflater.from(mContext);
		    convertView = inflater.inflate(R.layout.rtu_item,null);
	            person = new Person();
	            person.name = (TextView)convertView.findViewById(R.id.tv_name);
	            convertView.setTag(person);
			}else{
				person = (Person)convertView.getTag();
			}
			person.name.setText(list.get(position).toString());
			return convertView;
		}
	class Person{
	    TextView name;
	}
   }
}

主界面

activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    tools:context="com.example.dialogspinner.MainActivity" >

	 <RelativeLayout
          android:layout_width="wrap_content"
          android:layout_height="wrap_content"
          android:background="@drawable/title_background">
          
	    <Button
            android:id="@+id/btn_list"
            android:layout_width="25dp"
            android:layout_height="25dp"
            android:layout_alignParentLeft="true"
            android:layout_centerVertical="true"
            android:layout_marginLeft="15dip"
            android:background="@drawable/commom_title2"
            android:gravity="left|center_vertical"
            android:maxLines="1"
            android:visibility="visible" />
            
	    	<TextView
		        android:id="@+id/tvDeviceName2"
		        android:layout_width="fill_parent"
		        android:layout_height="25dp"
		        android:gravity="center"
		        android:layout_toRightOf="@+id/btn_list"
              	android:text="弹框ListView"
              	android:textSize="17sp"
		        android:textColor="#FF8C00" />
    </RelativeLayout>
</LinearLayout>

弹框显示样式

formcommonlist.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:id="@+id/layout_myview"
    android:layout_height="fill_parent"
    android:background="@android:color/background_light"
    android:orientation="vertical"
    android:padding="0.0dip" >

    <LinearLayout
        android:id="@+id/title"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
        android:background="#defafd"
        android:padding="10.0dip" >

        <TextView
            android:id="@+id/label"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_toRightOf="@id/title"
            android:text="请选择"
            android:textColor="#0182af"
            android:textSize="20.0dip" />
    </LinearLayout>

    <ListView
        android:id="@+id/formcustomspinner_list"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:layout_weight="1"
        android:cacheColorHint="@null"
        android:divider="@android:drawable/divider_horizontal_bright"
        android:scrollbars="none" /> <!-- listview 的线为灰色 -->

</LinearLayout>

弹框里的ListView单个选项

rtu_item.xml

<?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="35dip"
    android:orientation="horizontal" >

    <TextView
        android:id="@+id/tv_name"
        android:layout_width="fill_parent"
        android:layout_height="35dip"
        android:gravity="center"
        android:text="布丁"
        android:textColor="#000000"
        android:textSize="15sp" />

</LinearLayout>

好了,这样就完成了,有需要源码的请点击

下载源码

时间: 2024-11-05 06:24:03

点击按钮弹框显示ListView,点击ListView某一项做出相应的相关文章

jquery实现点击按钮弹出层和点击空白处隐藏层

昨天做项目遇到一个问题,和大家分享下,jquery实现点击按钮弹出层和点击空白处隐藏层的问题 if($('.autoBtn').length){                $('.autoBtn').find('.assess').unbind().bind('click',function(event){                    //取消事件冒泡                      event.stopPropagation(); if($('.abtnBox').is

android如果给TextView或EditText的email链接加下划线,并在点击在email连接上可以弹框显示

如何把textview的一些文字加上背景色: Spannable str = new SpannableString("#fdsfdfsdfdsfd#"); Matcher matcher = getEmailPattern().matcher((CharSequence) str); while (matcher.find()) { int start = matcher.start(); int end = matcher.end(); str.setSpan(new Foregr

Js浮动层插件,点击按钮弹出层,可关闭

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <title>石家庄礼品公司</title>

js弹框显示全部内容

1 file=file.replace(/\r\n/g,"<br>"); //回车换行显示 2 file=file.replace(/\n/g,"<br>"); 3 OpenWindow=window.open("", "newwin", "height=600, width=1000,top=150 ,left=220 ,scrollbars=yes, resizable=yes, tool

问题1:默认div隐藏,点击按钮时出现,再点击时隐藏。

例:默认div隐藏,点击按钮时出现,再点击时隐藏. <a href="#" onclick="f('ycbc')"; >控制按钮</a> <div id="ycbc" style="display:none">隐藏的内容</div> 解决方法一:javascript 利用onclick事件调用f('ycbc')函数,参数为隐藏的内容div的id,在函数加入钮时出现,再点击时隐藏代

点击按钮 弹出视频 并有遮罩层效果

涉及到css以及JavaScript. 最终显示效果:点击红色按钮,会有视屏弹出 并带有遮罩层 点击黄色区域可以关闭视频 并回到最初的状态. 页面主要代码:main中主要包含一个a,控制显示的按钮.设置有id值. <div class="main"> <a href="javascript:;" class="video" id="video"></a> </div> 以下代码就

JS点击按钮弹出窗口

由于没有系统学习过JS,遇到一个需求:点击按钮,弹出一个独立的窗口. 在网上百度了一下,并没有找到满意的结果,最重要的是各种方法很复杂.最终,仔细研究了一下,原来只是需要只要一个简单的函数就能满足自己的需求:window.open(). window.open() 功能:open() 方法用于打开一个新的浏览器窗口或查找一个已命名的窗口. 语法: window.open(URL,name,specs,replace) 其中,URL为指定的要打开的页面的url: name,指定target属性或窗

ASP.NET点击按钮弹出确认对话框方法

开发asp.net网页应用程序的时候,有些页面的按钮需要增加一个确认对话框,比如: 实现这个功能比较简单,代码这样写: Button.Attributes["onclick"] = "javascript:return confirm('您确定删除吗?一旦删除将无法恢复!');"; 或 Button.Attributes.Add("OnClick", "javascript:return confirm('您确定删除吗?一旦删除将无法恢

vux弹框显示

//点击按钮,执行什么成功,失败用这个合适this.$vux.toast.show({ text: '添加成功'}) //点击按钮,提示出现的问题 this.$vux.toast.show({ text: '请输入该问题', type: 'text', width: '180px', //设置显示宽度 position: 'bottom' //显示在底部,默认不填显示在中间}) //点击按钮,执行什么成功,失败用这个合适 this.$vux.confirm.show({ title: '系统提示