自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

鴻蒙開(kāi)源第三方組件—游戲框架JustWeEngine

開(kāi)發(fā) 項(xiàng)目管理
JustWeEngine是托管在Gitee 的一個(gè)開(kāi)源的Ohos原生開(kāi)發(fā)框架,可以讓Ohos的開(kāi)發(fā)人員非常便捷,無(wú)需切換語(yǔ)言和編譯器的制作Ohos原生游戲。

[[414844]]

想了解更多內(nèi)容,請(qǐng)?jiān)L問(wèn):

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

JustWeEngine

本項(xiàng)目是基于開(kāi)源項(xiàng)目JustWeEngine進(jìn)行ohos化的移植和開(kāi)發(fā)的,可以通過(guò)項(xiàng)目標(biāo)簽以及github地址(https://github.com/lfkdsk/JustWeEngine )追蹤到原項(xiàng)目版本

項(xiàng)目介紹

  • 項(xiàng)目名稱(chēng):JustWeEngine
  • 所屬系列:ohos的第三方組件適配移植
  • 功能:JustWeEngine是托管在Gitee 的一個(gè)開(kāi)源的Ohos原生開(kāi)發(fā)框架,可以讓Ohos的開(kāi)發(fā)人員非常便捷,無(wú)需切換語(yǔ)言和編譯器的制作Ohos原生游戲
  • 項(xiàng)目移植狀態(tài):完成
  • 調(diào)用差異:無(wú)
  • 原項(xiàng)目基線(xiàn)版本:v1.13
  • 編程語(yǔ)言:Java

效果展示

安裝教程

方法1.

  1. 編譯har包JustWeEngine.har。
  2. 啟動(dòng) DevEco Studio,將編譯的har包,導(dǎo)入工程目錄“entry->libs”下。
  3. 在moudle級(jí)別下的build.gradle文件中添加依賴(lài),在dependences標(biāo)簽中增加對(duì)libs目錄下har包的引用。
  1. dependencies { 
  2.     implementation fileTree(dir: 'libs', include: ['*.jar''*.har']) 
  3.     …… 

      4.在導(dǎo)入的har包上點(diǎn)擊右鍵,選擇“Add as Library”對(duì)包進(jìn)行引用,選擇需要引用的模塊,并點(diǎn)擊“OK”即引用成功。

方法2.

1.在工程的build.gradle的allprojects中,添加HAR所在的Maven倉(cāng)地址(等maven發(fā)布后進(jìn)行修改)

  1. repositories { 
  2.     maven { 
  3.         url 'https://s01.oss.sonatype.org/content/repositories/releases/'  
  4.     } 

2.在應(yīng)用模塊的build.gradle的dependencies閉包中,添加如下代碼:(等maven發(fā)布后進(jìn)行修改)

  1. dependencies { 
  2.     implementation 'io.github.dzsf:just-we-engine:1.0.1' 

使用說(shuō)明

1.基礎(chǔ)功能

  • 1.1繼承引擎核心類(lèi)
  • 1.2繪制文字
  • 1.3繪制圖片
  • 1.4使用精靈
  • 1.5使用按鈕

2.動(dòng)畫(huà)系統(tǒng)

  • 2.1綁定在BaseSub物品及精靈基類(lèi)上的動(dòng)畫(huà)類(lèi)
  • 2.2綁定在Button上的動(dòng)畫(huà)類(lèi)

3.物體分組碰撞檢測(cè)和死亡判定

4.屏幕掃描模式

5.工具類(lèi)

6.音頻系統(tǒng)

  • 6.1播放短音效
  • 6.2播放音頻
  • 6.3通過(guò)短音效編曲

進(jìn)階應(yīng)用

7.使用網(wǎng)絡(luò)

8.使用狀態(tài)機(jī)精靈

9.CrashHandler崩潰守護(hù)

10.使用藍(lán)牙

  • 10.1開(kāi)啟、關(guān)閉服務(wù)
  • 10.2掃描設(shè)備
  • 10.3發(fā)送消息

11.SQLite數(shù)據(jù)庫(kù)

  • 11.1創(chuàng)建表
  • 11.2增刪查改

基礎(chǔ)功能

繼承引擎核心類(lèi):

由于框架全部使用SurfaceView進(jìn)行繪制,不使用諸如Button、Layout等原生控件,所以應(yīng)該首先新建類(lèi)繼承引擎核心類(lèi)Engine,負(fù)責(zé)游戲的流程,注釋中已有明確的標(biāo)明功能。

  1. public class MainAbility extends Engine implements Runnable, Component.TouchEventListener, Component.DrawTask { 
  2.     // 一般在構(gòu)造函數(shù)完成變量的初始化 
  3.     public MainAbility() { 
  4.          
  5.     } 
  6.  
  7.     public void onStart(Intent intent) { 
  8.         // 調(diào)用初始化方法 
  9.         init(); 
  10.     } 
  11.      
  12.     // 載入一些UI參數(shù)和設(shè)置屏幕放向,默認(rèn)背景色,設(shè)定屏幕的掃描方式等 
  13.     public void init() { 
  14.         // 初始化UI默認(rèn)參數(shù),必須調(diào)用該方法,其中有一些用于多機(jī)型適配的參數(shù)需要初始化 
  15.         UIdefaultData.init(this); 
  16.     } 
  17.  
  18.     // 通常用于精靈,背景,圖片等物體的設(shè)置和載入 
  19.     public void load() { 
  20.  
  21.     } 
  22.  
  23.     // draw 和 update 在線(xiàn)程中進(jìn)行不斷的循環(huán)刷新 
  24.     // draw 負(fù)責(zé)繪制 update 負(fù)責(zé)更新數(shù)據(jù)和對(duì)象信息 
  25.     public void draw() { 
  26.  
  27.     } 
  28.  
  29.     public void update() { 
  30.  
  31.     } 
  32.      
  33.     // 將touch 事件傳回 功能和所設(shè)定的屏幕掃描方式有關(guān) 
  34.     public void touch(TouchEvent event) { 
  35.  
  36.     } 
  37.      
  38.     // 將碰撞事件傳回 傳回精靈和物品的基類(lèi)  
  39.     // 用于處理碰撞事件 默認(rèn)使用矩形碰撞 
  40.     public void collision(BaseSub baseSub) { 
  41.  
  42.     } 

繪制文字:

使用GamePrinter進(jìn)行文字繪制,除此以外還有多種方法繪制:

  1. @Override 
  2.   public void draw() { 
  3.       Canvas canvas = getCanvas(); 
  4.       GameTextPrinter printer = new GameTextPrinter(canvas); 
  5.       printer.drawText("哈哈哈", 100, 100); 
  6.   } 
  7.    

繪制圖片:

建議圖片存放在Resources中:

  1. GameTexture texture = new GameTexture(this); 
  2.     texture.loadFromAsset("resources/base/graphic/shoot.png"
  3.     texture.draw(canvas, 100, 100); 

另外也可使用loadFromAssetStripFrame從一個(gè)大的圖片中取出對(duì)應(yīng)位置的圖片。

  1. /** 
  2.     * get bitmap from a big bitmap 
  3.     * 
  4.     * @param filename 
  5.     * @param x 
  6.     * @param y 
  7.     * @param width 
  8.     * @param height 
  9.     * @return 
  10.     */ 
  11.    public boolean loadFromAssetStripFrame(String filename, 
  12.                                           int x, int y, 
  13.                                           int width, int height) 

PicUtils中提供了在Bitmap處理中很有用的各種特效和壓縮方法,大家可以一試。

使用精靈:

使用精靈可以使用BaseSprite也可以繼承該類(lèi)使用,BaseSprite封裝了很多方法供各種動(dòng)畫(huà)使用,這些功能很多都是需要結(jié)合動(dòng)畫(huà)系統(tǒng)來(lái)使用的,動(dòng)畫(huà)系統(tǒng)會(huì)在后面介紹。

新建精靈:

1.簡(jiǎn)單初始化:

  1. sprite = new BaseSprite(this); 

2.初始化連續(xù)幀動(dòng)畫(huà):

連續(xù)幀的初始化需要連續(xù)的幀圖片。

  1. GameTexture texture = new GameTexture(this); 
  2. texture.loadFromAsset("resources/base/graphic/flare.png"); 
  3. // 長(zhǎng)寬以及列數(shù) 
  4. sprite = new BaseSprite(this, 96, 96, 8); 
  5. sprite.setTexture(texture); 
  6. sprite.setPosition(100, 100); 
  7. sprite.setDipScale(100, 100); 
  8. // 幀切換動(dòng)畫(huà)是關(guān)鍵 
  9. sprite.addAnimation(new FrameAnimation(0, 63, 1)); 
  10. addToSpriteGroup(sprite); 

3.使用從大圖取出的多幀圖片:

  1. // 新建圖片資源(此圖為上圖的大圖) 
  2.         GameTexture texture = new GameTexture(this); 
  3.         texture.loadFromAsset("resources/base/graphic/shoot.png"); 
  4.         // 初始化設(shè)定模式和長(zhǎng)寬 
  5.         ship = new BaseSprite(this, 100, 124, FrameType.COMMON); 
  6.         // 設(shè)定資源 
  7.         ship.setTexture(texture); 
  8.         // 從大圖中取出兩幀 
  9.         ship.addRectFrame(0, 100, 100, 124); 
  10.         ship.addRectFrame(167, 361, 100, 124); 
  11.         ship.addAnimation(new FrameAnimation(0, 1, 1)); 

4.一些重要的其他設(shè)定:

  1. // 圖片資源 
  2.       ship.setTexture(texture); 
  3.       // 大圖取幀模式 
  4.       ship.addRectFrame(0, 100, 100, 124); 
  5.       // 設(shè)定位置 
  6.       ship.setPosition(x, y); 
  7.       // 設(shè)置dp大小 
  8.     ship.setDipScale(96, 96); 
  9.     // 設(shè)定dp位置 
  10.  ship.setDipPosition(x, y); 
  11.  // 設(shè)定透明度 
  12.  ship.setAlpha(...); 
  13.  // 只有將精靈添加到SpriteGroup中框架才會(huì)自行繪制,否則需要手動(dòng)調(diào)用 
  14.  addToSpriteGroup(ship); 
  15.  ... 
  16.   

使用按鈕:

使用的按鈕可以繼承BaseButton進(jìn)行拓展,也可以直接使用TextureButton和TextButton進(jìn)行使用。

Button設(shè)定功能的方式和原生一樣,通過(guò)設(shè)定接口回調(diào)的方式進(jìn)行:

  1. button.setOnClickListener(new OnClickListener() { 
  2.           @Override 
  3.           public void onClick() { 
  4.               Log.e("button""onClick"); 
  5.           } 
  6.         }); 
  7.          

TextureButton:

  1. TextureButton button; 
  2.      // 初始化并設(shè)定名字 
  3.      button = new TextureButton(this, "logo"); 
  4.   texture = new GameTexture(this); 
  5.      texture.loadFromAsset("resources/base/graphic/logo.jpg"); 
  6.      // 添加圖片資源 
  7.      button.setTexture(texture); 
  8.      // button的接口回調(diào),不是View的那個(gè)接口 
  9.      button.setOnClickListener(new OnClickListener() { 
  10.          @Override 
  11.          public void onClick() { 
  12.              Log.e("button""onClick"); 
  13.          } 
  14.        }); 
  15.      button.setPosition(200, 300); 
  16.      button.setDipScale(100, 150); 
  17.      // 添加到ButtonGroup進(jìn)行繪制和處理 
  18.      addToButtonGroup(button); 

結(jié)合PicUtil中的各種Bitmap處理方法可以很容易的做出各種樣式的Button。

TextButton:

TextButton button;

  1. TextButton button;   
  2.     button = new TextButton(this, "logo"); 
  3.     button.setText("劉豐愷"); 
  4.     addToButtonGroup(button); 
  5.     // 余略見(jiàn)源碼 
  6.  ... 

動(dòng)畫(huà)系統(tǒng)

目前的動(dòng)畫(huà)系統(tǒng)可以使用已經(jīng)封裝好的繼承了BaseAnimation的動(dòng)畫(huà),也可以繼承BaseAnim進(jìn)行自我定義動(dòng)畫(huà)類(lèi)進(jìn)行使用。

綁定在BaseSub物品及精靈基類(lèi)上的動(dòng)畫(huà)類(lèi)

AnimType中保存了Animation的應(yīng)用類(lèi)型。

綁定動(dòng)畫(huà)分為兩類(lèi),ListAnimation和FixedAnimation,ListAnimation將動(dòng)畫(huà)存儲(chǔ)到固定的一個(gè)List中,用于重復(fù)更新的動(dòng)畫(huà),

而FixedAnimation存儲(chǔ)在Map中,使用名字進(jìn)行調(diào)用,用于點(diǎn)擊或者非自動(dòng)更新的動(dòng)畫(huà)。

比如前面精靈類(lèi)動(dòng)畫(huà)的就是添加到ListAnimation。

下面的這種寫(xiě)法就是FixedAnimation,這個(gè)動(dòng)畫(huà)是飛機(jī)入場(chǎng),因?yàn)橹皇褂昧艘淮?,所以使用了FixedAnimation。

  1. ship.addfixedAnimation("start"
  2.                new MoveAnimation(UIdefaultData.centerInHorizontalX -   ship.getWidthWithScale() / 2, 
  3.                        UIdefaultData.screenHeight - 2 * ship.getHeightWidthScale(), new Float2(10, 10))); 
  4.             

綁定在Button上的動(dòng)畫(huà)類(lèi)

BaseButtonAnimation是BaseButton的動(dòng)畫(huà)類(lèi)繼承了BaseAnim的動(dòng)畫(huà)基類(lèi),通過(guò)提供Button的狀態(tài),設(shè)定Button的動(dòng)畫(huà)。

為Button設(shè)定放縮動(dòng)畫(huà):

  1. // 設(shè)定中心放縮 
  2.    button.setZoomCenter(true); 
  3.    // 三個(gè)參數(shù) 初始值/放大值/幀數(shù) 
  4.    button.setAnimation(new ZoomCenterButtonAnim(10, 30, 3)); 

為Button設(shè)定顏色動(dòng)畫(huà):

  1. // 初始顏色 / 按下顏色 
  2. button.setAnimation( 
  3.       new ColorAnimation(UIdefaultData.colorAccent, 
  4.       UIdefaultData.colorPressed)); 

物體分組碰撞檢測(cè)和死亡判定

使用設(shè)置ID和Name進(jìn)行物體分組,通過(guò)物體分組,框架核心類(lèi)會(huì)對(duì)對(duì)象進(jìn)行分類(lèi)處理。

  1. final int SHIP = 0; 
  2.     ship.setName("SHIP"); 
  3.     ship.setIdentifier(SHIP); 

只要使用了addToSpriteGroup(sprite)的精靈對(duì)象就會(huì)自動(dòng)進(jìn)行碰撞檢測(cè),而對(duì)碰撞檢測(cè)的結(jié)果會(huì)從

collision中進(jìn)行發(fā)回。

  1. @Override 
  2.   public void collision(BaseSub baseSub) { 
  3.     // 獲取與之碰撞的對(duì)象 
  4.       BaseSprite other = (BaseSprite) baseSub.getOffender(); 
  5.       // 獲取ID分組處理 
  6.       if (baseSub.getIdentifier() == BULLET && 
  7.               other.getIdentifier() == ENEMY) { 
  8.           // 設(shè)定死亡 
  9.           other.setAlive(false); 
  10.           // 回收 
  11.           removeFromSpriteGroup(other); 
  12.           addToRecycleGroup(other); 
  13.       } 
  14.   } 
  15.    

其中g(shù)etOffender()獲得與之碰撞的對(duì)象,通過(guò)getIdentifier()獲取設(shè)定的對(duì)象分組,實(shí)行邏輯判斷。

開(kāi)啟Debug模式會(huì)看見(jiàn)碰撞線(xiàn)。

屏幕掃描模式

屏幕掃描模式是用來(lái)優(yōu)先響應(yīng)屏幕點(diǎn)擊、Button點(diǎn)擊、和多點(diǎn)觸控而設(shè)的,放置在不同情況下都能優(yōu)化屏幕的刷新。

  1. // 檢測(cè)單一移動(dòng) 
  2. SINGLE, 
  3. // 檢測(cè)Button 
  4.  BUTTON, 
  5.  // 多點(diǎn)檢測(cè) 
  6.  FULL
  7.  // 單擊+Button 
  8.  SINGLE_BUTTON 

并且通過(guò)如下方式進(jìn)行設(shè)置:

  1. super.setTouchMode(TouchMode.BUTTON); 

工具類(lèi)

  • NetUtils 網(wǎng)絡(luò)狀態(tài)工具類(lèi)
  • PicUtils 圖片處理工具類(lèi)
  • ServiceUtils 服務(wù)工具類(lèi)
  • ImageHelper 圖型處理類(lèi)
  • DisplayUtils 數(shù)據(jù)轉(zhuǎn)換類(lèi)
  • SpUtils Sp簡(jiǎn)化工具類(lèi)(可存儲(chǔ)list和map)
  • ValidatorsUtils 正則表達(dá)式處理類(lèi)

音頻系統(tǒng)

播放短音效

播放短音效,首先初始化SoundManager用以加載音效。

  1. // 接收實(shí)例和Manager的尺寸 
  2.    SoundManager manager = new SoundManager(this, 5); 
  3.    // 從assets加載音頻 同時(shí)加載路徑也會(huì)作為音效名進(jìn)行存儲(chǔ) 
  4. manager.addSound("resource/rawfile/open.mid"); 
  5. // 通過(guò)加載名進(jìn)行播放 
  6. manager.play("resource/rawfile/open.mid"); 

完成以上步驟就可以播放了,當(dāng)然盡量只向其中放置較短的音效,如背景音樂(lè)的長(zhǎng)音頻,請(qǐng)見(jiàn)播放音頻。

  1. public void removeSound(String musicName) // 移除 
  2. public void play(String musicName, float volume) // 播放 + 音量 
  3. public boolean containSoundID(int soundID) // 判斷音頻是否存在 
  4. public int getSoundID(String soundName)  // 獲取ID 
  5. ... 

播放音頻

播放音頻適合例如背景音樂(lè)一樣的音樂(lè)。

  1. // 傳入兩個(gè)參數(shù) 上下文和文件名 
  2.     MusicPlayer player = new MusicPlayer(this, "resources/rawfile/open.mp3"); 
  3.     player.play(); 

以上的就能實(shí)現(xiàn)播放了,下面還有一些其他的方法。

  1. public void dispose() // 清理 
  2.     public void setLooping(boolean isLooping) // 是否循環(huán) 
  3.     public void setVolume(float volume) // 設(shè)定音量 
  4.     ... 

 通過(guò)短音效編曲

從SoundManager中導(dǎo)入多段音頻,快速播放達(dá)成音效的效果。

  1. SoundManager manager = new SoundManager(this, 5); 
  2.   manager.addSound("resources/rawfile/media/1.mid"); 
  3.   manager.addSound("resources/rawfile/media/2.mid"); 
  4.   SoundPlayer player = new SoundPlayer(manager, 500, 16); 
  5.   player.addSound("resources/rawfile/media/1.mid"); 
  6.   player.addSound("resources/rawfile/media/2.mid"); 
  7.   ...  

使用player.play();進(jìn)行播放。

使用網(wǎng)絡(luò)

網(wǎng)絡(luò)的使用可參考JustWe-WebServer中的介紹。

按照介紹操作就可以通過(guò):

  1. server.apply("/lfk", new OnWebStringResult() { 
  2.     @Override 
  3.     public String OnResult() { 
  4.         return "======="
  5.     } 
  6. }); 
  7.  
  8. server.apply("/main", new OnWebFileResult() { 
  9.     @Override 
  10.     public File returnFile() { 
  11.         return new File(WebServerDefault.WebServerFiles+"/"+"welcome.html"); 
  12.     } 
  13. }); 

這樣的簡(jiǎn)單方式綁定路由,而get/post數(shù)據(jù)可以直接使用http協(xié)議的get和post進(jìn)行。

使用狀態(tài)機(jī)精靈

  1. // 為狀態(tài)機(jī)添加一個(gè)任務(wù) 
  2. sprite.addState(new StateFinder() { 
  3.     @Override 
  4.     public boolean isContent(BaseSub baseSub) { 
  5.         return Math.abs(zom.s_position.x - baseSub.s_position.x) > 50; 
  6.     } 
  7. }, new FrameAnimation(0, 63, 1)); 

可以通過(guò)上述的addState方法為狀態(tài)機(jī)精靈添加一個(gè)任務(wù),只有當(dāng)?shù)谝粋€(gè)參數(shù)接口回調(diào)的返回值為真的時(shí)候,

才會(huì)去運(yùn)行第二個(gè)參數(shù)提供的指令,如果返回為假則會(huì)運(yùn)行第二項(xiàng)狀態(tài)的判斷。

狀態(tài)的優(yōu)先級(jí)由加入順序提供。

CrashHandler崩潰守護(hù)

CrashHandler用于處理游戲的意外崩潰事件,初始化推薦在Application中進(jìn)行。

CrashHandler可以自動(dòng)保存機(jī)型和異常日志,以便讓開(kāi)發(fā)者找到問(wèn)題所在。

  1. CrashHandler.getInstance().init(this); 

使用以上語(yǔ)句即可自動(dòng)保存錯(cuò)誤日志。

還可以:

  1. CrashHandler.getInstance().setRestartActivity(MainActivity.class); // 重啟的Activity 
  2.    // 添加崩潰回調(diào) 
  3.    CrashHandler.getInstance().addCrashListener(new AfterCrashListener() { 
  4.        @Override 
  5.        public void AfterCrash() {  // 設(shè)定保存項(xiàng)目 
  6.            ... 
  7.        } 
  8.    });     

使用藍(lán)牙

開(kāi)啟、關(guān)閉服務(wù)

使用藍(lán)牙需要新建BlueToothServer對(duì)象,傳入上下文和MessageBack接口。

  1.       blueToothServer = new BlueToothServer(this, new OnMessageBack() { 
  2.           @Override 
  3.           public void getMessage(String msg) { 
  4.               Log.e("L", msg); 
  5.           } 
  6.  
  7.           @Override 
  8.           public void sendMessage(String msg) { 
  9.               Log.e("L", msg); 
  10.           } 
  11.  
  12.           @Override 
  13.           public void getDevice(ArrayList<String> msg) { 
  14.               Log.e("L", msg.size() + ""); 
  15.           } 
  16.       }); 
  17.  
  18. // 使用如下語(yǔ)句進(jìn)行初始化 
  19.       blueToothServer.init(); 

服務(wù)初始化之后如未打開(kāi)藍(lán)牙,系統(tǒng)會(huì)自動(dòng)提示應(yīng)用要求藍(lán)牙開(kāi)啟。

通過(guò)MessageBack接口可以接收到發(fā)送、接收、以及掃描設(shè)備信息,采取對(duì)應(yīng)操作就可以獲得數(shù)據(jù)。

關(guān)閉服務(wù)時(shí)請(qǐng)使用blueToothServer.unBindService();關(guān)閉服務(wù)。

掃描設(shè)備

使用blueToothServer.doDiscovery();進(jìn)行設(shè)備掃描,返回結(jié)果在OnMessageBack()接口的

getDevice()方法接收。

使用blueToothServer.ensureDiscoverable();允許被掃描。

使用blueToothServer.getPairedDevices();返回已配對(duì)的設(shè)備列表。

發(fā)送消息

在配對(duì)成功之后就可以使用blueToothServer.sendMessage(String msg);發(fā)送消息了。

同時(shí),消息的接收也可以從getMessage()接口中獲得。

SQLite數(shù)據(jù)庫(kù)

SQLite使用了IOC的模式。

創(chuàng)建表

新建的創(chuàng)建表需要繼承Node并且寫(xiě)出注解類(lèi)。

  1. // 表名 
  2. @TableName(tableName = "lfkdsk"
  3. public class User extends Node { 
  4.  
  5. // 主鍵自增 INTEGER型 
  6.    @LabelName(autoincrement = true
  7.            type = LabelName.Type.INTEGER
  8.            columnName = "name"
  9.            generatedId = true
  10.    private int name
  11.  
  12. // TEXT型 欄名為user_name 
  13.    @LabelName(type = LabelName.Type.TEXT, 
  14.            columnName = "user_name"
  15.    private String user_name; 
  16.  
  17. // 自增主鍵所以只需要提供其他信息 
  18.    public User(String user_name) { 
  19.        super(user_name); 
  20.        this.user_name = user_name; 
  21.    } 
  22.  
  23.    public User(int name, String user_name) { 
  24.        super(name, user_name); 
  25.        this.name = name
  26.        this.user_name = user_name; 
  27.    } 
  28.  
  29.    public int getName() { 
  30.        return name
  31.    } 
  32.  
  33.    public void setName(int name) { 
  34.        this.name = name
  35.    } 
  36.  
  37.    public String getUser_name() { 
  38.        return user_name; 
  39.    } 
  40.  
  41.    public void setUser_name(String user_name) { 
  42.        this.user_name = user_name; 
  43.    } 
  1. // 通過(guò)這種方式獲取數(shù)據(jù)庫(kù)   表名 
  2.     private DataBase dataBase = DataBase.initAndOpen("user"User.class); 

增刪查改

  1. // add 
  2.     database.insert(User user); 
  3.     // find 
  4.     database.get(int position); 
  5.     // delete 
  6.     database.delete(int position); 
  7.     // update 
  8.     database.update(User user); 
  9.     ... 

相關(guān)資料

項(xiàng)目地址:https://gitee.com/openneusoft/just-we-engine

IDE官方下載地址:https://developer.harmonyos.com/cn/develop/deveco-studio

想了解更多內(nèi)容,請(qǐng)?jiān)L問(wèn):

51CTO和華為官方合作共建的鴻蒙技術(shù)社區(qū)

https://harmonyos.51cto.com

 

責(zé)任編輯:jianghua 來(lái)源: 鴻蒙社區(qū)
相關(guān)推薦

2021-03-10 15:03:40

鴻蒙HarmonyOS應(yīng)用

2021-04-29 14:32:24

鴻蒙HarmonyOS應(yīng)用

2021-03-24 09:30:49

鴻蒙HarmonyOS應(yīng)用

2021-03-01 14:00:11

鴻蒙HarmonyOS應(yīng)用

2021-08-26 16:07:46

鴻蒙HarmonyOS應(yīng)用

2021-01-27 10:04:46

鴻蒙HarmonyOS動(dòng)畫(huà)

2021-03-03 09:42:26

鴻蒙HarmonyOS圖片裁剪

2021-11-17 15:37:43

鴻蒙HarmonyOS應(yīng)用

2021-04-08 14:57:52

鴻蒙HarmonyOS應(yīng)用

2021-04-20 15:06:42

鴻蒙HarmonyOS應(yīng)用

2021-07-06 18:21:31

鴻蒙HarmonyOS應(yīng)用

2021-08-05 15:06:30

鴻蒙HarmonyOS應(yīng)用

2021-08-30 17:55:58

鴻蒙HarmonyOS應(yīng)用

2021-11-02 14:54:21

鴻蒙HarmonyOS應(yīng)用

2021-08-10 15:23:08

鴻蒙HarmonyOS應(yīng)用

2021-10-19 10:04:51

鴻蒙HarmonyOS應(yīng)用

2021-04-15 17:47:38

鴻蒙HarmonyOS應(yīng)用

2021-07-20 15:20:40

鴻蒙HarmonyOS應(yīng)用

2017-12-11 15:53:56

2015-11-05 16:44:37

第三方登陸android源碼
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)