編輯:關於Android編程
項目中經常需要底部彈出框,這裡我整理一下其中我用的比較順手的一個方式(底部彈出一個橫向滿屏的dialog)。
效果圖如下所示(只顯示關鍵部分):
步驟如下所示:
1.定義一個dialog的布局(lay_share.xml)
<?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="match_parent" android:background="@color/white" android:orientation="vertical"> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center_vertical" android:orientation="horizontal" android:paddingBottom="@dimen/padding_15" android:paddingTop="@dimen/padding_15"> <View android:layout_width="0dp" android:layout_height="0dp" android:layout_weight="1" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:drawablePadding="@dimen/padding_5" android:drawableTop="@mipmap/ic_weixin_share" android:gravity="center" android:text="微信" android:textColor="@color/color_999999" android:textSize="@dimen/text_14" /> <View android:layout_width="0dp" android:layout_height="0dp" android:layout_weight="1" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:drawablePadding="@dimen/padding_5" android:drawableTop="@mipmap/ic_circle_share" android:gravity="center" android:text="朋友圈" android:textColor="@color/color_999999" android:textSize="@dimen/text_14" /> <View android:layout_width="0dp" android:layout_height="0dp" android:layout_weight="1" /> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:drawablePadding="@dimen/padding_5" android:drawableTop="@mipmap/ic_weibo_share" android:gravity="center" android:text="微博" android:textColor="@color/color_999999" android:textSize="@dimen/text_14" /> <View android:layout_width="0dp" android:layout_height="0dp" android:layout_weight="1" /> </LinearLayout> <View android:layout_width="match_parent" android:layout_height="0.5dp" android:layout_marginLeft="@dimen/padding_10" android:layout_marginRight="@dimen/padding_10" android:background="@color/color_c9c9c9" /> <TextView android:id="@+id/tv_cancel" android:layout_width="match_parent" android:layout_height="wrap_content" android:gravity="center" android:padding="@dimen/padding_15" android:text="取消" android:textColor="@color/color_666666" android:textSize="@dimen/text_18" /> </LinearLayout>
2.定義彈出框彈出動畫(dialog_enter.xml)
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:duration="300" android:fromYDelta="100%p" android:toYDelta="0" /> </set> dialog_enter.xml
3.定義彈出框隱藏動畫(dialog_exit.xml)
<?xml version="1.0" encoding="utf-8"?> <set xmlns:android="http://schemas.android.com/apk/res/android"> <translate android:duration="300" android:fromYDelta="0" android:toYDelta="100%p" /> </set> dialog_exit.xml
4.定義動畫style
<!--彈出框動畫--> <style name="share_animation" parent="android:Animation"> <item name="android:windowEnterAnimation">@anim/dialog_enter</item> <item name="android:windowExitAnimation">@anim/dialog_exit</item> </style>
5.定義對話框樣式
<!-- 對話框樣式 --> <style name="dialog_bottom_full" parent="android:style/Theme.Dialog"> <item name="android:windowBackground">@android:color/transparent</item> <item name="android:windowNoTitle">true</item> <item name="android:windowIsFloating">true</item> <item name="android:windowContentOverlay">@null</item> <item name="android:scrollHorizontally">true</item> </style>
6.最後,在需要從底部彈出dialog的地方,直接調用showDialog()方法
/** * 顯示分享彈出框 */ private void showDialog() { if (mShareDialog == null) { initShareDialog(); } mShareDialog.show(); } /** * 初始化分享彈出框 */ private void initShareDialog() { mShareDialog = new Dialog(this, R.style.dialog_bottom_full); mShareDialog.setCanceledOnTouchOutside(true); mShareDialog.setCancelable(true); Window window = mShareDialog.getWindow(); window.setGravity(Gravity.BOTTOM); window.setWindowAnimations(R.style.share_animation); View view = View.inflate(this, R.layout.lay_share, null); view.findViewById(R.id.tv_cancel).setOnClickListener(new View.OnClickListener() { @Override public void onClick(View view) { if (mShareDialog != null && mShareDialog.isShowing()) { mShareDialog.dismiss(); } } }); window.setContentView(view); window.setLayout(WindowManager.LayoutParams.MATCH_PARENT, WindowManager.LayoutParams.WRAP_CONTENT);//設置橫向全屏 }
以上所述是小編給大家介紹的Android 從底部彈出Dialog(橫向滿屏)的實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對本站網站的支持!
Android有很多種drawable類型,除了前幾篇詳細講解的shape、selector、layer-list,還有上一篇提到的color、bitmap、
Android日常開發中,對於下拉與上拉刷新控件的使用非常之頻繁。一般都會采用第三方庫,但是下拉刷新做到簡單優雅並不是太多,甚至有的兼容性都存在問題。這個是不能接受的。最
概述Healthd是android4.4之後提出來的一種中介模型,該模型向下監聽來自底層的電池事件,向上傳遞電池數據信息給Framework層的BatteryServic
如果你有一定的Android的基礎和英語基礎, 有願意貢獻開源社區的心, 如果你對以下目錄感興趣, 歡迎加入我們協同翻譯《Embedded Android》 此次協同翻