`

自定义Dialog2

阅读更多
package qianlong.qlmobile.view;

import qianlong.qlmobile.tablet.R;
import android.app.Dialog;
import android.content.Context;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.GridView;
import android.widget.TextView;
import android.widget.AdapterView.OnItemClickListener;

public class MarketDialog extends Dialog {
	private Context context;
	private GridView gridview;
	private SelectedDialogAdapter adapter;
	private String[] texts;
	private int position = 0;
	OnListItemClickListener onListItemClickListener;
	
	public MarketDialog(Context context,String[] texts,int position) {
		super(context);
		// TODO Auto-generated constructor stub
		this.context=context;
		setCanceledOnTouchOutside(true);
		 this.texts=texts;
		 this.position=position;
	}
	public MarketDialog(Context context, int theme,String[] texts,int position) {    
        super(context, theme);    
        this.context = context;
        setCanceledOnTouchOutside(true);
        this.texts=texts;
        this.position=position;
        
//        //设置对话框位置
//        Window w=getWindow();
////        w.setBackgroundDrawableResource(R.drawable.dialog_bg_1);
//        WindowManager.LayoutParams wl = w.getAttributes();
//        int xNewPos=-130;
//        int yNewPos=-40;
//        Log.i("MarketDialog", "wl.width==="+wl.width);
//        Log.i("MarketDialog", "wl.height==="+wl.height);
//        wl.x = xNewPos;
//        wl.y = yNewPos;
//        w.setAttributes(wl);
    }
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		// TODO Auto-generated method stub
		super.onCreate(savedInstanceState);
		setContentView(R.layout.market_dialog);
		
		gridview=(GridView)findViewById(R.id.gridview_dialog);
		gridview.setColumnWidth(1);
		adapter=new SelectedDialogAdapter(context,texts,position);
		
		gridview.setAdapter(adapter);
		
		gridview.setOnItemClickListener(new OnItemClickListener() {
			
			@Override
			public void onItemClick(AdapterView<?> parent, View view,
					int position, long id) {
				// TODO Auto-generated method stub
				adapter.setSelectedItemPosition(position);
				adapter.notifyDataSetChanged();
				dismiss();
				onListItemClickListener.onItemClick(position);
			}
		});
	} 
	public void setOnListItemClickListener(
			OnListItemClickListener onListItemClickListener) {
		this.onListItemClickListener = onListItemClickListener;
	}
	class SelectedDialogAdapter extends BaseAdapter{
		private Context context;
		private String[] texts;
		private int selectedItemPosition;
		public int getSelectedItemPosition() {
			return selectedItemPosition;
		}

		public void setSelectedItemPosition(int selectedItemPosition) {
			this.selectedItemPosition = selectedItemPosition;
		}

		SelectedDialogAdapter(Context context,String[] texts,int selectedItemPosition){
			this.context=context;
			this.texts=texts;
			this.selectedItemPosition=selectedItemPosition;
		}

		@Override
		public int getCount() {
			// TODO Auto-generated method stub
			return texts.length;
		}

		@Override
		public Object getItem(int position) {
			// TODO Auto-generated method stub
			return texts[position];
		}

		@Override
		public long getItemId(int position) {
			// TODO Auto-generated method stub
			return position;
		}

		@Override
		public View getView(int position, View convertView, ViewGroup parent) {
			// TODO Auto-generated method stub
			if(convertView==null){
				LayoutInflater inflater = (LayoutInflater)context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
				convertView=inflater.inflate(R.layout.row_simple_list_item_1_for_dialog, null);
			}
			TextView tv=(TextView)convertView.findViewById(R.id.simple_item_0);
			tv.setText(texts[position]);
			if(selectedItemPosition==position){
				tv.setBackgroundResource(R.drawable.btn_bg_1);
			}else{
				tv.setBackgroundResource(R.drawable.btn_bg_2);
			}
			return convertView;
		}
	}
	/**
	 * 定义接口
	 * @author admin
	 *
	 */
	public interface OnListItemClickListener{
		void onItemClick(int position);
	}
}


使用到的market_dialog.xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="200dip"
    android:layout_height="fill_parent"
    android:background="@drawable/market_dialog_bg"
    >
    <TextView  android:id="@+id/tv_title" 
    android:layout_width="fill_parent"
    android:layout_height="wrap_content"
    android:text="选择市场"
    android:textColor="@color/white"
    android:textSize="@dimen/font_big"
    android:gravity="center"
    />
    <GridView android:id="@+id/gridview_dialog" 
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    android:numColumns="1"
    android:horizontalSpacing="10dip"
    android:verticalSpacing="10dip"
    android:listSelector="@null"
    android:background="@drawable/news_bg"
    android:cacheColorHint="@null"
    android:padding="10dip"
    android:layout_margin="10dip"
    />
</LinearLayout>

这里使用了GridView替代ListView,反正差不多。

GridView的圆角背景news_bg.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
       android:shape="rectangle"
       >
       <gradient  
       android:startColor="@color/news_bg"  
       android:endColor="@color/news_bg"  
       android:angle="270" 
       />
       <stroke android:width="1px" 
       android:color="@android:color/white" 
       /> 
       <!-- 
       <solid android:color="@android:color/news_bg"
       /> 
        -->
       <corners 
       android:bottomRightRadius="10px" 
       android:bottomLeftRadius="10px" 
       android:topLeftRadius="10px" 
       android:topRightRadius="10px" 
       />
</shape> 


使用到的图片market_dialog_bg.xml
<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android" 
       android:shape="rectangle"
       >
       <gradient  
       android:startColor="@color/blue_light_3"  
       android:endColor="@color/blue_light_3"  
       android:angle="270" 
       />
       <stroke android:width="1px" 
       android:color="@android:color/white" 
       /> 
       <!-- 
       <solid android:color="@android:color/news_bg"
       /> 
        -->
       <corners 
       android:bottomRightRadius="20px" 
       android:bottomLeftRadius="20px" 
       android:topLeftRadius="20px" 
       android:topRightRadius="20px" 
       />
</shape> 


GridView中使用的adapter文件:row_simple_list_item_1_for_dialog.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <TextView android:id="@+id/simple_item_0"
    android:layout_width="fill_parent" 
    android:layout_height="fill_parent" 
    android:gravity="center"
    android:layout_gravity="center"
    android:textColor="@color/black"
    android:textSize="@dimen/font_big"
    />
</LinearLayout>

用法:
MarketDialog dialog=new MarketDialog(context,R.style.Theme_NoTitleDialog,markets,mMarketIndex);
		        dialog.setOnListItemClickListener(new OnListItemClickListener() {
					
					@Override
					public void onItemClick(int position) {
						// TODO Auto-generated method stub
						if(mMarketIndex != position) {
							mMarketIndex = position;
							OnChangeMarketRequest(position);
						}
					}
				});
				dialog.show();

样式:
<?xml version="1.0" encoding="utf-8"?>
<resources>
	<style name="Theme_TransparentDialog">
      <item name="android:windowBackground">@android:color/transparent</item>
      <item name="android:windowFrame">@null</item>
      <item name="android:windowContentOverlay">@null</item>
      <item name="android:windowIsFloating">true</item>
      <item name="android:windowIsTranslucent">true</item>
      <item name="android:windowNoTitle">true</item>
      <item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
      <item name="android:backgroundDimEnabled">false</item>
	</style> 
	<style name="Theme_NoTitleDialog" parent="android:Theme.Dialog">
      <item name="android:windowNoTitle">true</item>
      <item name="android:windowBackground">@drawable/dialog_bg_1</item>
      <item name="android:windowContentOverlay">@null</item>
      <item name="android:backgroundDimEnabled">false</item>
      <item name="android:windowAnimationStyle">@android:style/Animation.Dialog</item>
	</style> 
</resources>



效果:



android ProgressDialog自定义方法
http://www.hlovey.cn/2009/10/26/android-progressdialog-method.html

选择对话框:自定义组合控件+自定义对话框 实现
http://blog.csdn.net/billpig/article/details/6664053

Android更改自定义Dialog的背景色
http://bigcat.easymorse.com/?p=1143

OPhone 2.0之百变对话框
http://www.ophonesdn.com/article/show/279
  • 大小: 89.7 KB
分享到:
评论

相关推荐

    各种自定义Dialog 以及Dialog加载动画

    2. **布局定制**:通过编写XML布局文件,可以自定义Dialog显示的内容,包括按钮、文本、图片等。将这个布局文件作为Dialog的内容视图,使用`setContentView()`方法将其设置进去。 3. **尺寸调整**:可以设置Dialog...

    android 自定义Dialog提示+动画效果

    在Android开发中,自定义Dialog是一种常见的需求,它允许开发者根据应用的UI风格和功能需求进行个性化设计。本文将深入探讨如何实现一个带有动画效果的自定义Dialog,并以"android 自定义Dialog提示+动画效果"为主题...

    qml 用item自定义dialog 对话框

    本文将深入探讨如何使用QML中的`Item`来创建一个自定义的`Dialog`组件。 首先,了解`Dialog`的基本概念。在Qt Quick中,`Dialog`是一个用于展示临时信息或进行用户交互的窗口,通常会有一个确定的关闭机制,如点击...

    自定义Dialog.zip

    "自定义Dialog.zip" 包含了一个实现七种动画效果的自定义Dialog示例,这将帮助开发者学习如何根据需求创建富有创意的弹出窗口。 首先,我们要了解Dialog的基本结构。Dialog通常由布局文件定义,包括标题(title)、...

    自定义dialog仿ios风格的dialog

    在Android开发中,自定义Dialog是一种常见的需求,它允许开发者创建具有独特设计和功能的对话框,以符合应用的品牌风格或提供更丰富的用户体验。本文将深入探讨如何在Android中实现一个仿iOS风格的Dialog,并根据...

    Android:自定义Dialog-Demo

    当系统默认的Dialog样式不能满足应用的特定需求时,开发者常常会选择自定义Dialog来实现更个性化的界面和交互体验。本示例"Android:自定义Dialog-Demo"就是针对这种情况提供的一种解决方案。 首先,我们来看自定义...

    自定义Dialog对话框(实现微信分享对话框)

    在Android开发中,自定义Dialog对话框是一种常见的需求,它能提供更为丰富的用户交互体验,尤其是在需要用户进行特定选择或操作时。本教程将详细讲解如何实现一个类似于微信分享的自定义Dialog对话框。 首先,我们...

    android自定义Dialog的简单实现

    在Android开发中,自定义Dialog是一种常见的需求,它允许开发者根据应用的设计风格或者特定功能来创建具有独特外观和行为的对话框。本篇文章将详细解析如何在Android中实现一个简单的自定义Dialog,以及相关的知识点...

    Android 自定义dialog

    在Android开发中,自定义Dialog是一种常见的需求,它允许开发者根据应用的UI风格和功能需求创建具有独特设计和交互方式的对话框。本篇将深入探讨如何在Android中实现自定义Dialog,包括基本原理、步骤以及相关的代码...

    小程序自定义dialog

    在微信小程序中,自定义dialog(对话框)是一种常见的用户交互设计,用于向用户展示重要信息或进行简单操作确认。自定义dialog可以帮助开发者摆脱微信小程序内置组件的限制,实现更符合应用风格和功能需求的设计。本...

    自定义dialog弹出框

    在Android开发中,自定义Dialog是一种常见的需求,它允许开发者根据应用的设计风格和功能需求创建具有独特外观和交互效果的对话框。本教程将深入探讨如何实现自定义Dialog,包括利用Shape和Selector来定制样式,以及...

    android 自定义dialog

    2. **自定义Dialog的基本步骤** - 创建一个新的布局文件:首先,你需要在`res/layout`目录下创建一个XML布局文件,用于定义Dialog的视图结构。 - 创建Dialog类:创建一个继承自`AppCompatDialog`的类,重写`...

    Android支付底部弹窗自定义dialog

    接下来,我们需要创建自定义Dialog类,继承自`AppCompatDialogFragment`。在这个类中,我们将加载上面创建的布局,并实现点击事件处理。 ```java public class BottomPaymentDialog extends ...

    自定义dialog

    "自定义Dialog"则是对系统默认Dialog样式进行扩展和改造,以满足更个性化的界面设计和功能需求。下面我们将深入探讨如何在Android中自定义Dialog。 一、自定义Dialog的基本步骤 1. 创建布局文件:首先,我们需要...

    Android自定义dialog

    2. 初始化自定义Dialog类:继承`android.app.Dialog`或`androidx.appcompat.app.AlertDialog.Builder`,在构造函数中传入上下文并调用`setContentView()`方法加载刚才创建的布局。 ```java public class ...

    自定义Dialog的最简Demo

    最近用到类似苹果悬浮按钮这种非全屏显示的界面,于是第一想到的是利用自定义Dialog来实现,写了一个自定义Dialog的最简单的Demo。比较简单,易于学习。另有我的博客介绍 ...

    自定义Dialog背景

    2. 创建自定义Dialog类,加载并设置自定义布局。 3. 修改Dialog的背景,可以通过设置背景颜色或者使用背景图片。 4. 在适当的时候显示自定义Dialog。 通过以上步骤,你就可以在Android应用中实现具有自己独特风格的...

    自定义Dialog简单解决多级菜单多选问题

    在Android开发中,自定义Dialog是一种常见的用户交互方式,它能提供更为丰富的界面展示和定制化功能。在处理多级菜单多选问题时,传统的做法可能会导致代码复杂度增加,逻辑难以维护。本文将深入探讨如何通过自定义...

Global site tag (gtag.js) - Google Analytics