|
@@ -41,18 +41,31 @@ THREE.MMDLoader = function ( manager ) {
|
|
|
|
|
|
THREE.Loader.call( this );
|
|
|
this.manager = ( manager !== undefined ) ? manager : THREE.DefaultLoadingManager;
|
|
|
- this.defaultTexturePath = './models/default/';
|
|
|
|
|
|
};
|
|
|
|
|
|
THREE.MMDLoader.prototype = Object.create( THREE.Loader.prototype );
|
|
|
THREE.MMDLoader.prototype.constructor = THREE.MMDLoader;
|
|
|
|
|
|
-THREE.MMDLoader.prototype.setDefaultTexturePath = function ( path ) {
|
|
|
-
|
|
|
- this.defaultTexturePath = path;
|
|
|
-
|
|
|
-};
|
|
|
+/*
|
|
|
+ * base64 encoded defalut toon textures toon00.bmp - toon10.bmp
|
|
|
+ * Users don't need to prepare default texture files.
|
|
|
+ *
|
|
|
+ * This idea is from http://www20.atpages.jp/katwat/three.js_r58/examples/mytest37/mmd.three.js
|
|
|
+ */
|
|
|
+THREE.MMDLoader.prototype.defaultToonTextures = [
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ '',
|
|
|
+ ''
|
|
|
+];
|
|
|
|
|
|
THREE.MMDLoader.prototype.load = function ( modelUrl, vmdUrls, callback, onProgress, onError ) {
|
|
|
|
|
@@ -2075,8 +2088,26 @@ THREE.MMDLoader.prototype.createMesh = function ( model, texturePath, onProgress
|
|
|
|
|
|
}
|
|
|
|
|
|
- var directoryPath = ( params.defaultTexturePath === true ) ? scope.defaultTexturePath : texturePath;
|
|
|
- var fullPath = directoryPath + filePath;
|
|
|
+ var fullPath;
|
|
|
+
|
|
|
+ if ( params.defaultTexturePath === true ) {
|
|
|
+
|
|
|
+ try {
|
|
|
+
|
|
|
+ fullPath = scope.defaultToonTextures[ parseInt( filePath.match( 'toon([0-9]{2})\.bmp$' )[ 1 ] ) ];
|
|
|
+
|
|
|
+ } catch ( e ) {
|
|
|
+
|
|
|
+ console.warn( 'THREE.MMDLoader: ' + filePath + ' seems like not right default texture path. Using toon00.bmp instead.' )
|
|
|
+ fullPath = scope.defaultToonTextures[ 0 ];
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ } else {
|
|
|
+
|
|
|
+ fullPath = texturePath + filePath;
|
|
|
+
|
|
|
+ }
|
|
|
|
|
|
var loader = THREE.Loader.Handlers.get( fullPath );
|
|
|
|