File size: 2,220 Bytes
d77c3c1
 
 
 
 
 
 
 
 
 
 
 
 
 
 
dc70674
 
 
 
 
 
d77c3c1
 
 
 
 
 
 
 
 
 
 
 
 
dc70674
 
 
 
 
 
 
 
 
 
 
 
d77c3c1
 
 
 
 
 
 
 
 
 
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
import streamlit as st
import svgwrite

# Define the card suits and values
suits = ["clubs", "diamonds", "hearts", "spades"]
values = ["A", "2", "3", "4", "5", "6", "7", "8", "9", "10", "J", "Q", "K"]

# Define the size of the cards
CARD_WIDTH = 75
CARD_HEIGHT = 100

# Define the size of the SVG canvas
CANVAS_WIDTH = CARD_WIDTH * 13
CANVAS_HEIGHT = CARD_HEIGHT * 4

# Load the SVG pictures for the card suits
club = svgwrite.image.Image("https://upload.wikimedia.org/wikipedia/commons/2/25/Svg_deck_01.svg", size=(40, 40))
diamond = svgwrite.image.Image("https://upload.wikimedia.org/wikipedia/commons/9/9f/Svg_deck_03.svg", size=(40, 40))
heart = svgwrite.image.Image("https://upload.wikimedia.org/wikipedia/commons/f/f7/Svg_deck_05.svg", size=(40, 40))
spade = svgwrite.image.Image("https://upload.wikimedia.org/wikipedia/commons/e/eb/Svg_deck_06.svg", size=(40, 40))

# Create a new SVG drawing
dwg = svgwrite.Drawing(size=(f"{CANVAS_WIDTH}px", f"{CANVAS_HEIGHT}px"))

# Draw each card in the SVG canvas
for suit_idx, suit in enumerate(suits):
    for value_idx, value in enumerate(values):
        # Calculate the position of the card on the canvas
        x = CARD_WIDTH * value_idx
        y = CARD_HEIGHT * suit_idx

        # Draw the card border
        dwg.add(dwg.rect((x, y), (CARD_WIDTH, CARD_HEIGHT), rx=10, ry=10, fill="white", stroke="black", stroke_width=2))

        # Draw the card suit picture
        suit_picture = None
        if suit == "clubs":
            suit_picture = club
        elif suit == "diamonds":
            suit_picture = diamond
        elif suit == "hearts":
            suit_picture = heart
        elif suit == "spades":
            suit_picture = spade
        suit_picture.translate(x + CARD_WIDTH // 2 - 20, y + CARD_HEIGHT // 2 - 20)
        dwg.add(suit_picture)

        # Draw the card value
        value = svgwrite.text.Text(value, insert=(x + 5, y + CARD_HEIGHT - 10), fill="black", font_size="16px", font_weight="bold")
        dwg.add(value)

# Convert the SVG drawing to a string
svg_string = dwg.tostring()

# Display the SVG canvas in the Streamlit app
st.write(f'<svg viewBox="0 0 {CANVAS_WIDTH} {CANVAS_HEIGHT}">{svg_string}</svg>', unsafe_allow_html=True)