生肖计算器(生肖计算器在线计算)

鸿蒙上实现“十二生肖”计算器

作者:狼哥Army

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

效果如下:

创建端云一体化项目,这里就不介绍的,可以移步到官方详细教程:

/d/file/gt/2023-10/r0gmjl10yqn CloudProgram 模块, 下面介绍项目开发,先从云侧开发开始,再到端侧开发。

云侧开发

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

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

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

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

let myHandler = async function (event, context, callback, logger) { // 打印参数 logger("**event: "+JSON.stringify(event)) // 定义十二生肖 let zodiac = ["猴", "鸡", "狗", "猪", "鼠", "牛", "虎", "兔", "龙", "蛇", "马", "羊"]; // 转化参数为对象参数 event.body = JSON.parse(event.body); // 根据年份计算生肖下标 let idx = parseInt(event.body.year)%12; // 获取生肖 let sx = zodiac[idx]; // 生成HTTP响应对象 let res = new context.HTTPResponse({"zodiac": sx}, { "faas-content-type": "json" }, "application/json", "200"); // 回调 callback(res);};export { myHandler };

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

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

端侧开发

①先看一下端侧模块结构:

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

import agconnect from '@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';const TAG = "[AGCConfig]";export function getAGConnect(context) { try { agconnectstance()it(context); Log(TAG, "xx init AGC SDK success"); return agconnect; } catch (err) { Log.error(TAG, "xx initAgcSDK failed" + err); }}

services 目录下 Function.ts:

import agconnect from '@hw-agconnect/api-ohos';import "@hw-agconnect/function-ohos";import { Log } from '../common/Log';import { getAGConnect } from './AgcConfig';const TAG = "[AGCFunction]";export function zodiac(context, params: any): Promise<string> { console('xx Function Params: ' + JSON.stringify(params)) return new Promise((resolve, reject) => { // 获取AGC连接 getAGConnect(context); let functionResult; // 获取云函数回调 let functionCallable = agconnectction().wrap("zodiacfun-$latest"); // 传递参数调用云函数 functionCallable.call(params).then((ret: any) => { Log(TAG,'xx Zodiac Function Sucess') // 获取成功返回结果集 functionResult = ret.getValue(); Log(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@Componentstruct Index { // 存储选择年份 @State year: number = 2022 // 计算出来生肖 @State born: string = "?" // 是否在计算中 @State flag: boolean = false // 计算生肖 getBorn() { // 标识为计算中 this.flag = true; console('xx Page year: ' + this.year) // 封装参数 let params = { "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 && errssage); }); } 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()lor(Color.Blue) .backgroundColor(Color.Transparent) } } }}

总结

由于调用云侧云函数是异步的,不能马上返回结果,这里添加 LoadingProgress 组件,让用户知道在运行中,效果看得不是很明显。

可能录制时,网速很快,LoadingProgress 组件闪一下就不见了,如果遇到网络慢时,LoadingProgress 就会一直转,直到云函数返回响应时,再消失 LoadingProgress。

鸿蒙上实现“十二生肖”计算器

作者:狼哥Army

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

效果如下:

创建端云一体化项目,这里就不介绍的,可以移步到官方详细教程:

/d/file/gt/2023-10/r0gmjl10yqn CloudProgram 模块, 下面介绍项目开发,先从云侧开发开始,再到端侧开发。

云侧开发

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

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

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

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

let myHandler = async function (event, context, callback, logger) { // 打印参数 logger("**event: "+JSON.stringify(event)) // 定义十二生肖 let zodiac = ["猴", "鸡", "狗", "猪", "鼠", "牛", "虎", "兔", "龙", "蛇", "马", "羊"]; // 转化参数为对象参数 event.body = JSON.parse(event.body); // 根据年份计算生肖下标 let idx = parseInt(event.body.year)%12; // 获取生肖 let sx = zodiac[idx]; // 生成HTTP响应对象 let res = new context.HTTPResponse({"zodiac": sx}, { "faas-content-type": "json" }, "application/json", "200"); // 回调 callback(res);};export { myHandler };

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

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

端侧开发

①先看一下端侧模块结构:

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

import agconnect from '@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';const TAG = "[AGCConfig]";export function getAGConnect(context) { try { agconnectstance()it(context); Log(TAG, "xx init AGC SDK success"); return agconnect; } catch (err) { Log.error(TAG, "xx initAgcSDK failed" + err); }}

services 目录下 Function.ts:

import agconnect from '@hw-agconnect/api-ohos';import "@hw-agconnect/function-ohos";import { Log } from '../common/Log';import { getAGConnect } from './AgcConfig';const TAG = "[AGCFunction]";export function zodiac(context, params: any): Promise<string> { console('xx Function Params: ' + JSON.stringify(params)) return new Promise((resolve, reject) => { // 获取AGC连接 getAGConnect(context); let functionResult; // 获取云函数回调 let functionCallable = agconnectction().wrap("zodiacfun-$latest"); // 传递参数调用云函数 functionCallable.call(params).then((ret: any) => { Log(TAG,'xx Zodiac Function Sucess') // 获取成功返回结果集 functionResult = ret.getValue(); Log(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@Componentstruct Index { // 存储选择年份 @State year: number = 2022 // 计算出来生肖 @State born: string = "?" // 是否在计算中 @State flag: boolean = false // 计算生肖 getBorn() { // 标识为计算中 this.flag = true; console('xx Page year: ' + this.year) // 封装参数 let params = { "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 && errssage); }); } 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()lor(Color.Blue) .backgroundColor(Color.Transparent) } } }}

总结

由于调用云侧云函数是异步的,不能马上返回结果,这里添加 LoadingProgress 组件,让用户知道在运行中,效果看得不是很明显。

可能录制时,网速很快,LoadingProgress 组件闪一下就不见了,如果遇到网络慢时,LoadingProgress 就会一直转,直到云函数返回响应时,再消失 LoadingProgress。

根据出生年计算生肖属相

今天我们来说说怎么根据出生日期计算生肖属相。

如图,我们要根据出生日期计算相应的属相。

步骤如下

运用公式:“=CHOOSE(MOD(YEAR(B2),12)+1,\"猴\",\"鸡\",\"狗\",\"猪\",\"鼠\",\"牛\",\"虎\",\"兔\",\"龙\",\"蛇\",\"马\",\"羊\")”。即可计算出相应的生肖。

当我们的年份能被12整除时,当年的月份为猴年,余1-11时分别是鸡、狗、猪……,我们依次将生肖属相罗列出来。用年份除以12的余数加一就可以依次对应相应的数值,引用相应位置的生肖属相了。

  • 版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,请发送邮件举报,一经查实,本站将立刻删除。
  • 本文地址:https://www.csxsg.com/forum/20231028/1697197621348396.html
上一篇:梦到家里有老鼠(梦到家里有老鼠是什么意思)
下一篇:扫脸看面相(扫脸看面相app)

网友推荐