@mint-ui/map 1.2.0-test.5 → 1.2.0-test.51
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CLAUDE.md +0 -1
- package/dist/components/mint-map/core/MintMapCore.js +5 -6
- package/dist/components/mint-map/core/advanced/CanvasMarkerLayer/CanvasMarkerLayer.d.ts +47 -0
- package/dist/components/mint-map/core/advanced/CanvasMarkerLayer/CanvasMarkerLayer.js +634 -0
- package/dist/components/mint-map/core/advanced/CanvasMarkerLayer/index.d.ts +3 -0
- package/dist/components/mint-map/core/advanced/CanvasPolygonLayer/CanvasPolygonLayer.d.ts +252 -0
- package/dist/components/mint-map/core/advanced/CanvasPolygonLayer/CanvasPolygonLayer.js +596 -0
- package/dist/components/mint-map/core/advanced/CanvasPolygonLayer/index.d.ts +3 -0
- package/dist/components/mint-map/core/advanced/CanvasPolygonLayer/renderer.d.ts +237 -0
- package/dist/components/mint-map/core/advanced/CanvasPolygonLayer/renderer.js +645 -0
- package/dist/components/mint-map/core/advanced/canvas/CanvasMarker.d.ts +7 -0
- package/dist/components/mint-map/core/advanced/canvas/CanvasMarkerClaude.js +7 -7
- package/dist/components/mint-map/core/advanced/canvas/index.d.ts +0 -1
- package/dist/components/mint-map/core/advanced/index.d.ts +3 -1
- package/dist/components/mint-map/core/advanced/shared/context.d.ts +39 -0
- package/dist/components/mint-map/core/advanced/{woongCanvas/shared → shared}/context.js +62 -79
- package/dist/components/mint-map/core/advanced/shared/helpers.d.ts +20 -0
- package/dist/components/mint-map/core/advanced/shared/helpers.js +40 -0
- package/dist/components/mint-map/core/advanced/shared/hooks.d.ts +74 -0
- package/dist/components/mint-map/core/advanced/shared/hooks.js +189 -0
- package/dist/components/mint-map/core/advanced/{woongCanvas/shared → shared}/index.d.ts +3 -0
- package/dist/components/mint-map/core/advanced/shared/performance.d.ts +77 -0
- package/dist/components/mint-map/core/advanced/shared/performance.js +262 -0
- package/dist/components/mint-map/core/advanced/shared/types.d.ts +127 -0
- package/dist/components/mint-map/core/advanced/{woongCanvas/shared → shared}/types.js +5 -1
- package/dist/components/mint-map/core/advanced/shared/utils.d.ts +130 -0
- package/dist/components/mint-map/core/advanced/shared/utils.js +303 -0
- package/dist/components/mint-map/core/advanced/shared/viewport.d.ts +42 -0
- package/dist/components/mint-map/core/advanced/shared/viewport.js +51 -0
- package/dist/components/mint-map/google/GoogleMintMapController.js +5 -4
- package/dist/components/mint-map/kakao/KakaoMintMapController.js +5 -4
- package/dist/components/mint-map/naver/NaverMintMapController.js +5 -4
- package/dist/index.es.js +3233 -2687
- package/dist/index.js +25 -10
- package/dist/index.umd.js +3247 -2689
- package/package.json +1 -1
- package/dist/components/mint-map/core/advanced/canvas/CanvasMarkerHanquf.d.ts +0 -22
- package/dist/components/mint-map/core/advanced/canvas/CanvasMarkerHanquf.js +0 -413
- package/dist/components/mint-map/core/advanced/woongCanvas/ClusterMarker.d.ts +0 -11
- package/dist/components/mint-map/core/advanced/woongCanvas/WoongKonvaMarker.d.ts +0 -50
- package/dist/components/mint-map/core/advanced/woongCanvas/WoongKonvaMarker.js +0 -1065
- package/dist/components/mint-map/core/advanced/woongCanvas/index.d.ts +0 -3
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/context.d.ts +0 -31
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/performance.d.ts +0 -161
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/performance.js +0 -343
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/types.d.ts +0 -131
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/utils.d.ts +0 -31
- package/dist/components/mint-map/core/advanced/woongCanvas/shared/utils.js +0 -164
- package/dist/components/mint-map/core/util/geohash.js +0 -125
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* 폴리곤 렌더링 유틸리티
|
|
3
|
+
*
|
|
4
|
+
* 이 파일은 폴리곤 렌더링을 위한 헬퍼 함수와 팩토리 함수를 제공합니다.
|
|
5
|
+
* GeoJSON MultiPolygon 형식을 지원하며, 도넛 폴리곤(구멍이 있는 폴리곤)도 처리할 수 있습니다.
|
|
6
|
+
*/
|
|
7
|
+
import { CustomRenderBase, CustomRenderEvent } from "../shared/types";
|
|
8
|
+
import type { PolygonStyleObject, PolygonStyleCustomizer } from "./CanvasPolygonLayer";
|
|
9
|
+
/**
|
|
10
|
+
* 폴리곤 그리기 파라미터 인터페이스
|
|
11
|
+
*/
|
|
12
|
+
interface DrawPolygonParams {
|
|
13
|
+
/** Canvas 2D 렌더링 컨텍스트 */
|
|
14
|
+
ctx: CanvasRenderingContext2D;
|
|
15
|
+
/** 변환된 폴리곤 좌표 배열 (4차원: [MultiPolygon][Polygon][Point][x/y]) */
|
|
16
|
+
polygonOffsets: number[][][][];
|
|
17
|
+
/** 도넛 폴리곤 여부 (구멍이 있는 폴리곤) */
|
|
18
|
+
isDonutPolygon: boolean;
|
|
19
|
+
/** 채우기 색상 */
|
|
20
|
+
fillColor: string;
|
|
21
|
+
/** 테두리 색상 */
|
|
22
|
+
strokeColor: string;
|
|
23
|
+
/** 테두리 두께 */
|
|
24
|
+
lineWidth: number;
|
|
25
|
+
}
|
|
26
|
+
/**
|
|
27
|
+
* 폴리곤 그리기 헬퍼 함수 (도넛 폴리곤 지원)
|
|
28
|
+
*
|
|
29
|
+
* Canvas 2D Context를 사용하여 폴리곤을 그립니다.
|
|
30
|
+
* 도넛 폴리곤의 경우 evenodd fill rule을 사용하여 구멍을 처리합니다.
|
|
31
|
+
*
|
|
32
|
+
* @param params 폴리곤 그리기 파라미터
|
|
33
|
+
*
|
|
34
|
+
* @remarks
|
|
35
|
+
* - **도넛 폴리곤 처리**:
|
|
36
|
+
* - 외부 폴리곤과 내부 구멍들을 같은 path에 추가
|
|
37
|
+
* - `fill('evenodd')`를 사용하여 구멍 뚫기
|
|
38
|
+
* - **일반 폴리곤 처리**: 각 폴리곤 그룹을 개별적으로 그리기
|
|
39
|
+
* - **성능**: O(n), n은 폴리곤의 총 좌표 수
|
|
40
|
+
*
|
|
41
|
+
* @example
|
|
42
|
+
* ```typescript
|
|
43
|
+
* drawPolygon({
|
|
44
|
+
* ctx,
|
|
45
|
+
* polygonOffsets: [[[[100, 200], [200, 200], [200, 100], [100, 100]]]],
|
|
46
|
+
* isDonutPolygon: false,
|
|
47
|
+
* fillColor: 'rgba(255, 0, 0, 0.5)',
|
|
48
|
+
* strokeColor: 'rgba(255, 0, 0, 1)',
|
|
49
|
+
* lineWidth: 2
|
|
50
|
+
* });
|
|
51
|
+
* ```
|
|
52
|
+
*/
|
|
53
|
+
export declare const drawPolygon: ({ ctx, polygonOffsets, isDonutPolygon, fillColor, strokeColor, lineWidth }: DrawPolygonParams) => void;
|
|
54
|
+
/**
|
|
55
|
+
* 폴리곤 Base 렌더링 함수 팩토리
|
|
56
|
+
*
|
|
57
|
+
* Base Layer에서 사용할 렌더링 함수를 생성합니다.
|
|
58
|
+
* 선택되지 않은 폴리곤만 렌더링하며, 선택된 항목은 Event Layer에서 처리됩니다.
|
|
59
|
+
*
|
|
60
|
+
* @template T 폴리곤 데이터의 추가 속성 타입
|
|
61
|
+
* @param baseFillColor 기본 폴리곤 채우기 색상
|
|
62
|
+
* @param baseStrokeColor 기본 폴리곤 테두리 색상
|
|
63
|
+
* @param baseLineWidth 기본 폴리곤 테두리 두께
|
|
64
|
+
* @returns Base Layer 렌더링 함수
|
|
65
|
+
*
|
|
66
|
+
* @remarks
|
|
67
|
+
* - 선택된 항목은 Event Layer에서 그려지므로 Base Layer에서는 스킵
|
|
68
|
+
* - 성능: O(n), n은 렌더링할 폴리곤 개수
|
|
69
|
+
* - 좌표 변환은 자동으로 캐싱되어 성능 최적화됨
|
|
70
|
+
*
|
|
71
|
+
* @example
|
|
72
|
+
* ```typescript
|
|
73
|
+
* const renderBase = renderPolygonBase(
|
|
74
|
+
* 'rgba(255, 100, 100, 0.5)',
|
|
75
|
+
* 'rgba(200, 50, 50, 0.8)',
|
|
76
|
+
* 2
|
|
77
|
+
* );
|
|
78
|
+
* ```
|
|
79
|
+
*/
|
|
80
|
+
export declare const renderPolygonBase: <T = any>(baseFillColor: string, baseStrokeColor: string, baseLineWidth: number) => CustomRenderBase<T>;
|
|
81
|
+
/**
|
|
82
|
+
* 폴리곤 Event 렌더링 함수 팩토리
|
|
83
|
+
*
|
|
84
|
+
* Event Layer에서 사용할 렌더링 함수를 생성합니다.
|
|
85
|
+
* 선택된 항목, hover된 항목, 마지막 선택된 항목을 각각 다른 스타일로 렌더링합니다.
|
|
86
|
+
*
|
|
87
|
+
* @template T 폴리곤 데이터의 추가 속성 타입
|
|
88
|
+
* @param baseFillColor 기본 폴리곤 채우기 색상 (필수, fallback용)
|
|
89
|
+
* @param baseStrokeColor 기본 폴리곤 테두리 색상 (필수, fallback용)
|
|
90
|
+
* @param baseLineWidth 기본 폴리곤 테두리 두께 (필수, fallback용)
|
|
91
|
+
* @param selectedFillColor 선택된 폴리곤 채우기 색상 (선택, 기본값: baseFillColor)
|
|
92
|
+
* @param selectedStrokeColor 선택된 폴리곤 테두리 색상 (선택, 기본값: baseStrokeColor)
|
|
93
|
+
* @param selectedLineWidth 선택된 폴리곤 테두리 두께 (선택, 기본값: baseLineWidth)
|
|
94
|
+
* @param activeFillColor 마지막 선택된 폴리곤 채우기 색상 (선택, 기본값: selectedFillColor)
|
|
95
|
+
* @param activeStrokeColor 마지막 선택된 폴리곤 테두리 색상 (선택, 기본값: selectedStrokeColor)
|
|
96
|
+
* @param activeLineWidth 마지막 선택된 폴리곤 테두리 두께 (선택, 기본값: selectedLineWidth)
|
|
97
|
+
* @param hoveredFillColor Hover 시 폴리곤 채우기 색상 (선택, 기본값: selectedFillColor)
|
|
98
|
+
* @param hoveredStrokeColor Hover 시 폴리곤 테두리 색상 (선택, 기본값: selectedStrokeColor)
|
|
99
|
+
* @param hoveredLineWidth Hover 시 폴리곤 테두리 두께 (선택, 기본값: selectedLineWidth)
|
|
100
|
+
* @returns Event Layer 렌더링 함수
|
|
101
|
+
*
|
|
102
|
+
* @remarks
|
|
103
|
+
* - **렌더링 순서**: 선택된 항목 → 마지막 선택된 항목 → hover된 항목 (최상단)
|
|
104
|
+
* - **성능**: O(m), m은 선택된 항목 수 + hover된 항목 수
|
|
105
|
+
* - 좌표 변환은 자동으로 캐싱되어 성능 최적화됨
|
|
106
|
+
* - hover된 항목이 선택되어 있으면 active 스타일 적용
|
|
107
|
+
*
|
|
108
|
+
* @example
|
|
109
|
+
* ```typescript
|
|
110
|
+
* const renderEvent = renderPolygonEvent(
|
|
111
|
+
* 'rgba(255, 100, 100, 0.5)', // baseFillColor
|
|
112
|
+
* 'rgba(200, 50, 50, 0.8)', // baseStrokeColor
|
|
113
|
+
* 2, // baseLineWidth
|
|
114
|
+
* 'rgba(255, 193, 7, 0.7)', // selectedFillColor
|
|
115
|
+
* 'rgba(255, 152, 0, 1)', // selectedStrokeColor
|
|
116
|
+
* 4 // selectedLineWidth
|
|
117
|
+
* );
|
|
118
|
+
* ```
|
|
119
|
+
*/
|
|
120
|
+
export declare const renderPolygonEvent: <T = any>(baseFillColor: string, baseStrokeColor: string, baseLineWidth: number, selectedFillColor?: string, selectedStrokeColor?: string, selectedLineWidth?: number, activeFillColor?: string, activeStrokeColor?: string, activeLineWidth?: number, hoveredFillColor?: string, hoveredStrokeColor?: string, hoveredLineWidth?: number) => CustomRenderEvent<T>;
|
|
121
|
+
/**
|
|
122
|
+
* 폴리곤 Base 렌더링 함수 팩토리 (객체 방식)
|
|
123
|
+
*
|
|
124
|
+
* Base Layer에서 사용할 렌더링 함수를 생성합니다.
|
|
125
|
+
* renderStyle 객체를 사용하여 기본 스타일을 적용합니다.
|
|
126
|
+
*
|
|
127
|
+
* @template T 폴리곤 데이터의 추가 속성 타입
|
|
128
|
+
* @param renderStyle 폴리곤 스타일 객체
|
|
129
|
+
* @returns Base Layer 렌더링 함수
|
|
130
|
+
*
|
|
131
|
+
* @remarks
|
|
132
|
+
* - 선택된 항목은 Event Layer에서 그려지므로 Base Layer에서는 스킵
|
|
133
|
+
* - 성능: O(n), n은 렌더링할 폴리곤 개수
|
|
134
|
+
* - 좌표 변환은 자동으로 캐싱되어 성능 최적화됨
|
|
135
|
+
*
|
|
136
|
+
* @example
|
|
137
|
+
* ```typescript
|
|
138
|
+
* const renderBase = renderPolygonBaseWithObject<MyDataType>({
|
|
139
|
+
* base: { fillColor: 'rgba(255, 100, 100, 0.5)', strokeColor: 'rgba(200, 50, 50, 0.8)', lineWidth: 2 }
|
|
140
|
+
* });
|
|
141
|
+
* ```
|
|
142
|
+
*/
|
|
143
|
+
export declare const renderPolygonBaseWithObject: <T = any>(renderStyle: PolygonStyleObject) => CustomRenderBase<T>;
|
|
144
|
+
/**
|
|
145
|
+
* 폴리곤 Event 렌더링 함수 팩토리 (객체 방식)
|
|
146
|
+
*
|
|
147
|
+
* Event Layer에서 사용할 렌더링 함수를 생성합니다.
|
|
148
|
+
* renderStyle 객체를 사용하여 개별 props 방식과 동일한 알고리즘으로 스타일을 적용합니다.
|
|
149
|
+
*
|
|
150
|
+
* @template T 폴리곤 데이터의 추가 속성 타입
|
|
151
|
+
* @param renderStyle 폴리곤 스타일 객체
|
|
152
|
+
* @returns Event Layer 렌더링 함수
|
|
153
|
+
*
|
|
154
|
+
* @remarks
|
|
155
|
+
* - **렌더링 순서**: 선택된 항목 → 마지막 선택된 항목 → hover된 항목 (최상단)
|
|
156
|
+
* - **성능**: O(m), m은 선택된 항목 수 + hover된 항목 수
|
|
157
|
+
* - 좌표 변환은 자동으로 캐싱되어 성능 최적화됨
|
|
158
|
+
* - **알고리즘**: 개별 props 방식과 동일
|
|
159
|
+
* - 기본값 설정: selected/active/hovered가 없으면 base 또는 상위 값 사용
|
|
160
|
+
* - 선택된 항목: selected 스타일
|
|
161
|
+
* - 마지막 선택된 항목 (호버 안 됨): active 스타일
|
|
162
|
+
* - 호버된 항목: 선택되어 있으면 active, 아니면 hovered 스타일
|
|
163
|
+
*
|
|
164
|
+
* @example
|
|
165
|
+
* ```typescript
|
|
166
|
+
* const renderEvent = renderPolygonEventWithObject<MyDataType>({
|
|
167
|
+
* base: { fillColor: 'rgba(255, 100, 100, 0.5)', strokeColor: 'rgba(200, 50, 50, 0.8)', lineWidth: 2 },
|
|
168
|
+
* selected: { fillColor: 'rgba(255, 193, 7, 0.7)', strokeColor: 'rgba(255, 152, 0, 1)', lineWidth: 4 },
|
|
169
|
+
* active: { fillColor: 'rgba(255, 152, 0, 0.8)', strokeColor: 'rgba(255, 87, 34, 1)', lineWidth: 5 },
|
|
170
|
+
* hovered: { fillColor: 'rgba(100, 150, 255, 0.8)', strokeColor: 'rgba(0, 100, 200, 1)', lineWidth: 3 }
|
|
171
|
+
* });
|
|
172
|
+
* ```
|
|
173
|
+
*/
|
|
174
|
+
export declare const renderPolygonEventWithObject: <T = any>(renderStyle: PolygonStyleObject) => CustomRenderEvent<T>;
|
|
175
|
+
/**
|
|
176
|
+
* 폴리곤 Base 렌더링 함수 팩토리 (커스터마이징 방식)
|
|
177
|
+
*
|
|
178
|
+
* Base Layer에서 사용할 렌더링 함수를 생성합니다.
|
|
179
|
+
* customStyle 함수를 사용하여 각 폴리곤의 스타일을 자유롭게 커스터마이징합니다.
|
|
180
|
+
*
|
|
181
|
+
* @template T 폴리곤 데이터의 추가 속성 타입
|
|
182
|
+
* @param customStyle 폴리곤 스타일 커스터마이징 함수
|
|
183
|
+
* @returns Base Layer 렌더링 함수
|
|
184
|
+
*
|
|
185
|
+
* @remarks
|
|
186
|
+
* - 선택된 항목은 Event Layer에서 그려지므로 Base Layer에서는 스킵
|
|
187
|
+
* - 성능: O(n), n은 렌더링할 폴리곤 개수
|
|
188
|
+
* - 좌표 변환은 자동으로 캐싱되어 성능 최적화됨
|
|
189
|
+
*
|
|
190
|
+
* @example
|
|
191
|
+
* ```typescript
|
|
192
|
+
* const renderBase = renderPolygonBaseWithCustomStyle<MyDataType>(
|
|
193
|
+
* (item, context, defaultStyle) => {
|
|
194
|
+
* if (item.someProperty > 100) {
|
|
195
|
+
* return { fillColor: 'red', strokeColor: 'darkred', lineWidth: 3 };
|
|
196
|
+
* }
|
|
197
|
+
* return defaultStyle;
|
|
198
|
+
* }
|
|
199
|
+
* );
|
|
200
|
+
* ```
|
|
201
|
+
*/
|
|
202
|
+
export declare const renderPolygonBaseWithCustomStyle: <T = any>(customStyle: PolygonStyleCustomizer<T>) => CustomRenderBase<T>;
|
|
203
|
+
/**
|
|
204
|
+
* 폴리곤 Event 렌더링 함수 팩토리 (커스터마이징 방식)
|
|
205
|
+
*
|
|
206
|
+
* Event Layer에서 사용할 렌더링 함수를 생성합니다.
|
|
207
|
+
* customStyle 함수를 사용하여 각 폴리곤의 스타일을 자유롭게 커스터마이징합니다.
|
|
208
|
+
*
|
|
209
|
+
* @template T 폴리곤 데이터의 추가 속성 타입
|
|
210
|
+
* @param customStyle 폴리곤 스타일 커스터마이징 함수
|
|
211
|
+
* @returns Event Layer 렌더링 함수
|
|
212
|
+
*
|
|
213
|
+
* @remarks
|
|
214
|
+
* - **렌더링 순서**: 선택된 항목 → 마지막 선택된 항목 → hover된 항목 (최상단)
|
|
215
|
+
* - **성능**: O(m), m은 선택된 항목 수 + hover된 항목 수
|
|
216
|
+
* - 좌표 변환은 자동으로 캐싱되어 성능 최적화됨
|
|
217
|
+
*
|
|
218
|
+
* @example
|
|
219
|
+
* ```typescript
|
|
220
|
+
* const renderEvent = renderPolygonEventWithCustomStyle<MyDataType>(
|
|
221
|
+
* (item, context, defaultStyle) => {
|
|
222
|
+
* if (context.isActive) {
|
|
223
|
+
* return { fillColor: 'yellow', strokeColor: 'orange', lineWidth: 5 };
|
|
224
|
+
* }
|
|
225
|
+
* if (context.isHovered) {
|
|
226
|
+
* return { fillColor: 'blue', strokeColor: 'darkblue', lineWidth: 3 };
|
|
227
|
+
* }
|
|
228
|
+
* if (context.isSelected) {
|
|
229
|
+
* return { fillColor: 'green', strokeColor: 'darkgreen', lineWidth: 4 };
|
|
230
|
+
* }
|
|
231
|
+
* return defaultStyle;
|
|
232
|
+
* }
|
|
233
|
+
* );
|
|
234
|
+
* ```
|
|
235
|
+
*/
|
|
236
|
+
export declare const renderPolygonEventWithCustomStyle: <T = any>(customStyle: PolygonStyleCustomizer<T>) => CustomRenderEvent<T>;
|
|
237
|
+
export {};
|