unity-UI-RawImage-SetNativeSize

在untiy ui的圖片格式選擇問題上我們一般會選擇sprite橡类,但是在遇到大尺寸圖片時sprite會占用非常大的存儲空間,增大包體芽唇,如果你把圖片格式改為texture會發(fā)現(xiàn)圖片大小減少很多顾画,但是Image不能選擇texture資源,這時可以選擇RawImage代替Image披摄,RawImage可以使用texture資源亲雪,但是RawImage使用SetNativeSize時發(fā)現(xiàn)由于untiy會對導(dǎo)入的圖片資源進行處理,如果選擇texture格式會強行將分辨率改為2的次方大小的疚膊,RawImage設(shè)置為初始尺寸后發(fā)現(xiàn)會按照導(dǎo)入后圖片的分辨率來設(shè)置而不是根據(jù)圖片的原始尺寸設(shè)置大小义辕,由于美術(shù)出圖時很少會按照2的次方大小來出圖,所有還需要切到windows中查看圖片分辨率寓盗,再去設(shè)置(寫好長灌砖,手好酸,好難過璧函,不想寫了,代碼很簡單基显,也不需要注釋)蘸吓,身為一個懶比,抵制這種操作撩幽,下面是代碼:

    ///rawImage拓展方法
    //setActiveSize
    [MenuItem("CONTEXT/RawImage/SetNativeSize")]
    public static void SetRawImageNativeSize(){
        GameObject[] gos = Selection.gameObjects;
        //Debug.Log ("go name:" + gos [0].name);
        System.DateTime startTime = System.DateTime.Now;
        for (int i = 0; i < gos.Length; i++) {
            GameObject go = gos [i];
            Texture t = go.GetComponent<RawImage> ().texture;
            if (t == null) {
                Debug.LogError ("raw image 未選擇圖片");
                return;
            } else {
                string path = AssetDatabase.GetAssetPath (t);
                TextureImporter textureimporter = AssetImporter.GetAtPath (path) as TextureImporter;
                TextureImporterType type = textureimporter.textureType;
                textureimporter.textureType = TextureImporterType.Sprite;
                AssetDatabase.ImportAsset(path);
                Sprite sprite = AssetDatabase.LoadAssetAtPath<Sprite> (path);
                Rect rect = sprite.rect;
                textureimporter.textureType = type;
                AssetDatabase.ImportAsset (path);
                (go.transform as RectTransform).sizeDelta = new Vector2(rect.width , rect.height);
                
            }
        }
        System.DateTime endtime = System.DateTime.Now;
        double time = (endtime - startTime).TotalSeconds ;
        Debug.Log ("total seconds:" + time.ToString ("f2") + "s");
    }
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末库继,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子窜醉,更是在濱河造成了極大的恐慌宪萄,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,042評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件榨惰,死亡現(xiàn)場離奇詭異拜英,居然都是意外死亡,警方通過查閱死者的電腦和手機琅催,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評論 2 384
  • 文/潘曉璐 我一進店門居凶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人藤抡,你說我怎么就攤上這事侠碧。” “怎么了杰捂?”我有些...
    開封第一講書人閱讀 156,674評論 0 345
  • 文/不壞的土叔 我叫張陵舆床,是天一觀的道長。 經(jīng)常有香客問我嫁佳,道長挨队,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,340評論 1 283
  • 正文 為了忘掉前任蒿往,我火速辦了婚禮盛垦,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘瓤漏。我一直安慰自己腾夯,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 65,404評論 5 384
  • 文/花漫 我一把揭開白布蔬充。 她就那樣靜靜地躺著蝶俱,像睡著了一般。 火紅的嫁衣襯著肌膚如雪饥漫。 梳的紋絲不亂的頭發(fā)上榨呆,一...
    開封第一講書人閱讀 49,749評論 1 289
  • 那天,我揣著相機與錄音庸队,去河邊找鬼积蜻。 笑死闯割,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的竿拆。 我是一名探鬼主播宙拉,決...
    沈念sama閱讀 38,902評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼丙笋!你這毒婦竟也來了谢澈?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,662評論 0 266
  • 序言:老撾萬榮一對情侶失蹤不见,失蹤者是張志新(化名)和其女友劉穎澳化,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體稳吮,經(jīng)...
    沈念sama閱讀 44,110評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,451評論 2 325
  • 正文 我和宋清朗相戀三年井濒,在試婚紗的時候發(fā)現(xiàn)自己被綠了灶似。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,577評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡瑞你,死狀恐怖酪惭,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情者甲,我是刑警寧澤春感,帶...
    沈念sama閱讀 34,258評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站虏缸,受9級特大地震影響鲫懒,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜刽辙,卻給世界環(huán)境...
    茶點故事閱讀 39,848評論 3 312
  • 文/蒙蒙 一窥岩、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧宰缤,春花似錦颂翼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至氧骤,卻和暖如春呻疹,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背语淘。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評論 1 264
  • 我被黑心中介騙來泰國打工诲宇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留际歼,地道東北人。 一個月前我還...
    沈念sama閱讀 46,271評論 2 360
  • 正文 我出身青樓姑蓝,卻偏偏與公主長得像鹅心,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子纺荧,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 43,452評論 2 348

推薦閱讀更多精彩內(nèi)容