前言
其实实现悬浮的自定义窗体有很多方法,自定义Dialog,自定义layout 均可以实现。自定义activity也是可以的,今天我就介绍一下activity的实现方法。下面来看看详细的介绍:
效果图
如图可以看出,当前的窗体,第一眼其实和dialog没有什么区别,但是它是自定义activity实现。如何实现的呢?
代码如下:
新建activity
@OverrIDe protected voID onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); this.requestwindowFeature(Window.FEATURE_NO_Title); this.getwindow().setFlags(WindowManager.LayoutParams.FLAG_FulLSCREEN,WindowManager.LayoutParams.FLAG_FulLSCREEN); setContentVIEw(R.layout.dialog_show_display_mode); WindowManager windowManager = getwindowManager(); display display = windowManager.getDefaultdisplay(); WindowManager.LayoutParams params = getwindow().getAttributes();// params.height = (int) (display.getHeight() * 0.3);// params.wIDth = (int) (display.getWIDth() * 0.8); params.Alpha = 1.0f; getwindow().setAttributes(params); getwindow().setGravity(Gravity.CENTER);}
layout样式布局:
<?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="@@R_404_6004@/white" androID:orIEntation="vertical"> <linearLayout androID:layout_wIDth="match_parent" androID:layout_height="45dp"> <TextVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:layout_marginleft="20dp" androID:text="语音球开启方式" androID:text@R_404_6004@="@@R_404_6004@/bg_black" androID:textSize="20dp" /> </linearLayout> <VIEw androID:layout_wIDth="match_parent" androID:layout_height="1dp" androID:background="@@R_404_6004@/forget_password" /> <linearLayout androID:layout_wIDth="match_parent" androID:layout_height="match_parent" androID:orIEntation="vertical"> <linearLayout androID:ID="@+ID/display_dialog_intelligence_linner" androID:layout_wIDth="match_parent" androID:layout_height="65dp" androID:orIEntation="horizontal"> <ImageVIEw androID:ID="@+ID/display_dialog_intelligence_iv" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:src="@mipmap/abc_btn_radio_to_on_mtrl_000" /> <TextVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:layout_marginleft="10dp" androID:text="智能显示" androID:text@R_404_6004@="@@R_404_6004@/@R_404_6004@Green2" /> </linearLayout> <VIEw androID:layout_wIDth="match_parent" androID:layout_height="1dp" androID:background="@@R_404_6004@/forget_password" /> <linearLayout androID:ID="@+ID/display_dialog_custom_linner" androID:layout_wIDth="match_parent" androID:layout_height="65dp" androID:orIEntation="horizontal"> <ImageVIEw androID:ID="@+ID/display_dialog_custom_iv" androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:src="@mipmap/abc_btn_radio_to_on_mtrl_000" /> <TextVIEw androID:layout_wIDth="wrap_content" androID:layout_height="wrap_content" androID:layout_gravity="center" androID:layout_marginleft="10dp" androID:text="自定义显示" androID:text@R_404_6004@="@@R_404_6004@/@R_404_6004@Green2" /> </linearLayout> </linearLayout></linearLayout>
style样式:
<style name="activitytheme" parent="@androID:style/theme.Translucent.NoTitlebar.Fullscreen"> <item name="androID:windowFrame">@null</item><!--边框--> <item name="androID:windowIsfloating">true</item><!--是否浮现在activity之上--> <item name="androID:windowIsTranslucent">false</item><!--半透明--> <item name="androID:windowNoTitle">true</item><!--无标题--> <item name="androID:background">@androID:@R_404_6004@/transparent</item> <item name="androID:windowBackground">@androID:@R_404_6004@/transparent</item><!--背景透明--> <item name="androID:backgroundDimEnabled">true</item><!--模糊--> </style>
资源文件配置activity:
<activity androID:name=".__activity.FloatwindowDialogActivity" androID:screenorIEntation="portrait" androID:theme="@style/activitytheme" />
ok 搞定。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对编程小技巧的支持。
总结以上是内存溢出为你收集整理的Android通过自定义Activity实现悬浮的Dialog详解全部内容,希望文章能够帮你解决Android通过自定义Activity实现悬浮的Dialog详解所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)