close
当前位置: 物联网在线 > 技术文库 > android >

Android动态壁纸解析

建议 下载使用 Style动态壁纸 应用

文章后面会给出相应引用的链接

Android动态壁纸

动态壁纸是Android主屏幕中,可以动的、交互的背景。自Android 2.1开始支持。例如双击屏幕(Style中双击屏幕壁纸会变清晰)。相关的api在 android.service.wallpaper 包中。

动态壁纸应用实际上和其他应用是很相似的。下面我们一步一步来学习怎么创建一款动态壁纸应用。最终的实现效果如下:

Android动态壁纸解析

如何创建动态壁纸应用

要创建壁纸应用,首先你需要在 /res/xml 文件夹下面创建一个XML文件。这个文件包含了这个应用的描述、图标、以及应用指定的壁纸设置页面等。在壁纸设置页面会显示这些信息(右下角)。

Android动态壁纸解析

同时,你也需要创建一个 Service ,继承自 WallpaperService 类。 WallpaperService 这个类是系统所有动态壁纸等基类。你必须实现 onCreateEngine() 方法,返回一个 android.service.wallpaper.WallpaperService.Engine 对象。这个对象处理动态壁纸生命周期中的事件,壁纸的动画和绘制。 Engine 类定义了一些生命周期方法,例如: onCreate() , onSurfaceCreated() , onVisibilityChanged() , onOffsetsChanged() , onTouchEvent() 和 onCommand() 。

另外,这个 Service 需要 android.permission.BIND_WALLPAPER 权限,它必须被注册到一个 IntentFilter 中,并且这个 IntentFilter 的action是 android.service.wallpaper.WallpaperService 。

打开壁纸设定的Intent

public void onClick(View view) { Intent intent = new Intent( WallpaperManager.ACTION_CHANGE_LIVE_WALLPAPER); intent.putExtra(WallpaperManager.EXTRA_LIVE_WALLPAPER_COMPONENT, new ComponentName(this, MyWallpaperService.class)); startActivity(intent); }

上代码

以下代码可以在 这里 找到。

创建一个新的Project,可以选择不要Activity。但是为了让用户直接跳转到壁纸设置页面,我们创建了一个 MainActivity 。让用户能够对我们提供的壁纸进行设置,我们再创建一个 SettingActivity 。

在 /res/xml 文件夹下创建 wallpaper.xml ,当然名字可以自取。包含如下内容。注意 android:settingsActivity 的值,是刚才创建的 SettingActivity 的包名,可能你需要修改。

<?xml version="1.0" encoding="utf-8"?> <wallpaper xmlns:android="http://schemas.android.com/apk/res/android" android:description="@string/normal_wallpaper_des" android:settingsActivity="com.yalin.wallpaper.demo.SettingActivity" android:thumbnail="@drawable/ic_launcher_round" />

这个文件包含了壁纸的描述和图标,同时包含一个设置页面(设置页面是可选的)。

这个文件会在 AndroidManifest.xml 中用到。

创建一个 NormalWallpaperService 类,暂时不用实现里面的方法。

public class NormalWallpaperService extends WallpaperService { @Override public Engine onCreateEngine() { return null; } }

同时在 AndroidManifest.xml 中声明它。

<service android:name=".normal.NormalWallpaperService" android:enabled="true" android:label="@string/wallpaper" android:permission="android.permission.BIND_WALLPAPER"> <intent-filter android:priority="1"> <action android:name="android.service.wallpaper.WallpaperService" /> </intent-filter> <meta-data android:name="android.service.wallpaper" android:resource="@xml/normal_wallpaper" /> </service>

我们还必须在 AndroidManifest.xml 中增加下面的代码:

<uses-feature android:name="android.software.live_wallpaper" android:required="true" > </uses-feature>

到此我们的基本配置已经OK了。下来我们来一步步实现动态壁纸的绘制。

我们创建一个 MyPoint 类,用来存储我们绘制过的点。

public class MyPoint { String text; int x; int y; public MyPoint(String text, int x, int y) { this.text = text; this.x = x; this.y = y; } }

在 /res/xml 文件夹下创建 prefs.xml 。用于对动态壁纸的设置。

<?xml version="1.0" encoding="utf-8"?> <PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android"> <CheckBoxPreference android:key="touch" android:title="Enable Touch" /> <EditTextPreference android:key="numberOfCircles" android:title="Number of Circles" /> </PreferenceScreen>

在我们创建的 SettingActivity 中增加如下代码:

public class SettingActivity extends PreferenceActivity { @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); addPreferencesFromResource(R.xml.prefs01); // add a validator to the "numberofCircles" preference so that it only // accepts numbers Preference circlePreference = getPreferenceScreen().findPreference( "numberOfCircles"); // add the validator circlePreference.setOnPreferenceChangeListener(numberCheckListener); } /** * Checks that a preference is a valid numerical value */ Preference.OnPreferenceChangeListener numberCheckListener = new Preference.OnPreferenceChangeListener() { @Override public boolean onPreferenceChange(Preference preference, Object newValue) { // check that the string is an integer if (newValue != null && newValue.toString().length() > 0 && newValue.toString().matches("d*")) { return true; } // If now create a message to the user Toast.makeText(SettingActivity.this, "Invalid Input", Toast.LENGTH_SHORT).show(); return false; } }; }

当然不能忘了在 AndroidManifest.xml 中注册。

<activity android:name=".SettingActivity" android:exported="true" android:label="@string/app_name"> </activity>
(责任编辑:ioter)

用户喜欢...

Android Weekly #276 安卓开发周刊 中文版

您是否了解过Android的Lifecycle-Aware库?(android.jlelse.eu) 我们如何了解Lifecycle-Aware库代码? Nishant Srivastava展示了可以跟踪活动或Lifecycle-Aware的Lifecycle Arch组件的片段,并相应地调整其行为。 为Mos...


Android Weekly #275 安卓开发周刊 中文版

MapMe — Android地图适配器 (medium.com) Josh Burton介绍MapMe,是一个用Kotlin编写的Android库,可以将适配器模式带到地图上。 赞助 CloudRail - 连接到API 10x更快 (cloudrail.com) 当我们用单一的界面连接到所...


使用Android Studio开发可独立运行(runnable)混淆过的Jar程序

之前开发Java程序一直都是使用Eclipse 开发Jar程序,现在开发基本上都已经弃用Eclipse了,但是有时偶尔开发个小的Jar程序,还要切换回去好麻烦,刚好前几天有人问几个相关的问题,就顺便整...


Android Weekly #274 安卓开发周刊 中文版

探索Android Oreo上的别后执行限制(medium.com) 在这篇文章中,Joe Birch解释了关于Android Oreo在后台运行服务的变化。 non-Time领主的time – 第5部分 (blog.stylingandroid.com) Mark Allison继续分析JSR 310 date和...


Android Weekly #273 安卓开发周刊 中文版

开源你的Android代码(android.jlelse.eu) 通过您的开源Android代码,您将(希望地)为Android社区提供有价值的代码,收到建设性的反馈,并与您最初建立的内容进行协作从而使您的代码变得更好。这...


Android Weekly #272 安卓开发周刊 中文版

Android Dev 101:每个初学者都应该知道的一些做法() 看一些初学者或媒介等级开发人员(不要错过任何人)应该知道的一些做法,以便更好地摆脱Android框架。 99.9% crash free sessions (medium.com) Chr...


Android Weekly #271 安卓开发周刊 中文版

依赖注入检查(medium.com) 在本文中,MihályNagy引入了依赖注入检查,一种开源注释处理器,可帮助您解决一些出现在所有JSR 330 DI库中常见的问题。 使用Android Studio插件提高效率 (blog.mindorks.com...


Android Weekly #270 安卓开发周刊 中文版

带有RxJava2的SOLID Android分析 (medium.com) 在这篇文章中,Aris Papadopoulos将解释如何正确创建一个分析系统,同时遵循SOLID原则,并使用RxJava2来解决问题。 (blog.stylingandroid.com) Java中的编程时间很难...


Android内存泄漏思考

Android内存泄漏是一个经常要遇到的问题,程序在内存泄漏的时候很容易导致OOM的发生。那么如何查找内存泄漏和避免内存泄漏就是需要知晓的一个问题,首先我们需要知道一些基础知识。...


Android Weekly #269 安卓开发周刊 中文版

在Google上快速提出操作 () Wolfram Rittmeyer分享了开始在Google上快速创建操作所需的所有信息(为了家庭与助理)。 RxJava中的错误处理(rongi.github.io) 一旦开始编写RxJava代码,你就会意识到有些事...