将 Google 的 Gemini AI 集成到 Android 应用程序中

2024-05-29 06:04

本文主要是介绍将 Google 的 Gemini AI 集成到 Android 应用程序中,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Google 的 Gemini SDK 是一款功能强大的工具,可直接访问 Android 应用程序中的 Gemini AI 模型。此集成简化了应用程序开发,因为开发人员无需管理复杂的后端 AI 基础架构。让我们深入了解如何将 Gemini 的功能引入您的 Android 项目。

我们首先从https://aistudio.google.com/app/apikey获取 api 密钥。如果您被重定向到https://ai.google.dev/available_regions,则意味着该 api 在您所在的地区尚不可用(您可以使用 VPN 进行测试)。

然后我们导入依赖项

generativeai = { group = “com.google.ai.client.generativeai”, name = “generativeai”, version. ref = “ai” }

人工智能能够为文本或文本和图像输入创建文本输出。如果您计划仅传递文本输入,建议使用“gemini-pro”,否则使用“gemini-pro-vision”模型。

我们首先创建模型

val model = GenerativeModel( modelName = "gemini-pro" , apiKey = BuildConfig.apiKey // 或者您存储 api 密钥的任何位置
)

然后生成对你的提示的响应非常容易:

suspend  fun  parseInput (prompt: String ) : String? { return withContext(Dispatchers.IO) { val response = model.generateContent(prompt) return @withContext response.text } 
}

如果你还想传递图像,那么你应该使用以下方法初始化你的模型

val model = GenerativeModel( modelName = "gemini-pro-vision" , apiKey = BuildConfig.apiKey // 或者您存储 api 密钥的任何位置
)

然后你用以下方法从文本和图像生成输出

suspend  fun  parseInput (prompt: String , image: Bitmap ) : String? { return withContext(Dispatchers.IO) { val inputContent = content { image(image) text(prompt) } // 如果愿意,您可以传递多张图片val response = model.generateContent(inputContent) return @withContext response.text } 
}

如果我们检查上面的内容函数,我们会看到

public fun content(role: String? = "user",init: Content.Builder.() -> Unit
): Content

这也可以用于创建聊天类集成的角色。我们可以拥有一个“用户”角色和一个“模型”角色,存储之前的问题和答案,并利用对话上下文轻松地与我们的模型聊天。

private  val chatHistory = mutableListOf( content(role = "user" ) { text( "您好,我想问一个问题" ) }, content(role = "model" ) { text( "很高兴认识您。您想知道什么?" ) } 
) 
suspend  fun  converse (prompt: String ) : String? { return withContext(Dispatchers.IO) { val chat = generativeModel.startChat(history = chatHistory) return @withContext   chat.sendMessage(prompt).text?.also { chatHistory.add(content(role = "user" ) { text(prompt) }) chatHistory.add(content(role = "model" ) { text(it) }) } } 
}

如果你不想等待完整的响应,而是分块获取响应(类似于在线人工智能模型的做法),那么设置起来相当容易

suspend  fun  parseInput (prompt: String ) : Flow<String> { return withContext(Dispatchers.IO) { return @withContext generativeModel .generateContentStream(prompt) .mapNotNull { it.text } } 
}

这将创建部分响应流,然后您可以收集它并显示在您的 UI 层中。

这是关于如何在您的应用中集成 Gemini 的快速指南,只需几个步骤,您就可以添加尖端的 AI 功能来增强用户体验。

这篇关于将 Google 的 Gemini AI 集成到 Android 应用程序中的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1012845

相关文章

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

AI绘图怎么变现?想做点副业的小白必看!

在科技飞速发展的今天,AI绘图作为一种新兴技术,不仅改变了艺术创作的方式,也为创作者提供了多种变现途径。本文将详细探讨几种常见的AI绘图变现方式,帮助创作者更好地利用这一技术实现经济收益。 更多实操教程和AI绘画工具,可以扫描下方,免费获取 定制服务:个性化的创意商机 个性化定制 AI绘图技术能够根据用户需求生成个性化的头像、壁纸、插画等作品。例如,姓氏头像在电商平台上非常受欢迎,

从去中心化到智能化:Web3如何与AI共同塑造数字生态

在数字时代的演进中,Web3和人工智能(AI)正成为塑造未来互联网的两大核心力量。Web3的去中心化理念与AI的智能化技术,正相互交织,共同推动数字生态的变革。本文将探讨Web3与AI的融合如何改变数字世界,并展望这一新兴组合如何重塑我们的在线体验。 Web3的去中心化愿景 Web3代表了互联网的第三代发展,它基于去中心化的区块链技术,旨在创建一个开放、透明且用户主导的数字生态。不同于传统

AI一键生成 PPT

AI一键生成 PPT 操作步骤 作为一名打工人,是不是经常需要制作各种PPT来分享我的生活和想法。但是,你们知道,有时候灵感来了,时间却不够用了!😩直到我发现了Kimi AI——一个能够自动生成PPT的神奇助手!🌟 什么是Kimi? 一款月之暗面科技有限公司开发的AI办公工具,帮助用户快速生成高质量的演示文稿。 无论你是职场人士、学生还是教师,Kimi都能够为你的办公文

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

Android平台播放RTSP流的几种方案探究(VLC VS ExoPlayer VS SmartPlayer)

技术背景 好多开发者需要遴选Android平台RTSP直播播放器的时候,不知道如何选的好,本文针对常用的方案,做个大概的说明: 1. 使用VLC for Android VLC Media Player(VLC多媒体播放器),最初命名为VideoLAN客户端,是VideoLAN品牌产品,是VideoLAN计划的多媒体播放器。它支持众多音频与视频解码器及文件格式,并支持DVD影音光盘,VCD影

AI hospital 论文Idea

一、Benchmarking Large Language Models on Communicative Medical Coaching: A Dataset and a Novel System论文地址含代码 大多数现有模型和工具主要迎合以患者为中心的服务。这项工作深入探讨了LLMs在提高医疗专业人员的沟通能力。目标是构建一个模拟实践环境,人类医生(即医学学习者)可以在其中与患者代理进行医学

AI行业应用(不定期更新)

ChatPDF 可以让你上传一个 PDF 文件,然后针对这个 PDF 进行小结和提问。你可以把各种各样你要研究的分析报告交给它,快速获取到想要知道的信息。https://www.chatpdf.com/

【北交大信息所AI-Max2】使用方法

BJTU信息所集群AI_MAX2使用方法 使用的前提是预约到相应的算力卡,拥有登录权限的账号密码,一般为导师组共用一个。 有浏览器、ssh工具就可以。 1.新建集群Terminal 浏览器登陆10.126.62.75 (如果是1集群把75改成66) 交互式开发 执行器选Terminal 密码随便设一个(需记住) 工作空间:私有数据、全部文件 加速器选GeForce_RTX_2080_Ti