仿Iphone从屏幕底部弹出半透明的PopupWindow

简介: main.xml如下: styles.xml如下: @anim/in @anim/out popupwindow.

main.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="fill_parent"
    android:layout_height="fill_parent"
    >
    <Button 
        android:id="@+id/button"
        android:text="popupWindow"
        android:layout_width="fill_parent"
        android:layout_height="wrap_content"
    />
</RelativeLayout>


styles.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <style name="popupAnimation" parent="android:Animation">
		<item name="android:windowEnterAnimation">@anim/in</item>
		<item name="android:windowExitAnimation">@anim/out</item>
	</style>
</resources>


popupwindow.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:background="#b5555555" >

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_alignParentBottom="true"
        android:layout_marginBottom="12dip"
        android:paddingLeft="10dip"
        android:paddingRight="10dip"
        android:orientation="vertical" >
        <Button
            android:id="@+id/confirmButton"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:text="确定"/>

        <Button
            android:id="@+id/cancleButton"
            android:layout_marginTop="12dip"
            android:layout_width="fill_parent"
            android:layout_height="wrap_content"
            android:layout_gravity="center"
            android:text="取消" />
    </LinearLayout>

</RelativeLayout>


in.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:fromYDelta="5000"
        android:toYDelta="0"
        android:duration="1500"
    />
</set>


out.xml如下:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android">
    <translate
        android:fromYDelta="0"
        android:toYDelta="5000"
        android:duration="1500"
    />
</set>

 

PopupWindowTestActivity.java如下:

import android.app.Activity;
import android.graphics.drawable.BitmapDrawable;
import android.os.Bundle;
import android.view.Gravity;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup.LayoutParams;
import android.widget.Button;
import android.widget.PopupWindow;
/**
 * Demo描述:
 * 仿Iphone从屏幕底部弹出半透明的PopupWindow
 */
public class PopupWindowTestActivity extends Activity {
	private Button button;
    private Button confirmButton;
    private Button cancleButton;
    private PopupWindow popupWindow;
    private View popupWindowView;
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
        init();
    }
    private void init(){
    	  button=(Button) findViewById(R.id.button);
    	  button.setOnClickListener(new ButtonOnClickListener());
    }

	private class ButtonOnClickListener implements OnClickListener {
		@Override
		public void onClick(View v) {
			switch (v.getId()) {
			case R.id.button:
				LayoutInflater inflater = (LayoutInflater) getSystemService(LAYOUT_INFLATER_SERVICE);
				popupWindowView = inflater.inflate(R.layout.popupwindow, null);
				popupWindow = new PopupWindow(popupWindowView,LayoutParams.FILL_PARENT, LayoutParams.FILL_PARENT,true);
				popupWindow.setBackgroundDrawable(new BitmapDrawable());
				//设置PopupWindow的弹出和消失效果
				popupWindow.setAnimationStyle(R.style.popupAnimation);
				confirmButton = (Button) popupWindowView.findViewById(R.id.confirmButton);
				confirmButton.setOnClickListener(new ButtonOnClickListener());
				cancleButton = (Button) popupWindowView.findViewById(R.id.cancleButton);
				cancleButton.setOnClickListener(new ButtonOnClickListener());
				popupWindow.showAtLocation(confirmButton, Gravity.CENTER, 0, 0);
				break;
			case R.id.confirmButton:
				System.out.println("点击了确定按钮");
				break;
			case R.id.cancleButton:
				popupWindow.dismiss();
				break;
			default:
				break;
			}

		}}
}



 

相关文章
|
iOS开发
iPhone与iPad的屏幕支持方向
iPhone与iPad的屏幕支持方向
152 0
iPhone与iPad的屏幕支持方向
|
传感器 安全 小程序
小程序对IPhone全面屏手机底部黑线的安全区域处理
小程序对IPhone全面屏手机底部黑线的安全区域处理
334 0
小程序对IPhone全面屏手机底部黑线的安全区域处理
|
Web App开发 iOS开发
为 iPhone 和 iPad 自定义网站的主屏幕图标
iPhone 和 iPad 等苹果设备使用主屏幕 (Home Screen, 也称桌面) 管理应用程序, 还可以通过浏览器的添加到主屏幕功能将网站链接作为快捷方式添加为主屏幕图标. 是否你也想过为网站定义一个图标, 如果用户将网站添加至主屏幕, 网站链接看起来更像原生程序, 也能获得更多的关注.
1440 0
|
前端开发 JavaScript iOS开发
jqm选项卡开发,底部标签式设计,jqm模仿iPhone手机桌面菜单,jqm实战开发,jqm开发例子Demo
我有一个水货的上司,大家都是知道的。所以我就只能自学了,今天我给大家带来的是jQuery Mobile 模仿iphone 手机桌面的选项卡功能。比如电话,短信,浏览器,音乐的标签菜单。好吧,直接上代码:<pre code_snippet_id="378715" snippet_file_name="blog_20140605_1_1293162" name="code" class="ht
1470 0
|
编解码 iOS开发
iphone 开发的基本入门知识
iphone 开发的基本入门知识
165 0