three.js 場景編輯器 源碼解析(四)

      場景中編輯的模型會很多,而且文件會很大,使用瀏覽器本身的數據庫存放這些數據是一個好方法,相比於localstring,瀏覽器本身的數據庫支持大文件存儲,支持事務,用起來更合適,編輯器使用了瀏覽器自帶的indexDB數據庫,代碼如下:

//存儲類(序列化類),使用的是瀏覽器數據庫,這個數據庫是否會拖慢編輯器的速度
var Storage = function () {

	//瀏覽器本身的數據庫
	var indexedDB = window.indexedDB || window.mozIndexedDB || window.webkitIndexedDB || window.msIndexedDB;

	//如果數據庫不存在
	if ( indexedDB === undefined  ) {
		//瀏覽器不支持數據庫
		console.warn( 'Storage: IndexedDB not available.' );
		//返回空對象
		return { init: function () {}, get: function () {}, set: function () {}, clear: function () {} };

	}

	//數據庫名稱、數據版本
	var name = 'threejs-editor';
	var version = 1;

	//數據庫句柄
	var database;

	return {
		//初始化
		init: function ( callback ) {
			//打開數據庫
			var request = indexedDB.open( name, version );
			//數據庫升級回調
			request.onupgradeneeded = function ( event ) {

				var db = event.target.result;

				if ( db.objectStoreNames.contains( 'states' ) === false ) {

					db.createObjectStore( 'states' );

				}

			};

			//數據庫操作成功
			request.onsuccess = function ( event ) {

				database = event.target.result;

				callback();

			};

			//數據庫操作錯誤
			request.onerror = function ( event ) {

				console.error( 'IndexedDB', event );

			};


		},

		//異步形式獲取數據
		get: function ( callback ) {

			var transaction = database.transaction( [ 'states' ], 'readwrite' );
			var objectStore = transaction.objectStore( 'states' );
			var request = objectStore.get( 0 );
			request.onsuccess = function ( event ) {
				callback( event.target.result );
			};

		},

		//設置數據
		set: function ( data, callback ) {
			//開始執行
			var start = performance.now();
			//啓動事務
			var transaction = database.transaction( [ 'states' ], 'readwrite' );
			var objectStore = transaction.objectStore( 'states' );
			//存放數據
			var request = objectStore.put( data, 0 );
			//數據陳工提示
			request.onsuccess = function ( event ) {

				console.log( '[' + /\d\d\:\d\d\:\d\d/.exec( new Date() )[ 0 ] + ']', 'Saved state to IndexedDB. ' + ( performance.now() - start ).toFixed( 2 ) + 'ms' );

			};

		},

		//清空數據
		clear: function () {

			if ( database === undefined ) return;

			var transaction = database.transaction( [ 'states' ], 'readwrite' );
			var objectStore = transaction.objectStore( 'states' );
			var request = objectStore.clear();
			request.onsuccess = function ( event ) {

				console.log( '[' + /\d\d\:\d\d\:\d\d/.exec( new Date() )[ 0 ] + ']', 'Cleared IndexedDB.' );

			};

		}

	};

};

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章