android Activity实现从底部弹出或滑出选择菜单或窗口

http://104zz.iteye.com/blog/1685425

本例使用activity实现弹出滑动窗口或菜单,主要是使用了一些设置activity的样式来实现弹出窗口和滑动效果,实现如下:

第一步:设计要弹出窗口的xml布局:

Xml代码 复制代码  收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <RelativeLayout    
  3.     xmlns:android="http://schemas.android.com/apk/res/android"  
  4.     android:layout_width="fill_parent"  
  5.     android:layout_height="wrap_content"  
  6.     android:gravity="center_horizontal"  
  7.     android:orientation="vertical"  
  8.   >  
  9.   
  10. <LinearLayout    
  11.     android:id="@+id/pop_layout"  
  12.     android:layout_width="fill_parent"  
  13.     android:layout_height="wrap_content"  
  14.     android:gravity="center_horizontal"  
  15.     android:orientation="vertical"  
  16.     android:layout_alignParentBottom="true"  
  17.      android:background="@drawable/btn_style_alert_dialog_background"  
  18.      >  
  19.   
  20.        
  21.     <Button  
  22.         android:id="@+id/btn_take_photo"  
  23.         android:layout_marginLeft="20dip"  
  24.         android:layout_marginRight="20dip"  
  25.         android:layout_marginTop="20dip"  
  26.         android:layout_width="fill_parent"  
  27.         android:layout_height="wrap_content"  
  28.         android:text="拍照"  
  29.         android:background="@drawable/btn_style_alert_dialog_button"  
  30.         android:textStyle="bold"  
  31.          />  
  32.   
  33.     <Button  
  34.         android:id="@+id/btn_pick_photo"  
  35.         android:layout_marginLeft="20dip"  
  36.         android:layout_marginRight="20dip"  
  37.         android:layout_marginTop="5dip"    
  38.          android:layout_width="fill_parent"  
  39.         android:layout_height="wrap_content"  
  40.         android:text="从相册选择"  
  41.          android:background="@drawable/btn_style_alert_dialog_button"  
  42.          android:textStyle="bold"  
  43.          />  
  44.   
  45.     <Button  
  46.         android:id="@+id/btn_cancel"  
  47.        android:layout_marginLeft="20dip"  
  48.        android:layout_marginRight="20dip"  
  49.        android:layout_marginTop="15dip"    
  50.        android:layout_marginBottom="15dip"  
  51.        android:layout_width="fill_parent"  
  52.        android:layout_height="wrap_content"  
  53.        android:text="取消"  
  54.        android:background="@drawable/btn_style_alert_dialog_cancel"  
  55.        android:textColor="#ffffff"  
  56.        android:textStyle="bold"  
  57.           
  58.         />  
  59. </LinearLayout>  
  60. </RelativeLayout>  

 第二步:创建SelectPicPopupWindow类继承Activity类并实现OnClickListener接口(可以不用在这里实现这个借口,根据自己需要和方便实现),其他代码实现跟编写常规Activity一样就OK,如下:

Java代码 复制代码  收藏代码
  1. mport android.app.Activity;   
  2. import android.os.Bundle;   
  3. import android.view.MotionEvent;   
  4. import android.view.View;   
  5. import android.view.View.OnClickListener;   
  6. import android.widget.Button;   
  7. import android.widget.LinearLayout;   
  8. import android.widget.Toast;   
  9.   
  10. public class SelectPicPopupWindow extends Activity implements OnClickListener{   
  11.   
  12.     private Button btn_take_photo, btn_pick_photo, btn_cancel;   
  13.     private LinearLayout layout;   
  14.        
  15.     @Override  
  16.     protected void onCreate(Bundle savedInstanceState) {   
  17.         super.onCreate(savedInstanceState);   
  18.         setContentView(R.layout.alert_dialog);   
  19.         btn_take_photo = (Button) this.findViewById(R.id.btn_take_photo);   
  20.         btn_pick_photo = (Button) this.findViewById(R.id.btn_pick_photo);   
  21.         btn_cancel = (Button) this.findViewById(R.id.btn_cancel);   
  22.            
  23.         layout=(LinearLayout)findViewById(R.id.pop_layout);   
  24.            
  25.         //添加选择窗口范围监听可以优先获取触点,即不再执行onTouchEvent()函数,点击其他地方时执行onTouchEvent()函数销毁Activity   
  26.         layout.setOnClickListener(new OnClickListener() {   
  27.                
  28.             public void onClick(View v) {   
  29.                 // TODO Auto-generated method stub   
  30.                 Toast.makeText(getApplicationContext(), "提示:点击窗口外部关闭窗口!",    
  31.                         Toast.LENGTH_SHORT).show();    
  32.             }   
  33.         });   
  34.         //添加按钮监听   
  35.         btn_cancel.setOnClickListener(this);   
  36.         btn_pick_photo.setOnClickListener(this);   
  37.         btn_take_photo.setOnClickListener(this);   
  38.     }   
  39.        
  40.     //实现onTouchEvent触屏函数但点击屏幕时销毁本Activity   
  41.     @Override  
  42.     public boolean onTouchEvent(MotionEvent event){   
  43.         finish();   
  44.         return true;   
  45.     }   
  46.   
  47.     public void onClick(View v) {   
  48.         switch (v.getId()) {   
  49.         case R.id.btn_take_photo:   
  50.             break;   
  51.         case R.id.btn_pick_photo:                  
  52.             break;   
  53.         case R.id.btn_cancel:                  
  54.             break;   
  55.         default:   
  56.             break;   
  57.         }   
  58.         finish();   
  59.     }   
  60.        
  61. }  
mport android.app.Activity;
import android.os.Bundle;
import android.view.MotionEvent;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.Button;
import android.widget.LinearLayout;
import android.widget.Toast;

public class SelectPicPopupWindow extends Activity implements OnClickListener{

	private Button btn_take_photo, btn_pick_photo, btn_cancel;
	private LinearLayout layout;
	
	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.alert_dialog);
		btn_take_photo = (Button) this.findViewById(R.id.btn_take_photo);
		btn_pick_photo = (Button) this.findViewById(R.id.btn_pick_photo);
		btn_cancel = (Button) this.findViewById(R.id.btn_cancel);
		
		layout=(LinearLayout)findViewById(R.id.pop_layout);
		
		//添加选择窗口范围监听可以优先获取触点,即不再执行onTouchEvent()函数,点击其他地方时执行onTouchEvent()函数销毁Activity
		layout.setOnClickListener(new OnClickListener() {
			
			public void onClick(View v) {
				// TODO Auto-generated method stub
				Toast.makeText(getApplicationContext(), "提示:点击窗口外部关闭窗口!", 
						Toast.LENGTH_SHORT).show();	
			}
		});
		//添加按钮监听
		btn_cancel.setOnClickListener(this);
		btn_pick_photo.setOnClickListener(this);
		btn_take_photo.setOnClickListener(this);
	}
	
	//实现onTouchEvent触屏函数但点击屏幕时销毁本Activity
	@Override
	public boolean onTouchEvent(MotionEvent event){
		finish();
		return true;
	}

	public void onClick(View v) {
		switch (v.getId()) {
		case R.id.btn_take_photo:
			break;
		case R.id.btn_pick_photo:				
			break;
		case R.id.btn_cancel:				
			break;
		default:
			break;
		}
		finish();
	}
	
}

 

 第三步:编写MainActivity类,这里很简单就是点击启动刚才要实现窗口的MainActivity即可:

Java代码 复制代码  收藏代码
  1. import android.app.Activity;   
  2. import android.content.Intent;   
  3. import android.os.Bundle;   
  4. import android.view.View;   
  5. import android.view.View.OnClickListener;   
  6. import android.widget.TextView;   
  7.   
  8. public class MainActivity extends Activity {   
  9.        
  10.     @Override  
  11.     public void onCreate(Bundle savedInstanceState) {   
  12.         super.onCreate(savedInstanceState);   
  13.         setContentView(R.layout.activity_main);   
  14.         TextView tv = (TextView) this.findViewById(R.id.text);   
  15.         //把文字控件添加监听,点击弹出自定义窗口   
  16.         tv.setOnClickListener(new OnClickListener() {              
  17.             public void onClick(View v) {   
  18.                 startActivity(new Intent(MainActivity.this,SelectPicPopupWindow.class));   
  19.             }   
  20.         });   
  21.     }   
  22.        
  23. }  
import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;
import android.view.View;
import android.view.View.OnClickListener;
import android.widget.TextView;

public class MainActivity extends Activity {
	
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        TextView tv = (TextView) this.findViewById(R.id.text);
        //把文字控件添加监听,点击弹出自定义窗口
        tv.setOnClickListener(new OnClickListener() {			
			public void onClick(View v) {
				startActivity(new Intent(MainActivity.this,SelectPicPopupWindow.class));
			}
		});
    }
    
}
 

第四步:这里要注意下AndroidManifest.xml对SelectPicPopupWindow的配置跟常规的不一样为该activity改添加android:theme属性,如下:

Xml代码 复制代码  收藏代码
  1. <activity android:name=".SelectPicPopupWindow" android:theme="@style/MyDialogStyleBottom" />   

 第五步:这一步是实现本实例最重要的一部就是设置android:theme属性样式以实现本例所需要的效果,如下:

 

Xml代码 复制代码  收藏代码
  1. <style name="AnimBottom" parent="@android:style/Animation">  
  2.     <item name="android:windowEnterAnimation">@anim/push_bottom_in</item>  
  3.     <item name="android:windowExitAnimation">@anim/push_bottom_out</item>  
  4. </style>  
  5.   
  6. <style name="MyDialogStyleBottom" parent="android:Theme.Dialog">  
  7.     <item name="android:windowAnimationStyle">@style/AnimBottom</item>  
  8.     <item name="android:windowFrame">@null</item>  
  9. ;!-- 边框 -->  
  10.     <item name="android:windowIsFloating">true</item>  
  11. ;!-- 是否浮现在activity之上 -->  
  12.     <item name="android:windowIsTranslucent">true</item>  
  13. ;!-- 半透明 -->  
  14.     <item name="android:windowNoTitle">true</item>  
  15. ;!-- 无标题 -->  
  16.     <item name="android:windowBackground">@android:color/transparent</item>  
  17. ;!-- 背景透明 -->  
  18.     <item name="android:backgroundDimEnabled">true</item>  
  19. ;!-- 模糊 -->  
  20. </style>  

 第六步:在贴出弹出和销毁时的动画效果代码:

 

push_bottom_in.xml

Xml代码 复制代码  收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <!-- 上下滑入式 -->  
  3. <set xmlns:android="http://schemas.android.com/apk/res/android" >  
  4.   
  5.     <translate  
  6.         android:duration="200"  
  7.         android:fromYDelta="100%p"  
  8.         android:toYDelta="0"           
  9.      />         
  10. </set>  

 push_buttom_out.xml

Xml代码 复制代码  收藏代码
  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <!-- 上下滑出式 -->  
  3. <set xmlns:android="http://schemas.android.com/apk/res/android" >  
  4.   
  5.        
  6.     <translate  
  7.         android:duration="200"  
  8.         android:fromYDelta="0"  
  9.         android:toYDelta="50%p" />  
  10. </set>  

 注意:这两个xml需要放在res/anim的anim文件夹下

 

第七步;运行效果如图:


 

  • 1
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值