mirror of
https://github.com/maxartz15/MA_TextureAtlasser.git
synced 2024-11-22 05:25:34 +01:00
Export options/settings, material export, prefab export.
Moved/changed replace OBJ to ReplaceMesh. Optional model/texture/material export. Added Material export option, set shader and shader properties to assign exported textures. Added Prefab export option, exports mesh as an Unity .asset file and creates a prefab to link it to the mesh filter/renderer, added the option for auto assignment of the exported material (New default).
This commit is contained in:
parent
947eb6f18e
commit
406720d718
@ -1,6 +1,7 @@
|
|||||||
using UnityEngine;
|
using UnityEngine;
|
||||||
using System.Collections;
|
using System.Collections;
|
||||||
using MA_Texture;
|
using MA_Texture;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
|
||||||
namespace MA_TextureAtlasserPro
|
namespace MA_TextureAtlasserPro
|
||||||
{
|
{
|
||||||
@ -10,8 +11,11 @@ namespace MA_TextureAtlasserPro
|
|||||||
[HideInInspector]
|
[HideInInspector]
|
||||||
public bool canModify = true;
|
public bool canModify = true;
|
||||||
|
|
||||||
|
public bool exportModels = true;
|
||||||
public ModelExportSettings modelExportSettings = new ModelExportSettings();
|
public ModelExportSettings modelExportSettings = new ModelExportSettings();
|
||||||
|
public bool exportTextures = true;
|
||||||
public TextureExportSettings textureExportSettings = new TextureExportSettings();
|
public TextureExportSettings textureExportSettings = new TextureExportSettings();
|
||||||
|
public bool exportMaterials = true;
|
||||||
public MaterialExportSettings materialExportSettings = new MaterialExportSettings();
|
public MaterialExportSettings materialExportSettings = new MaterialExportSettings();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -19,8 +23,7 @@ namespace MA_TextureAtlasserPro
|
|||||||
public class ModelExportSettings
|
public class ModelExportSettings
|
||||||
{
|
{
|
||||||
[Header("Model settings:")]
|
[Header("Model settings:")]
|
||||||
public ModelFormat modelFormat = ModelFormat.Obj;
|
public ModelFormat modelFormat = ModelFormat.UnityMeshPrefab;
|
||||||
public bool replaceModel = false;
|
|
||||||
public bool uvFlipY = true;
|
public bool uvFlipY = true;
|
||||||
public int uvChannel = 0;
|
public int uvChannel = 0;
|
||||||
public bool uvWrap = true;
|
public bool uvWrap = true;
|
||||||
@ -35,17 +38,19 @@ namespace MA_TextureAtlasserPro
|
|||||||
public MA_TextureUtils.TextureScaleMode textureScaleMode = MA_TextureUtils.TextureScaleMode.Bilinear;
|
public MA_TextureUtils.TextureScaleMode textureScaleMode = MA_TextureUtils.TextureScaleMode.Bilinear;
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ExportPreset
|
[System.Serializable]
|
||||||
|
public class MaterialExportSettings
|
||||||
{
|
{
|
||||||
Custom,
|
[Header("Material settings:")]
|
||||||
Default,
|
public Shader shader = null;
|
||||||
Sprites,
|
public List<string> shaderPropertyNames = new List<string>() { "_MainTex", "_MetallicGlossMap", "_BumpMap" };
|
||||||
ReplaceObjMeshes
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public enum ModelFormat
|
public enum ModelFormat
|
||||||
{
|
{
|
||||||
None,
|
None,
|
||||||
|
UnityMeshPrefab,
|
||||||
|
ReplaceMesh,
|
||||||
Obj
|
Obj
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -61,12 +66,4 @@ namespace MA_TextureAtlasserPro
|
|||||||
Sprite,
|
Sprite,
|
||||||
SpriteSliced
|
SpriteSliced
|
||||||
}
|
}
|
||||||
|
|
||||||
[System.Serializable]
|
|
||||||
public class MaterialExportSettings
|
|
||||||
{
|
|
||||||
[Header("Material settings:")]
|
|
||||||
public string shader = "Standard";
|
|
||||||
public string[] shaderPropertyNames = { "_MainTex", "_MetallicGlossMap", "_BumpMap" };
|
|
||||||
}
|
|
||||||
}
|
}
|
@ -60,6 +60,8 @@ namespace MA_TextureAtlasserPro
|
|||||||
|
|
||||||
if (_settings != null)
|
if (_settings != null)
|
||||||
{
|
{
|
||||||
|
_settings.materialExportSettings.shader = Shader.Find("Standard");
|
||||||
|
|
||||||
CreateFolder(EXPORT_ASSET_PATH);
|
CreateFolder(EXPORT_ASSET_PATH);
|
||||||
AssetDatabase.CreateAsset(_settings, SETTINGS_ASSET_PATH + name + ".asset");
|
AssetDatabase.CreateAsset(_settings, SETTINGS_ASSET_PATH + name + ".asset");
|
||||||
AssetDatabase.SaveAssets();
|
AssetDatabase.SaveAssets();
|
||||||
@ -387,29 +389,32 @@ namespace MA_TextureAtlasserPro
|
|||||||
}
|
}
|
||||||
|
|
||||||
#region Export
|
#region Export
|
||||||
public static void ExportAtlasModels(MA_TextureAtlasserProAtlas atlas, ModelExportSettings modelExportSettings, string savePath = EXPORT_ASSET_PATH)
|
public static string[] ExportAtlasModels(MA_TextureAtlasserProAtlas atlas, ModelExportSettings modelExportSettings, string material = null, string savePath = EXPORT_ASSET_PATH)
|
||||||
{
|
{
|
||||||
switch(modelExportSettings.modelFormat)
|
switch(modelExportSettings.modelFormat)
|
||||||
{
|
{
|
||||||
case ModelFormat.None:
|
case ModelFormat.None:
|
||||||
break;
|
break;
|
||||||
case ModelFormat.Obj:
|
case ModelFormat.ReplaceMesh:
|
||||||
ExportAtlasObj(atlas, modelExportSettings, savePath);
|
ReplaceAtlasMesh(atlas, modelExportSettings, savePath: savePath);
|
||||||
break;
|
break;
|
||||||
|
case ModelFormat.UnityMeshPrefab:
|
||||||
|
return ExportAtlasUnityMeshPrefab(atlas, modelExportSettings, material: material, savePath: savePath);
|
||||||
|
case ModelFormat.Obj:
|
||||||
|
return ExportAtlasObj(atlas, modelExportSettings, savePath: savePath);
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void ExportAtlasObj(MA_TextureAtlasserProAtlas atlas, ModelExportSettings modelExportSettings, string savePath = EXPORT_ASSET_PATH)
|
private static void ReplaceAtlasMesh(MA_TextureAtlasserProAtlas atlas, ModelExportSettings modelExportSettings, string savePath = EXPORT_ASSET_PATH)
|
||||||
{
|
{
|
||||||
if (atlas == null || atlas.textureQuads == null)
|
if (atlas == null || atlas.textureQuads == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if(modelExportSettings.replaceModel)
|
|
||||||
{
|
|
||||||
var quads = atlas.textureQuads;
|
var quads = atlas.textureQuads;
|
||||||
|
|
||||||
for (var index = 0; index < quads.Count; index++)
|
for (var index = 0; index < quads.Count; index++)
|
||||||
{
|
{
|
||||||
var quad = quads[index];
|
var quad = quads[index];
|
||||||
@ -429,8 +434,14 @@ namespace MA_TextureAtlasserPro
|
|||||||
|
|
||||||
AssetDatabase.SaveAssets();
|
AssetDatabase.SaveAssets();
|
||||||
}
|
}
|
||||||
else
|
|
||||||
|
private static string[] ExportAtlasUnityMeshPrefab(MA_TextureAtlasserProAtlas atlas, ModelExportSettings modelExportSettings, string material = null, string savePath = EXPORT_ASSET_PATH)
|
||||||
{
|
{
|
||||||
|
if (atlas == null || atlas.textureQuads == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
List<string> assetPaths = new List<string>();
|
||||||
|
|
||||||
foreach (MA_TextureAtlasserProQuad quad in atlas.textureQuads)
|
foreach (MA_TextureAtlasserProQuad quad in atlas.textureQuads)
|
||||||
{
|
{
|
||||||
//Export Mesh
|
//Export Mesh
|
||||||
@ -447,37 +458,83 @@ namespace MA_TextureAtlasserPro
|
|||||||
//Remap UV's
|
//Remap UV's
|
||||||
newMesh = MA_MeshUtils.MA_UVReMap(newMesh, atlas.textureAtlasSize, quad.guiRect, modelExportSettings.uvChannel, modelExportSettings.uvFlipY, modelExportSettings.uvWrap);
|
newMesh = MA_MeshUtils.MA_UVReMap(newMesh, atlas.textureAtlasSize, quad.guiRect, modelExportSettings.uvChannel, modelExportSettings.uvFlipY, modelExportSettings.uvWrap);
|
||||||
//Save it
|
//Save it
|
||||||
string modelName = string.IsNullOrEmpty(quad.name) ? "" : quad.name + "-";
|
string meshName = string.IsNullOrEmpty(quad.name) ? "" : quad.name + "-";
|
||||||
modelName += quad.meshes[m].name;
|
meshName += quad.meshes[m].name;
|
||||||
int n = m + 1;
|
int n = m + 1;
|
||||||
modelName += "_" + n.ToString("#000");
|
meshName += "_" + n.ToString("#000");
|
||||||
|
|
||||||
MA_MeshUtils.MeshToFile(newMesh, modelName, savePath);
|
string asset = MA_MeshUtils.MA_SaveMeshPrefab(newMesh, meshName, savePath, material: material);
|
||||||
}
|
assetPaths.Add(asset);
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void ExportAtlasTextures(MA_TextureAtlasserProAtlas atlas, TextureExportSettings textureExportSettings, string savePath = EXPORT_ASSET_PATH, string tempPath = TEXTURE_ATLASSER_PATH)
|
return assetPaths.ToArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
private static string[] ExportAtlasObj(MA_TextureAtlasserProAtlas atlas, ModelExportSettings modelExportSettings, string savePath = EXPORT_ASSET_PATH)
|
||||||
|
{
|
||||||
|
if (atlas == null || atlas.textureQuads == null)
|
||||||
|
return null;
|
||||||
|
|
||||||
|
List<string> assetPaths = new List<string>();
|
||||||
|
|
||||||
|
foreach (MA_TextureAtlasserProQuad quad in atlas.textureQuads)
|
||||||
|
{
|
||||||
|
//Export Mesh
|
||||||
|
if (quad.meshes != null)
|
||||||
|
{
|
||||||
|
for (int m = 0; m < quad.meshes.Count; m++)
|
||||||
|
{
|
||||||
|
if (quad.meshes[m] != null)
|
||||||
|
{
|
||||||
|
//Create new mesh
|
||||||
|
Mesh newMesh = new Mesh();
|
||||||
|
//Duplicate it from the current one
|
||||||
|
newMesh = MA_MeshUtils.MA_DuplicateMesh(quad.meshes[m]);
|
||||||
|
//Remap UV's
|
||||||
|
newMesh = MA_MeshUtils.MA_UVReMap(newMesh, atlas.textureAtlasSize, quad.guiRect, modelExportSettings.uvChannel, modelExportSettings.uvFlipY, modelExportSettings.uvWrap);
|
||||||
|
//Save it
|
||||||
|
string meshName = string.IsNullOrEmpty(quad.name) ? "" : quad.name + "-";
|
||||||
|
meshName += quad.meshes[m].name;
|
||||||
|
int n = m + 1;
|
||||||
|
meshName += "_" + n.ToString("#000");
|
||||||
|
|
||||||
|
string asset = MA_MeshUtils.MeshToFile(newMesh, meshName, savePath);
|
||||||
|
assetPaths.Add(asset);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return assetPaths.ToArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string[] ExportAtlasTextures(MA_TextureAtlasserProAtlas atlas, TextureExportSettings textureExportSettings, string savePath = EXPORT_ASSET_PATH, string tempPath = TEXTURE_ATLASSER_PATH)
|
||||||
{
|
{
|
||||||
switch (textureExportSettings.textureFormat)
|
switch (textureExportSettings.textureFormat)
|
||||||
{
|
{
|
||||||
case TextureFormat.None:
|
case TextureFormat.None:
|
||||||
break;
|
break;
|
||||||
case TextureFormat.Png:
|
case TextureFormat.Png:
|
||||||
ExportAtlasPNG(atlas, textureExportSettings, savePath);
|
return ExportAtlasPNG(atlas, textureExportSettings, savePath);
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void ExportAtlasPNG(MA_TextureAtlasserProAtlas atlas, TextureExportSettings textureExportSettings, string savePath = EXPORT_ASSET_PATH, string tempPath = TEMP_ASSET_PATH)
|
private static string[] ExportAtlasPNG(MA_TextureAtlasserProAtlas atlas, TextureExportSettings textureExportSettings, string savePath = EXPORT_ASSET_PATH, string tempPath = TEMP_ASSET_PATH)
|
||||||
{
|
{
|
||||||
if (atlas == null || atlas.textureQuads == null || atlas.textureGroupRegistration == null)
|
if (atlas == null || atlas.textureQuads == null || atlas.textureGroupRegistration == null)
|
||||||
return;
|
return null;
|
||||||
|
|
||||||
|
string[] assetPaths = new string[atlas.textureGroupRegistration.Count];
|
||||||
|
|
||||||
|
//Create temp folder
|
||||||
|
CreateFolder(tempPath);
|
||||||
|
|
||||||
//Foreach texture group
|
//Foreach texture group
|
||||||
for (int i = 0; i < atlas.textureGroupRegistration.Count; i++)
|
for (int i = 0; i < atlas.textureGroupRegistration.Count; i++)
|
||||||
@ -496,9 +553,6 @@ namespace MA_TextureAtlasserPro
|
|||||||
string orginalTexturePath = AssetDatabase.GetAssetPath(q.textureGroups[i].texture);
|
string orginalTexturePath = AssetDatabase.GetAssetPath(q.textureGroups[i].texture);
|
||||||
string orginalTextureExtension = System.IO.Path.GetExtension(orginalTexturePath);
|
string orginalTextureExtension = System.IO.Path.GetExtension(orginalTexturePath);
|
||||||
|
|
||||||
//Create temp folder
|
|
||||||
CreateFolder(tempPath);
|
|
||||||
|
|
||||||
string tempTexturePath = tempPath + q.textureGroups[i].texture.name + orginalTextureExtension;
|
string tempTexturePath = tempPath + q.textureGroups[i].texture.name + orginalTextureExtension;
|
||||||
AssetDatabase.CopyAsset(orginalTexturePath, tempTexturePath);
|
AssetDatabase.CopyAsset(orginalTexturePath, tempTexturePath);
|
||||||
|
|
||||||
@ -528,12 +582,11 @@ namespace MA_TextureAtlasserPro
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//Delete temp folder
|
|
||||||
DeleteFolder(tempPath);
|
|
||||||
|
|
||||||
//Save it
|
//Save it
|
||||||
newTexture.MA_Save2D(newTexture.name, savePath);
|
newTexture.MA_Save2D(newTexture.name, savePath);
|
||||||
|
|
||||||
|
assetPaths[i] = (savePath + newTexture.name + '.' + textureExportSettings.textureFormat.ToString());
|
||||||
|
|
||||||
//Set settings.
|
//Set settings.
|
||||||
switch (textureExportSettings.textureType)
|
switch (textureExportSettings.textureType)
|
||||||
{
|
{
|
||||||
@ -555,8 +608,13 @@ namespace MA_TextureAtlasserPro
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//Delete temp folder
|
||||||
|
DeleteFolder(tempPath);
|
||||||
|
|
||||||
//Refresh
|
//Refresh
|
||||||
AssetDatabase.Refresh();
|
AssetDatabase.Refresh();
|
||||||
|
|
||||||
|
return assetPaths;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void SetAtlasSpriteSettings(MA_TextureAtlasserProAtlas atlas, TextureExportSettings textureExportSettings, string savePath = EXPORT_ASSET_PATH)
|
private static void SetAtlasSpriteSettings(MA_TextureAtlasserProAtlas atlas, TextureExportSettings textureExportSettings, string savePath = EXPORT_ASSET_PATH)
|
||||||
@ -603,26 +661,41 @@ namespace MA_TextureAtlasserPro
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void ExportAtlasMaterial(MA_TextureAtlasserProAtlas atlas, MaterialExportSettings materialExportSettings, Texture[] textures, string savePath = EXPORT_ASSET_PATH)
|
public static string ExportAtlasMaterial(MA_TextureAtlasserProAtlas atlas, MaterialExportSettings materialExportSettings, string[] textures = null, string savePath = EXPORT_ASSET_PATH)
|
||||||
{
|
{
|
||||||
if (atlas == null || atlas.textureQuads == null || atlas.textureGroupRegistration == null || textures == null)
|
if (atlas == null || atlas.textureQuads == null || atlas.textureGroupRegistration == null)
|
||||||
return;
|
return null;
|
||||||
|
|
||||||
Shader shader = Shader.Find(materialExportSettings.shader);
|
string assetPath = "";
|
||||||
|
|
||||||
|
Shader shader = materialExportSettings.shader;
|
||||||
if (shader)
|
if (shader)
|
||||||
{
|
{
|
||||||
Material material = new Material(shader);
|
Material material = new Material(shader)
|
||||||
material.name = atlas.name;
|
|
||||||
|
|
||||||
for (int i = 0; i < (int)Mathf.Max(materialExportSettings.shaderPropertyNames.Length - 1, textures.Length - 1); i++)
|
|
||||||
{
|
{
|
||||||
material.SetTexture(materialExportSettings.shaderPropertyNames[i], textures[i]);
|
name = atlas.name
|
||||||
|
};
|
||||||
|
|
||||||
|
if(textures != null)
|
||||||
|
{
|
||||||
|
for (int i = 0; i < (int)Mathf.Min(materialExportSettings.shaderPropertyNames.Count, textures.Length); i++)
|
||||||
|
{
|
||||||
|
Texture t = AssetDatabase.LoadAssetAtPath<Texture>(textures[i]);
|
||||||
|
if (t != null)
|
||||||
|
{
|
||||||
|
material.SetTexture(materialExportSettings.shaderPropertyNames[i], t);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
assetPath = savePath + material.name + ".mat";
|
||||||
|
|
||||||
//Save material
|
//Save material
|
||||||
AssetDatabase.CreateAsset(material, EXPORT_ASSET_PATH + material.name);
|
AssetDatabase.CreateAsset(material, assetPath);
|
||||||
AssetDatabase.Refresh();
|
AssetDatabase.Refresh();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return assetPath;
|
||||||
}
|
}
|
||||||
#endregion
|
#endregion
|
||||||
}
|
}
|
||||||
|
@ -122,7 +122,7 @@ namespace MA_TextureAtlasserPro
|
|||||||
}
|
}
|
||||||
if(GUILayout.Button("+", EditorStyles.miniButtonRight, GUILayout.ExpandWidth(false)))
|
if(GUILayout.Button("+", EditorStyles.miniButtonRight, GUILayout.ExpandWidth(false)))
|
||||||
{
|
{
|
||||||
curWindow.textureAtlas.selectedTextureQuad.meshes.Insert(i, null);
|
curWindow.textureAtlas.selectedTextureQuad.meshes.Insert(i + 1, null);
|
||||||
}
|
}
|
||||||
GUILayout.EndHorizontal();
|
GUILayout.EndHorizontal();
|
||||||
}
|
}
|
||||||
|
@ -10,7 +10,7 @@ namespace MA_TextureAtlasserPro
|
|||||||
{
|
{
|
||||||
public class MA_TextureAtlasserProExportWindow : EditorWindow
|
public class MA_TextureAtlasserProExportWindow : EditorWindow
|
||||||
{
|
{
|
||||||
private const int windowHeight = 300;
|
private const int windowHeight = 385;
|
||||||
private const int windowWidth = 320;
|
private const int windowWidth = 320;
|
||||||
|
|
||||||
//Editor
|
//Editor
|
||||||
@ -19,6 +19,7 @@ namespace MA_TextureAtlasserPro
|
|||||||
|
|
||||||
//Data
|
//Data
|
||||||
private static bool isLoaded = false; //Make sure we wait a frame at the start to setup and don't draw.
|
private static bool isLoaded = false; //Make sure we wait a frame at the start to setup and don't draw.
|
||||||
|
private Vector2 scrollPos;
|
||||||
|
|
||||||
[MenuItem("MA_ToolKit/MA_TextureAtlasserPro/Export Atlas")]
|
[MenuItem("MA_ToolKit/MA_TextureAtlasserPro/Export Atlas")]
|
||||||
private static void Init()
|
private static void Init()
|
||||||
@ -91,8 +92,7 @@ namespace MA_TextureAtlasserPro
|
|||||||
GUILayout.BeginArea(new Rect(MA_TextureAtlasserProUtils.VIEW_OFFSET, MA_TextureAtlasserProUtils.VIEW_OFFSET, position.width - (MA_TextureAtlasserProUtils.VIEW_OFFSET * 2), position.height - (MA_TextureAtlasserProUtils.VIEW_OFFSET * 2)));
|
GUILayout.BeginArea(new Rect(MA_TextureAtlasserProUtils.VIEW_OFFSET, MA_TextureAtlasserProUtils.VIEW_OFFSET, position.width - (MA_TextureAtlasserProUtils.VIEW_OFFSET * 2), position.height - (MA_TextureAtlasserProUtils.VIEW_OFFSET * 2)));
|
||||||
GUILayout.BeginVertical();
|
GUILayout.BeginVertical();
|
||||||
|
|
||||||
|
if (curWindow != null && curWindow.textureAtlas != null)
|
||||||
if(curWindow != null && curWindow.textureAtlas != null)
|
|
||||||
{
|
{
|
||||||
//Export
|
//Export
|
||||||
GUILayout.BeginVertical();
|
GUILayout.BeginVertical();
|
||||||
@ -102,7 +102,7 @@ namespace MA_TextureAtlasserPro
|
|||||||
|
|
||||||
if(curWindow.textureAtlas.exportSettings != null)
|
if(curWindow.textureAtlas.exportSettings != null)
|
||||||
{
|
{
|
||||||
DrawExportAdvancedOptions();
|
DrawExportOptions();
|
||||||
}
|
}
|
||||||
|
|
||||||
GUILayout.EndVertical();
|
GUILayout.EndVertical();
|
||||||
@ -154,9 +154,41 @@ namespace MA_TextureAtlasserPro
|
|||||||
|
|
||||||
if (GUILayout.Button("Export", GUILayout.ExpandWidth(true), GUILayout.Height(37)))
|
if (GUILayout.Button("Export", GUILayout.ExpandWidth(true), GUILayout.Height(37)))
|
||||||
{
|
{
|
||||||
MA_TextureAtlasserProUtils.ExportAtlasModels(curWindow.textureAtlas, curWindow.textureAtlas.exportSettings.modelExportSettings);
|
bool export = false;
|
||||||
MA_TextureAtlasserProUtils.ExportAtlasTextures(curWindow.textureAtlas, curWindow.textureAtlas.exportSettings.textureExportSettings);
|
|
||||||
//MA_TextureAtlasserProUtils.ExportAtlasMaterial(curWindow.textureAtlas, curWindow.textureAtlas.exportSettings.materialExportSettings);
|
if(curWindow.textureAtlas.exportSettings.modelExportSettings.modelFormat == ModelFormat.ReplaceMesh)
|
||||||
|
{
|
||||||
|
if(EditorUtility.DisplayDialog("Replace original models?", "Are you sure you want to replace the original models, this can't be undone!", "Replace", "Cancel"))
|
||||||
|
{
|
||||||
|
export = true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
export = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(export)
|
||||||
|
{
|
||||||
|
string[] textures = null;
|
||||||
|
string material = null;
|
||||||
|
string[] models = null;
|
||||||
|
|
||||||
|
if (curWindow.textureAtlas.exportSettings.exportTextures)
|
||||||
|
{
|
||||||
|
textures = MA_TextureAtlasserProUtils.ExportAtlasTextures(curWindow.textureAtlas, curWindow.textureAtlas.exportSettings.textureExportSettings);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(curWindow.textureAtlas.exportSettings.exportMaterials)
|
||||||
|
{
|
||||||
|
material = MA_TextureAtlasserProUtils.ExportAtlasMaterial(curWindow.textureAtlas, curWindow.textureAtlas.exportSettings.materialExportSettings, textures: textures);
|
||||||
|
}
|
||||||
|
|
||||||
|
if(curWindow.textureAtlas.exportSettings.exportModels)
|
||||||
|
{
|
||||||
|
models = MA_TextureAtlasserProUtils.ExportAtlasModels(curWindow.textureAtlas, curWindow.textureAtlas.exportSettings.modelExportSettings, material: material);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
GUI.enabled = wasEnabled;
|
GUI.enabled = wasEnabled;
|
||||||
@ -164,7 +196,7 @@ namespace MA_TextureAtlasserPro
|
|||||||
GUILayout.EndHorizontal();
|
GUILayout.EndHorizontal();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void DrawExportAdvancedOptions()
|
private void DrawExportOptions()
|
||||||
{
|
{
|
||||||
bool wasEnabled = GUI.enabled;
|
bool wasEnabled = GUI.enabled;
|
||||||
|
|
||||||
@ -179,18 +211,37 @@ namespace MA_TextureAtlasserPro
|
|||||||
|
|
||||||
EditorGUILayout.BeginVertical(EditorStyles.helpBox);
|
EditorGUILayout.BeginVertical(EditorStyles.helpBox);
|
||||||
|
|
||||||
GUILayout.Label("Models:", EditorStyles.miniBoldLabel);
|
curWindow.textureAtlas.exportSettings.exportModels = GUILayout.Toggle(curWindow.textureAtlas.exportSettings.exportModels, "Models:", EditorStyles.toggle);
|
||||||
curWindow.textureAtlas.exportSettings.modelExportSettings.modelFormat = (ModelFormat)EditorGUILayout.EnumPopup("ModelFormat:", curWindow.textureAtlas.exportSettings.modelExportSettings.modelFormat);
|
curWindow.textureAtlas.exportSettings.modelExportSettings.modelFormat = (ModelFormat)EditorGUILayout.EnumPopup("ModelFormat:", curWindow.textureAtlas.exportSettings.modelExportSettings.modelFormat);
|
||||||
curWindow.textureAtlas.exportSettings.modelExportSettings.replaceModel = EditorGUILayout.Toggle("ReplaceModels:", curWindow.textureAtlas.exportSettings.modelExportSettings.replaceModel);
|
|
||||||
curWindow.textureAtlas.exportSettings.modelExportSettings.uvFlipY = EditorGUILayout.Toggle("UV FlipY:", curWindow.textureAtlas.exportSettings.modelExportSettings.uvFlipY);
|
curWindow.textureAtlas.exportSettings.modelExportSettings.uvFlipY = EditorGUILayout.Toggle("UV FlipY:", curWindow.textureAtlas.exportSettings.modelExportSettings.uvFlipY);
|
||||||
curWindow.textureAtlas.exportSettings.modelExportSettings.uvChannel = EditorGUILayout.IntField("UV Channel:", curWindow.textureAtlas.exportSettings.modelExportSettings.uvChannel);
|
curWindow.textureAtlas.exportSettings.modelExportSettings.uvChannel = EditorGUILayout.IntField("UV Channel:", curWindow.textureAtlas.exportSettings.modelExportSettings.uvChannel);
|
||||||
curWindow.textureAtlas.exportSettings.modelExportSettings.uvWrap = EditorGUILayout.Toggle("UV Wrap:", curWindow.textureAtlas.exportSettings.modelExportSettings.uvWrap);
|
curWindow.textureAtlas.exportSettings.modelExportSettings.uvWrap = EditorGUILayout.Toggle("UV Wrap:", curWindow.textureAtlas.exportSettings.modelExportSettings.uvWrap);
|
||||||
|
|
||||||
GUILayout.Label("Textures:", EditorStyles.miniBoldLabel);
|
curWindow.textureAtlas.exportSettings.exportTextures = GUILayout.Toggle(curWindow.textureAtlas.exportSettings.exportTextures, "Textures:", EditorStyles.toggle);
|
||||||
curWindow.textureAtlas.exportSettings.textureExportSettings.textureFormat = (TextureFormat)EditorGUILayout.EnumPopup("TextureFormat:", curWindow.textureAtlas.exportSettings.textureExportSettings.textureFormat);
|
curWindow.textureAtlas.exportSettings.textureExportSettings.textureFormat = (TextureFormat)EditorGUILayout.EnumPopup("TextureFormat:", curWindow.textureAtlas.exportSettings.textureExportSettings.textureFormat);
|
||||||
curWindow.textureAtlas.exportSettings.textureExportSettings.textureType = (TextureType)EditorGUILayout.EnumPopup("TextureType:", curWindow.textureAtlas.exportSettings.textureExportSettings.textureType);
|
curWindow.textureAtlas.exportSettings.textureExportSettings.textureType = (TextureType)EditorGUILayout.EnumPopup("TextureType:", curWindow.textureAtlas.exportSettings.textureExportSettings.textureType);
|
||||||
curWindow.textureAtlas.exportSettings.textureExportSettings.textureScaleMode = (MA_TextureUtils.TextureScaleMode)EditorGUILayout.EnumPopup("TextureScaleMode:", curWindow.textureAtlas.exportSettings.textureExportSettings.textureScaleMode);
|
curWindow.textureAtlas.exportSettings.textureExportSettings.textureScaleMode = (MA_TextureUtils.TextureScaleMode)EditorGUILayout.EnumPopup("TextureScaleMode:", curWindow.textureAtlas.exportSettings.textureExportSettings.textureScaleMode);
|
||||||
|
|
||||||
|
curWindow.textureAtlas.exportSettings.exportMaterials = GUILayout.Toggle(curWindow.textureAtlas.exportSettings.exportMaterials, "Materials:", EditorStyles.toggle);
|
||||||
|
curWindow.textureAtlas.exportSettings.materialExportSettings.shader = (Shader)EditorGUILayout.ObjectField("Shader:", curWindow.textureAtlas.exportSettings.materialExportSettings.shader, typeof(UnityEngine.Shader), false);
|
||||||
|
|
||||||
|
scrollPos = EditorGUILayout.BeginScrollView(scrollPos, false, false, GUILayout.ExpandWidth(true), GUILayout.ExpandHeight(true));
|
||||||
|
for (int i = 0; i < curWindow.textureAtlas.exportSettings.materialExportSettings.shaderPropertyNames.Count; i++)
|
||||||
|
{
|
||||||
|
GUILayout.BeginHorizontal();
|
||||||
|
curWindow.textureAtlas.exportSettings.materialExportSettings.shaderPropertyNames[i] = EditorGUILayout.TextField("", curWindow.textureAtlas.exportSettings.materialExportSettings.shaderPropertyNames[i]);
|
||||||
|
if (GUILayout.Button("-", EditorStyles.miniButtonLeft, GUILayout.ExpandWidth(false)))
|
||||||
|
{
|
||||||
|
curWindow.textureAtlas.exportSettings.materialExportSettings.shaderPropertyNames.RemoveAt(i);
|
||||||
|
}
|
||||||
|
if (GUILayout.Button("+", EditorStyles.miniButtonRight, GUILayout.ExpandWidth(false)))
|
||||||
|
{
|
||||||
|
curWindow.textureAtlas.exportSettings.materialExportSettings.shaderPropertyNames.Insert(i + 1, "");
|
||||||
|
}
|
||||||
|
GUILayout.EndHorizontal();
|
||||||
|
}
|
||||||
|
EditorGUILayout.EndScrollView();
|
||||||
|
|
||||||
EditorGUILayout.EndVertical();
|
EditorGUILayout.EndVertical();
|
||||||
|
|
||||||
GUI.enabled = wasEnabled;
|
GUI.enabled = wasEnabled;
|
||||||
|
@ -17,12 +17,9 @@ namespace MA_Mesh
|
|||||||
{
|
{
|
||||||
public static class MA_MeshUtils
|
public static class MA_MeshUtils
|
||||||
{
|
{
|
||||||
public static void MA_SaveMeshAsset(Mesh mesh, string savePath, string meshName = "")
|
public static string MA_SaveMeshAsset(Mesh mesh, string meshName, string savePath)
|
||||||
{
|
{
|
||||||
Mesh newMesh = new Mesh();
|
Mesh newMesh = mesh;
|
||||||
newMesh.SetVertices(new List<Vector3>(mesh.vertices));
|
|
||||||
newMesh.SetTriangles(mesh.triangles, 0);
|
|
||||||
newMesh.SetUVs(0, new List<Vector2>(mesh.uv));
|
|
||||||
|
|
||||||
if(meshName == "")
|
if(meshName == "")
|
||||||
{
|
{
|
||||||
@ -33,8 +30,49 @@ namespace MA_Mesh
|
|||||||
newMesh.name = meshName;
|
newMesh.name = meshName;
|
||||||
}
|
}
|
||||||
|
|
||||||
AssetDatabase.CreateAsset(newMesh, savePath);
|
string assetPath = savePath + newMesh.name + ".asset";
|
||||||
|
|
||||||
|
AssetDatabase.CreateAsset(newMesh, assetPath);
|
||||||
AssetDatabase.SaveAssets();
|
AssetDatabase.SaveAssets();
|
||||||
|
|
||||||
|
return assetPath;
|
||||||
|
}
|
||||||
|
|
||||||
|
public static string MA_SaveMeshPrefab(Mesh mesh, string meshName, string savePath, string material)
|
||||||
|
{
|
||||||
|
string assetPath = "";
|
||||||
|
|
||||||
|
if (meshName == "")
|
||||||
|
{
|
||||||
|
meshName = mesh.name;
|
||||||
|
}
|
||||||
|
|
||||||
|
string meshPath = MA_SaveMeshAsset(mesh, meshName, savePath);
|
||||||
|
Mesh curMesh = AssetDatabase.LoadAssetAtPath<Mesh>(meshPath);
|
||||||
|
|
||||||
|
if (curMesh != null)
|
||||||
|
{
|
||||||
|
GameObject gameObject = new GameObject
|
||||||
|
{
|
||||||
|
name = meshName
|
||||||
|
};
|
||||||
|
|
||||||
|
gameObject.AddComponent<MeshFilter>().mesh = curMesh;
|
||||||
|
gameObject.AddComponent<MeshRenderer>();
|
||||||
|
|
||||||
|
Material curMaterial = AssetDatabase.LoadAssetAtPath<Material>(material);
|
||||||
|
if (curMaterial != null)
|
||||||
|
{
|
||||||
|
gameObject.GetComponent<MeshRenderer>().material = curMaterial;
|
||||||
|
}
|
||||||
|
|
||||||
|
assetPath = savePath + meshName + ".prefab";
|
||||||
|
PrefabUtility.SaveAsPrefabAsset(gameObject, assetPath);
|
||||||
|
|
||||||
|
UnityEngine.GameObject.DestroyImmediate(gameObject);
|
||||||
|
}
|
||||||
|
|
||||||
|
return assetPath;
|
||||||
}
|
}
|
||||||
|
|
||||||
public static Mesh MA_DuplicateMesh(Mesh mesh)
|
public static Mesh MA_DuplicateMesh(Mesh mesh)
|
||||||
@ -199,12 +237,18 @@ namespace MA_Mesh
|
|||||||
return sb.ToString();
|
return sb.ToString();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void MeshToFile(Mesh mesh, string filename, string savePath)
|
public static string MeshToFile(Mesh mesh, string filename, string savePath)
|
||||||
{
|
{
|
||||||
using (StreamWriter sw = new StreamWriter(savePath + filename + ".obj"))
|
string assetPath = savePath + filename + ".obj";
|
||||||
|
|
||||||
|
using (StreamWriter sw = new StreamWriter(assetPath))
|
||||||
{
|
{
|
||||||
sw.Write(MeshToString(mesh));
|
sw.Write(MeshToString(mesh));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AssetDatabase.Refresh();
|
||||||
|
|
||||||
|
return assetPath;
|
||||||
}
|
}
|
||||||
//End
|
//End
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user