- PHASE-X-BX.md: 유형 B 미완료 6개 task 수행 방향 상세 (02번 먼저 → 03번 확장) - PHASE-X-C.md: 서브존 프리셋 기반 범용 레이아웃 방향 Co-Authored-By: Claude Opus 4.6 (1M context) <noreply@anthropic.com>
143 lines
4.5 KiB
Markdown
143 lines
4.5 KiB
Markdown
# Phase X-C: 서브존 프리셋 기반 범용 레이아웃
|
|
|
|
> 최종 업데이트: 2026-04-07
|
|
> 전제: Type A, Type B 건드리지 않음. Type C로 새 접근.
|
|
> 의존: Phase X-BX' 완료 후 시작 (zone 기반 코드 전환 완료 필요)
|
|
|
|
---
|
|
|
|
## 핵심 아이디어
|
|
|
|
**AI는 "고르는 것"에만 쓰고, "만드는 것"은 코드가 한다.**
|
|
|
|
### 고정 구조
|
|
|
|
모든 슬라이드는 3개 zone:
|
|
```
|
|
┌───────────────────────────┐
|
|
│ header (제목) │ ← 고정
|
|
├───────────────────────────┤
|
|
│ body (본문) │ ← 서브존 프리셋 적용
|
|
├───────────────────────────┤
|
|
│ footer (핵심 요약) │ ← 고정
|
|
└───────────────────────────┘
|
|
```
|
|
|
|
### 서브존 프리셋
|
|
|
|
body 안의 배치를 row 조합으로 정의:
|
|
|
|
```
|
|
row 유형:
|
|
F = 전체폭 (1칸)
|
|
H = 2분할
|
|
T = 3분할
|
|
Q = 4분할
|
|
|
|
프리셋 예시:
|
|
S1: F → 1단 전체폭
|
|
S2: H → 2단 (좌/우)
|
|
S3: T → 3단 균등
|
|
S4: F+H → 상단 전체폭 + 하단 2분할 (현재 Type B에 해당)
|
|
S5: H+F → 상단 2분할 + 하단 전체폭
|
|
S6: H+H → 상하 각 2분할 (2x2)
|
|
S7: F+T → 상단 전체폭 + 하단 3분할
|
|
S8: T+F → 상단 3분할 + 하단 전체폭
|
|
S9: F+F → 전체폭 2단 (현재 Type A에 가까움)
|
|
```
|
|
|
|
### Kei 역할 (최소화)
|
|
|
|
1. **꼭지 추출** — 콘텐츠를 몇 개 덩어리로 나눌지
|
|
2. **꼭지 간 관계** — 비교/나열/종속/독립
|
|
3. **프리셋 선택** — 번호로 고르기 (또는 코드가 자동 매핑)
|
|
|
|
### 코드 역할
|
|
|
|
1. 프리셋 → zone/sub-zone px 계산 (사칙연산)
|
|
2. 텍스트량 기반 비율 계산
|
|
3. before→filled→after 파이프라인 (Selenium 측정 → 재배분)
|
|
4. MDX 원본 텍스트 배치
|
|
5. 블록 선택 (프리셋별 적합 블록 매핑)
|
|
|
|
---
|
|
|
|
## 질문: Kei가 프리셋을 고를 수 있는가?
|
|
|
|
### 자동 매핑 (코드가 결정) — 안정적이지만 제한적
|
|
```python
|
|
if len(topics) == 1: preset = "S1" # 1단
|
|
if len(topics) == 2: preset = "S2" # 2분할
|
|
if len(topics) == 3: preset = "S3" # 3단
|
|
if len(topics) == 4: preset = "S6" # 2x2
|
|
```
|
|
→ 꼭지 관계 무시. 비교 3개 + 정리 1개 같은 경우 대응 못 함.
|
|
|
|
### Kei 선택 — 유연하지만 불안정 위험
|
|
```json
|
|
{"topics": [...], "preset": "S4", "reason": "상단 3개 비교 + 하단 종합"}
|
|
```
|
|
→ 블록 선택도 불안한데 프리셋 선택이 안정적일지 미지수.
|
|
|
|
### 하이브리드 (유력) — 코드가 후보 제시, Kei가 선택
|
|
```
|
|
코드: "꼭지 4개이므로 후보: S4, S6, S7"
|
|
Kei: "비교 관계이므로 S4"
|
|
```
|
|
→ 선택지를 3개 이하로 좁히면 Kei가 잘 고를 가능성 높음.
|
|
|
|
---
|
|
|
|
## 기술적 구현 방향
|
|
|
|
### sub-zone px 계산
|
|
|
|
```python
|
|
def calculate_sub_zones(preset: str, body_width: int, body_height: int, gap: int):
|
|
rows = parse_preset(preset) # "F+H" → [F, H]
|
|
row_count = len(rows)
|
|
row_height = (body_height - gap * (row_count - 1)) // row_count
|
|
|
|
zones = []
|
|
for i, row_type in enumerate(rows):
|
|
col_count = {"F": 1, "H": 2, "T": 3, "Q": 4}[row_type]
|
|
col_width = (body_width - gap * (col_count - 1)) // col_count
|
|
for j in range(col_count):
|
|
zones.append({
|
|
"row": i, "col": j,
|
|
"width": col_width, "height": row_height,
|
|
})
|
|
return zones
|
|
```
|
|
|
|
### 비율 조정
|
|
```python
|
|
# 텍스트량 기반 비율
|
|
text_lengths = [len(topic.text) for topic in row_topics]
|
|
total = sum(text_lengths)
|
|
ratios = [l / total for l in text_lengths]
|
|
# 최소 20%, 최대 60% 제한
|
|
ratios = [max(0.2, min(0.6, r)) for r in ratios]
|
|
```
|
|
|
|
---
|
|
|
|
## 단계별 진행 계획
|
|
|
|
1. **X-C-1: 프리셋 정의** — S1~S9 구조 + px 계산 함수
|
|
2. **X-C-2: 자동 매핑 먼저** — 꼭지 수 → 프리셋 (코드만으로)
|
|
3. **X-C-3: 조립 범용화** — zone 기반으로 어떤 프리셋이든 조립
|
|
4. **X-C-4: Kei 선택 실험** — 하이브리드 방식 테스트
|
|
5. **X-C-5: before→filled→after 연결** — X-BX'의 zone 기반 코드 활용
|
|
6. **X-C-6: 검증** — 01/02/03번 + 새 MDX로 범용성 테스트
|
|
|
|
---
|
|
|
|
## Type A/B와의 관계
|
|
|
|
- Type A, B는 기존 코드 그대로 유지
|
|
- Type C는 별도 경로로 동작
|
|
- 추후 Type C가 안정화되면 A/B를 C의 프리셋으로 흡수 가능:
|
|
- Type A ≈ S9 (F+F) + sidebar
|
|
- Type B ≈ S4 (F+H)
|