当前位置: 移动技术网 > IT编程>移动开发>Android > activity控制对话框风格、显示大小与位置

activity控制对话框风格、显示大小与位置

2019年07月24日  | 移动技术网IT编程  | 我要评论

锦绣龙城业主论坛,dmm1,守夜人5.95攻略

项目开发的需要,因为到现在项目接近完工,用户提出对条件筛选方式进行修改,为做到最小的改动实现用户的需求,各种百度,对于对话框风格大家普遍使用popupwindow,但由于之前开发设计时使用的是activity对话框方式,所以今天就为大家介绍一下,如何通过activity实现与popupwindow相同的效果,废话不多讲现在开始干货。

实现对话框风格的activity,我们需要在androidmanifest.xml添加一句样式声明:

<activity
  android:name=".product.myselfpayproduct"
  android:screenorientation="portrait"
  android:theme="@android:style/theme.dialog" >

不过这样的对话框风格往往无法满足我们的需要,显示的效果不那么令人满意,第一点就是如何控制对话框的大小

//窗口对齐屏幕宽度
window win = this.getwindow();
win.getdecorview().setpadding(0, 0, 0, 0);
windowmanager.layoutparams lp = win.getattributes();
lp.width = windowmanager.layoutparams.match_parent;
lp.height = windowmanager.layoutparams.wrap_content;
lp.gravity = gravity.top;//设置对话框置顶显示
win.setattributes(lp);

将这个控制语句添加在我们的对话框activity的onclick()方法中,这样我们的对话框就可以宽度与屏幕一样宽了,lp.gravity = gravity.top;//设置对话框置顶显示,android默认对话框居中显示,我们可以通过这句代码设置对话框的显示位置。

到这里是不是已经达到你的满意了呢?下面在给大家介绍一下,如何通过activity实现微信右上角点击加号的显示效果。做这个显示效果,我们需要通过在布局文件中通过android:layout_margintop="50dp"这样来调整对话框的位置,android默认弹出框效果非常难看,为了达到更好的显示效果,我们这里添加一个显示的动画效果:

进入动画:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
  <scale
    android:fromxscale="1.0"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
    android:toxscale="1.0" 
    android:fromyscale="0.0"
    android:toyscale="1.0"
    android:duration="200"
    android:pivotx="0"
    android:pivoty="10%"
    />
</set>

退出动画:

<?xml version="1.0" encoding="utf-8"?>
<set xmlns:android="http://schemas.android.com/apk/res/android" >
  <scale
    android:fromxscale="1.0"
android:interpolator="@android:anim/accelerate_decelerate_interpolator"
    android:toxscale="1.0" 
    android:fromyscale="1.0"
    android:toyscale="0.0"
    android:duration="200"
    android:pivotx="0"
    android:pivoty="10%"
    />
</set>

android动画文件一般置于res的anim文件夹下,默认该文件夹不存在,需要我们手动添加。

下面我们需要把我们的动画添加的android的样式文件:style.xml

<resources>
  <!--
    base application theme, dependent on api level. this theme is replaced
    by appbasetheme from res/values-vxx/styles.xml on newer devices.
  -->
  <style name="appbasetheme" parent="android:theme.light">
    <!--
      theme customizations available in newer api levels can go in
      res/values-vxx/styles.xml, while customizations related to
      backward-compatibility can go here.
    -->
  </style>
  <!-- application theme. -->
  <style name="apptheme" parent="appbasetheme">
    <!-- all customizations that are not specific to a particular api-level can go here. -->
  </style>
  <!-- 没有标题 -->
  <style name="notitle" parent="appbasetheme">
     <item name="android:windownotitle">true</item>
  </style>
  <!-- 类似对话框效果 -->
  <style name="mydialogtopright"> 
    <item name="android:windowbackground">@android:color/transparent</item> 
    <item name="android:windowistranslucent">true</item> 
    <item name="android:windownotitle">true</item> 
    <item name="android:windowanimationstyle">@style/anim_scale</item> 
  </style> 
   <style name="anim_scale" parent="@android:style/animation.activity">
    <item name="android:activityopenenteranimation">@anim/scale_in</item>
    <item name="android:activityopenexitanimation">@anim/scale_out</item>
    <item name="android:activitycloseenteranimation">@anim/scale_in</item>
    <item name="android:activitycloseexitanimation">@anim/scale_out</item>
  </style>
</resources>

最后我们需要修改一下我们在androidmanifest.xml文件中的声明:

android:theme="@style/mydialogtopright"

到这里我们就完美实现了activity的对话框风格显示。

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持移动技术网!

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网