블로그 이미지
Every unexpected event is a path to learning for you. blueasa

카테고리

분류 전체보기 (2859)
Unity3D (898)
Programming (479)
Server (33)
Unreal (4)
Gamebryo (56)
Tip & Tech (192)
협업 (64)
3DS Max (3)
Game (12)
Utility (142)
Etc (99)
Link (34)
Portfolio (19)
Subject (90)
iOS,OSX (53)
Android (16)
Linux (5)
잉여 프로젝트 (2)
게임이야기 (3)
Memories (20)
Interest (38)
Thinking (38)
한글 (30)
PaperCraft (5)
Animation (408)
Wallpaper (2)
재테크 (19)
Exercise (3)
나만의 맛집 (3)
냥이 (10)
육아 (16)
Total
Today
Yesterday

NGUI UILabel BBCode

Unity3D/NGUI / 2014. 12. 31. 14:15

The use of Unity3d NGUI (two) (UILabel Chinese font and click on the font)

Unity3d NGUI can create font can click effect, click on the open web links

There are Chinese font display, can direct call system built-in fonts, does not need the third party font support


UILabel (Script parameters)


The first font options, NGUI is using a static font, when we need to show Chinese, it is best to use dynamic fonts, or you can create static font set

Font Size: font size

Material: The font textures, such as the need for font color

Text: Display content

Overflow: Filler content options, 1, ShrinkContent (content based filling) 2, ClampContent (in the font for the base shear)

3, ResizeFreely (content as the base level for filling) 4, with content high as reference for filling

Alignment: Alignment, font

Keep crisp: Dynamic font sharpening

Gradient: Font change

Effect: The fonts

Spaceing: Font spacing

Max Lines: The number of rows to display font

BBCode: Use the NGUI custom formatting font font


1, Create Chinese font

A. first creates a UILabel in Widget Tool

B. in the NGUI inspector window, select Unity UILabel, then select Font-Arial

C. We are now using dynamic fonts, can display Chinese


2, Create a link font

A. need to add the click event UILabel add a Script

	void OnClick ()
	{
		UILabel lbl = GetComponent<UILabel>();
		
		if (lbl != null)
		{
			string url = lbl.GetUrlAtPosition(UICamera.lastHit.point);
			if (!string.IsNullOrEmpty(url)) Application.OpenURL(url);
		}
	}

The B. for the current UILabel add a Box Collider, adjust the Box Collider size for the current UILabel window size 

The Is Trigger option is on the hook


C. NGUI currently supports formatting font three, 1 ([b]bold[/b] display effect dynamic font changes) 2 ([u]underline[/u] underline

[s]strikethrough[/s] Delete line) 3 ([url=http://www.tasharen.com/][u]clickable hyperlinks[/u][/url] add a web link)


Show all formatting, click clickable to open the link



The use of Unity3d NGUI (two) (UILabel Chinese font and click on the font)


출처 : http://www.programering.com/a/MTO2gDNwATU.html

반응형

'Unity3D > NGUI' 카테고리의 다른 글

Coloring individual characters in an NGUI UILabel text  (0) 2014.12.31
NGUI UILabel Reference  (0) 2014.12.31
PSD Layers to PNG Files(PSD2PNGs)  (0) 2014.12.31
PSD Layers to 2D Tool Kit(PSD2TK2D)  (0) 2014.12.31
PSD Layers to NGUI(PSD2NGUI)  (0) 2014.12.31
Posted by blueasa
, |


홈페이지 링크 : http://www.magicnreal.com/



PSD Layers to PNG Files

카테고리:에디터 익스텐션/유틸리티
퍼블리셔:Magic n Real
평가하기:
평가가 충분하지 않습니다

가격:$10

이 익스텐션은 사용하는 유니티당 하나씩의 라이센스가 필요합니다.

유니티 3.4.2 이상의 버전이 필요합니다.

Extracts PSD layers from your Photoshop files directly to PNG files in Unity!
A fantastic time-saving utility!

Email: gblue1223@gmail.com
Forum


반응형

'Unity3D > NGUI' 카테고리의 다른 글

NGUI UILabel Reference  (0) 2014.12.31
NGUI UILabel BBCode  (0) 2014.12.31
PSD Layers to 2D Tool Kit(PSD2TK2D)  (0) 2014.12.31
PSD Layers to NGUI(PSD2NGUI)  (0) 2014.12.31
NGUI - scroll view 재사용 객체  (0) 2014.12.16
Posted by blueasa
, |

홈페이지 링크 : http://www.magicnreal.com/


에셋스토어 링크 : https://www.assetstore.unity3d.com/kr/#!/content/2842



PSD Layers to 2D Tool Kit

카테고리:에디터 익스텐션/유틸리티
퍼블리셔:Magic n Real
평가하기:
(4)

가격:$20

이 익스텐션은 사용하는 유니티당 하나씩의 라이센스가 필요합니다.

유니티 4.5.0 이상의 버전이 필요합니다.

Convert PSD layers to 2D Toolkit Sprite format in just one click!

Check the screen shots below for more information. Easy-to-use and intuitive
interface.

Important: You must have 2D Toolkit to use this.
Note: Now It's support 2D Tool Kit 2.4 and Unity4.5

Email: gblue1223@gmail.com
Forum


반응형

'Unity3D > NGUI' 카테고리의 다른 글

NGUI UILabel BBCode  (0) 2014.12.31
PSD Layers to PNG Files(PSD2PNGs)  (0) 2014.12.31
PSD Layers to NGUI(PSD2NGUI)  (0) 2014.12.31
NGUI - scroll view 재사용 객체  (0) 2014.12.16
NGUI용 Virtual Joystick Script「UIJoystick」  (0) 2014.08.04
Posted by blueasa
, |

링크 : http://www.magicnreal.com/psd2ngui/


유니티에셋 링크 : https://www.assetstore.unity3d.com/kr/#!/content/11220



요약

PSD2NGUI 를 이용해주셔서 감사합니다.
PSD2NGUI 는 NGUI 를 위한 자동화 툴입니다. PSD2NGUI 는 PSD Layer 들을 NGUI Widget 들로 바꾸어 줍니다. 예를 들어 label, editbox, button, checkbox, scrollview, 등을 PSD Layer 에 간단한 명령어를 삽입하는 것만으로 만들 수 있습니다. 그리고 작업자가 PSD 파일을 수정했을 때, Unity3D 에서도 수정한 결과가 그대로 반영됩니다. PSD2NGUI 를 사용한다면, 더이상 Atlas Maker, Widget, Font 툴을 이용하지 않고 편리하게 GUI 를 만들 수 있습니다. 또한 이미지를 자르기 위해 Sprite 를 세팅할 필요도 없습니다. PSD Layer 에 Slice 명령어만 붙여주면 됩니다. PSD2NGUI 를 이용하면 GUI 를 개발하는데 걸리는 시간을 굉장히 절약하실 수 있게 될겁니다.

중요: PSD2NGUI 는 NGUI(2.2.7 ~ 3.0.2) 가 있어야 작동합니다.
노트: PSD2NGUI 는 PhotoShop 없이도 사용 가능합니다.
노트: PSD2NGUI 는 PhotoShop 의 ’스마트 오브젝트 레이어’, ’라스터 이미지 레이어’, ’텍스트 레이어’ 만 지원합니다.

사용법

1. 열기

a. PSD 파일위에서 마우스 오른쪽 버튼을 클릭하면 PSD2NGUI 를 열 수 있습니다.

b. NGUI 메뉴에서 마우스 오른쪽 버튼을 클릭하면 PSD2NGUI 를 열 수 있습니다.

2. PSD 파일 추가

a. PSD Layer 에 명령어를 추가 합니다.

3. 작업 실행

a. RUN 버튼 실행.

4. 메뉴 설명

  • Load
    PSD2NGUI 설정을 로드합니다.
  • Delete
    PSD2NGUI 설정을 삭제합니다.
  • Run
    PSD Layer 를 NGUI 로 변환합니다.
  • NGUI Root
    NGUI 의 UIRoot 를 링크합니다. Run 으로 변환을 시작하면 자동으로 링크됩니다.
  • Camera
    NGUI 의 카메라 종류를 설정 합니다.
  • Target Screen Size
    배포될 디바이스의 화면 사이즈를 설정 합니다.
  • Add Font
    비트맵 폰트를 추가합니다.
  • Font Data
    비트맵 폰트 이미지의 단어별 위치 정보가 있는 텍스트파일을 넣는 곳입니다.
  • Font Texture
    비트맵 폰트의 이미지를 넣는 곳입니다.
  • Font Prefab
    생성된 NGUI 폰트의 프리팹이 들어가는 곳입니다.
    만약 [Font Data], [Font Texture] 둘중 하나라도 설정 되어있지 않으면 생성되지 않으며, 이미 존재하는 프리팹을 넣을 수도 있습니다.
    반대로, 모두 설정 되어있으면 프리팹이 생성되며, 이미 존재하는 프리팹은 새로운 데이터로 교채 됩니다.
  • Assign Font To All Labels
    NGUI Root 의 모든 자식 UILabel 에 [Font Prefab] 에서 설정한 프리팹을 넣어줍니다.
    이미 폰트가 설정되어있는 UILabel 은 무시합니다.
  • Remove Font To All Labels
    NGUI Root 의 모든 자식 UILabel 에서 폰트 설정을 삭제합니다.
  • Use One Atlas
    하나의 아트라스에 모든 이미지를 넣습니다.
    체크를 해제하면 PSD 파일별로 아트라스를 생성하게 됩니다.
  • Keep Old Sprites
    체크를 해제하면 기존의 아틀라스에 있던 이미지들은 삭제됩니다.
  • Create Controls
    체크를 해제하면 아트라스와 폰트만 만들게 됩니다.
  • Remove All
    모든 PSD 파일을 목록에서 제거합니다. 실제 파일은 지워지지 않습니다.
  • Add Font All
    아트라스를 PSD 파일마다 개별로 만들 때 각 아틀라스에 폰트 추가옵션을 한꺼번에 킨다.
  • Remove Font All
    아트라스를 PSD 파일마다 개별로 만들 때 각 아틀라스에 폰트 추가옵션을 한꺼번에 끈다.

비디오

a. 기본 사용법.

명령어

* Sub commands : 컨트롤 들을 추가 적으로 꾸미기 위한 용도로 사용하며, Label, Button, ComboBox 는 추가 하지 않아도 상관 없다.
  • Sprite

     
    ex) layerName
    만약 커맨드명이 없다면 PSD2NGUI 는 Sprite 로 가정합니다.
  • Slice

     
    ex) layerName@slice=(LeftTop)x(RightTop)x(LeftBottom)x(RightBottom)
    Layer 이름을 layerName@slice=2x2x2x2 와 같이 설정하면, PSD2NGUI 는 Layer 의 가장자리를 2픽셀의 정사각형으로 잘라낼 것입니다. 결과적으로 이미지 크기는 4x4 가 됩니다.
    Layer 이름을 layerName@slice=50%x50%x10%x10% 와 같이 설정하면. PSD2NGUI 는 백분율을 픽셀로 치환하고, 잘라낼 것입니다.
    만약 잘라낼 크기가 모두 같다면 layerName@slice=2 와 같이 한곳만 설정해줘도 됩니다.

  • Panel

     
    ex) groupName@panel
    PSD2NGUI 는 UIPanel 을 만들 것입니다. 명령어를 Group(Folder)에 해야합니다.
  • Label

     
    ex) layerName@label(혹은 명령어 없이 Text Layer)
    PSD2NGUI 는 UILabel 을 만들 것입니다.
    Sub commands.
     sameLayerName@label@color=black, layerName@label@color=ff00ff : 컬러설정
     sameLayerName@label@bold=true : 폰트를 굵게
     sameLayerName@label@shadow=true : 폰트에 그림자 추가
     sameLayerName@label@text=Hello PSD2NGUI : 보여질 문장
     sameLayerName@label@align=[topleft, top, topright, left, center, right, bottomleft, bottom, bottomright] : 텍스트 align(pivot)

     sameLayerName@label@fontsize=14 : 픽셀단위 폰트 크기
  • Button

     
    ex) layerName@button
    PSD2NGUI 는 UIButton 을 만들 것입니다.
    만일 button.hover 혹은 button.pressed 와 같은 sub-commands 가 있다면 PSD2NGUI 는 UIImageButton 을 만들 것입니다.
    Sub commands.
     sameLayerName@button.hover : 마우스오버 상태일때의 이미지
     sameLayerName@button.pressed : 마우스가 눌려졌을때의 이미지
     sameLayerName@button.label : 버튼의 제목
  • LabelButton

     
    ex) textLayer@button
    PSD2NGUI 는 글자만 있는 UIButton 을 만들 것입니다.
  • Toggle(Checkbox)

     
    ex) layerName@toggle, layerName@checkbox
    PSD2NGUI 는 UIToggle(UICheckBox) 를 만들 것입니다.
    Sub commands.
     sameLayerName@toggle(checkbox).checked : 체크되었을 때의 이미지
  • Input(EditBox)

     
    ex) layerName@input, layerName@editbox
    PSD2NGUI 는 UIEditBox 를 만들 것입니다.
  • Password

     
    ex) layerName@password
    PSD2NGUI 는 UIEditBox 를 만들고 Password 옵션을 켜둘 것입니다.
  • ComboBox

     
    ex) layerName@combobox
    PSD2NGUI 는 UIComboBox 를 만들 것입니다.
    Sub commands.
     sameLayerName@combobox.bar : 콤보박스 아이템 선택 이미지
     sameLayerName@combobox.listbg : 콤보박스 배경 이미지
  • Slider

     
    ex) layerName@hslider or layerName@vslider
    PSD2NGUI 는 UISlider 를 만들 것입니다.(Slider).
    Sub commands.
     sameLayerName@h(or v)slider.fg : Slider 의 Bar 이미지 입니다.
  • ProgressBar

     
    ex) layerName@hprogressbar or layerName@vprogressbar
    PSD2NGUI will make UISlider(Progress Bar).
    Sub commands.
     sameLayerName@h(or v)progressbar.fg : ProgressBar 의 foreground(bar) 이미지 입니다.
  • ScrollBar

     
    ex) layerName@hscrollbar or layerName@vscrollbar
    PSD2NGUI will make UIScrollBar.
    Sub commands.
     sameLayerName@h(or v)scrollbar.fg : ScrollBar 의 foreground(bar) 이미지 입니다.
  • ScrollView

     
    ex) layerName@scrollview
    PSD2NGUI 는 UIDraggablePanel 과 UIDragPanelContents 를 만들 것입니다.
    Sub commands.
     sameLayerName@scrollview.item : ScrollView 아이템. 안에는 다른 Widget 들이 들어갈 수 있습니다.
     sameLayerName@h(or v)scrollbar.bg : ScrollBar 의 background(bar) 이미지 입니다.
     sameLayerName@h(or v)scrollbar.fg : ScrollBar 의 foreground(bar) 이미지 입니다.

  • VirtualView

     
    ex) layerName@virtualview
    PSD2NGUI 는 PsdLayerVirtualView 를 만들 것입니다. ScrollView 와 다른 점은 UI 와 Data 가 분리 되었기 때문에, 방대한 데이터도 사용 가능합니다.
    Sub commands.
     sameLayerName@virtualview.item : ScrollView 아이템. 안에는 다른 Widget 들이 들어갈 수 있습니다.
     sameLayerName@h(or v)scrollbar.bg : ScrollBar 의 background(bar) 이미지 입니다.
     sameLayerName@h(or v)scrollbar.fg : ScrollBar 의 foreground(bar) 이미지 입니다.

  • SpriteFont

     
    ex) groupName@spritefont
    PSD2NGUI 는 PsdLayerSpriteFont 를 만들 것입니다. Sprite 가 간단한 폰트처럼 사용될 것입니다.

  • Animation

     
    ex) gropuName@animation@fps=30 or groupName@ani@fps=15
    PSD2NGUI 는 PsdLayerSpriteAnimation 를 만들 것입니다. 매우 단순한 애니메이션 클래스 입니다.
  • Collider

     
    ex) layerName@collider=box
    PSD2NGUI 는 BoxCollider 를 만들 것입니다. Sprite 혹은 Label 에만 적용됩니다.
  • Script

     
    ex) textLayer@script
    PSD2NGUI 는 PsdLayerUserScript 를 만들 것입니다. 멤버 변수로 data 가 있고, data 의 값은 PSD Text Layer 에서 입력했던 문자열이 들어가게 됩니다.
  • Ignore

     
    ex) layerName@ignore
    만약 Layer 에 Ignore 명령어가 붙게되면 레이어를 로드하지 않을 것입니다.

지원

Forum: PSD2NGUI


반응형
Posted by blueasa
, |

unity3d grid

Unity3D/Link / 2014. 12. 19. 17:18







grid_unity_20140227_work.zip



전 프로젝트에서 grid 렌더링이 있었는데 맥스로 작업해서 붙여도 이쁘지 않아서 그냥 손으로 만들었습니다. 기본 원리는  위, 또는 옆에서 보아도 대충 볼륨감이 있어야 되서 십자로 사각형 둘을 붙여서 만들었습니다.


제작자 : 게임코디 - 빵고등어님


출처 : http://www.gamecodi.com/board/zboard.php?id=GAMECODI_Talkdev&page=1&sn1=&divpage=1&sn=off&ss=on&sc=on&select_arrange=headnum&desc=asc&no=3035


반응형

'Unity3D > Link' 카테고리의 다른 글

[링크] Unity3D 일일 자동 빌드 하기  (0) 2016.06.14
Unity Cloud Data 소개  (0) 2015.01.20
Tree Pack(FBX)  (0) 2014.09.03
awesome-unity - UNITY 관련 자료 모음 GitHub 프로젝트  (0) 2014.08.14
유니티 짱(Unity Chan)  (0) 2014.04.11
Posted by blueasa
, |


링크 : http://jenemia.tistory.com/311

반응형
Posted by blueasa
, |



  • 1. Unity 엔진 최적화 테크닉 총정리 http://cafe.naver.com/devrookie 2014.12.08
  • 2. 1. 스크립트 최적화 2. 리소스 최적화 3. 그래픽스 최적화 4. 물리 엔진 최적화 5. 기타
  • 3. 들어가기에 앞서 본 내용은 인터넷에 공개된 다양한 참고 자료들을 바탕으로 작성 되었습니다. 유니티의 버전업에 따라서 본내용이 다를 수도 있습니다. (ex. Unity 5.x) 보다 자세한 내용은 마지막 참고자료 링크를 참조해 주세요.
  • 4. 병목지점을 파악하라
  • 5. 5 최적화의 시작은 병목 파악부터 CPU • 너무 많은 DP CALL • 복잡한 스크립트나 물리 연산 Vertex Processing • 너무 많은 버텍스들 • 버텍스당 너무 많은 연산 (버텍스 셰이더) Fragment Processing • 너무 많은 픽셀, 오버 드로우(OverDraw) • 프래그먼트당 너무 많은 연산 (프래그먼트 셰이더/픽셀 셰이더) Band Width • 크고, 압축되지 않은 텍스쳐 • 고해상도 프레임 버퍼
  • 6. 스크립트 최적화
  • 7. 7 스크립트 최적화 (1) • 유니티의 핵심 기능은 모두 C++로 제작되어 있다 • 예) Transform.position 에서 Transform은 C# 속성, position은 C++ 영역 • 유니티 객체들을 변수에 저장해서, 캐싱해서 사용하는것이 좋다. • FindObject 계열 함수들은 매우 느리다. (미리 찾아서 캐싱) • Instanitate 와 Destory 함수를 이용한 프리팹의 생성/해제는 비용이 크다 • 활성화/비활성화를 활용 -> 오브젝트 풀링 • Update 함수보다는 CoRoutine을 활용한다. • 나눗셈 보다는 곱셈이 몇 십 배 빠르다.
  • 8. 8 스크립트 최적화 (2) • 박싱과 언박싱은 부하가 큰 작업이다 • 나눗셈보다는 곱셈이 몇십배 빠르다 • magnitude 보다는 sqrMagnitude를 사용해서 비교한다. (제곱근 계산 x) • 삼각함수의 값은 상수로 저장하고, 사용하는 것이 좋다. • 문자열은 readonly 혹은 const 키워드를 사용하여, 가비지 컬렉션으로부터 벗어나도록 한다.
  • 9. 9 만흉의 원인 : 가비지 컬렉터 가비지 컬렉터(GC)는 언제 일어날지 모른다. • Mono의 동적 메모리 관리 때문에, 메모리 해제를 위해 GC가 자동 호출 된다. • GC는 언제 일어날지 모른다. • GC가 일어나면, 게임이 멈추는 현상(랙)이 발생하게 된다. • 동적 메모리 해제가 가능한 일어나지 않도록 하는것이 GC 관리의 핵심 오브젝트 풀링 • 오브젝트(or 프리팹)의 동적 생성과 해제는 부하가 크다. • 오브젝트가 해제되면, 언젠가는 GC가 동작하여 정리 한다 = 랙이 발생 • 오브젝트를 풀을 만들어 미리 많이 만들어 두고, 활성화/비활성화로 사용한다. • 풀에서 가져와서 사용하고, 사용이 끝나면 비활성화 상태로 풀에 반환 • 오브젝트 풀링 사용은 선택이 아닌 필수!!
  • 10. 10 GC에게 먹이 주지 않기 문자열 병합은 StringBuilder • 일반 String + String을 쓰면 임시 문자열이 생성됨 • StringBuilder.Append() 함수를 사용하여 병합 foreach 대신에 for문 사용 • 일반 array에 한해서… • Foreach는 한번 돌때마다 24byte의 쓰레기 메모리를 생성 • 10번만 돌아도 240byte의 GC 수거 메모리를 남김 태그 비교에는 compareTag() 사용 • If(go.tag == “enemy”) 대신에 go.compareTag(“enemy”) 사용 • 객체의 tag 프로퍼티를 호출하는것은 추가 메모리를 할당하고, 복사
  • 11. 11 GC에게 먹이 주지 않기 (2) 데이터 타입에는 Class 대신 구조체 사용 • 구조체는 GC에 들어가지 않는다. Stack에 할당 즉시 해제할 때는 Dispose 수동 호출 • 오브젝트의 dispose를 수동으로 호출하여, 즉시 cleanup 임시 객체들을 만들어내는 API들을 조심 • Ex. GetComponents<T>, Mesh.Vertices, Camra.allCameras, etc…
  • 12. 12 C++ <-> C# 오버 헤드 객체의 변경 사항을 캐싱 • 객체의 이동과 변형에 대한 처리를 캐싱하고, 매프레임에서 딱 한번만 처리한다. • Ex. Move() 컴포넌트 참조를 캐싱 • Getcomponent()는 한번만 호출하여, 객체를 캐싱해두고 사용 한다. 빈 콜백 함수는 제거 • Start()나 Update() 같은 콜백함수는 비어있어도, 성능에 영향을 끼친다.
  • 13. 리소스 최적화
  • 14. 14 권장 압축 텍스쳐 사용하기 • 아이폰(PowerVR) : PVRCT • 안드로이드(Tegra) : DXT • 안드로이드(Adreno) : ATC • 안드로이드(공통) : ETC1
  • 15. 15 텍스쳐 • 텍스쳐 사이즈는 무조건 2의 제곱이어야 한다. • POT(Power of Two) • POT가 아닌경우 POT 텍스쳐로 변환되어 로딩 된다. • 900 x 900 -> 실제로는 1024 X 1024로 변환 • 텍스쳐 아틀라스를 활용 하라. • 텍스쳐 아틀라스로 최대한 묶음 • UI 만이 아니라, 같은 재질의 오브젝트들을 묶음
  • 16. 16 텍스쳐 • 압축된 텍스쳐와 밉맵을 사용하자. (대역폭 최적화) • 32bit가 아닌 16bit 텍스쳐 사용도 상황에 맞게 고려
  • 17. 텍스쳐 메모리 사용량 프로파일링 17 //로그를 서버에 남기면 프로파일링에 도움이 된다
  • 18. 18 Mesh Import시에 언제나 “Optimize Mesh” 옵션 사용 • 변환 전/변환 후 버텍스 캐쉬를 최적화 해준다 언제나 Optimize Mesh Data 옵션을 사용한다 • Player Setting > Other Settings • 사용하지 않는 버텍스 정보들을 줄여 준다(tangents, Normal, color, etc…)
  • 19. 19 오디오 • 모바일에서 스테레오는 의미 없다. • 모두 92kb, 모노로 인코딩 • 사운드 파일을 임포트하면 디폴트로 3D 사운드로 설정 • 2D 사운드로 변경 • 압축 사운드(mp3, ogg), 비압축 사운드(wav) 구별 • 비압축 사운드 : 순간적인 효과음, 이펙트 등 • 압축 사운드 : 배경 음악
  • 20. 20 폰트 리소스 최적화 NDC2013 - ‘갤럭시S1’ 에서 풀프레임 퍼즐주주 만들기
  • 21. 21
  • 22. 22 메모리 용량을 ¼로 절약
  • 23. 23 NDC2013 - ‘갤럭시S1’ 에서 풀프레임 퍼즐주주 만들기
  • 24. 24 리소스 기타 ResourceLoadAsync() 함수는 엄청 느리다 • 게임 레벨 로드시에 사용했을 경우, 일반 함수에 비해 수십배나 느렸다.
  • 25. 그래픽스 최적화
  • 26. 26 Culling 프러스텀(Frustum) 컬링 • 각 Layer 별로 컬링 거리를 설정하는 것이 가능하다!! • 멀리 보이는 중요한 오브젝트(ex. 성, 산맥...)은 거리를 멀게 설정하고, 중요도가 낮은 풀이나 나무등은 컬링 거리를 짧게 설정
  • 27. 27 Culling 오클루젼(Occlusion) 컬링 • Window->Occlusion Culling 메뉴에서 설정 가능
  • 28. 28 오브젝트 통합(Combine) • 드로우콜은 오즈젝트에 설정된 재질의 셰이더 패스당 하나씩 일어난다. • 렌더러에 사용된 재질의 수만큼 드로우 콜이 발생 Combine (통합) • 성질이 동일한 오브젝트들은 하나의 메쉬와 재질을 사용하도록 통합 • Script 패키지 – CombineChildren 컴포넌트 제공 • 하위 오브젝트를 모두 하나로 통합 • 통합하는 경우 텍스쳐는 하나로 합쳐서, Texture Atlas를 사용해야 된다.
  • 29. 29 Batch Static Batch • Edit > Project Setting > Player 에서 설정 • 움직이지 않는 오브젝트들은 static으로 설정해서, 배칭이 되게 한다. • Static으로 설정된 게임 오브젝트에서 동일한 재질을 사용 할 경우, 자동으로 통합 • 통합되는 오브젝트를 모두 하나의 커다란 메쉬로 만들어서 따로 저장(메모리 사용량 증가) Dynamic Batch • 움직이는 물체를 대상으로 동일한 재질을 사용하는 경우, 자동으로 통합 • 동적 배칭은 계산량이 많으므로, 정점이 900개 미만인 오브젝트만 대상이 됨
  • 30. 30 라이팅 라이트 맵을 사용하자 • 고정된 라이트와 오브젝트의 경우(배경) 라이트 맵을 최대한 활용 한다. • 아주 빠르게 실행된다 (Per-Pixel Light 보다 2~3배) • 더 좋은 결과를 얻을 수 있는 GI와 Light Mapper를 사용할 수 있다. 라이트 렌더 모드 • 라이팅 별로 Render Mode : Important / Not Important 설정 가능 • 게임에서 중요한 동적 라이팅만 Important로 설정 (Per-Pixel Light) • 그렇지 않은 라이트들은 Not Important로 설정
  • 31. 31 Overdraw 화면의 한 픽셀에 두번 이상 그리게 되는 경우 (Fill rate) • DP Call의 문제만큼이나, Overdraw로 인한 프레임 저하도 중요한 문제 • 특히 2D 게임에서는 DP Call 보다 더욱 큰 문제가 된다. 기본적으로 앞에서 뒤로 그린다 • Depth testing으로 인해서 오버드로우를 방지 한다 • 하지만 알파 블렌딩이 있는 오브젝트의 경우에는 알파 소팅 문제가 발생 반투명 오브젝트의 개수의 제한을 건다 • 반투명 오브젝트는 뒤에서부터 앞으로 그려야 한다. -> Overdraw 증가 • 반투명 오브젝의 지나친 사용에는 주의해야 한다
  • 32. 32 Overdraw (2) 유티니의 Render Mode를 통한 overdraw 확인 가능
  • 33. 33 유니티 셰이더 기본 셰이더는 모바일용 셰이더 사용 • 기본 셰이더를 사용할 경우, 모바일용 셰이더를 사용. • Mobile > VertexLit은 가장 빠른 셰이더 복잡한 수학 연산 • pow, exp, log, cos, sin, tan 같은 수학 함수들은 고비용이다. • 픽셀별 그런 연산을 하나 이상 사용하지 않는 것이 좋다. • 텍스쳐 룩업테이블을 만들어서 사용하는 방법도 좋다. • 알파 테스트 연산(discard)는 느리다. • 기본적인 연산보다는 최적화 시키고 간략화시킨 공식들을 찾아서 사용할 수 있다
  • 34. 34 유니티 셰이더 (2) 실수 연산 • float : 32bit - 버텍스 변환에 사용. 아주 느린 성능 (픽셸 셰이더에서 사용은 피함) • Half : 16bit – 텍스쳐 uv에 적합. 대략 2배 빠름 • fixed : 10bit – 컬러, 라이트 계산과 같은 고성능 연산에 적합. 대략 4배 빠름 라이트 맵을 사용하자 • 고정된 라이트와 오브젝트의 경우(배경) 라이트 맵을 최대한 활용 한다. • 아주 빠르게 실행된다 (Per-Pixel Light 보다 2~3배) • 더 좋은 결과를 얻을 수 있는 GI와 Light Mapper를 사용할 수 있다.
  • 35. 물리엔진 최적화
  • 36. 36 Fixed Update 주기 조절 • FixedUpdate()는 Update와 별도로 주기적으로 불리며, 주로 물리 엔진 처리 • 디폴트는 0.02초. 즉 1초에 50번이나 호출됨 • TimeManager에서 수정 가능 • 게임에 따라, 0.2초 정도(혹은 이상)로 수정해도 문제 없음
  • 37. 37 물리 엔진 설정 Static Object • 움직이지 않는 배경 물체는, static으로 설정 충돌체의 이동 • 리지드 바디가 없는 고정 충돌체를 움직이면, CPU 부하 발생 • 이럴 경우 리지드 바디를 추가하고, IsKinematic 옵션 사용 Maximum Allowed timestep 조정 • 시스템에 부하가 걸려, 지정되 시간보다 오래 걸릴 경우, 물리 계산을 건너뛰는 설정
  • 38. 38 물리 엔진 설정 (2) Solver Iteration Count 조정 • 물리 관련 계산을 얼마나 정교하게 할지를 지정. (높을수록 정교) • Edit > Project Setting > Physics Sleep 조절 • 리지드 바디의 속력이 설정된 값보다 작을 경우, 휴면상태에 들어감 • Physics.Sleep() 함수를 이용하면, 강제 휴면 상태를 만들 수 있음
  • 39. 39 물리 엔진 스크립트 래그돌 사용 최소화 • 랙돌은 물리 시뮬레이션 루프의 영역이 아니기 때문에, 꼭 필요할때만 활성화 한다 태그 대신 레이어 • 물리 처리에서 레이어가 훨씬 유리. 성능과 메모리에서 장점을 가진다 메쉬 콜라이더는 절대 사용하지 않는다. 레이캐스트와 Sphere Check 같은 충돌 감지 요소를 최소화
  • 40. 40 Tilemap Collision Mesh 2D 게임에서 타일맵의 Collison Mesh를 최적화하라 • Tilemap을 디폴트로 사용해서, 각 타일별로 충돌 메쉬가 있는 경우, 물리 부하가 커진다 • 연결된 Tilemap을 하나의 Collision Mesh로 물리 연산을 최적화 하라
  • 41. 참고 자료 • Unity 3D 최적화 http://www.uzoo.in/?mid=master_codesnippet&order_type=desc&document_srl=539&listStyle=viewer • 유니티3D 게임 리소스 최적화? 3가지만 기억해라 HTTP://TECHHOLIC.CO.KR/ARCHIVES/17907 • Optimizing Graphics Performance on Unity : 유니티에서 그래픽 성능 최적화 하기 http://smilemugi.net/wordpress/archives/227 • "14일만에 0에서 60프레임 만들기" Unity3D를 사용하여 우리의 게임을 최적화시키면서 배웠던 것들 • 유니티가 당신에게 알려주지 않는 것들 http://www.slideshare.net/MrDustinLee/ss-27739454?related=3 • NDC2013 - ‘갤럭시S1’ 에서 풀프레임 퍼즐주주 만들기 http://www.slideshare.net/olambdao/unity3d-2d-20130424?related=1 • Unite 2013 optimizing unity games for mobile platforms http://www.slideshare.net/hnam7/unite-2013-optimizing-unity-games-for-mobile-platforms-37933478 • Optimizing unity games (Google IO 2014) • Unity Internals: Memory and Performance



반응형
Posted by blueasa
, |

* Memory 해제 관련...

*. Prefab 을 public GameObject variable 로 연결하면 1개가 살아있다...
     - Resource 로 옮기고 Resource.Load 후 Instantiate 해준다음 Resource.UnloadUnusedAsset으로 로드했던 prefab을 해제시키자.


* Texture

- WWW 혹은 다른곳에서 load 한 texture 들은 사용하지 않을때 DestroyImmediate 로 꼭 해제시켜줘야 한다. DestroyImmediate 해주면 바로 memory 에서 해제된다.


*. GameObject Destroy 는 memory 를 바로 해제시키지 않는다.
     - Resource.UnloadUnusedAssets 를 해야 memory 에서 해제된다.
     - GameObject 를 DestroyImmediate 해도 포함되있는 Texture, material, 등은 memory에서 해제되지 않는다.

*. Load 한 Texture 들을 Member 로 가지고 있으면 GameObject Destroy 시 memory 해제 안된다.
     - Texture 는 개별 DestroyImmediate 하여 바로바로 해제하자.



출처 : http://limchaeng.tistory.com/35

반응형
Posted by blueasa
, |
IEnumerator fImageDownCheck() {

WWW www = new WWW(_url);
yield return www;

if(www.size == 0) {
mImage = true;
StopCoroutine("fImageDownCheck");
}  else {
noticeManager.fNoticeTextureMake(www.texture);
Debug.Log("Image Save");
//	Texture2D savedTexture = _materialToSave.mainTexture as Texture2D;
       Texture2D newTexture = new Texture2D(www.texture.width, www.texture.height, TextureFormat.ARGB32, false);
 
             newTexture.SetPixels(0,0, www.texture.width, www.texture.height, www.texture.GetPixels());
       newTexture.Apply();
             byte[] bytes = newTexture.EncodeToPNG();
Debug.Log(bytes);
            File.WriteAllBytes(Application.temporaryCachePath+"/"+"test.png", bytes);
}
}
Application.temporaryCachePath 폴더 : /var/folders/dy/********************/T/DefaultCompany/ProjectName 에 저장 됩니다.




출처 : http://gods2000.tistory.com/67

반응형

'Unity3D > Script' 카테고리의 다른 글

다중 해상도 비율 고정 카메라  (0) 2015.04.21
timeScale Lerp for Unity 3D: Custom Time Manager  (0) 2015.03.09
Load Textrue with WWW  (0) 2014.12.02
OnGUI() 상에서 마우스 더블 클릭 구현  (0) 2014.11.20
LightMap 동적 로딩.  (0) 2014.10.01
Posted by blueasa
, |

Load Textrue with WWW

Unity3D/Script / 2014. 12. 2. 00:59

[WWW.texture] : http://docs.unity3d.com/ScriptReference/WWW-texture.html

using UnityEngine;
using System.Collections;

public class ExampleClass : MonoBehaviour {
    public string url = "http://images.earthcam.com/ec_metros/ourcams/fridays.jpg";
    IEnumerator Start() {
        WWW www = new WWW(url);
        yield return www;
        renderer.material.mainTexture = www.texture;
    }
}



[WWW.LoadImageIntoTexture] : http://docs.unity3d.com/ScriptReference/WWW.LoadImageIntoTexture.html

	// Continuously get the latest webcam shot from outside "Friday's" in Times Square
	// and DXT compress them at runtime
	var url = "http://images.earthcam.com/ec_metros/ourcams/fridays.jpg";

function Start () { // Create a texture in DXT1 format renderer.material.mainTexture = new Texture2D(4, 4, TextureFormat.DXT1, false); while(true) { // Start a download of the given URL var www = new WWW(url);

// wait until the download is done yield www;

// assign the downloaded image to the main texture of the object www.LoadImageIntoTexture(renderer.material.mainTexture); } }


반응형
Posted by blueasa
, |