Android如何实现模糊的半透明窗口Android工程师

/ 华南女子学院经济学院Android工程师 / 2017-05-14

android工程师,android初学者,专业资讯,经验分享

这实例是使用自定义主题样式,实现模糊半透明的Activity,分成以下几个步骤:

1.  定义清单文件(AndroidManifest.xml)

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
      package="my.android.test"
      android:versionCode="1"
      android:versionName="1.0">
      <!-- 使用android:theme属性给Activity设置主题样式 -->
    <application android:icon="@drawable/icon" android:label="@string/app_name">
        <activity android:name=".TranslucentBlur"
                  android:label="@string/app_name"
                  android:theme="@style/Theme.Transparent">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>
    <uses-sdk android:minSdkVersion="9" />
</manifest>

2.  定义字符串资源(values/strings.xml)

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <string name="hello">Hello World, TranslucentBlur!</string>
    <string name="app_name">TranslucentBlur</string>
    <string name="translucent_background">Example of how you can make an
            activity have a translucent background, compositing over
            whatever is behind it.</string>
</resources>

3.  定义用于描画的颜色资源(values/colors.xml)

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <drawable name="transparent_background">#00000000</drawable>
</resources>

4.  定义模糊半透明主题样式(values/styles.xml)

<?xml version="1.0" encoding="utf-8"?>
<resources>
    <!-- 应用默认的主题样式 -->
    <style name="Theme" parent="android:Theme">
    </style>
    <!-- 修改应用程序的主题样式,让Activity有一个透明效果的背景
                        本例中没有使用Android内置的半透明主题,而是使用完全自定义半透明的主题样式。
    -->
    <style name="Theme.Transparent" >
        <!-- 设置允许窗口半透明 -->
        <item name="android:windowIsTranslucent">true</item>
        <!-- 引用Android系统的动画半透明样式 -->
        <item name="android:windowAnimationStyle">@android:style/Animation.Translucent</item>
        <!-- 设定窗口背景颜色 -->
        <item name="android:windowBackground">@drawable/transparent_background</item>
        <!-- 隐藏窗口标题栏 -->
        <item name="android:windowNoTitle">true</item>
        <!-- 设定文字前景色 -->
        <item name="android:colorForeground">#fff</item>
    </style>
</resources>

5.  定义布局(translucent_blackground.xml)

<?xml version="1.0" encoding="utf-8"?>
<!-- 用于显示示例文字 -->
<TextView xmlns:android="http://schemas.android.com/apk/res/android" android:id="@+id/text"
    android:layout_width="match_parent" android:layout_height="match_parent"
    android:gravity="center_vertical|center_horizontal"
    android:text="@string/translucent_background"/>

6.  定义Activity类(TranslucentBlur.java)

package my.android.test;
 
import android.app.Activity;
import android.os.Bundle;
import android.view.WindowManager;
 
publicclass TranslucentBlur extends Activity {
    /** Activity被首次创建时,调用这个回调方法*/
    @Override
    publicvoid onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        /**
         * getWindow()方法获取当前Activity的Window对象,通过这个对象可以直接访问Window类的
         * API接口,本例中调用setFlags()方法设置布局参数FLAG_BLUR_BEHIND,让窗口中的每个组件都变的模糊
         */
        getWindow().setFlags(WindowManager.LayoutParams.FLAG_BLUR_BEHIND, WindowManager.LayoutParams.FLAG_BLUR_BEHIND);
        //填充Activity布局
        setContentView(R.layout.translucent_background);
    }
}

    运用多了自然而然就会很简单


公众号,微信

汇鱼网海峡创乐汇
汇鱼网海峡创乐汇