Gandalf - 守护你的应用更新守护者
在任何应用的生命周期中,都有必要停止对某个功能的支持,结束产品的生命周期,或者通知用户进行维护。Gandalf 正是为了这个目的而生!
Gandalf 轻松地添加了一个远程文件检查功能,能够通过简单的警告通知用户,告知他们可选的更新信息,甚至在极端情况下,阻止用户访问旧版本的应用(例如,发现安全漏洞)。
下载与集成
Gandalf 在 JCenter 摁仓库上托管,并可以通过 Gradle 进行下载:
compile 'com.btkelly:gandalf:{latest_version}'
使用方法
Gandalf 的目标是快速为你的应用添加基本的模板代码。你需要在自定义的 Application 类中以及在公共服务器上托管一个 JSON 文件。
自定义 Application 类
在 onCreate() 方法中扩展 Application 类并调用以下代码:
public class CustomApplication extends Application {
@Override
public void onCreate() {
super.onCreate();
new Gandalf.Installer()
.setContext(this)
.setPackageName("com.my.package")
.setBootstrapUrl("http://www.example.com/bootstrap.json")
.install();
}
}
启动界面
扩展 GandalfActivity 作为你的主启动活动。魔法就在这里发生。只需提供一个布局资源ID以在检查期间显示,并实现 youShallPass() 方法,该方法在成功检查后执行:
public class SplashActivity extends GandalfActivity {
@Override
public void youShallPass() {
// 成功检查后,更改内容视图,也可以加载新活动或执行其他逻辑。
setContentView(R.layout.activity_splash_finished_loading);
}
@Override
public int contentView() {
// 加载布局时显示
return R.layout.activity_splash_loading;
}
}
修改 Manifest
在 application 标签上添加 android:name 属性,指定上面的自定义 Application 类路径,并将 SplashActivity 设置为应用的入口点:
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="io.github.btkelly.gandalf.example">
<application
android:name=".CustomApplication"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:theme="@style/AppTheme">
<activity
android:name=".SplashActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN" />
<category android:name="android.intent.category.LAUNCHER" />
</intent-filter>
</activity>
</application>
</manifest>
JSON 文件
您需要在远程位置托管一个 JSON 文件,然后在 Gandalf 的安装器中设置该文件的 URL。JSON 文件使用的是 Android 的 versionCode,而不是 versionName 来获取版本信息。默认格式如下,如果您需要自定义 JSON,请参考 自定义 JSON 反序列化器。
{
"android": {
"alert": {
"message": "我们正在进行服务器维护,请稍后再试。",
"blocking": true
},
...
}
}
特性与优势
- 简单集成:只需要几步就可以轻松地让您的应用程序支持远程通知和强制更新。
- 灵活性:提供自定义的标题、按钮文本和消息,允许您根据品牌和用户体验来定制对话框。
- 多场景应对:支持警报提示、可选更新提醒和必需更新要求等多种情况。
- 可扩展性:可以使用自定义监听器处理用户选择更新的情况,适应不同应用商店或其他下载源的下载流程。
- 自定义反序列化器:如果您的 JSON 格式不同,可以提供自己的
JsonDeserializer来解析。
应用场景
无论是小型创业公司的首款产品,还是大型企业级应用,Gandalf 都能为你提供强大的应用更新管理能力。尤其对于那些需要确保用户始终运行最新最安全版本的应用来说,Gandalf 是一个理想的解决方案。
现在就开始使用 Gandalf,让你的应用变得更加智能和可控!
AutoGLM-Phone-9BAutoGLM-Phone-9B是基于AutoGLM构建的移动智能助手框架,依托多模态感知理解手机屏幕并执行自动化操作。Jinja00
Kimi-K2-ThinkingKimi K2 Thinking 是最新、性能最强的开源思维模型。从 Kimi K2 开始,我们将其打造为能够逐步推理并动态调用工具的思维智能体。通过显著提升多步推理深度,并在 200–300 次连续调用中保持稳定的工具使用能力,它在 Humanity's Last Exam (HLE)、BrowseComp 等基准测试中树立了新的技术标杆。同时,K2 Thinking 是原生 INT4 量化模型,具备 256k 上下文窗口,实现了推理延迟和 GPU 内存占用的无损降低。Python00
GLM-4.6V-FP8GLM-4.6V-FP8是GLM-V系列开源模型,支持128K上下文窗口,融合原生多模态函数调用能力,实现从视觉感知到执行的闭环。具备文档理解、图文生成、前端重构等功能,适用于云集群与本地部署,在同类参数规模中视觉理解性能领先。Jinja00
HunyuanOCRHunyuanOCR 是基于混元原生多模态架构打造的领先端到端 OCR 专家级视觉语言模型。它采用仅 10 亿参数的轻量化设计,在业界多项基准测试中取得了当前最佳性能。该模型不仅精通复杂多语言文档解析,还在文本检测与识别、开放域信息抽取、视频字幕提取及图片翻译等实际应用场景中表现卓越。00
GLM-ASR-Nano-2512GLM-ASR-Nano-2512 是一款稳健的开源语音识别模型,参数规模为 15 亿。该模型专为应对真实场景的复杂性而设计,在保持紧凑体量的同时,多项基准测试表现优于 OpenAI Whisper V3。Python00
GLM-TTSGLM-TTS 是一款基于大语言模型的高质量文本转语音(TTS)合成系统,支持零样本语音克隆和流式推理。该系统采用两阶段架构,结合了用于语音 token 生成的大语言模型(LLM)和用于波形合成的流匹配(Flow Matching)模型。 通过引入多奖励强化学习框架,GLM-TTS 显著提升了合成语音的表现力,相比传统 TTS 系统实现了更自然的情感控制。Python00
Spark-Formalizer-X1-7BSpark-Formalizer 是由科大讯飞团队开发的专用大型语言模型,专注于数学自动形式化任务。该模型擅长将自然语言数学问题转化为精确的 Lean4 形式化语句,在形式化语句生成方面达到了业界领先水平。Python00