利用unity3d分離圖集

本期視頻演講稿
https://www.bilibili.com/video/bv1C54y1W7vn

最近正在進行U3D項目移植到h5平臺,在移植UI圖集時,需要將分離圖集
那麼如何將下圖分離成小圖?

最終移植效果遊戲在線試玩http://www.4399.com/flash/217641.htm
在這裏插入圖片描述
分離後
在這裏插入圖片描述


操作步驟

在u3d中選擇圖片,設置爲可讀可寫模式,模式爲multiple
在這裏插入圖片描述
使用spriteEditor自動劃分圖集邊界
在這裏插入圖片描述


在這裏插入圖片描述
完成
在這裏插入圖片描述
分離圖集的工具


using UnityEngine;
using System.Collections;
using UnityEditor;
using System.IO;
using System.Collections.Generic;
using UnityEngine.UI;

public static class ImageSlicer
{
   
   
    [MenuItem("Assets/ImageSlicer/Process to Sprites")]
    static void ProcessToSprite()
    {
   
   
        Texture2D image = Selection.activeObject as Texture2D;//獲取旋轉的對象
        string rootPath = Path.GetDirectoryName(AssetDatabase.GetAssetPath(image));//獲取路徑名稱
        string path = rootPath + "/" + image.name + ".PNG";//圖片路徑名稱


        TextureImporter texImp = AssetImporter.GetAtPath(path) as TextureImporter;//獲取圖片入口


        AssetDatabase.CreateFolder(rootPath, image.name);//創建文件夾


        foreach (SpriteMetaData metaData in texImp.spritesheet)//遍歷小圖集
        {
   
   
            Texture2D myimage = new Texture2D((int)metaData.rect.width, (int)metaData.rect.height);

            //abc_0:(x:2.00, y:400.00, width:103.00, height:112.00)
            for (int y = (int)metaData.rect.y; y < metaData.rect.y + metaData.rect.height; y++)//Y軸像素
            {
   
   
                for (int x = (int)metaData.rect.x; x < metaData.rect.x + metaData.rect.width; x++)
                    myimage.SetPixel(x - (int)metaData.rect.x, y - (int)metaData.rect.y, image.GetPixel(x, y));
            }


            //轉換紋理到EncodeToPNG兼容格式
            if (myimage.format != TextureFormat.ARGB32 && myimage.format != TextureFormat.RGB24)
            {
   
   
                Texture2D newTexture = new Texture2D(myimage.width, myimage.height);
                newTexture.SetPixels(myimage.GetPixels(0), 0);
                myimage = newTexture;
            }
            var pngData = myimage.EncodeToPNG();


            //AssetDatabase.CreateAsset(myimage, rootPath + "/" + image.name + "/" + metaData.name + ".PNG");
            File.WriteAllBytes(rootPath + "/" + image.name + "/" + metaData.name + ".PNG", pngData);
            // 刷新資源窗口界面
           
        }

        AssetDatabase.Refresh();
    }



    [MenuItem("Assets/ImageSlicer/Process to Sprites Ugui Iamge")]
    static void ProcessToSpriteUguiImage()
    {
   
   

        // string rootPath = Path.GetDirectoryName(AssetDatabase.GetAssetPath(image));//獲取路徑名稱
        string path = Application.dataPath + "/ExpUGUIIMAGE";// + image.name + ".PNG";//圖片路徑名稱

        AssetDatabase.CreateFolder(Application.dataPath, path);//創建文件夾
        foreach (var item in Selection.objects)
        {
   
   

            var myimage = (item as GameObject).GetComponent<Image>().sprite;
            //轉換紋理到EncodeToPNG兼容格式
            //if (myimage.format != TextureFormat.ARGB32 && myimage.format != TextureFormat.RGB24)
            //{
   
   
            //    Texture2D newTexture = new Texture2D(myimage.width, myimage.height);
            //    newTexture.SetPixels(myimage.GetPixels(0), 0);
            //    myimage = newTexture;
            //}
            //var pngData =  myimage.texture.EncodeToPNG();

            //TextureImporter texImp = AssetImporter.GetAtPath(path) as TextureImporter;

            //texImp.isReadable = true;
            //texImp.


            var pngData = myimage.texture.EncodeToPNG();

            //AssetDatabase.CreateAsset(myimage, rootPath + "/" + image.name + "/" + metaData.name + ".PNG");


            File.WriteAllBytes(path + "/" + myimage.name + ".png", pngData);
        }
        


      


      
        AssetDatabase.Refresh();
    }
}

本期內容講解完畢,感謝觀看
在這裏插入圖片描述

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