精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

分享元服務「心情盲盒」開發經歷

開發
因為這個元服務的業務功能定義為盲盒,所以查看者和發布者都是匿名的。盲盒信息是每日自動更新的,因為每個人每天都會有新的心情,所以服務端只保存了當天的心情數據,昨天和之前的會被服務器自動刪除,到了明天今天的心情數據也會消失。

想了解更多關于開源的內容,請訪問:

51CTO 鴻蒙開發者社區

https://ost.51cto.com

前言

這次的端云一體化活動同樣是開發鴻蒙應用或者元服務,上次的端云一體化活動,我也參加了,當時簡單入手,在原有模板的基礎上開發了一個元服務,那個完全不算一個正常的項目,充其量只能稱呼為一個測試DEMO。通過那個DEMO,我熟悉了端云一體化開發的步驟,工具的用法,服務卡片的開發和交互也都熟悉了。但當時受限于個人的技術水平,沒能開發一個像樣的元服務提交發布,但當時有了一個簡單的構思,暢想了一下自己會做一個什么樣的元服務,當時構思的項目是“快遞盲盒”,這個快遞裝載著陌生朋友的心情,所以叫它盲盒。礙于當時個人對端云一體化的云端還不夠熟悉,手邊也沒有支持API9的真機可以調試,所以當時研究了幾天,感覺無望,毅然放棄了。時隔了小半年的時間,通過不斷的學習官網的文檔和別人的帖子,發現在自己項目中集成serverless云服務真是并不復雜,一旦搞懂,就所向披靡了,感覺開發的道路豁然開朗,有任何想法都可以去試試手了。這次,為了圓夢,我就把上次那個想法開發出來了,做成了一個元服務,并成功上架了。這個元服務就是“心情盲盒”,使用的人不多,可能使用價值和受歡迎程度都還不夠,不要緊,這次的經歷,堅定了我克服困難勇往直前的信念,也大大提高了自己遇到問題時分析問題和解決問題的能力。

簡介

“心情盲盒”這款元服務,主要包含兩個模塊,服務卡片和應用主頁面。

服務卡片查看隨機抽取的陌生人的心情寄語,用戶點擊卡片盒子邊緣空白處,可以改變盒子的顏色,點擊盒子會觸發盒子旋轉,同時獲取別人的心情,心情分為喜怒哀樂四種,分別以不同的表情圖像顯示,圖像下會顯示對方的手機號末尾4位數字,卡片中間顯示心情詳情,下方是功能操作按鈕,可以繼續獲取,或者發布一個心情。

應用主頁面中,用戶可以輸入自己的心里話,并選擇此刻的心情,然后發布。

因為這個元服務的業務功能定義為盲盒,所以查看者和發布者都是匿名的。盲盒信息是每日自動更新的,因為每個人每天都會有新的心情,所以服務端只保存了當天的心情數據,昨天和之前的會被服務器自動刪除,到了明天今天的心情數據也會消失。

本篇文檔簡單介紹一下心情盲盒的功能和實現過程。

預覽

功能介紹

盒子顏色可以隨機改變,點擊服務卡片中盒子外的部分,盒子顏色和背景底色都會跟隨改變。

點擊盒子,觸發盒子旋轉動畫,同時跳轉到新的界面。

獲取到心情數據后,會直接顯示心情信息。

上方的人臉表情是代表喜怒哀樂心情的,看上面這樣子好像是有些不高興,下方的小數字代表發布者手機號尾部4位,說明這句心里話是尾號6236的朋友發布的。中間的黑色文字就是對方說的話。點擊“再換個人”,會重新返回盲盒界面,同時顏色隨機改變,再點擊盲盒,又會繼續獲取新的心情信息。不論你登錄與否,都可以查看別人的心情,但要想發表自己的心情,就需要通過手機號進行注冊一下了。

有時,也可能你是當天第一個查看盲盒的人,沒有新數據就會顯示如下界面,此時,你可以發表一個心情,作為首發哦。或者刷新一下,看看是不是因為網絡不太好的原因沒獲取到數據。

點擊發表之后,會出現如下的發表界面。

在我想說中,輸入自己想說的心里話,在心情一欄,選擇自己此刻的比較接近的心情,然后點擊“發布盲盒”就可以了。

發布成功后,會提示發布成功,用戶可以選擇“再發一個”繼續發表心情,或者“以后再說”關閉發表界面。

如果用戶首次使用,沒有登錄,會提示如下界面,讓用戶進行登錄。

勾選底部的“閱讀并同意”的方框,就可以進行登錄操作了。

其他玩法

基于鴻蒙系統對卡片支持的多功能性,我們可以添加多個心情盲盒服務卡片,構成一個卡片墻,或者把多個心情盲盒堆疊在一起。

盲盒墻效果:

盲盒堆疊效果:

代碼實現

服務卡片通過message類型的action通知EntryFormAbility獲取新數據。

async getMood() {
  postCardAction(this, {
    'action': 'message',
    'params': {
    }
  });
}

EntryFormAbility在onFormEvent中處理message類型消息,并讀取云數據庫。

async onFormEvent(formId, message) {
    // Called when a specified message event defined by the form provider is triggered.
    initialize(this.context, json);

    try {
      const context =  this.context
      const value = await context.resourceManager.getRawFileContent('schema.json');
      let json: string = buffer.from(value).toString("utf8");
      let objectTypeInfo: ObjectTypeInfo = JSON.parse(json);

	...

      let agcDataBase = cloud.database({ objectTypeInfo: objectTypeInfo, zoneName: "MessageDB" })
      const resultArray = await (agcDataBase as Database)
        .collection(Message)
        .query()
        .equalTo('insertDate', curDate)
        .orderByDesc("id")
        .limit(100, 0)
        .get();
	
	...

    } catch (err) {

    }
  }

然后將結果反饋給服務卡片。

// updateform
      let formData = {
        'user': msg.getUser(),
        'content': msg.getContent(),
        'mood': moodIdx,
      };

      let formInfo = formBindingData.createFormBindingData(formData)
      formProvider.updateForm(formId, formInfo).then((data) => {
        console.info('FormAbility updateForm success.' + JSON.stringify(data));
      }).catch((error) => {
        console.error('FormAbility updateForm failed: ' + JSON.stringify(error));
      })

用戶發布心情數據,直接更新云數據庫。

const value = await context.resourceManager.getRawFileContent('schema.json');
let json: string = buffer.from(value).toString("utf8");
let schema: ObjectTypeInfo = JSON.parse(json);

const record = await cloud.database({ objectTypeInfo: schema, zoneName: "MessageDB" })
  .collection(Message)
  .upsert({
    "user": phone,
    "content": content,
    "mood": mood,
    "insertDate": curDate
  });

用戶登錄的實現。

Login({
  modes: [AuthMode.PHONE_VERIFY_CODE],
  onSuccess: async (user: AuthUser) => {
    // this.shownPartIndex = 2;
    this.isShowButton = false
    AppStorage.Set<AuthUser>('user', user);
    this.currentUser = AppStorage.Get<AuthUser>('user');
    if (this.currentUser != null && this.currentUser != undefined) {

      let agcUserExtra = await this.currentUser.getUserExtra();
      this.creatTime = agcUserExtra.getCreateTime()
      this.lastLogin = agcUserExtra.getLastSignInTime()

      router.replaceUrl({
        url: 'pages/Home'
      })
    }
  }
}) {
  if (this.isShowButton && this.isAccept) {
    Button({ type: ButtonType.Normal }) {
      Text($r('app.string.auth_service_login_button_text'))
        .fontColor($r('app.color.white'))
    }
  }
}

用戶登出的實現。

async logout() {
  cloud.auth().signOut().then(() => {
    this.isShowButton = true
    this.currentUser = null
  }).catch((error: Object) => {
  });
}

用戶注銷的實現。

deleteUser() {
  cloud.auth().deleteUser().then(() => {
    this.isShowButton = true
    this.currentUser = null
  }).catch((err: Object) => {
  })
}

總結

通過這次實踐,熟悉了端云一體化新模板的功能,也熟悉了云數據庫、云函數和用戶認證的用法,為以后開發其他項目打了一個基礎。

想了解更多關于開源的內容,請訪問:

51CTO 鴻蒙開發者社區

https://ost.51cto.com

責任編輯:jianghua 來源: 51CTO 鴻蒙開發者社區
相關推薦

2013-03-20 09:54:43

某單位軟件

2023-08-04 17:24:43

2021-03-23 18:07:54

戴爾

2012-10-29 10:00:31

2021-05-28 14:38:13

數字化轉型數字化CIO

2015-07-30 09:31:26

阿里巴巴前端面試

2010-02-26 14:12:27

WCF元數據

2022-02-12 23:35:29

索尼AI元宇宙

2023-09-13 15:27:14

鴻蒙應用元服務

2021-01-28 08:48:43

微信朋友圈騰訊

2010-03-02 10:50:57

WCF元數據交換

2025-01-02 07:10:00

2016-04-11 17:34:35

首席架構師經歷

2009-04-15 08:17:36

AndroidGoogle移動OS

2013-07-11 13:30:32

智能機頂盒

2013-10-10 14:15:22

微信開發
點贊
收藏

51CTO技術棧公眾號

高清不卡一二三区| 国产一区二区三区亚洲| 日韩码欧中文字| 成人免费视频网站| 在线精品免费视| 围产精品久久久久久久| 亚洲国产欧美一区二区三区同亚洲| 欧美aⅴ在线观看| 黄色网址免费在线观看| fc2成人免费人成在线观看播放 | 三级在线看中文字幕完整版| 国产精品久久国产精麻豆99网站| 国产精品视频入口| 一级α片免费看刺激高潮视频| 亚洲美女91| 久久综合电影一区| 五月婷六月丁香| 欧美变态挠脚心| 日韩一区二区三区四区| 亚洲黄色a v| 色偷偷色偷偷色偷偷在线视频| 亚洲美女精品一区| 中文字幕人成一区| 国产永久免费高清在线观看视频| 9色porny自拍视频一区二区| 97av自拍| 国产美女裸体无遮挡免费视频| 日韩精品乱码av一区二区| 国内精品视频在线| 可以直接看的黄色网址| 欧美大片aaaa| 中文字幕日韩综合av| free性中国hd国语露脸| 里番精品3d一二三区| 日韩精品在线一区| aaaaaaaa毛片| 麻豆国产一区| 欧美一级日韩免费不卡| 91高清国产视频| 日本久久一区| 7878成人国产在线观看| 婷婷丁香激情网| 成人精品国产| 欧美日韩三级一区| 亚洲视频第二页| jizz亚洲女人高潮大叫| 欧美性生活大片视频| 亚洲精品高清无码视频| 另类中文字幕国产精品| 欧美伊人久久久久久久久影院| 日韩欧美在线免费观看视频| 日韩在线观看不卡| 欧美日韩高清在线播放| 日日干日日操日日射| 欧美aaaaaa| 在线不卡a资源高清| 成人黄色一级大片| 亚洲性视频在线| 亚洲成在人线av| 免费观看一级一片| 日韩欧美三级| 久久亚洲精品小早川怜子66| 印度午夜性春猛xxx交| 亚洲一级二级| 91福利视频在线观看| www.欧美色| 免费不卡在线观看| 亚洲综合色av| 五月天婷婷在线播放| 久久久不卡影院| 一区二区三区三区在线| 青草视频在线免费直播| 欧美日韩激情美女| 美女一区二区三区视频| 日本一区二区乱| 亚洲精品成人av| 免费黄在线观看| 亚洲精品va| 69久久夜色精品国产69乱青草| 台湾佬中文在线| 激情丁香综合五月| 国产一区二区三区四区五区加勒比 | 激情高潮到大叫狂喷水| 欧美女激情福利| 欧美最近摘花xxxx摘花| 97超碰中文字幕| 成人av电影免费在线播放| 水蜜桃亚洲精品| 欧美xxxx免费虐| 欧美日韩综合在线| 岛国精品一区二区三区| 国产一区二区三区探花| 九九久久国产精品| 中文有码在线播放| 成人爱爱电影网址| 青青草原国产免费| 黑人巨大亚洲一区二区久 | 一级毛片视频在线| 亚洲午夜久久久久久久久电影院| caopor在线视频| 久久精品福利| 久久综合五月天| 日韩精品在线免费视频| 国产传媒久久文化传媒| 亚洲第一综合| 亚洲男人av| 精品久久人人做人人爽| 强制高潮抽搐sm调教高h| 羞羞视频在线观看欧美| aa成人免费视频| 丝袜美腿美女被狂躁在线观看| 欧美性猛交xxxx久久久| 深夜视频在线观看| 久久久久免费av| 国产精品国产自产拍高清av水多| 天天av天天翘| 亚洲综合无码一区二区| 日韩精品aaa| 青草国产精品| 日韩av观看网址| 天天躁日日躁狠狠躁伊人| 亚洲人妖av一区二区| 欧美伦理片在线观看| 蜜桃一区二区三区| 91福利视频在线观看| 蜜桃91麻豆精品一二三区| 中文字幕一区二区三区乱码在线| caoporn超碰97| 制服丝袜日韩| 日韩美女中文字幕| 蝌蚪视频在线播放| 色婷婷一区二区| 国精产品一区一区三区免费视频| 99国产精品久久久久久久| 国产66精品久久久久999小说| 久久久久久久久免费视频| 欧美日韩国产免费| 青青草华人在线视频| 秋霞午夜av一区二区三区| 色阁综合av| 免费成人毛片| 久久中国妇女中文字幕| 99久久精品国产色欲| 亚洲日本在线观看| 日韩精品在线播放视频| 国产精品s色| 丁香婷婷久久久综合精品国产| 午夜av在线播放| 亚洲电影免费观看高清完整版在线| 久久久久亚洲av成人片| 成人av免费在线观看| 69堂免费视频| 教室别恋欧美无删减版| 国产精品视频网| 日本激情在线观看| 91精品国产91久久久久久一区二区| 天天综合天天做| 成人午夜激情片| 北条麻妃69av| 精品国产美女| 91美女片黄在线观| 欧美aaa免费| 亚洲女同精品视频| 一区二区小视频| 一区二区视频免费在线观看| 欧美xxxxx少妇| 久久久夜精品| 在线观看日韩羞羞视频| 日韩欧美一级| 欧美伊久线香蕉线新在线| aaa日本高清在线播放免费观看| 欧美精品自拍偷拍动漫精品| 麻豆一区二区三区精品视频| wwwwxxxxx欧美| 欧美激情第3页| 欧美黄色一级视频| 欧美另类网站| 国产一区二区三区免费在线| 国产91精品久久久久久| 欧美日韩在线看片| 亚洲精品在线电影| 国产天堂第一区| 亚洲精品免费在线观看| 一区二区精品免费| 国产精品一区二区久久精品爱涩| 免费看的黄色大片| 99久久精品网| 欧美视频1区| 亚洲一区二区电影| 国产精品久久久久久久天堂| 欧美78videosex性欧美| 伊人成人开心激情综合网| 成人激情四射网| 欧美亚洲免费在线一区| 日本少妇激情舌吻| 1区2区3区欧美| 天天躁日日躁aaaa视频| 成人永久免费视频| 精品综合久久久久| 男女精品视频| 黄色一级片在线看| 在线精品小视频| 日韩欧美在线电影| 欧美电影完整版在线观看| 91精品免费久久久久久久久| 欧美日韩123区| 久久久久久久国产精品视频| 成人video亚洲精品| 亚洲午夜av久久乱码| 欧美一区二区三区黄片| 91精品国产综合久久福利| 波多野结衣高清在线| 亚洲国产视频一区| 老熟妇高潮一区二区三区| 国产欧美视频一区二区| 欧美性xxxx图片| 国产成人免费在线视频| 四虎1515hh.com| 精品一区二区三区免费毛片爱 | 亚洲色图国产精品| 午夜成人免费影院| 精品福利一二区| 国产黄色片av| 91精品国产综合久久精品性色| 中文字幕在线2019| 在线亚洲精品福利网址导航| www亚洲视频| 性欧美疯狂xxxxbbbb| 久久久久久激情| 一区二区三区在线观看国产| 91视频综合网| 亚洲啪啪综合av一区二区三区| 香蕉成人在线视频| 中文字幕免费不卡| 九九热免费在线| 中文字幕的久久| www.黄色在线| 日本一区二区高清| 黄色激情小视频| 国产精品毛片久久久久久久| 五月激情四射婷婷| 国产精品久99| 欧美手机在线观看| 亚洲女同一区二区| 99精品久久久久| 亚洲午夜在线视频| 成年人午夜视频| 色婷婷久久久亚洲一区二区三区| 黄色av网站免费观看| 欧美视频一区在线观看| 一炮成瘾1v1高h| 欧美一区二区福利视频| 黄色av免费观看| 精品视频在线播放免| 国产九色在线| 久久精品男人天堂| 超碰在线97国产| 欧美一级高清免费| 91国内外精品自在线播放| 成人精品视频久久久久| 中文字幕一区二区三区四区久久| 国产一区二区三区奇米久涩| 国语产色综合| 神马午夜伦理影院| 亚洲精品字幕| 在线观看av日韩| 国产麻豆日韩欧美久久| 国产高潮视频在线观看| 国产午夜精品久久久久久免费视| 一级片久久久久| 亚洲欧美日韩国产一区二区三区| 久久精品国产亚洲AV无码麻豆| 色综合天天综合狠狠| 一女二男一黄一片| 亚洲国产天堂久久国产91| av在线播放网| 色综合老司机第九色激情| 韩国成人漫画| 99porn视频在线| 视频一区中文| 成人在线视频一区二区三区| 久久精品电影| 日本55丰满熟妇厨房伦| 久久免费视频一区| 欧美日韩在线视频免费播放| 欧美日韩中文字幕日韩欧美| 国产婷婷一区二区三区久久| 亚洲国产精品成人va在线观看| 日本激情视频在线观看| 2018日韩中文字幕| 亚洲青青一区| 免费成人av网站| 一区二区三区在线电影| 一本久道中文无码字幕av| 国产精品伊人色| 在线观看免费小视频| 亚洲444eee在线观看| 91麻豆成人精品国产免费网站| 日韩av在线免播放器| 成人黄色网址| 国产精品久久一区主播| 国产精品久av福利在线观看| 国产成人精品免费看在线播放| 先锋影音久久| 韩国黄色一级片| 亚洲免费在线观看视频| 久久精品偷拍视频| 日韩电视剧在线观看免费网站| 91亚洲天堂| 国产欧美精品日韩| 国内精品伊人久久久| 伊人成色综合网| 国产99久久久国产精品潘金网站| 国精产品久拍自产在线网站| 欧美色播在线播放| 全部免费毛片在线播放一个| 欧美猛交免费看| 成人综合日日夜夜| 一区二区三区在线视频看| 日韩福利电影在线观看| 爱爱免费小视频| 岛国av午夜精品| 欧美一级特黄aaaaaa大片在线观看| 插插插亚洲综合网| 自拍偷拍欧美日韩| 一区二区三区四区久久| 美女在线一区二区| 日本一二三不卡视频| 在线国产亚洲欧美| 国产乱理伦片a级在线观看| 日本亚洲欧美成人| 国产精品美女久久久久久不卡| 欧美精品99久久| 久久色在线观看| 久久夜色精品国产噜噜亚洲av| 日韩精品福利在线| 中国字幕a在线看韩国电影| 国产精品嫩草在线观看| 激情欧美一区| 亚洲图片综合网| 精品久久久精品| 久色视频在线| 国产精品丝袜久久久久久不卡| 日韩一区欧美| 91视频福利网| 亚洲国产精品欧美一二99| 国产小视频免费观看| 97久久精品人人澡人人爽缅北| 国内精品国产成人国产三级粉色 | 成人午夜电影小说| 日本一级片免费看| 亚洲欧美一区二区三区四区| 日本少妇一区| 在线观看视频黄色| 国产91对白在线观看九色| 国产成人一区二区三区影院在线| 亚洲精品久久久一区二区三区 | 日韩欧美国产麻豆| 福利在线导航136| 精品综合久久| 日本欧美久久久久免费播放网| 午夜成人亚洲理伦片在线观看| 欧美一二三区在线| 国产三线在线| 日本高清一区| 国产酒店精品激情| 日韩免费一级片| 国产亚洲精品综合一区91| 9999在线精品视频| 日本a在线免费观看| 久久精品视频一区| 国产三级在线观看视频| 韩国三级电影久久久久久| 神马影视一区二区| 亚洲午夜精品在线观看| 欧美色xxxx| 超碰公开在线| 免费看成人片| 极品尤物av久久免费看| 日韩欧美中文字幕一区二区| 国产亚洲在线播放| 亚洲三级av| 免费av网址在线| 亚洲日本在线天堂| 免费播放片a高清在线观看| 91视频免费在线| 亚洲影院在线| 免费麻豆国产一区二区三区四区| 亚洲人精品午夜在线观看| 麻豆一二三区精品蜜桃| 免费无码国产v片在线观看| 亚洲人精品午夜| 日韩电影免费| 鬼打鬼之黄金道士1992林正英| 七七婷婷婷婷精品国产| 日韩成人在线免费视频| 久久久国产成人精品| 九一成人免费视频| 国产黑丝一区二区| 日韩一区二区三区精品视频|