File size: 4,764 Bytes
b7d75f3
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
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
"""

주사위 굴리기 관련 유틸리티 함수 모듈

"""
import random
import re
import time
import streamlit as st

def roll_dice(dice_type=20, num_dice=1):
    """

    주사위 굴리기 함수

    

    Args:

        dice_type (int): 주사위 면 수 (기본값: 20)

        num_dice (int): 굴릴 주사위 개수 (기본값: 1)

        

    Returns:

        list: 주사위 결과 목록

    """
    return [random.randint(1, dice_type) for _ in range(num_dice)]

def calculate_dice_result(dice_expression):
    """

    주사위 표현식 계산 (예: '2d6+3', '1d20-2', '3d8' 등)

    

    Args:

        dice_expression (str): 주사위 표현식 

        

    Returns:

        dict: 주사위 결과 정보

    

    Raises:

        ValueError: 표현식이 유효하지 않을 경우

    """
    # 표현식 분석
    pattern = r'(\d+)d(\d+)([+-]\d+)?'
    match = re.match(pattern, dice_expression.lower().replace(' ', ''))
    
    if not match:
        raise ValueError(f"유효하지 않은 주사위 표현식: {dice_expression}")
    
    num_dice = int(match.group(1))
    dice_type = int(match.group(2))
    modifier = match.group(3)
    
    # 주사위 굴리기
    rolls = roll_dice(dice_type, num_dice)
    
    # 보정값 적용
    total = sum(rolls)
    modifier_value = 0
    
    if modifier:
        modifier_value = int(modifier)
        total += modifier_value
    
    return {
        'rolls': rolls,
        'total': total,
        'modifier': modifier_value,
        'num_dice': num_dice,
        'dice_type': dice_type
    }

def display_dice_animation(placeholder, dice_expression='1d20', duration=1.0):
    """

    주사위 굴리기 애니메이션 표시

    

    Args:

        placeholder (st.empty): 애니메이션을 표시할 빈 요소

        dice_expression (str): 주사위 표현식

        duration (float): 애니메이션 지속 시간(초)

        

    Returns:

        dict: 주사위 결과 정보

    """
    # 주사위 표현식 파싱
    pattern = r'(\d+)d(\d+)([+-]\d+)?'
    match = re.match(pattern, dice_expression.lower().replace(' ', ''))
    
    if match:
        num_dice = int(match.group(1))
        dice_type = int(match.group(2))
        modifier = match.group(3) or "+0"
        modifier_value = int(modifier)
    else:
        # 기본값
        num_dice = 1
        dice_type = 20
        modifier_value = 0
        modifier = "+0"
    
    # 굴리기 시작 시간
    start_time = time.time()
    
    # 주사위 아이콘 선택
    dice_icons = {
        4: "🎲 (d4)",
        6: "🎲 (d6)",
        8: "🎲 (d8)",
        10: "🎲 (d10)",
        12: "🎲 (d12)",
        20: "🎲 (d20)",
        100: "🎲 (d%)"
    }
    dice_icon = dice_icons.get(dice_type, "🎲")
    
    # 애니메이션 표시
    while time.time() - start_time < duration:
        # 임시 주사위 결과 생성
        temp_rolls = [random.randint(1, dice_type) for _ in range(num_dice)]
        temp_total = sum(temp_rolls) + modifier_value
        
        # 간소화된 애니메이션 표시
        dice_html = f"""

        <div class='dice-animation'>

            <div class='dice-rolling'>

                {dice_icon}<br>

                <span style='font-size: 1rem;'>{' + '.join([str(r) for r in temp_rolls])}{modifier if modifier_value != 0 else ""}</span><br>

                <span style='font-weight: bold;'>= {temp_total}</span>

            </div>

        </div>

        """
        placeholder.markdown(dice_html, unsafe_allow_html=True)
        time.sleep(0.1)
    
    # 최종 주사위 결과 계산
    result = calculate_dice_result(dice_expression)
    
    # 간소화된 결과 표시
    final_html = f"""

    <div class='dice-result-container'>

        <div style='font-size: 2rem;'>{dice_icon}</div>

        <div>{dice_expression.upper()}</div>

        <div style='margin: 10px 0;'>

    """
    
    # 각 주사위 결과를 간소화하여 표시
    for roll in result['rolls']:
        color = "#4CAF50" if roll == dice_type else "#F44336" if roll == 1 else "#e0e0ff"
        final_html += f"<span style='display:inline-block; margin:0 5px; color:{color};'>{roll}</span>"
    
    # 수정자 및 총점
    if result['modifier'] != 0:
        modifier_sign = "+" if result['modifier'] > 0 else ""
        final_html += f"<br><span>수정자: {modifier_sign}{result['modifier']}</span>"
    
    final_html += f"<br><div style='font-size: 1.8rem; font-weight: bold; color: #FFD700;'>{result['total']}</div></div></div>"
    
    placeholder.markdown(final_html, unsafe_allow_html=True)
    return result