女人荫蒂被添全过程13种图片,亚洲+欧美+在线,欧洲精品无码一区二区三区 ,在厨房拨开内裤进入毛片

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

鴻蒙海報編輯器APP,分享端云一體化開發的經驗!

陳姚豐 ? 來源:jf_83680738 ? 作者:jf_83680738 ? 2025-03-16 16:09 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

前言

在我工作的日常中,經常會用一些畫圖編輯器,簡單設計一些頁面原型。而在去年低代碼很火的時候,我在公司就開發了一款大屏可視化編輯器,可以通過拖拉拽生成網頁的一個工具。后面也想著自己也開發一個畫圖的編輯器,可以用來自己平時做圖或者設計海報之類的。而這次我將使用鴻蒙ArkTs來開發這款海報編輯器APP,順便分享一下我這次的開發經驗。

項目架構與開發流程

我這次項目功能架構以及整體開發流程如下:

項目功能結構

海報編輯器架構.png

整體開發流程

海報編輯器端云一體開發流程.png

這次開發我使用了鴻蒙的端云一體化的開發模式進行整個項目的構建。說實話:之前我都是自己寫后端代碼,開發流程確實比較繁瑣。而云開發模式就很方便了,端側與云側同時開發,無需搭建服務器,工具成本低。這點我還是很喜歡的。

端云一體化工程講解

端云一體化的工程我也是第一次開發,相信很多伙伴也沒開發過。我這次用的是官方提供的云模板工程,我大概給大家講解一下:

image.png

整體結構很簡單,使用起來也比較方便。所有的操作DevEco Studio開發工具都集成了。

而在講解之前,使用云模板創建項目之前需要在華為開發平臺創建項目,具體創建流程可以到官方文檔查看,地址我也放在下面:https://developer.harmonyos.com/cn/docs/documentation/doc-guides-V3/agc-harmonyos-clouddev-agcapp-0000001439436876-V3#section397317130308

注意:記得是創建項目哦,不是應用。我一開始就搞錯了

創建表與方法

  1. 比如你要新建一張數據庫表,只需在clouddb云數據庫入口文件點擊右鍵,點擊new,然后你選擇需要創建什么。
    image.png

而我比較喜歡在開發平臺創建,比較方便,傻瓜式操作。大家也可以看看官方文檔:https://developer.huawei.com/consumer/cn/doc/AppGallery-connect-Guides/agc-clouddb-createfirstclouddb-0000001569588629

2.比如你要創建一個云函數方法,也是只需在cloudfuntion云函數入口文件點擊右鍵,點擊new,然后你直接創建一個對應的云函數即可。

image.png

開發函數與數據庫的使用

由于第一次使用云函數與云數據庫,一路上磕磕碰碰。所以我打算將自己經驗都分享給大家,希望能幫助大家。

開發云函數

在創建云函數之后,代碼結構如下:

image.png

其中有一個ts文件,這個就是我們的函數入口了,其他的我們都暫時不用動。這里我默認的是nodejs開發模式以及http請求模式。如果你們需要修改配置可以看一下官方文檔:https://developer.huawei.com/consumer/cn/doc/AppGallery-connect-Guides/agc-cloud-function-start-from-here-0000001512489692

ts文件里面默認有一個主入口方法:

let myHandler = async function (event, context, callback, logger) {
  // 獲取你的參數
  const body = event.body ? JSON.parse(event.body) : event

  // 寫你的業務代碼

  callback({
      code: 200,
      data: [],
      msg: '提示內容'
  });
};

export { myHandler };
  • myHandler:入口方法名稱。
  • event:調用方傳遞的事件對象,JSON格式。具體內容請參見event對象
  • context:函數運行時上下文對象,封裝了日志接口、回調接口、環境變量env對象等。
  • callback:事件處理結果。
  • logger:記錄日志。

這里需要注意的是:獲取參數的方式,我在本地調試的時候,event就是參數對象了,但是發布到云服務器之后,端側傳遞的參數需要通過event.body來判斷是否存在,然后將數據JSON化。也不知道是不是我用的不對,但是目前我是遇到這個問題了。

接下來我講解一下云函數調用云數據庫與云存儲的相關步驟。詳細步驟如下:

云函數使用云數據庫

1. 云數據庫注冊認證

在使用云數據庫的所有方法時,都需要先注冊認證哈

const path = require('path');
const clouddb = require('@hw-agconnect/database-server/dist/index.js')
const { AGCClient, CredentialParser } = require("@hw-agconnect/common-server");
const db_demo = require('./db/bd_demo') // 從開發者平臺下載對應的js配置文件,放在對應的函數目錄根目錄下

// 加載憑證文件,憑證文件也是在開發者平臺下載,具體看我的截圖
let client_name = "./db/agc-apiclient-chen.json";
let client_path = path.join(__dirname, client_name);
let credential = CredentialParser.toCredential(client_path);
AGCClient.initialize(credential, "clientCN", "CN");

let myHandler = async function (event, context, callback, logger) {
  // xxxx
};

export { myHandler };

1.1 下載加載對象類型文件
image.png
1.2 將上面下載的文件引入到云函數目錄中
image.png
1.3 下載憑證文件
image.png

2. 初始化云數據庫實例以及打開存儲區

// 接著加載憑證文件的相關代碼下
const agcClient = AGCClient.getInstance("clientCN");
clouddb.AGConnectCloudDB.initialize(agcClient);
const agconnectCloudDB = clouddb.AGConnectCloudDB.getInstance(agcClient);
//云數據庫區塊,獲取方法看以下截圖
const zoneName = '區塊名稱';
const cloudDBZoneConfig = new clouddb.CloudDBZoneConfig(zoneName);
const mCloudDBZone = agconnectCloudDB.openCloudDBZone(cloudDBZoneConfig);

2.1 獲取區塊名稱
image.png

3. 使用云數據庫的方法

3.1 云數據庫-新增數據

需要注意的是:表名稱,直接寫對應的字符串名稱就好

// 上面是注冊、加載憑證、打開存儲區的代碼

let myHandler = async function (event, context, callback, logger) {
  // 獲取你的參數
  const body = event.body ? JSON.parse(event.body) : event

  //表名稱也是通過開發者平臺獲取即可,字符串模式
  const bookInfo = clouddb.CloudDBZoneGenericObject.build('表名稱')
  // 添加屬性對應的數據,按照自己定義的字段格式去賦值
  bookInfo.addFieldValue('字段名稱1', '數據')
  bookInfo.addFieldValue('字段名稱2', '數據')
  // 同步插入表里
  const resp = await mCloudDBZone.executeUpsert(bookInfo)
  callback({
      code: 200,
      data: [],
      msg: '提示內容'
  });
};

export { myHandler };

3.2 云數據庫-更新數據

需要注意的是:要先獲取表實例以及定位唯一鍵

const db_demo = require('./db/bd_demo')
// 上面是注冊、加載憑證、打開存儲區的代碼

let myHandler = async function (event, context, callback, logger) {
  // 獲取你的參數
  const body = event.body ? JSON.parse(event.body) : event
  
  // 引入表實例
  const bookInfo = new db_demo.db_demo();
  // 定位唯一鍵,目的找到對應的數據
  bookInfo.setId('主鍵數據值') // 主鍵字段,自己在創建數據庫的時候需要自定義主鍵
  // 注冊
  const operator = clouddb.CloudDBZoneObjectOperator.build(bookInfo)
  operator.update('字段名稱1', 數據) // 更新對應字段數據
  operator.update('字段名稱2', 數據) // 更新對應字段數據
  operator.update('字段名稱3', 數據) // 更新對應字段數據
  // ....
  // 更新表里數據
  const resp = await mCloudDBZone.executeUpdate(operator)
  callback({
      code: 200,
      data: [],
      msg: '提示內容'
  });
};

export { myHandler };

3.2 云數據庫-查詢數據

這里需要注意的是:查詢方式有很多,我這邊只用到很基礎的。想要更多操作可以看一下官網:https://developer.huawei.com/consumer/cn/doc/AppGallery-connect-Guides/agc-clouddb-otheroperations-servernodejs-0000001569466329#section171182910246

const db_demo = require('./db/bd_demo')
// 上面是注冊、加載憑證、打開存儲區的代碼

let myHandler = async function (event, context, callback, logger) {
  // 獲取你的參數
  const body = event.body ? JSON.parse(event.body) : event
  
  // 初始化表
  let cloudDBZoneQuery = clouddb.CloudDBZoneQuery.where(db_demo.db_demo)
  // 查詢字段名稱等于xxx的數據
  const userCloudDBZoneQuery = cloudDBZoneQuery.equalTo('字段名稱', 'xxx');
  const respUser = await mCloudDBZone.executeQuery(userCloudDBZoneQuery);
  const data = respUser.getSnapshotObjects()[0] // 獲取對應數據
  callback({
      code: 200,
      data: [],
      msg: '提示內容'
  });
};

export { myHandler };

3.3 云數據庫-刪除數據

刪除相關的操作我還沒使用過,等我使用之后再補充給大家

云函數使用云存儲

1. 云存儲注冊認證

在使用云存儲的所有方法時,也是都需要先注冊認證哈

import {AGCClient, CredentialParser} from "@agconnect/common-server"
import {StorageManagement, Bucket, File, AGCCloudStorage} from "@agconnect/cloudstorage-server"

// 加載憑證文件
let client_name = "./db/agc-apiclient-chen.json";
let client_path = path.join(__dirname, client_name);
let credential = CredentialParser.toCredential(client_path);
AGCClient.initialize(credential, "clientDW");

let storage = AGCCloudStorage.getInstance("clientDW");
// name: 存儲實例名稱,獲取方式從開發者平臺獲取
let bucket = storage.bucket('xxxx');

let myHandler = async function (event, context, callback, logger) {
  // xxxx
};

export { myHandler };

1.1 獲取存儲實例名稱

image.png

2. 使用云存儲的方法

2.1 上傳文件

需要注意的是:上傳文件需要注意destination的文件路徑規則。需要上傳的文件對應的路徑則是本地路徑,文件在云函數的根目錄下,。后續我也會將怎么通過端側上傳圖片到云函數再上傳到云存儲的相關操作。

// 以上是認證的相關代碼

let myHandler = async function (event, context, callback, logger) {
    const options = {
      destination:  'demo/demo.png', // 對應云存儲中的文件路徑,demo文件夾需要自己在開發者平臺創建,文件名稱自定義,存在則覆蓋不存在則新增
      onUploadProgress: (event) = > {}
    };
    bucket.upload('需要上傳的文件路徑,例如:./static/demo.png', options);
};

export { myHandler };

2.2 下載文件

// 以上是認證的相關代碼

let myHandler = async function (event, context, callback, logger) {
    const remoteFile = bucket.file(‘云存儲下的文件具體路徑’);
    const localFile = '需要上傳的文件路徑,例如:./static/demo.png'
    const directory = path.dirname(localFile);
    // 判斷本地是否有當前文件,有則創建
    if (!fs.existsSync(directory)) {
      fs.mkdirSync(directory, { recursive: true });
    }
    
    // 下載云存儲的文件內容到對應的本地文件
    await remoteFile.createReadStream()
      .on('error', (err) = > {})
      .on('end', () = > {
        // 業務代碼
      })
      .pipe(fs.createWriteStream(localFile));
};

export { myHandler };

總結

這次的鴻蒙端云一體化的開發經驗就講解到這里,可能我講的不是很細,因為也是第一次使用,希望可以幫助大家。如果上面描述的有問題,歡迎大家在評論區指出來,謝謝。后面我們也會分享端側的開發經驗,以及會將對應app上線,到時候有相關技術討論的都可以找我們

審核編輯 黃宇

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 鴻蒙
    +關注

    關注

    59

    文章

    2573

    瀏覽量

    43900
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

    一體化解決方案Jama Software,如何支持醫療設備開發中的需求管理、風險管理與驗證?

    醫療設備開發中的需求管理太復雜?試試一體化解決方案Jama Connect——支持ISO 1497等關鍵標準的合規認證、FMEA分析、可追溯性與變更管理等。
    的頭像 發表于 06-25 11:36 ?100次閱讀
    <b class='flag-5'>一體化</b>解決方案Jama Software,如何支持醫療設備<b class='flag-5'>開發</b>中的需求管理、風險管理與驗證?

    Linux下Vim編輯器的使用技巧

    【Vim】常用總結? 簡介? image 什么是vim?? Linux下兩大編輯神器之 vim ? Linux/Unix下使用最多的編輯器 ? vi的改進版 ? 可能是最難上手的編輯器
    的頭像 發表于 04-01 17:36 ?474次閱讀
    Linux下Vim<b class='flag-5'>編輯器</b>的使用技巧

    華為發布一體化網絡安全解決方案

    3月20日至21日,以“因聚而生 眾智有為”為主題的華為中國合作伙伴大會2025在深圳舉行。期間,華為數據通信產品線安全分銷領域總監張峰在“華為坤靈直播間”面向中小企業發布一體化
    的頭像 發表于 03-21 17:28 ?680次閱讀

    【McCharts】基于鴻蒙ArkTS語法開發的圖表組件--折線圖

    編輯器,可以用來自己平時做圖或者設計海報之類的。而這次我將使用鴻蒙 ArkTs 來開發這款海報編輯器
    發表于 03-15 15:27

    多省市聚焦車路一體化發展,共繪智能交通產業新藍圖

    多省市聚焦車路一體化發展,共繪智能交通產業新藍圖
    的頭像 發表于 02-18 08:49 ?524次閱讀
    多省市聚焦車路<b class='flag-5'>云</b><b class='flag-5'>一體化</b>發展,共繪智能交通產業新藍圖

    如祺出行入選智能網聯車路一體化典型案例

    在2024第三屆未來交通產業發展峰會上,如祺出行“車路一體化C-V2X車載終端規模化應用項目”入選大會“智能網聯車路一體化典型案例”。
    的頭像 發表于 01-14 11:43 ?686次閱讀

    華為入選中國網安一體化能力領導者

    近日,中國數字產業第三方權威調研咨詢機構數世咨詢發布了《網安一體化能力指南》報告(以下簡稱“報告”)。報告對中國11家具備網安相關解決方案和產品的主流廠商進行了調研,華為憑借在
    的頭像 發表于 12-20 15:11 ?732次閱讀

    華礪智行亮相2024車路一體化融合發展論壇

    當前,“車路一體化”邁入了產業規模化建設和應用的關鍵時期。作為支撐車路一體化建設的重要城市,上海、合肥、宜昌、武漢等城市正在大力發展新能源和智能網聯汽車、智慧交通等戰略性新興產業,
    的頭像 發表于 12-02 17:33 ?805次閱讀

    德晟達助力解決車路一體化發展難題

    隨著智能交通的發展,車路一體化成為實現高效、安全、環保出行的重要手段。而車路一體化的普及推廣,需要產業上下游伙伴緊密攜手共破產業難題。為了解決車路
    的頭像 發表于 11-25 18:11 ?727次閱讀

    Vivado編輯器亂碼問題

    我們在日常開發中經常使用sublime、vim、vs code等第三方的編輯器,這些編輯器可以使用很多插件來提高我們的編碼效率,但是也往往會帶來亂碼的問題。我般使用的是sublime
    的頭像 發表于 10-15 17:24 ?2389次閱讀
    Vivado<b class='flag-5'>編輯器</b>亂碼問題

    中偉視界:AI邊一體化平臺的智能化全流程解析

    AI邊一體化管控平臺通過將邊緣計算與云端服務整合,實現了從數據采集到決策的全流程智能化管理,提升了效率與安全性。平臺支持多種設備的靈活集成及自動化運維,為企業的智能化轉型提供了強有力的技術支持。
    的頭像 發表于 09-19 11:41 ?631次閱讀

    vim編輯器如何使用

    Vim編輯器個功能強大的文本編輯器,它基于Vi進行改進,并增加了許多新特性。Vim編輯器的使用主要涉及其不同的工作模式及相應操作。以下是Vim
    的頭像 發表于 08-30 14:58 ?855次閱讀

    揭秘! 經緯恒潤“車路一體化”方案研發服務背后的科技驅動力

    汽車“車路一體化”正迎來新輪的發展高潮。經緯恒潤基于在港口領域多年的研發與運營經驗,打造了智能網聯汽車“車路
    的頭像 發表于 08-13 08:00 ?1365次閱讀
    揭秘! 經緯恒潤“車路<b class='flag-5'>云</b><b class='flag-5'>一體化</b>”方案研發服務背后的科技驅動力

    一體化物聯網平臺如何實現?有什么功能

    一體化物聯網平臺(CloudEdge Integration IoT Platform)是種結合了計算和邊緣計算優勢的物聯網解決方案。它通過在云端和邊緣
    的頭像 發表于 07-29 14:34 ?763次閱讀

    國家公布“車路一體化”試點城市!

    來源:5G智聯車 編輯:感知芯視界 Link 7月3日,工業和信息化部、公安部、自然資源部、住房和城鄉建設部、交通運輸部發布關于公布智能網聯汽車“車路一體化”應用試點城市名單的通知。5G智聯車公眾
    的頭像 發表于 07-05 09:23 ?719次閱讀
    主站蜘蛛池模板: 东城区| 友谊县| 象州县| 清河县| 民和| 绵竹市| 西平县| 中西区| 永德县| 高淳县| 九台市| 伊通| 洛南县| 灌阳县| 耿马| 铜山县| 寻乌县| 江津市| 丰原市| 温州市| 浠水县| 景泰县| 鄂托克前旗| 军事| 阿拉善左旗| 福贡县| 轮台县| 裕民县| 唐山市| 津南区| 铁岭市| 霍林郭勒市| 铜梁县| 余江县| 青冈县| 太谷县| 新郑市| 邳州市| 台北县| 米林县| 澄江县|