实现从屏幕底部向上弹出新窗口的思路
来源:互联网 发布:生日派对知乎 编辑:程序博客网 时间:2024/05/16 07:20
设计要弹出窗口的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="wrap_content" android:gravity="center_horizontal" android:orientation="vertical" > <LinearLayout android:id="@+id/pop_layout" android:layout_width="fill_parent" android:layout_height="wrap_content" android:gravity="center_horizontal" android:orientation="vertical" android:layout_alignParentBottom="true" android:background="@drawable/btn_style_alert_dialog_background" > <Button android:id="@+id/btn_take_photo" android:layout_marginLeft="20dip" android:layout_marginRight="20dip" android:layout_marginTop="20dip" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="拍照" android:background="@drawable/btn_style_alert_dialog_button" android:textStyle="bold" /> <Button android:id="@+id/btn_pick_photo" android:layout_marginLeft="20dip" android:layout_marginRight="20dip" android:layout_marginTop="5dip" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="从相册选择" android:background="@drawable/btn_style_alert_dialog_button" android:textStyle="bold" /> <Button android:id="@+id/btn_cancel" android:layout_marginLeft="20dip" android:layout_marginRight="20dip" android:layout_marginTop="15dip" android:layout_marginBottom="15dip" android:layout_width="fill_parent" android:layout_height="wrap_content" android:text="取消" android:background="@drawable/btn_style_alert_dialog_cancel" android:textColor="#ffffff" android:textStyle="bold" /> </LinearLayout> </RelativeLayout>
第二步:;
创建SelectPicPopupWindow类继承Activity类并实现OnClickListener接口(可以不用在这里实现这个借口,根据自己需要和方便实现),其他代码实现跟编写常规Activity一样就OK,如下:
import 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里没有复杂的逻辑,只是为一段文字设置了点击事件,点击后会弹出在第二步中的PopupWindow:
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里配置SelectPicPoopuWindow。这里要注意下AndroidManifest.xml对SelectPicPopupWindow的配置跟常规的不一样,需要为这个activity添加一个自定义的主题样式android:theme属性,如下:
<activity android:name=".SelectPicPopupWindow" android:theme="@style/MyDialogStyleBottom" />
第五步:
配置在第四步中的AndroidManifest.xml里所出现的自定义主题样式。这一步是实现本实例最重要的一步,就是设置android:theme属性样式以实现本例所需要的效果,如下:
<style name="AnimBottom" parent="@android:style/Animation"> <item name="android:windowEnterAnimation">@anim/push_bottom_in</item> <item name="android:windowExitAnimation">@anim/push_bottom_out</item> </style> <style name="MyDialogStyleBottom" parent="android:Theme.Dialog"> <item name="android:windowAnimationStyle">@style/AnimBottom</item> <item name="android:windowFrame">@null</item> <!-- 边框 --> <item name="android:windowIsFloating">true</item> <!-- 是否浮现在activity之上 --> <item name="android:windowIsTranslucent">true</item> <!-- 半透明 --> <item name="android:windowNoTitle">true</item> <!-- 无标题 --> <item name="android:windowBackground">@android:color/transparent</item> <!-- 背景透明 --> <item name="android:backgroundDimEnabled">true</item> <!-- 模糊 --> </style>
第六步:
配置窗口弹出和销毁时的动画效果代码,需要注意的是,动画效果的配置文件需要放在res/anim的anim文件夹下
窗口弹出的动画效果配置文件,文件名为:push_bottom_in.xml
<?xml version="1.0" encoding="utf-8"?> <!-- 上下滑入式 --> <set xmlns:android="http://schemas.android.com/apk/res/android" > <translate android:duration="200" android:fromYDelta="100%p" android:toYDelta="0" /> </set>
窗口销毁的动画效果配置文件,文件名为:push_buttom_out.xml
<?xml version="1.0" encoding="utf-8"?> <!-- 上下滑出式 --> <set xmlns:android="http://schemas.android.com/apk/res/android" > <translate android:duration="200" android:fromYDelta="0" android:toYDelta="50%p" /> </set>
最后,
安卓4.0的手机测试时滑出的的窗口可能与整个屏幕两侧会有间隙
如果要让此界面的宽度撑满整个屏幕,可以在setContentView(R.layout.activity_main); 之后加上
getWindow().setLayout(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
- 实现从屏幕底部向上弹出新窗口的思路
- 实现一个从底部向上弹出的菜单栏
- Activity从底部向上半透明弹出效果实现
- 从屏幕底部弹出PopupWindow
- 从屏幕底部弹出PopupWindow
- 实现从底部弹出的PopupWindow
- PopupWindow实现屏幕底部弹出
- 仿Iphone从屏幕底部弹出半透明的PopupWindow
- 从底部弹出充满屏幕宽度的diaolog
- Android从屏幕底部弹出popupWindow
- Android开发 — 实现手指从屏幕底部向上滑动的方式来显示Dialog(可为实现自由拖动Dialog提供参考)
- Edittext弹出键盘移动屏幕底部Button的实现
- Android 实现屏幕底部弹出Dialog
- 从底部弹出的PopupWindow
- Android实现从底部弹出的Dialog(一)
- Android实现从底部弹出的Dialog(二)
- 自定义的界面底部向上弹出的PopupWindow
- 分享从下向上弹出的popwindow
- 查找算法总结
- 商人小鑫
- 多线程的优缺点
- linux程序内存空间基本布局
- 裁完员还不够 外媒称乐视把美国总部大楼也卖了
- 实现从屏幕底部向上弹出新窗口的思路
- ElasticSearch速学
- JSP页面导包
- WAMPServer自定义网站根目录
- C/C++连接MySql数据库
- java 文章
- okHttp3.0下载文件
- 解决 java 中引用的jar包乱码问题
- Spring Boot(4)—— Spring Boot中Redis的使用