메뉴 건너뛰기

게임
2020.11.20 21:22

스프라이트 하프 밉맵

조회 수 201 추천 수 0 댓글 0


Honeycam 2020-11-20 20-48-32.gif

가운데가 하프밉맵 적용한 오브젝트.

 

다른 스프라이트는 해상도에 따라서 좀 흐려져도 그러려니 하지만

주인공만은 어떻게든 선명하게 보여주고 싶었다.

 

하지만 밉맵은 1/2 사이즈로 점차 줄어드니까 그 사이에 있는 1.5 / 2에서는 좀 덜 선명한 상황 발생.

그렇다면 그 1.5 / 2에도 밉맵을 추가하면 어떨까 싶어서 만들어본 기능.

 

카메라 높이나 게임 해상도가 변화하면 이벤트 받아서 현재 화면상의 스프라이트 크기를 구해서

원본 스프라이트와 0.75배 스프라이트 중에서 골라서 LateUpdate에서 반영하도록 하였다.

 

무작정 사이즈만 0.75배로 줄인 텍스쳐를 만들면 유니티가 Non power of two라면서 신경질내므로 전용 스프라이트 아틀라스를 또 하나 뽑아줘야한다.

그리고 0.75배 텍스쳐는 Pixels Per Unit도 원본 텍스쳐의 75%로 해주어야 한다.

 

스프라이트 한 장 한 장을 매핑해서 Dictionary에 등록해주기 너무 귀찮았으므로 그냥 스프라이트 이름으로 구분하도록 하였다.

 

조잡함!

 

 


using System.Collections;
using System.Collections.Generic;
using UnityEngine;

 

public class HalfMipmapSprite : MonoBehaviour {

 

    public SpriteRenderer _sRenderer;

    public Sprite[] halfMipmapSpriteList;
    private Dictionary<int, Sprite> spriteNameToSpriteDic = new Dictionary<int, Sprite>();

    
    public int originalMipmapLevel;
    [ReadOnly]
    public float currentSize;
    [ReadOnly]
    public int applyingLevel;
    [ReadOnly]
    public Vector2[] mipmapRanges;

    private float originalSize;

    private void Reset() {
        if (_sRenderer == null) _sRenderer = GetComponent<SpriteRenderer>();
    }

    private void Awake() {
        for (int i = 0; i < halfMipmapSpriteList.Length; i++) {
            spriteNameToSpriteDic.Add(halfMipmapSpriteList[i].name.GetHashCode(), halfMipmapSpriteList[i]);
        }

        originalSize = _sRenderer.sprite.rect.size.x;
        
        int totalLength = originalMipmapLevel + originalMipmapLevel - 1;
        float unitSize = originalSize / totalLength;
        
        float[] sizes = new float[totalLength];

        float tempSize = originalSize;
        for (int i = sizes.Length - 1; i >= 0; i--) {
            if (i % 2 == 0) {
                sizes[i] = tempSize;
                tempSize = tempSize * 0.5f;
            } else {
                sizes[i] = (tempSize + tempSize * 2) * 0.5f;
            }
        }

        mipmapRanges = new Vector2[totalLength];
        float midSize = 0;
        for (int i = 0; i < mipmapRanges.Length; i++) {
            float tempNewMidSize = 99999;
            if (i + 1 < mipmapRanges.Length) tempNewMidSize = (sizes[i] + sizes[i + 1]) * 0.5f;
            mipmapRanges[i] = new Vector2(midSize, tempNewMidSize);
            midSize = tempNewMidSize;
        }

 

 

        GameManager.gameResolutionChangeDGT += OnResolutionChangeEvent;
        GameManager.mainCameraManageUpdateDGT += OnResolutionChangeEvent;


    }


    private void OnDestroy() {


        GameManager.gameResolutionChangeDGT -= OnResolutionChangeEvent;
        GameManager.mainCameraManageUpdateDGT -= OnResolutionChangeEvent;

 


    }

    
    private void OnResolutionChangeEvent() {
        Vector2 spriteSize = _sRenderer.sprite.rect.size;
        Vector2 pixelSize = spriteSize / _sRenderer.sprite.pixelsPerUnit;
        
        Vector3 world_size = pixelSize;
        world_size.x *= transform.lossyScale.x;
        world_size.y *= transform.lossyScale.y;

        Vector3 screen_size = 0.5f * world_size / Camera.main.orthographicSize;
        screen_size.y *= Camera.main.aspect;

        Vector3 in_pixels = new Vector3(screen_size.x * Camera.main.pixelWidth, screen_size.y * Camera.main.pixelHeight, 0) * 0.5f;

        currentSize = in_pixels.x;// / spriteSize.x * originalSize;
    }

    private void LateUpdate() {
        int hash = _sRenderer.sprite.name.GetHashCode();
        if (spriteNameToSpriteDic.ContainsKey(hash)) {
            for (int i = 0; i < mipmapRanges.Length; i++) {
                if ((currentSize >= mipmapRanges[i].x) && (currentSize <= mipmapRanges[i].y)) {
                    applyingLevel = i;
                    if (applyingLevel % 2 == 1) {
                        _sRenderer.sprite = spriteNameToSpriteDic[hash];
                        
                    }
                    break;
                }
            }
        }

    }

}

 

 

 


사진 및 파일 첨부

여기에 파일을 끌어 놓거나 왼쪽의 버튼을 클릭하세요.

파일 용량 제한 : 0MB (허용 확장자 : *.*)

0개 첨부 됨 ( / )

List of Articles
번호 분류 제목 글쓴이 날짜 조회 수
53 게임 콜라이더 달린 총알 최적화하기 11 file 조루나 2020.06.11 489
52 게임 텍스쳐 쓰까쓰까 쉐이더 (SplatMap) - UV 스케일링 가능하게 업데이트 1 file 조루나 2020.06.18 397
51 게임 아! Texture의 Mesh Type 너무너무 무섭다. 1 file 조루나 2020.07.07 276
50 게임 멀티텍스쳐 쉐이더가 너무 무거워서 최적화를 위해 Bake file 조루나 2020.07.11 279
49 게임 남의 쉐이더가 역시 좋구만 file 조루나 2020.07.17 622
48 음악 직접 만든 신데마스 매쉬업 리믹스 3곡을 올려보겠습니다 2 file deric99 2020.07.31 193
47 게임 씬에 몬스터 박기 편하라고 미리보기 만들기 1 file 조루나 2020.08.12 327
46 게임 뭐! 지도에 캐릭터 위치를 보여달라고! 1 file 조루나 2020.08.20 340
45 게임 2D 게임이라도 팝콘이 튀기고 싶어 file 조루나 2020.09.09 256
44 게임 수동 밉맵(mipmap) 3 file 조루나 2020.09.11 323
43 게임 버프버프 2 file 조루나 2020.09.22 235
42 게임 엔터 더 건전 따라서 UI에 현재 무기 그림이 나오게 해달라기에. 1 file 조루나 2020.10.16 307
41 게임 총알 방패막 + 회전회오리슛 1 file 조루나 2020.10.27 291
40 게임 3D 입문. Vroid Studio로 날먹 해보기. file 조루나 2020.11.09 321
39 게임 3D 입문2. Mixamo 애니메이션으로 날로 먹기 1 file 조루나 2020.11.10 258
» 게임 스프라이트 하프 밉맵 가운데가 하프밉맵 적용한 오브젝트. 다른 스프라이트는 해상도에 따라서 좀 흐려져도 그러려니 하지만 주인공만은 어떻게든 선명하게 보여주고 싶었다. 하지만 ... file 조루나 2020.11.20 201
37 게임 스크롤러 에셋과 VerticalLayoutGroup의 저주 file 조루나 2021.03.10 250
36 게임 2D 쿼터뷰 게임의 스프라이트 Sorting Order 정렬 방법 file 조루나 2021.04.30 287
35 게임 2D 쿼터뷰 타일 게임을 3D처럼 해달라잖아! file 조루나 2021.05.27 262
34 게임 게임에 한 붓 그리기 퍼즐을 넣고 싶다길래... file 조루나 2021.07.15 201
Board Pagination Prev 1 2 3 Next
/ 3