디시인사이드 갤러리

갤러리 이슈박스, 최근방문 갤러리

갤러리 본문 영역

솔직히 프로그래밍= 개좆도 모르겠고 아는척함

ㅆㅇㅆ(124.216) 2024.09.21 16:38:25
조회 90 추천 0 댓글 0

ㅋㅋㅋㄹㅇ


내가 짠 코드보면 한숨 나옴



1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
using System.Collections.Generic;
using UnityEngine;
using Core;
using MainGame;
 
namespace Target2DSystem
{
    /// <summary>
    /// QuadTree를 사용하여 2D 환경에서 타겟팅 시스템을 관리하는 클래스
    /// 이 클래스는 적 또는 다른 타겟을 QuadTree에 추가 및 제거하며,
    /// 지정된 위치에서 가장 가까운 타겟, 가장 먼 타겟, 또는 우선순위가 가장 높은 타겟을 검색하는 기능을 제공
    /// </summary>
    public class QuadTreeTargetingSystem : Singleton<QuadTreeTargetingSystem>
    {
        private QuadTree quadTree; // QuadTree 객체
        private Rect worldBounds;  // QuadTree가 커버하는 월드 범위
 
        private bool isInitialized = false// 초기화 여부를 확인하기 위한 플래그
 
        /// <summary>
        /// QuadTreeTargetingSystem을 초기화하는 메서드
        /// 던전 빌더로부터 던전 경계를 가져와 QuadTree를 생성
        /// </summary>
        private void Initialize()
        {
            worldBounds = DungeonBuilder.Instance.GetDungeonBounds(); // 던전 경계를 가져옴
            quadTree = new QuadTree(worldBounds, 4); // QuadTree를 생성, 최대 4개의 객체를 가지는 노드로 설정
            isInitialized = true// 초기화 완료
        }
 
        /// <summary>
        /// QuadTreeTargetingSystem이 초기화되었는지 확인하고, 초기화되지 않은 경우 초기화를 수행
        /// </summary>
        private void EnsureInitialized()
        {
            if (!isInitialized)
            {
                Initialize();
            }
        }
 
        /// <summary>
        /// 새로운 타겟을 QuadTree에 추가
        /// </summary>
        /// <param name="target">추가할 타겟</param>
        public void AddTarget(ITargetable target)
        {
            EnsureInitialized(); // 초기화 확인
            // 타겟 추가 전 Faction 정보를 출력
            //Faction faction = target.GetFactionDetails().GetFaction();
            //Debug.Log($"[쿼드트리 타겟 추가] 타겟: {target}, Faction: {faction}");
            quadTree.Insert(target); // 타겟 추가
        }
 
        /// <summary>
        /// 타겟을 QuadTree에서 제거
        /// </summary>
        /// <param name="target">제거할 타겟</param>
        public void RemoveTarget(ITargetable target)
        {
            EnsureInitialized(); // 초기화 확인
            quadTree.Remove(target); // 타겟 제거
        }
 
        /// <summary>
        /// 지정된 유닛과 현재 저장할 타겟을 기반으로 가장 가까운 적절한 타겟을 반환합니다.
        /// </summary>
        /// <param name="sender">타겟을 찾는 유닛</param>
        /// <param name="currentTarget">결과로 저장할 타겟</param>
        /// <returns>가장 가까운 타겟, 없으면 null 반환</returns>
        public ITargetable GetClosestTargetWithDifferentFaction(ITargetable sender, ITargetable currentTarget)
        {
            EnsureInitialized(); // 초기화 확인
 
            Vector3 position = sender.GetTargetTransform().position;
            Faction senderFaction = sender.GetFactionDetails().GetFaction(); // Sender의 Faction
 
            List<ITargetable> potentialTargets = quadTree.Retrieve(position); // 잠재적 타겟 검색
            //Debug.Log($"검색된 잠재적 타겟 수: {potentialTargets.Count}");
 
 
            ITargetable closestTarget = null;
            float closestDistance = float.MaxValue;
 
            foreach (ITargetable potentialTarget in potentialTargets)
            {
                Faction targetFaction = potentialTarget.GetFactionDetails().GetFaction(); // 잠재적 타겟의 Faction
                //Debug.Log($"잠재적 타겟: {potentialTarget}, Faction: {potentialTarget.GetFactionDetails().GetFaction()}");
 
                if (targetFaction == senderFaction)
                {
                    //Debug.Log($"[타겟 검색] 타겟이 같은 Faction입니다: {targetFaction}, 건너뜀.");
                    continue// 같은 Faction의 타겟은 건너뜀
                }
                //Debug.Log($"[타겟 발견] 다른 Faction 발견! 타겟: {potentialTarget}, Faction: {targetFaction}");
 
                float distance = Vector3.Distance(position, potentialTarget.GetTargetTransform().position);
                if (distance < closestDistance)
                {
                    closestDistance = distance;
                    closestTarget = potentialTarget;
                    //Debug.Log($"[타겟 검색] 새로운 가장 가까운 타겟: {closestTarget}, 거리: {closestDistance}");
 
                }
            }
 
            currentTarget = closestTarget; // 가장 가까운 타겟을 currentTarget에 저장
            Debug.Log($"최종 반환할 타겟: {currentTarget}");
            return currentTarget; // 가장 가까운 타겟을 반환
        }
 
 
        /// <summary>
        /// 지정된 위치에서 현재 유닛과 같은 팩션에 속하지 않은 또는 팩션이 없는 가장 가까운 타겟을 반환합니다.
        /// </summary>
        /// <param name="sender">타겟을 찾는 유닛</param>
        /// <param name="currentTarget">결과로 저장할 타겟</param>
        /// <returns>가장 가까운 타겟, 없으면 null 반환</returns>
        public ITargetable GetClosestTargetWithDifferentOrNoFaction(ITargetable sender, ref ITargetable currentTarget)
        {
            EnsureInitialized(); // 초기화 확인
 
            Vector3 position = sender.GetTargetTransform().position;
            Faction currentFaction = sender.GetFactionDetails().GetFaction();
 
            List<ITargetable> potentialTargets = quadTree.Retrieve(position); // 잠재적 타겟 검색
 
            ITargetable closestTarget = currentTarget;
            float closestDistance = currentTarget != null ? Vector3.Distance(position, currentTarget.GetTargetTransform().position) : float.MaxValue;
 
            foreach (ITargetable potentialTarget in potentialTargets)
            {
                if (potentialTarget.GetFactionDetails().GetFaction() != currentFaction) // 같은 팩션이 아닌 경우
                {
                    float distance = Vector3.Distance(position, potentialTarget.GetTargetTransform().position);
                    if (distance < closestDistance)
                    {
                        closestDistance = distance;
                        closestTarget = potentialTarget;
                    }
                }
            }
 
            currentTarget = closestTarget; // 가장 가까운 타겟을 currentTarget에 저장
 
            return closestTarget; // 가장 가까운 타겟을 반환
        }
 
    }
}
 
cs

추천 비추천

0

고정닉 0

0

댓글 영역

전체 댓글 0
등록순정렬 기준선택
본문 보기

하단 갤러리 리스트 영역

왼쪽 컨텐츠 영역

갤러리 리스트 영역

갤러리 리스트
번호 제목 글쓴이 작성일 조회 추천
이슈 [디시人터뷰] 라이징 스타로 인정받은 걸그룹, ‘리센느(RESCENE)’ 운영자 24/11/08 - -
설문 축의금 적게 내면 눈치 줄 것 같은 스타는? 운영자 24/11/11 - -
2772213 메이플할때 가장 중요한점 하나 알려준다. ㅇㅇ(123.213) 11.10 21 0
2772212 미래의 어느 역사학자들의 대화라는데 (에필로그) 아갤러(121.129) 11.10 32 0
2772211 클라우드는 도대체 뭘 공부 하는거임? 프갤러(61.101) 11.10 28 0
2772210 미래의 어느 역사학자들의 대화라는데 (요약편) 아갤러(121.129) 11.10 35 0
2772209 내 수면시간 ㅁㅌㅊ?? ㅇㅇ(123.213) 11.10 33 0
2772208 미래의 어느 역사학자들의 대화라는데 아갤러(121.129) 11.10 31 0
2772206 포폴은 서류전형에서 보기시작하냐 아니면 면접때보냐 [3] ㅇㅇ갤로그로 이동합니다. 11.10 81 0
2772205 구글서버 요즘 불안불안하네 [1] 뉴진파갤로그로 이동합니다. 11.10 37 0
2772204 [긴급소식] Rx Recording System 리뉴얼 페이지 유출!!! 프갤러(121.172) 11.10 35 1
2772203 애인구함 ㄴㄴㄴ 별루별루 안구함. 솔직히 외로운 지라치 뽑았음 일본어로 도리스아(14.35) 11.10 16 0
2772201 개년 [6] ♥Sub2냥덩♥갤로그로 이동합니다. 11.10 53 1
2772198 나님 술상 ㅁㅌㅊ냐?? 집안의 장남에게 어머니가 술상 차려오셨다. ㅇㅇ(223.62) 11.10 30 2
2772195 못생겼으니까 취업 안되는거임 ㅇㅅㅇ [2] 류류(59.5) 11.10 57 0
2772194 나님 국적 최초공개 ♥Sub2냥덩♥갤로그로 이동합니다. 11.10 22 0
2772191 웹개발의 본질은 백엔드에 있는게 맞는듯 [2] 프갤러(14.34) 11.10 69 0
2772190 내 수면시간 ㅁㅌㅊ?? [1] ㅇㅇ(123.213) 11.10 35 0
2772189 골골대며 지팡이 짚고가는 할배보니 감회가 새롭구나 [1] 헬마스터갤로그로 이동합니다. 11.10 22 0
2772188 코딩은 글 잘쓰는 애들이 유리함 [2] ㅇㅇ(221.146) 11.10 121 0
2772185 우리에게 시간이 없는게 아니라 가진것조차 활용못하는거 아닐까?? ㅇㅇ(123.213) 11.10 24 0
2772182 지방러 유명 부트 캠프(우테코, 싸피 etc) 가능함? [4] 프갤러(14.55) 11.10 48 0
2772179 대방어와 슈톨렌의 계절이 오는구나... 낭만이다. ㅇㅇ(223.62) 11.10 18 0
2772176 메이플은 해도 재획은 안함 ㅇㅅㅇ;; ㅇㅇ(223.62) 11.10 32 0
2772173 SI 아닌이상 신규구축은없지않음..? [1] 프갤러(39.118) 11.10 63 0
2772169 한글 초성으로 검색하는 기능 어케함? 프갤러(58.237) 11.10 51 0
2772167 요즘 개발자들 수습때 잘짜르는편임?? [6] 프갤러(59.18) 11.10 123 1
2772166 아스카 한국에 오다 [5] 아스카영원히사랑해갤로그로 이동합니다. 11.10 82 0
2772164 주말에 연락 받지마 [1] 프갤러(118.218) 11.10 46 0
2772163 시도 때도 없이 지랄인 이세상 [1] 주아갤로그로 이동합니다. 11.10 32 0
2772162 진짜 다 죽여버리고 싶다 [3] 주아갤로그로 이동합니다. 11.10 46 0
2772157 다 죽이고싶다 주아갤로그로 이동합니다. 11.10 28 0
2772156 알바를 할까말까... 고민이 많아요~ ㅇㅇ(123.213) 11.10 20 0
2772154 일본에서 한국남자보다 중국남자가 더 낫습니다 [1] 프로외노자갤로그로 이동합니다. 11.10 41 0
2772153 러우전쟁 우크라이나 절대 지지. 도리스아(14.35) 11.10 15 0
2772152 ☀나님 시작합니당☀ ♥Sub2냥덩♥갤로그로 이동합니다. 11.10 19 0
2772151 진정한 동료모집의 형태는 [81] 딱국(118.235) 11.10 188 1
2772150 나이가 드니까 글자는 큰 게 좋아 프갤러(121.172) 11.10 45 2
2772146 나는 기분이 울적할때 케이크를 먹어 40대프린이(118.235) 11.10 26 0
2772145 앞으로의 고민 [3] 프갤러(165.76) 11.10 37 0
2772143 메이플할때 중요한건 현질 금액을 제한하는것 같음 ㅇㅅㅇ ㅇㅇ(123.213) 11.10 13 0
2772140 예수님은 남의 일에도 하나하나 우셨을까? [1] 딱국(118.235) 11.10 35 0
2772139 개쩌는 아이디어가 떠올랐는데 엑셀주도개발 어떰? [2] 프갤러(118.218) 11.10 48 0
2772138 Ai 그림 생성기 앱들을 사용해 봤다- [2] 프갤러(121.172) 11.10 53 2
2772136 정신병은 응어리를 풀어야 해결이 돼 [2] 딱국(118.235) 11.10 40 0
2772134 클라우드 벤더별로 외우고 있는 애들 있냐? [1] 프갤러(160.238) 11.10 26 0
2772130 둥둥둥 발명도둑잡기갤로그로 이동합니다. 11.10 19 0
2772129 19충 특) 씨알도 안먹히는 도배광고 손으로 함 프갤러(121.170) 11.10 19 0
2772126 쿠팡 일용직 다녀보신분 계신가요~ 가볼만 한가요 [1] ㅇㅇ(123.213) 11.10 37 0
2772124 인생 날로 먹고 싶은데 프로그래머 하면 일당 얼마임 [2] Snob갤로그로 이동합니다. 11.10 41 0
2772122 데이터분석 할 사람 카톡 오픈 채팅방 프취달 3기 드루와 프갤러(114.206) 11.10 25 0
2772120 설수리14 진짜 대단하신분 한분 계셔. 벌써 교수야 20대에 딱국(118.235) 11.10 28 0
갤러리 내부 검색
제목+내용게시물 정렬 옵션

오른쪽 컨텐츠 영역

실시간 베스트

1/8

뉴스

디시미디어

디시이슈

1/2