端云一体化开发-计算十二生肖-云函数

端云一体化开发-计算十二生肖-云函数

作者:狼哥Army 2023-03-14 21:19:29

云计算 这次直接使用端云一体化开发,方便了很多,不用手工集成云函数SDK, 而且在DevEco Studio 就可以完成端侧代码开发和云侧代码开发,一键部署云函数和云数据库。

​​想了解更多关于开源的内容,请访问:​​

​​51CTO 开源基础软件社区​​

​​https://ost.IDC.NET​​

一、前言

之前帖子介绍过用不同方式计算十二生肖,也用过Serverless云函数计算,但那时是用Java调用云函数,这次直接使用端云一体化开发,方便了很多,不用手工集成云函数SDK, 而且在DevEco Studio 就可以完成端侧代码开发和云侧代码开发,一键部署云函数和云数据库,下面先来看一下效果。

二、效果

三、讲解

创建端云一体化项目,这里就不介绍的,可以移步到官方详细教程 ​​创建端云一体化开发工程-端云一体化开发-应用/服务开发-DevEco Studio使用指南(HarmonyOS)-工具-HarmonyOS应用开发​​ 端云一体化项目结构和之前不一样,多了CloudProgram模块, 下面介绍项目开发,先从云侧开发开始,再到端侧开发。

四、云侧开发

1、展开CloudProgram模块,右击cloudfunctions目录,创建自定义云函数:

2、打开function-config.json文件,记录修改authType为apigw-client。

{
"handler": "zodiacFun.myHandler",
"triggers": [
{
"type": "http",
"properties": {
"enableUriDecode": true,
"authFlag": "true",
"authAlgor": "HDA-SYSTEM",
"authType": "apigw-client"
}
}
]
}

3、打开zodiacFun.ts文件,编写自定云函数逻辑,计算十二生肖方法就是写在这里,同时把结果返回端侧.

letmyHandler=asyncfunction (event, context, callback, logger) {
// 打印参数
logger.info("**event: "+JSON.stringify(event))
// 定义十二生肖
letzodiac= ["猴", "鸡", "狗", "猪", "鼠", "牛", "虎", "兔", "龙", "蛇", "马", "羊"];

// 转化参数为对象参数
event.body=JSON.parse(event.body);
// 根据年份计算生肖下标
letidx=parseInt(event.body.year)%12;
// 获取生肖
letsx=zodiac[idx];
// 生成HTTP响应对象
letres=newcontext.HTTPResponse({"zodiac": sx}, {
"faas-content-type": "json"
}, "application/json", "200");

// 回调
callback(res);

};

export { myHandler };

4、部署云侧代码到AGC上,右击自定义云函数目录,选择Deploy Function, 自动部署到Serverless上,如果提示没有登录,登录成功后,再操作一次部署。

5、到这里云侧开发就完成了,可以登录到AGC->云函数,找到刚才部署的云函数,测试一下自定义云函数。

五、端侧开发

1、先看一下端侧模块结构:

2、common目录放一些公共的封装类,比如Log类; components目录放自定义组件;entryability是自动生成的,里面有一个EntryAbility类,包含生命周期;pages目录放UI布局页面;services目录放业务逻辑类,比如调用云侧接口。 3、这里只介绍services目录和pages目录下的工作,先介绍如何和AGC连接上的,这里使用一个单独的文件来处理:

services目录下AgcConfig.ts

importagconnectfrom'@hw-agconnect/api-ohos';
import"@hw-agconnect/core-ohos";
import"@hw-agconnect/auth-ohos";
import'@hw-agconnect/auth-types-ohos';

import { Log } from'../common/Log';

constTAG="[AGCConfig]";

exportfunctiongetAGConnect(context) {
try {
agconnect.instance().init(context);
Log.info(TAG, "xx init AGC SDK success");
returnagconnect;
}
catch (err) {
Log.error(TAG, "xx initAgcSDK failed"+err);
}
}

services目录下Function.ts

importagconnectfrom'@hw-agconnect/api-ohos';
import"@hw-agconnect/function-ohos";
import { Log } from'../common/Log';
import { getAGConnect } from'./AgcConfig';
constTAG="[AGCFunction]";
exportfunctionzodiac(context, params: any): Promise<string> {
console.info('xx Function Params: '+JSON.stringify(params))
returnnewPromise((resolve, reject) => {
// 获取AGC连接
getAGConnect(context);
letfunctionResult;
// 获取云函数回调
letfunctionCallable=agconnect.function().wrap("zodiacfun-$latest");
// 传递参数调用云函数
functionCallable.call(params).then((ret: any) => {
Log.info(TAG,'xx Zodiac Function Sucess')
// 获取成功返回结果集
functionResult=ret.getValue();
Log.info(TAG, "xx Zodiac Function Called, Returned Value: "+JSON.stringify(ret.getValue()));
// 返回结果集给界面
resolve(functionResult.zodiac);
}).catch((error: any) => {
Log.error(TAG, "xx Error - could not obtain zodiac function result. " );
Log.error(TAG, "xx Error Detail: "+JSON.stringify(error));
reject(error);
});
});
}

pages目录 Index.ts 这里是页面布局,上面看到的效果,就是这里实现的。

import { zodiac } from'../services/Function';

@Entry
@Component
structIndex {
// 存储选择年份
@Stateyear: number=2022
// 计算出来生肖
@Stateborn: string="?"
// 是否在计算中
@Stateflag: boolean=false

// 计算生肖
getBorn() {
// 标识为计算中
this.flag=true;
console.info('xx Page year: '+this.year)
// 封装参数
letparams= {
"year": this.year
}
// 调用函数
zodiac(getContext(this), params).then((res) => {
// 计算完成
this.flag=false;
// 结果赋值给生肖变量
this.born=res;
}).catch((err) => {
// 计算完成
this.flag=false;
console.error('xx error: ', err&&err.message);
});
}

build() {
Stack() {
if (!this.flag) {
Column({space: 20}) {
Text('请选择年份')
.fontSize(20)
.fontWeight(FontWeight.Bold)

// 选择年份
Column() {
Text(this.year+'')
.fontSize(20)
.fontWeight(FontWeight.Bold)
.padding(10)
.width(100)
.border({ width: 1, radius: 8 })
}
.bindMenu([
{ value: '2006', action: () => {this.year=2006; this.born='?'} },
{ value: '2007', action: () => {this.year=2007; this.born='?'} },
{ value: '2008', action: () => {this.year=2008; this.born='?'} },
{ value: '2009', action: () => {this.year=2009; this.born='?'} },
{ value: '2010', action: () => {this.year=2010; this.born='?'} },
{ value: '2011', action: () => {this.year=2011; this.born='?'} },
{ value: '2012', action: () => {this.year=2012; this.born='?'} },
{ value: '2013', action: () => {this.year=2013; this.born='?'} },
{ value: '2014', action: () => {this.year=2014; this.born='?'} },
{ value: '2015', action: () => {this.year=2015; this.born='?'} },
{ value: '2016', action: () => {this.year=2016; this.born='?'} },
{ value: '2017', action: () => {this.year=2017; this.born='?'} },
{ value: '2018', action: () => {this.year=2018; this.born='?'} },
{ value: '2019', action: () => {this.year=2019; this.born='?'} },
{ value: '2020', action: () => {this.year=2020; this.born='?'} },
{ value: '2021', action: () => {this.year=2021; this.born='?'} },
{ value: '2022', action: () => {this.year=2022; this.born='?'} },
{ value: '2023', action: () => {this.year=2023; this.born='?'} },
{ value: '2024', action: () => {this.year=2024; this.born='?'} },
{ value: '2025', action: () => {this.year=2025; this.born='?'} }
])

// 计算按钮操作
Button('计算', {type: ButtonType.Normal, stateEffect: true})
.fontSize(18)
.borderRadius(8)
.width(100)
.margin({bottom: 20})
.onClick(() => {
// 根据年份计算生肖
this.getBorn()
})

// 显示计算结果
Text(`${this.year}年生肖是 ${this.born}`)
.fontSize(20)
.fontWeight(FontWeight.Bold)
}
.width('100%')
.height('100%')
.padding({top: '33%'})
} else {
// 计算中
LoadingProgress().color(Color.Blue)
.backgroundColor(Color.Transparent)
}
}
}
}

六、总结

由于调用云侧云函数是异步的,不能马上返回结果,这里添加LoadingProgress组件,让用户知道在运行中,效果看得不是很明显,可能录制时,网速很快,LoadingProgress组件闪一下就不见了,如果遇到网络慢时,LoadingProgress就会一直转,直到云函数返回响应时,再消失LoadingProgress。

​​想了解更多关于开源的内容,请访问:​​

​​51CTO 开源基础软件社区​​

​​https://ost.IDC.NET​​

文章来源网络,作者:运维,如若转载,请注明出处:https://shuyeidc.com/wp/233533.html<

(0)
运维的头像运维
上一篇2025-04-20 16:25
下一篇 2025-04-20 16:26

相关推荐

  • 个人主题怎么制作?

    制作个人主题是一个将个人风格、兴趣或专业领域转化为视觉化或结构化内容的过程,无论是用于个人博客、作品集、社交媒体账号还是品牌形象,核心都是围绕“个人特色”展开,以下从定位、内容规划、视觉设计、技术实现四个维度,详细拆解制作个人主题的完整流程,明确主题定位:找到个人特色的核心主题定位是所有工作的起点,需要先回答……

    2025-11-20
    0
  • 社群营销管理关键是什么?

    社群营销的核心在于通过建立有温度、有价值、有归属感的社群,实现用户留存、转化和品牌传播,其管理需贯穿“目标定位-内容运营-用户互动-数据驱动-风险控制”全流程,以下从五个维度展开详细说明:明确社群定位与目标社群管理的首要任务是精准定位,需明确社群的核心价值(如行业交流、产品使用指导、兴趣分享等)、目标用户画像……

    2025-11-20
    0
  • 香港公司网站备案需要什么材料?

    香港公司进行网站备案是一个涉及多部门协调、流程相对严谨的过程,尤其需兼顾中国内地与香港两地的监管要求,由于香港公司注册地与中国内地不同,其网站若主要服务内地用户或使用内地服务器,需根据服务器位置、网站内容性质等,选择对应的备案路径(如工信部ICP备案或公安备案),以下从备案主体资格、流程步骤、材料准备、注意事项……

    2025-11-20
    0
  • 如何企业上云推广

    企业上云已成为数字化转型的核心战略,但推广过程中需结合行业特性、企业痛点与市场需求,构建系统性、多维度的推广体系,以下从市场定位、策略设计、执行落地及效果优化四个维度,详细拆解企业上云推广的实践路径,精准定位:明确目标企业与核心价值企业上云并非“一刀切”的方案,需先锁定目标客户群体,提炼差异化价值主张,客户分层……

    2025-11-20
    0
  • PS设计搜索框的实用技巧有哪些?

    在PS中设计一个美观且功能性的搜索框需要结合创意构思、视觉设计和用户体验考量,以下从设计思路、制作步骤、细节优化及交互预览等方面详细说明,帮助打造符合需求的搜索框,设计前的规划明确使用场景:根据网站或APP的整体风格确定搜索框的调性,例如极简风适合细线条和纯色,科技感适合渐变和发光效果,电商类则可能需要突出搜索……

    2025-11-20
    0

发表回复

您的邮箱地址不会被公开。必填项已用 * 标注