国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務器之家:專注于服務器技術及軟件下載分享
分類導航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務器之家 - 編程語言 - JavaScript - js教程 - 游戲開發中如何使用CocosCreator進行音效處理

游戲開發中如何使用CocosCreator進行音效處理

2022-03-01 16:54weixin_39745013 js教程

這篇文章主要介紹了游戲開發中如何使用CocosCreator進行音效處理,并對音效組件進行封裝,方便以后使用,同學們看完之后,一定要親手實驗一下

在游戲開發中,我們經常需要使用音效來營造游戲氛圍,因此本文給大家總結下 Cocos Creator 游戲開發中音效組件的封裝和使用。

一、 Cocos Creator 中音頻播放基礎

1. 基礎知識

游戲開發中如何使用CocosCreator進行音效處理

【1】AudioSource 組件官方文檔:http://docs.cocos.com/creator/manual/zh/audio/audio.html

【2】cc.audioEngine官方文檔:http://docs.cocos.com/creator/manual/zh/audio/audio.html

Cocos Creator 提供兩種音頻播放方式,AudioEngine 與 AudioSource 都能播放音頻,它 們的區別在于 AudioSource 是組件,可以添加到場景中,由編輯器設置。而 AudioEngine 是 引擎提供的純 API,只能在腳本中進行調用。

共同點:本質都是處理 AudioClip 音頻資源,需要在 Cocos Creator 編輯器中掛載組件。

個人建議使用這個來替換 AudioSource 組件播放聲音,接口齊全,測試有效,可以自己 封裝一個類似 AudioSource 組件的腳本來使用。

方式一:使用 AudioSource 組件播放

創建一個空節點,在這個空節點上,添加一個 其他組件 -> AudioSource

在腳本上預設好 AudioSource,并且根據實際需求,完善腳本的對外接口,如下

cc.Class({

	properties: {

		audioSource: {

			type: cc.AudioSource,
			default: null

		},
	},
	play() {

		this.audioSource.play();

	},
	pause() {

		this.audioSource.pause();

	},
});

方式二:使用 AudioEngine 播放

在腳本內定義一個 audioClip 資源對象,如下示例中 properties 對象內。

直接使用 cc.audioEngine.play(audio, loop, volume); 播放。如下示例中 onLoad 中。

cc.Class({

	properties: {

		audio: {

			default: null,
			type: cc.AudioClip

		}

	},
	onLoad() {

		this.current = cc.audioEngine.play(this.audio, false, 1);

	},
	onDestroy() {

		cc.audioEngine.stop(this.current);

	}

});

AudioEngine 播放的時候,需要注意這里的傳入的是一個完整的 AudioClip 對象(而不 是 url)。所以我們不建議在 play 接口內直接填寫音頻的 url 地址,而是希望大家先定義 一個 AudioClip,然后在編輯器內將音頻拖拽過來。

2. 常用方法

【1】組件 AudioSource

play ( ) 播放音頻剪輯。

stop ( ) 停止當前音頻剪輯。

pause ( ) 暫停當前音頻剪輯。

resume ( ) 恢復播放。

【2】聲音系統 cc.audioEngine

// 背景音樂,循環

cc.audioEngine.playMusic(source);

cc.audioEngine.stopMusic(source);

// 短音效

cc.audioEngine.playEffect(source);

cc.audioEngine.stopEffect(source);

上面的第一種方法原生平臺有很多 Bug,所以我們的游戲都用的第二種方法播放聲音。

二、 Cocos Creator 音效管理組件封裝

1.創建音效管理類 SoundMgr.ts

const {
	ccclass,
	property
} = cc._decorator;

@ccclass

exportdefaultclassSoundMgr {

	sound_path: string = "res/sounds/";

	// sound 中保存的是音樂的名稱和音頻對象的 key-value 鍵值對

	sounds: {
		[key: string]: any
	} = {};

	enabled: boolean = true;

	music: string = "";

	// 單例模式

	protectedstatic instance: SoundMgr;

	publicstatic getInstance(): SoundMgr {

		if (!this.instance) {

			this.instance = newSoundMgr();

		}

		returnthis.instance;

	}

	// 添加聲音資源

	addSound(key: string, clip: cc.AudioClip) {

		this.sounds[key] = clip;

	}

	playFx(fxName: string) {

		if (!this.enabled) return;

		cc.audioEngine.playEffect(this.sounds[fxName], false);

	}

	playMusic(musicName: string) {

		this.music = musicName;

		if (!this.enabled) return;

		cc.audioEngine.playMusic(this.sounds[musicName], true);

	}

	stopMusic() {

		cc.audioEngine.stopMusic();

	}

	setEnabled(enabled: boolean) {

		this.enabled = enabled;

		if (this.enabled) {

			this.playMusic(this.music);

		} else {

			cc.audioEngine.stopAll();

		}

	}

	getEnable() {

		returnthis.enabled;

	}

}

2. 在初始化的時候加載音頻資源

通過 Cocos Creator 可視化編輯工具,我們設置游戲場景和資源如下:

游戲開發中如何使用CocosCreator進行音效處理

因為 sounds 我們是通過代碼動態加載,故我們將保存所有聲音文件的 sounds 文件夾放 到 resources 文件夾內(如上圖)。

然后,新建 GameMgr.ts,掛載到 Canvas 節點上。

游戲開發中如何使用CocosCreator進行音效處理

onst {
	ccclass,
	property
} = cc._decorator;

importSoundMgrfrom "SoundMgr";

@ccclass

exportdefaultclassGameMgrextends cc.Component {

	loadSounds() {

		// 注意通過代碼動態加載的資源必須放到 resources 文件夾下

		cc.loader.loadResDir("sounds", cc.AudioClip, function(err, clips) {

			console.log("load clips:", clips);

			if (err) {

				console.log("err:", err);

			}

			for (let i = 0; i

				SoundMgr.getInstance().addSound(clips[i].name, clips[i]);

			}

		});

	}

	onLoad() {

		this.loadSounds();

		console.log("sounds:", SoundMgr.getInstance().sounds);

	}

	onPlayClick() {

		console.log("play");

		SoundMgr.getInstance().playMusic("spring_music");

	}

	onPauseClick() {

		console.log("pause");

		SoundMgr.getInstance().stopMusic();

	}

}

在 GameMgr 自定義組件的 onLoad 方法中,調用 loadSounds 加載游戲中所需要的所有 聲音資源。同時在 GameMgr.ts 中提供播放和暫停接口方法 onPlayClick 和 onPauseClick 方法。

供播放和暫停按鈕調用。

3. 播放和暫停調用

游戲開發中如何使用CocosCreator進行音效處理

4. 運行測試

游戲開發中如何使用CocosCreator進行音效處理

聲音資源全部加載成功,并且點擊播放和暫停按鈕,都能測試通過。

游戲開發中如何使用CocosCreator進行音效處理

三、 注意事項

注意:如果音頻播放相關的設置都完成后,在部分瀏覽器上預覽或者運行時仍聽不到聲 音,那可能是由于瀏覽器兼容性導致的問題。例如:Chrome 禁用了 WebAudio 的自動播放,而音頻默認是使用 Web Audio 的方式加載并播放的,此時用戶就需要在 資源管理器中選中音頻資源,然后在 屬性檢查器 中將音頻的加載模式修改為 DOM Audio 才能在瀏覽器上正常播放。

游戲開發中如何使用CocosCreator進行音效處理

以上就是游戲開發中如何使用CocosCreator進行音效處理的詳細內容,更多關于CocosCreator音效處理的資料請關注服務器之家其它相關文章!

原文鏈接:https://blog.csdn.net/weixin_39745013/article/details/112118478

延伸 · 閱讀

精彩推薦
  • js教程JavaScript實現滾動加載更多

    JavaScript實現滾動加載更多

    這篇文章主要為大家詳細介紹了JavaScript實現滾動加載更多,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    予傾9962021-12-20
  • js教程js正則表達式簡單校驗方法

    js正則表達式簡單校驗方法

    在本篇文章里小編給大家整理了一篇關于js正則表達式簡單校驗方法,有需要的朋友們可以參考下。...

    小妮淺淺11322021-12-24
  • js教程詳解微信小程序軌跡回放實現及遇到的坑

    詳解微信小程序軌跡回放實現及遇到的坑

    這篇文章主要介紹了詳解微信小程序軌跡回放實現及遇到的坑,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要...

    Keen6182022-01-12
  • js教程JS 實現請求調度器

    JS 實現請求調度器

    這篇文章主要介紹了JS 實現請求調度器的方法,幫助大家更好的理解和學習使用js,感興趣的朋友可以了解下...

    孟陬9722022-02-13
  • js教程JavaScript實現切換多張圖片

    JavaScript實現切換多張圖片

    這篇文章主要為大家詳細介紹了JavaScript實現切換多張圖片,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    是M11782022-01-10
  • js教程玩轉 Mockjs,前端也能跑得很溜

    玩轉 Mockjs,前端也能跑得很溜

    mockjs作用就是,生成隨機模擬數據,攔截 ajax 請求,可以對數據進行增刪改查。在生成數據時,我們就需要能夠熟練使用 mock.js 的語法。...

    前端人4852022-01-05
  • js教程基于JavaScript實現簡單的輪播圖

    基于JavaScript實現簡單的輪播圖

    這篇文章主要為大家詳細介紹了基于JavaScript實現簡單的輪播圖,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    llt2990225342022-01-25
  • js教程JavaScript 實現繼承的幾種方式

    JavaScript 實現繼承的幾種方式

    這篇文章主要介紹了JavaScript 實現繼承的幾種方式,幫助大家更好的理解和使用JavaScript,感興趣的朋友可以了解下...

    him89882022-01-21
主站蜘蛛池模板: 黄桃av| 日韩国产免费观看 | 午夜黄色 | 伊人一区二区三区 | 国产成年人视频 | 国内精品一级毛片国产99 | 欧美成人免费电影 | 美女黄网| 91精品国产一区二区三区免费 | 伊人色爱 | 视频一区二区国产 | 国产成人久久精品麻豆二区 | 国产精品久久久久久一区 | 精品久久精品 | 亚洲欧美在线视频 | 91精品综合久久久久久五月天 | 成人精品一区二区三区 | 亚洲精品久久久久久久久久久 | 国产精品久久久久国产a级 国产免费久久 | 国产精品久久久亚洲 | 国产精品免费久久久久久久久久中文 | 欧美国产综合一区 | av在线精品 | 久久精品电影 | 成人午夜精品久久久久久久网站 | 国产伦精品一区二区三区四区视频 | 国产成人欧美一区二区三区的 | 久久综合九色综合欧美狠狠 | 欧美久久综合 | 狠狠爱综合 | 成人网av| 久久久国产精品一区 | 日韩欧美精品在线 | 亚洲欧美自拍偷拍 | 高清国产一区 | 中文精品在线 | 成人福利电影 | 亚洲一区国产视频 | 国产精品久久久久久久久久久久久 | 亚洲视频区 | 久久伊人网视频 |