您的位置:首页 > 移动开发 > Android开发

Android中实现底部弹出菜单栏

2016-12-09 14:14 453 查看
今天闲的没事写了一个底部弹出菜单栏,虽然很简单,但是为了以后方便用,索性还是写下来了,那好,我们先看一下实现效果吧,我想这种效果现在用的实在是太多了(点击按钮显示底部菜单栏,然后单击空白地方隐藏菜单栏(记住只需要单击空白地方就可以,很方便,用户体验也比较好))那好我们接下来就说一下他的具体流程、1:主界面的代码就不贴了,因为就是一个按钮,很简单,我们就写一下弹出的代码:(布局名字为bottom_dialog)
<?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="300dp"
android:background="#ffffff"
android:orientation="vertical"
android:paddingBottom="20dp"
[/b]android:paddingLeft="22.5dp"
android:paddingRight="22.5dp"
android:paddingTop="20dp">

<Button
android:id="@+id/btn_open_camera"
android:layout_width="match_parent"
android:layout_height="42dp"
android:background="@drawable/reg_bg"
android:gravity="center"
android:text="拍照"
android:textColor="#ffffff"
android:textSize="18sp" />

<Button
android:id="@+id/btn_choose_img"
android:layout_width="match_parent"
android:layout_height="42dp"
android:layout_marginTop="16dp"
android:background="@drawable/reg_bg"
android:gravity="center"
android:text="从相册中选取"
android:textColor="#ffffff"
android:textSize="18sp" />

<Button
android:id="@+id/btn_cancel"
android:layout_width="match_parent"
android:layout_height="42dp"
android:layout_marginTop="16dp"
android:background="@drawable/reg_bg"
android:gravity="center"
android:text="取消"
android:textColor="#ffffff"
android:textSize="18sp" />
</LinearLayout>
我们写的是弹出,弹出就涉及到动画 了,然后我们在res下自定义一个包 anim(一定是res下,不要在drawable下,不然会报错,新手注意了),下面贴代码这个@anim/dialog_in  是进入动画,<?xml version="1.0" encoding="utf-8"?><translate xmlns:android="http://schemas.android.com/apk/res/android"android:duration="200"android:fromYDelta="100%"android:toYDelta="0" />这个@anim/dialog_iout 是退出动画,<?xml version="1.0" encoding="utf-8"?><translate xmlns:android="http://schemas.android.com/apk/res/android"android:duration="200"android:fromYDelta="0"android:toYDelta="100%" />然后我们在style里面自定义样式:
<style name="BottomDialog" parent="@android:style/Theme.Dialog">

<!-- 背景透明 -->
<item name="android:windowBackground">@android:color/transparent</item>
<item name="android:windowContentOverlay">@null</item>
<!-- 浮于Activity之上 -->
<item name="android:windowIsFloating">true</item>
<!-- 边框 -->
<item name="android:windowFrame">@null</item>
<!-- Dialog以外的区域模糊效果 -->
<item name="android:backgroundDimEnabled">true</item>
<!-- 无标题 -->
<item name="android:windowNoTitle">true</item>
<!-- 半透明 -->
<item name="android:windowIsTranslucent">true</item>
<!-- Dialog进入及退出动画 -->
<item name="android:windowAnimationStyle">@style/DialogAnimation</item>
</style>
<!-- ActionSheet进出动画 -->
<style name="DialogAnimation" parent="@android:style/Animation.Dialog">
<item name="android:windowEnterAnimation">@anim/actionsheet_dialog_in</item>
<item name="android:windowExitAnimation">@anim/actionsheet_dialog_out</item>
</style>
接下来就是mainActivity里面的代码实现:
public class MainActivity extends AppCompatActivity implements View.OnClickListener {private Button btn_bottom_dialog;@Overrideprotected void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);btn_bottom_dialog= (Button) findViewById(R.id.btn_bottom_dialog);btn_bottom_dialog.setOnClickListener(this);}@Overridepublic void onClick(View view) {switchb88e(view.getId()) {case R.id.btn_bottom_dialog://弹出对话框setDialog();break;case R.id.btn_choose_img://选择照片按钮Toast.makeText(this, "请选择照片", Toast.LENGTH_SHORT).show();break;case R.id.btn_open_camera://拍照按钮Toast.makeText(this, "即将打开相机", Toast.LENGTH_SHORT).show();break;case R.id.btn_cancel://取消按钮Toast.makeText(this, "取消", Toast.LENGTH_SHORT).show();break;}}private void setDialog() {Dialog mCameraDialog = new Dialog(this, R.style.BottomDialog);LinearLayout root = (LinearLayout) LayoutInflater.from(this).inflate(R.layout.bottom_dialog, null);//初始化视图root.findViewById(R.id.btn_choose_img).setOnClickListener(this);root.findViewById(R.id.btn_open_camera).setOnClickListener(this);root.findViewById(R.id.btn_cancel).setOnClickListener(this);mCameraDialog.setContentView(root);Window dialogWindow = mCameraDialog.getWindow();dialogWindow.setGravity(Gravity.BOTTOM);//        dialogWindow.setWindowAnimations(R.style.dialogstyle); // 添加动画WindowManager.LayoutParams lp = dialogWindow.getAttributes(); // 获取对话框当前的参数值lp.x = 0; // 新位置X坐标lp.y = 0; // 新位置Y坐标lp.width = (int) getResources().getDisplayMetrics().widthPixels; // 宽度root.measure(0, 0);lp.height = root.getMeasuredHeight();lp.alpha = 9f; // 透明度dialogWindow.setAttributes(lp);mCameraDialog.show();}
只需要简单几步,就可以实现这个小功能,代码贴的比较全,直接复制粘贴就可以使用了呢 O(∩_∩)O
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: