2018-01-28 20:48:02 +00:00
//-----------------------------------------------------------------------------
// Copyright (c) 2013 GarageGames, LLC
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to
// deal in the Software without restriction, including without limitation the
// rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
// sell copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
// FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
// IN THE SOFTWARE.
//-----------------------------------------------------------------------------
2021-01-05 06:58:18 +00:00
# pragma once
2018-01-28 20:48:02 +00:00
# ifndef MATERIALASSET_H
# include "MaterialAsset.h"
# endif
# ifndef _ASSET_MANAGER_H_
# include "assets/assetManager.h"
# endif
# ifndef _CONSOLETYPES_H_
# include "console/consoleTypes.h"
# endif
# ifndef _TAML_
# include "persistence/taml/taml.h"
# endif
# ifndef _ASSET_PTR_H_
# include "assets/assetPtr.h"
# endif
2021-01-15 00:00:56 +00:00
# include "T3D/assets/assetImporter.h"
2021-01-05 06:58:18 +00:00
2021-07-19 06:07:08 +00:00
StringTableEntry MaterialAsset : : smNoMaterialAssetFallback ( StringTable - > insert ( Con : : getVariable ( " $Core::NoMaterialAssetFallback " ) ) ) ;
2018-01-28 20:48:02 +00:00
//-----------------------------------------------------------------------------
IMPLEMENT_CONOBJECT ( MaterialAsset ) ;
ConsoleType ( MaterialAssetPtr , TypeMaterialAssetPtr , MaterialAsset , ASSET_ID_FIELD_PREFIX )
//-----------------------------------------------------------------------------
ConsoleGetType ( TypeMaterialAssetPtr )
{
// Fetch asset Id.
return ( * ( ( AssetPtr < MaterialAsset > * ) dptr ) ) . getAssetId ( ) ;
}
//-----------------------------------------------------------------------------
ConsoleSetType ( TypeMaterialAssetPtr )
{
// Was a single argument specified?
if ( argc = = 1 )
{
// Yes, so fetch field value.
const char * pFieldValue = argv [ 0 ] ;
// Fetch asset pointer.
AssetPtr < MaterialAsset > * pAssetPtr = dynamic_cast < AssetPtr < MaterialAsset > * > ( ( AssetPtrBase * ) ( dptr ) ) ;
// Is the asset pointer the correct type?
if ( pAssetPtr = = NULL )
{
// No, so fail.
//Con::warnf("(TypeMaterialAssetPtr) - Failed to set asset Id '%d'.", pFieldValue);
return ;
}
// Set asset.
pAssetPtr - > setAssetId ( pFieldValue ) ;
return ;
}
// Warn.
Con : : warnf ( " (TypeMaterialAssetPtr) - Cannot set multiple args to a single asset. " ) ;
}
2020-11-02 05:32:34 +00:00
2021-07-19 06:07:08 +00:00
ConsoleType ( assetIdString , TypeMaterialAssetId , const char * , ASSET_ID_FIELD_PREFIX )
2020-11-02 05:32:34 +00:00
ConsoleGetType ( TypeMaterialAssetId )
{
// Fetch asset Id.
return * ( ( const char * * ) ( dptr ) ) ;
}
ConsoleSetType ( TypeMaterialAssetId )
{
// Was a single argument specified?
if ( argc = = 1 )
{
// Yes, so fetch field value.
const char * pFieldValue = argv [ 0 ] ;
// Fetch asset Id.
StringTableEntry * assetId = ( StringTableEntry * ) ( dptr ) ;
// Update asset value.
* assetId = StringTable - > insert ( pFieldValue ) ;
return ;
}
// Warn.
Con : : warnf ( " (TypeMaterialAssetId) - Cannot set multiple args to a single asset. " ) ;
}
2018-01-28 20:48:02 +00:00
//-----------------------------------------------------------------------------
MaterialAsset : : MaterialAsset ( )
{
mShaderGraphFile = " " ;
2019-05-06 06:49:58 +00:00
mScriptFile = StringTable - > EmptyString ( ) ;
2020-08-09 06:32:27 +00:00
mScriptPath = StringTable - > EmptyString ( ) ;
2019-05-06 06:49:58 +00:00
mMatDefinitionName = StringTable - > EmptyString ( ) ;
2021-07-19 06:07:08 +00:00
mMaterialDefinition = nullptr ;
2018-01-28 20:48:02 +00:00
}
//-----------------------------------------------------------------------------
MaterialAsset : : ~ MaterialAsset ( )
{
2021-07-19 06:07:08 +00:00
//SAFE_DELETE(mMaterialDefinition);
2018-01-28 20:48:02 +00:00
}
//-----------------------------------------------------------------------------
2021-07-19 06:07:08 +00:00
void MaterialAsset : : consoleInit ( )
{
Parent : : consoleInit ( ) ;
Con : : addVariable ( " $Core::NoMaterialAssetFallback " , TypeString , & smNoMaterialAssetFallback ,
" The assetId of the material to display when the requested material asset is missing. \n "
" @ingroup GFX \n " ) ;
}
2018-01-28 20:48:02 +00:00
void MaterialAsset : : initPersistFields ( )
{
// Call parent.
Parent : : initPersistFields ( ) ;
//addField("shaderGraph", TypeRealString, Offset(mShaderGraphFile, MaterialAsset), "");
2019-05-04 16:49:42 +00:00
addProtectedField ( " scriptFile " , TypeAssetLooseFilePath , Offset ( mScriptFile , MaterialAsset ) ,
& setScriptFile , & getScriptFile , " Path to the file containing the material definition. " ) ;
2019-05-06 06:49:58 +00:00
addField ( " materialDefinitionName " , TypeString , Offset ( mMatDefinitionName , MaterialAsset ) , " Name of the material definition this asset is for. " ) ;
2018-01-28 20:48:02 +00:00
}
void MaterialAsset : : initializeAsset ( )
{
// Call parent.
Parent : : initializeAsset ( ) ;
2020-08-09 06:32:27 +00:00
mScriptPath = getOwned ( ) ? expandAssetFilePath ( mScriptFile ) : mScriptPath ;
2019-05-28 22:24:29 +00:00
2021-07-23 01:55:46 +00:00
if ( Torque : : FS : : IsScriptFile ( mScriptPath ) )
2020-08-09 06:32:27 +00:00
Con : : executeFile ( mScriptPath , false , false ) ;
2021-07-19 06:07:08 +00:00
loadMaterial ( ) ;
2018-01-28 20:48:02 +00:00
}
void MaterialAsset : : onAssetRefresh ( )
{
2020-08-09 06:32:27 +00:00
mScriptPath = getOwned ( ) ? expandAssetFilePath ( mScriptFile ) : mScriptPath ;
2019-05-28 22:24:29 +00:00
2021-07-23 01:55:46 +00:00
if ( Torque : : FS : : IsScriptFile ( mScriptPath ) )
2020-08-09 06:32:27 +00:00
Con : : executeFile ( mScriptPath , false , false ) ;
2018-01-28 20:48:02 +00:00
2021-07-19 06:07:08 +00:00
loadMaterial ( ) ;
2018-01-28 20:48:02 +00:00
}
2019-05-04 16:49:42 +00:00
void MaterialAsset : : setScriptFile ( const char * pScriptFile )
{
// Sanity!
AssertFatal ( pScriptFile ! = NULL , " Cannot use a NULL script file. " ) ;
// Fetch image file.
pScriptFile = StringTable - > insert ( pScriptFile ) ;
// Update.
2019-05-28 22:24:29 +00:00
mScriptFile = getOwned ( ) ? expandAssetFilePath ( pScriptFile ) : pScriptFile ;
2019-05-04 16:49:42 +00:00
// Refresh the asset.
refreshAsset ( ) ;
}
2018-01-28 20:48:02 +00:00
//------------------------------------------------------------------------------
2021-07-19 06:07:08 +00:00
void MaterialAsset : : loadMaterial ( )
2018-01-28 20:48:02 +00:00
{
2021-07-19 06:07:08 +00:00
if ( mMaterialDefinition )
SAFE_DELETE ( mMaterialDefinition ) ;
if ( mMatDefinitionName ! = StringTable - > EmptyString ( ) )
{
Material * matDef ;
if ( ! Sim : : findObject ( mMatDefinitionName , matDef ) )
{
Con : : errorf ( " MaterialAsset: Unable to find the Material %s " , mMatDefinitionName ) ;
mLoadedState = BadFileReference ;
return ;
}
mMaterialDefinition = matDef ;
mLoadedState = Ok ;
mMaterialDefinition - > reload ( ) ;
return ;
}
mLoadedState = Failed ;
2018-01-28 20:48:02 +00:00
}
2021-07-19 06:07:08 +00:00
//------------------------------------------------------------------------------
2018-01-28 20:48:02 +00:00
void MaterialAsset : : copyTo ( SimObject * object )
{
// Call to parent.
Parent : : copyTo ( object ) ;
}
2020-11-02 05:32:34 +00:00
//------------------------------------------------------------------------------
2021-07-19 06:07:08 +00:00
U32 MaterialAsset : : getAssetByMaterialName ( StringTableEntry matName , AssetPtr < MaterialAsset > * matAsset )
2020-11-02 05:32:34 +00:00
{
2021-07-19 06:07:08 +00:00
AssetQuery query ;
U32 foundAssetcount = AssetDatabase . findAssetType ( & query , " MaterialAsset " ) ;
if ( foundAssetcount = = 0 )
2020-11-02 05:32:34 +00:00
{
//Didn't work, so have us fall back to a placeholder asset
2021-07-19 06:07:08 +00:00
matAsset - > setAssetId ( MaterialAsset : : smNoMaterialAssetFallback ) ;
if ( matAsset - > isNull ( ) )
2020-11-02 05:32:34 +00:00
{
2021-07-19 06:07:08 +00:00
//Well that's bad, loading the fallback failed.
Con : : warnf ( " MaterialAsset::getAssetByMaterialName - Finding of asset associated with material name %s failed with no fallback asset " , matName ) ;
return AssetErrCode : : Failed ;
2021-01-05 06:58:18 +00:00
}
2021-07-19 06:07:08 +00:00
//handle noshape not being loaded itself
if ( ( * matAsset ) - > mLoadedState = = BadFileReference )
2021-01-05 06:58:18 +00:00
{
2021-07-19 06:07:08 +00:00
Con : : warnf ( " ShapeAsset::getAssetByMaterialName - Finding of associated with aterial name %s failed, and fallback asset reported error of Bad File Reference. " , matName ) ;
return AssetErrCode : : BadFileReference ;
}
2021-01-05 06:58:18 +00:00
2021-07-19 06:07:08 +00:00
Con : : warnf ( " ShapeAsset::getAssetByMaterialName - Finding of associated with aterial name %s failed, utilizing fallback asset " , matName ) ;
2021-01-05 06:58:18 +00:00
2021-07-19 06:07:08 +00:00
( * matAsset ) - > mLoadedState = AssetErrCode : : UsingFallback ;
return AssetErrCode : : UsingFallback ;
}
else
{
for ( U32 i = 0 ; i < foundAssetcount ; i + + )
{
MaterialAsset * tMatAsset = AssetDatabase . acquireAsset < MaterialAsset > ( query . mAssetList [ i ] ) ;
if ( tMatAsset & & tMatAsset - > getMaterialDefinitionName ( ) = = matName )
2021-01-05 06:58:18 +00:00
{
2021-07-19 06:07:08 +00:00
matAsset - > setAssetId ( query . mAssetList [ i ] ) ;
AssetDatabase . releaseAsset ( query . mAssetList [ i ] ) ;
return ( * matAsset ) - > mLoadedState ;
2021-01-05 06:58:18 +00:00
}
2021-07-19 06:07:08 +00:00
AssetDatabase . releaseAsset ( query . mAssetList [ i ] ) ; //cleanup if that's not the one we needed
}
}
}
2021-01-05 06:58:18 +00:00
2021-07-19 06:07:08 +00:00
StringTableEntry MaterialAsset : : getAssetIdByMaterialName ( StringTableEntry matName )
{
if ( matName = = StringTable - > EmptyString ( ) )
return StringTable - > EmptyString ( ) ;
2021-01-05 06:58:18 +00:00
2021-07-19 06:07:08 +00:00
StringTableEntry materialAssetId = MaterialAsset : : smNoMaterialAssetFallback ;
2021-01-05 06:58:18 +00:00
2021-07-19 06:07:08 +00:00
AssetQuery query ;
U32 foundCount = AssetDatabase . findAssetType ( & query , " MaterialAsset " ) ;
if ( foundCount ! = 0 )
{
for ( U32 i = 0 ; i < foundCount ; i + + )
{
MaterialAsset * matAsset = AssetDatabase . acquireAsset < MaterialAsset > ( query . mAssetList [ i ] ) ;
if ( matAsset & & matAsset - > getMaterialDefinitionName ( ) = = matName )
2021-01-05 06:58:18 +00:00
{
2021-07-19 06:07:08 +00:00
materialAssetId = matAsset - > getAssetId ( ) ;
AssetDatabase . releaseAsset ( query . mAssetList [ i ] ) ;
break ;
2021-01-05 06:58:18 +00:00
}
2021-07-19 06:07:08 +00:00
AssetDatabase . releaseAsset ( query . mAssetList [ i ] ) ;
2020-11-02 05:32:34 +00:00
}
}
return materialAssetId ;
}
2021-07-19 06:07:08 +00:00
U32 MaterialAsset : : getAssetById ( StringTableEntry assetId , AssetPtr < MaterialAsset > * materialAsset )
2020-11-02 05:32:34 +00:00
{
( * materialAsset ) = assetId ;
2021-07-19 06:07:08 +00:00
if ( materialAsset - > notNull ( ) )
{
return ( * materialAsset ) - > mLoadedState ;
}
else
{
//Didn't work, so have us fall back to a placeholder asset
materialAsset - > setAssetId ( MaterialAsset : : smNoMaterialAssetFallback ) ;
if ( materialAsset - > isNull ( ) )
{
//Well that's bad, loading the fallback failed.
Con : : warnf ( " MaterialAsset::getAssetById - Finding of asset with id %s failed with no fallback asset " , assetId ) ;
return AssetErrCode : : Failed ;
}
//handle noshape not being loaded itself
if ( ( * materialAsset ) - > mLoadedState = = BadFileReference )
{
Con : : warnf ( " MaterialAsset::getAssetById - Finding of asset with id %s failed, and fallback asset reported error of Bad File Reference. " , assetId ) ;
return AssetErrCode : : BadFileReference ;
}
2020-11-02 05:32:34 +00:00
2021-07-19 06:07:08 +00:00
Con : : warnf ( " MaterialAsset::getAssetById - Finding of asset with id %s failed, utilizing fallback asset " , assetId ) ;
2020-11-02 05:32:34 +00:00
2021-07-19 06:07:08 +00:00
( * materialAsset ) - > mLoadedState = AssetErrCode : : UsingFallback ;
return AssetErrCode : : UsingFallback ;
}
}
2020-11-02 05:32:34 +00:00
2021-07-19 06:07:08 +00:00
# ifdef TORQUE_TOOLS
DefineEngineStaticMethod ( MaterialAsset , getAssetIdByMaterialName , const char * , ( const char * materialName ) , ( " " ) ,
" Queries the Asset Database to see if any asset exists that is associated with the provided material name. \n "
" @return The AssetId of the associated asset, if any. " )
{
return MaterialAsset : : getAssetIdByMaterialName ( StringTable - > insert ( materialName ) ) ;
2020-11-02 05:32:34 +00:00
}
2021-07-19 06:07:08 +00:00
# endif
2020-11-02 05:32:34 +00:00
2018-01-28 20:48:02 +00:00
//-----------------------------------------------------------------------------
// GuiInspectorTypeAssetId
//-----------------------------------------------------------------------------
IMPLEMENT_CONOBJECT ( GuiInspectorTypeMaterialAssetPtr ) ;
ConsoleDocClass ( GuiInspectorTypeMaterialAssetPtr ,
2020-11-02 05:32:34 +00:00
" @brief Inspector field type for Shapes \n \n "
2018-01-28 20:48:02 +00:00
" Editor use only. \n \n "
" @internal "
) ;
void GuiInspectorTypeMaterialAssetPtr : : consoleInit ( )
{
Parent : : consoleInit ( ) ;
ConsoleBaseType : : getType ( TypeMaterialAssetPtr ) - > setInspectorFieldType ( " GuiInspectorTypeMaterialAssetPtr " ) ;
}
GuiControl * GuiInspectorTypeMaterialAssetPtr : : constructEditControl ( )
{
// Create base filename edit controls
2020-11-02 05:32:34 +00:00
GuiControl * retCtrl = Parent : : constructEditControl ( ) ;
if ( retCtrl = = NULL )
return retCtrl ;
2018-01-28 20:48:02 +00:00
// Change filespec
char szBuffer [ 512 ] ;
2021-01-03 14:58:53 +00:00
dSprintf ( szBuffer , sizeof ( szBuffer ) , " AssetBrowser.showDialog( \" MaterialAsset \" , \" AssetBrowser.changeAsset \" , %s, \" \" ); " ,
getIdString ( ) ) ;
2020-11-02 05:32:34 +00:00
mBrowseButton - > setField ( " Command " , szBuffer ) ;
2018-01-28 20:48:02 +00:00
2020-11-02 05:32:34 +00:00
setDataField ( StringTable - > insert ( " targetObject " ) , NULL , mInspector - > getInspectObject ( ) - > getIdString ( ) ) ;
2018-01-28 20:48:02 +00:00
2020-11-02 05:32:34 +00:00
// Create "Open in Editor" button
mEditButton = new GuiBitmapButtonCtrl ( ) ;
2019-05-04 16:49:42 +00:00
2020-11-02 05:32:34 +00:00
dSprintf ( szBuffer , sizeof ( szBuffer ) , " AssetBrowser.editAsset(%d.getText()); " , retCtrl - > getId ( ) ) ;
mEditButton - > setField ( " Command " , szBuffer ) ;
2018-01-28 20:48:02 +00:00
2020-11-02 05:32:34 +00:00
char bitmapName [ 512 ] = " tools/worldEditor/images/toolbar/material-editor " ;
2021-07-19 06:07:08 +00:00
mEditButton - > setBitmap ( StringTable - > insert ( bitmapName ) ) ;
2018-01-28 20:48:02 +00:00
2020-11-02 05:32:34 +00:00
mEditButton - > setDataField ( StringTable - > insert ( " Profile " ) , NULL , " GuiButtonProfile " ) ;
mEditButton - > setDataField ( StringTable - > insert ( " tooltipprofile " ) , NULL , " GuiToolTipProfile " ) ;
mEditButton - > setDataField ( StringTable - > insert ( " hovertime " ) , NULL , " 1000 " ) ;
mEditButton - > setDataField ( StringTable - > insert ( " tooltip " ) , NULL , " Open this file in the Material Editor " ) ;
2018-01-28 20:48:02 +00:00
2020-11-02 05:32:34 +00:00
mEditButton - > registerObject ( ) ;
addObject ( mEditButton ) ;
2019-05-04 16:49:42 +00:00
2020-11-02 05:32:34 +00:00
return retCtrl ;
2018-01-28 20:48:02 +00:00
}
bool GuiInspectorTypeMaterialAssetPtr : : updateRects ( )
{
S32 dividerPos , dividerMargin ;
mInspector - > getDivider ( dividerPos , dividerMargin ) ;
Point2I fieldExtent = getExtent ( ) ;
Point2I fieldPos = getPosition ( ) ;
mCaptionRect . set ( 0 , 0 , fieldExtent . x - dividerPos - dividerMargin , fieldExtent . y ) ;
mEditCtrlRect . set ( fieldExtent . x - dividerPos + dividerMargin , 1 , dividerPos - dividerMargin - 34 , fieldExtent . y ) ;
bool resized = mEdit - > resize ( mEditCtrlRect . point , mEditCtrlRect . extent ) ;
2020-11-02 05:32:34 +00:00
if ( mBrowseButton ! = NULL )
2019-05-04 16:49:42 +00:00
{
2020-11-02 05:32:34 +00:00
mBrowseRect . set ( fieldExtent . x - 32 , 2 , 14 , fieldExtent . y - 4 ) ;
resized | = mBrowseButton - > resize ( mBrowseRect . point , mBrowseRect . extent ) ;
2019-05-04 16:49:42 +00:00
}
2020-11-02 05:32:34 +00:00
if ( mEditButton ! = NULL )
2018-01-28 20:48:02 +00:00
{
2020-11-02 05:32:34 +00:00
RectI shapeEdRect ( fieldExtent . x - 16 , 2 , 14 , fieldExtent . y - 4 ) ;
resized | = mEditButton - > resize ( shapeEdRect . point , shapeEdRect . extent ) ;
2018-01-28 20:48:02 +00:00
}
return resized ;
2019-05-04 16:49:42 +00:00
}
2020-11-02 05:32:34 +00:00
IMPLEMENT_CONOBJECT ( GuiInspectorTypeMaterialAssetId ) ;
2020-07-11 21:20:10 +00:00
2020-11-02 05:32:34 +00:00
ConsoleDocClass ( GuiInspectorTypeMaterialAssetId ,
" @brief Inspector field type for Material Assets \n \n "
" Editor use only. \n \n "
" @internal "
) ;
2019-05-04 16:49:42 +00:00
2020-11-02 05:32:34 +00:00
void GuiInspectorTypeMaterialAssetId : : consoleInit ( )
2019-05-04 16:49:42 +00:00
{
2020-11-02 05:32:34 +00:00
Parent : : consoleInit ( ) ;
2019-05-04 16:49:42 +00:00
2020-11-02 05:32:34 +00:00
ConsoleBaseType : : getType ( TypeMaterialAssetId ) - > setInspectorFieldType ( " GuiInspectorTypeMaterialAssetId " ) ;
2019-05-04 16:49:42 +00:00
}