Pyydän nöyrimmin apua olen aloitteleva koodauksen opiskelija (python)

Liittynyt
11.01.2025
Viestejä
15
Nyt pyytäisin apua joltain python taitajalta kun opiskelen tekemään apuohjelmia virtuaalisen Simpu Gui Os sisään. En ymmärrä miten saan toimimaan piirto ohjelmassa painikkeet ympyrän piirto ja neliön piirto siten, että valitsen hiiren vasemmalla piirtoalueelle miten se piirtää sen? Ja mie sweeper peli käynnistyy valikon kautta kun painan painiketta. Sain aikaisemmin toimimaan mutta en tyhmänä tallentanut koodia kun yritin saada toimintoa kun painaa tyhjää kohtaa niin sinne ilmaantuu numeroin kuinka monta tyhjää on miinan vieressä?

Tässä oli yksinkertaisen miinaharavan koodin pätkä tällä millä pystyi hiirellä painelemaan ja tyhjästä ei tapahtu mitään, mutta peli alkoi uudelleen miinaan osuessaan.

Tarvitsen viisaamman apua miten pitää muuttaa koodia ja mitä tapahtui, että nämä pari ohjelmaa lakkasi toimimasta? Olen kiitollinen avusta olen vasta alkuvaiheessa opiskelen itsenäisesti omaksi iloksi ja kokeilen kaikkea.

class Minesweeper:
def __init__(self, root):
self.root = root
self.root.title("Minesweeper")
self.create_board()

def create_board(self):
self.board_size = 8
self.mine_count = 10
self.buttons = {}
self.mines = set(random.sample(range(self.board_size ** 2), self.mine_count))

for row in range(self.board_size):
for col in range(self.board_size):
btn = tk.Button(self.root, width=3, height=1, command=lambda r=row, c=col: self.reveal_cell(r, c))
btn.grid(row=row, column=col)
self.buttons[(row, col)] = btn

def reveal_cell(self, row, col):
idx = row * self.board_size + col
if idx in self.mines:
self.buttons[(row, col)].config(text="*")
messagebox.showinfo("Game Over", "You hit a mine!")
self.reset_game()
else:
self.buttons[(row, col)].config(text="0", state=tk.DISABLED)

Tähän alas nyt laitan sen uusimman koodin missä kaikki muut ohjelmat toimivat, mutta ei piirto ohjelma ja minesweeper peli?

Koodi :

import tkinter as tk
from tkinter import simpledialog, colorchooser, messagebox, filedialog
import os
import random
class SimpleGUIOS:
def __init__(self, root):
self.root = root
self.root.title("Simple GUI OS")
self.create_widgets()
def create_widgets(self):
# Create a frame for the menu
self.menu_frame = tk.Frame(self.root)
self.menu_frame.pack(side=tk.LEFT, fill=tk.Y, padx=10, pady=10)
# Add buttons for various applications to the menu frame
tk.Button(self.menu_frame, text='File Manager', command=self.open_file_manager).pack(pady=5)
tk.Button(self.menu_frame, text='Calculator', command=self.open_calculator).pack(pady=5)
tk.Button(self.menu_frame, text='Drawing App', command=self.open_drawing_app).pack(pady=5)
tk.Button(self.menu_frame, text='Minesweeper Game', command=self.open_minesweeper).pack(pady=5)
tk.Button(self.menu_frame, text='Text Editor', command=self.open_text_editor).pack(pady=5)
tk.Button(self.menu_frame, text='Solitaire', command=self.open_solitaire).pack(pady=5)
tk.Button(self.menu_frame, text='Exit', command=self.close_app).pack(pady=5)
# Label for welcome message
self.label = tk.Label(self.root, text="Welcome to Simple GUI OS")
self.label.pack(pady=10)
def open_file_manager(self):
file_manager_window = tk.Toplevel(self.root)
FileManager(file_manager_window)
def open_calculator(self):
calculator_window = tk.Toplevel(self.root)
Calculator(calculator_window)
def open_drawing_app(self):
drawing_window = tk.Toplevel(self.root)
DrawingApp(drawing_window)
def open_minesweeper(self):
minesweeper_window = tk.Toplevel(self.root)
Minesweeper(minesweeper_window)
def open_text_editor(self):
text_editor_window = tk.Toplevel(self.root)
TextEditor(text_editor_window)
def open_solitaire(self):
solitaire_window = tk.Toplevel(self.root)
Solitaire(solitaire_window)
def close_app(self):
self.root.quit()

class FileManager:
def __init__(self, root):
self.root = root
self.root.title("File Manager")
self.label = tk.Label(root, text="Select a folder:")
self.label.pack(pady=5)
self.folder_path = tk.Entry(root, width=50)
self.folder_path.pack(pady=5)
browse_btn = tk.Button(root, text="Browse", command=self.browse_folder)
browse_btn.pack(pady=5)
self.files_listbox = tk.Listbox(root, width=50, height=20)
self.files_listbox.pack(pady=10)
def browse_folder(self):
folder = filedialog.askdirectory()
if folder:
self.folder_path.delete(0, tk.END)
self.folder_path.insert(0, folder)
self.list_files(folder)
def list_files(self, folder):
self.files_listbox.delete(0, tk.END)
for file in os.listdir(folder):
self.files_listbox.insert(tk.END, file)

class Calculator:
def __init__(self, root):
self.root = root
self.root.title("Calculator")
self.create_widgets()
def create_widgets(self):
self.entry = tk.Entry(self.root, width=16, font=('Arial', 24), borderwidth=5)
self.entry.pack(pady=10)
button_frame = tk.Frame(self.root)
button_frame.pack()
buttons = [
'7', '8', '9', '/',
'4', '5', '6', '*',
'1', '2', '3', '-',
'0', '.', '=', '+'
]
row = 0
col = 0
for button in buttons:
action = lambda x=button: self.on_button_click(x)
tk.Button(button_frame, text=button, width=5, height=2, command=action).grid(row=row, column=col)
col += 1
if col > 3:
col = 0
row += 1
def on_button_click(self, value):
if value == '=':
try:
result = str(eval(self.entry.get()))
self.entry.delete(0, tk.END)
self.entry.insert(0, result)
except Exception as e:
self.entry.delete(0, tk.END)
self.entry.insert(0, "Error")
else:
self.entry.insert(tk.END, value)

class DrawingApp:
def __init__(self, root):
self.root = root
self.root.title("Drawing App")
self.color = "black"
self.current_tool = "free_draw"
self.start_x = None
self.start_y = None
self.temp_shape = None
self.create_canvas()
def create_canvas(self):
self.canvas = tk.Canvas(self.root, bg="white", width=600, height=400)
self.canvas.pack(fill=tk.BOTH, expand=True)
self.canvas.bind("<B1-Motion>", self.paint)
self.canvas.bind("<Button-1>", self.start_draw)
self.canvas.bind("<ButtonRelease-1>", self.end_draw)
button_frame = tk.Frame(self.root)
button_frame.pack(pady=5)
free_draw_btn = tk.Button(button_frame, text="Free Draw", command=lambda: self.select_tool("free_draw"))
free_draw_btn.pack(side=tk.LEFT, padx=5)
circle_btn = tk.Button(button_frame, text="Draw Circle", command=lambda: self.select_tool("circle"))
circle_btn.pack(side=tk.LEFT, padx=5)
square_btn = tk.Button(button_frame, text="Draw Square", command=lambda: self.select_tool("square"))
square_btn.pack(side=tk.LEFT, padx=5)
color_btn = tk.Button(button_frame, text="Select Color", command=self.select_color)
color_btn.pack(side=tk.LEFT, padx=5)
clear_btn = tk.Button(button_frame, text="Clear", command=self.clear_canvas)
clear_btn.pack(side=tk.LEFT, padx=5)
def select_tool(self, tool):
self.current_tool = tool
def select_color(self):
self.color = colorchooser.askcolor(color=self.color)[1]
def start_draw(self, event):
self.start_x, self.start_y = event.x, event.y
if self.current_tool in ["circle", "square"]:
self.temp_shape = None
def end_draw(self, event):
if self.current_tool == "circle":
if self.temp_shape:
self.canvas.delete(self.temp_shape)
self.canvas.create_oval(self.start_x, self.start_y, event.x, event.y, outline=self.color, width=2)
elif self.current_tool == "square":
if self.temp_shape:
self.canvas.delete(self.temp_shape)
self.canvas.create_rectangle(self.start_x, self.start_y, event.x, event.y, outline=self.color, width=2)
self.temp_shape = None
def paint(self, event):
if self.current_tool == "free_draw":
x, y = event.x, event.y
self.canvas.create_line(x, y, x + 1, y + 1, fill=self.color, width=2)
elif self.current_tool in ["circle", "square"]:
if self.temp_shape:
self.canvas.delete(self.temp_shape)
if self.current_tool == "circle":
self.temp_shape = self.canvas.create_oval(self.start_x, self.start_y, event.x, event.y, outline=self.color, width=2)
elif self.current_tool == "square":
self.temp_shape = self.canvas.create_rectangle(self.start_x, self.start_y, event.x, event.y, outline=self.color, width=2)
def clear_canvas(self):
self.canvas.delete("all")
class Minesweeper:
def __init__(self, root):
self.root = root
self.root.title("Minesweeper")
self.create_board()
def create_board(self):
self.board_size = 8
self.mine_count = 10
self.buttons = {}
self.mines = set(random.sample(range(self.board_size ** 2), self.mine_count))
self.adjacent_counts = [[0 for _ in range(self.board_size)] for _ in range(self.board_size)]
for mine in self.mines:
row, col = divmod(mine, self.board_size)
for r in range(max(0, row - 1), min(self.board_size, row + 2)):
for c in range(max(0, col - 1), min(self.board_size, col + 2)):
self.adjacent_counts[r][c] += 1
for row in range(self.board_size):
for col in range(self.board_size):
btn = tk.Button(self.root, width=3, height=1)
btn.grid(row=row, column=col)
btn.bind("<Button-1>", lambda e, r=row, c=col: self.reveal_cell(r, c))
btn.bind("<Button-3>", lambda e, r=row, c=col: self.mark_mine(r, c))
self.buttons[(row, col)] = btn
def reveal_cell(self, row, col):
idx = row * self.board_size + col
if idx in self.mines:
self.buttons[(row, col)].config(text="*", bg="red")
messagebox.showinfo("Game Over", "You hit a mine!")
self.reset_game()
else:
count = self.adj
class TextEditor:
def __init__(self, root):
self.root = root
self.root.title("Text Editor")
self.create_widgets()
def create_widgets(self):
self.text = tk.Text(self.root, wrap='word')
self.text.pack(expand=True, fill='both')
toolbar = tk.Frame(self.root)
toolbar.pack(side=tk.TOP, fill=tk.X)
bold_button = tk.Button(toolbar, text="Bold", command=self.toggle_bold)
bold_button.pack(side=tk.LEFT)
italic_button = tk.Button(toolbar, text="Italic", command=self.toggle_italic)
italic_button.pack(side=tk.LEFT)
size_button = tk.Button(toolbar, text="Change Font Size", command=self.change_font_size)
size_button.pack(side=tk.LEFT)
def toggle_bold(self):
current_tags = self.text.tag_names("sel.first")
if "bold" in current_tags:
self.text.tag_remove("bold", "sel.first", "sel.last")
else:
self.text.tag_add("bold", "sel.first", "sel.last")
self.text.tag_configure("bold", font=("Arial", 12, "bold"))
def toggle_italic(self):
current_tags = self.text.tag_names("sel.first")
if "italic" in current_tags:
self.text.tag_remove("italic", "sel.first", "sel.last")
else:
self.text.tag_add("italic", "sel.first", "sel.last")
self.text.tag_configure("italic", font=("Arial", 12, "italic"))
def change_font_size(self):
size = simpledialog.askinteger("Font Size", "Enter font size:", minvalue=1, maxvalue=100)
if size:
self.text.tag_configure("font_size", font=("Arial", size))
self.text.tag_add("font_size", "sel.first", "sel.last")

class Solitaire:
def __init__(self, root):
self.root = root
self.root.title("Solitaire")
self.setup_game()
def setup_game(self):
self.create_widgets()
self.initialize_deck()
self.deal_cards()
def create_widgets(self):
self.canvas = tk.Canvas(self.root, width=800, height=600, bg="green")
self.canvas.pack(fill=tk.BOTH, expand=True)
self.canvas.bind("<Button-1>", self.on_click)
def initialize_deck(self):
suits = ['♠', '♥', '♦', '♣']
self.deck = [f"{value} {suit}" for suit in suits for value in range(1, 14)]
random.shuffle(self.deck)
self.columns = [[] for _ in range(7)]
self.stock = []
self.waste = []
self.foundation = {suit: [] for suit in suits}
def deal_cards(self):
for i in range(7):
for j in range(i + 1):
card = self.deck.pop()
self.columns.append(card)
self.stock = self.deck
self.draw_tableau()
def draw_tableau(self):
self.canvas.delete("all")
x_offset = 50
y_offset = 50
for i, column in enumerate(self.columns):
x = x_offset + i * 100
for j, card in enumerate(column):
y = y_offset + j * 30
text = card if j == len(column) - 1 else "X"
self.canvas.create_rectangle(x, y, x + 70, y + 100, fill="white" if j == len(column) - 1 else "gray")
self.canvas.create_text(x + 35, y + 50, text=text, font=("Arial", 12))
self.canvas.create_rectangle(50, 400, 120, 470, fill="blue")
self.canvas.create_text(85, 435, text="Stock", font=("Arial", 12))
if self.waste:
self.canvas.create_rectangle(150, 400, 220, 470, fill="white")
self.canvas.create_text(185, 435, text=self.waste[-1], font=("Arial", 12))
def on_click(self, event):
x, y = event.x, event.y
if 50 <= x <= 120 and 400 <= y <= 470:
self.draw_from_stock()
return
column_clicked = (x - 50) // 100
if 0 <= column_clicked < len(self.columns):
self.handle_tableau_click(column_clicked)
def draw_from_stock(self):
if self.stock:
card = self.stock.pop()
self.waste.append(card)
else:
self.stock = self.waste[::-1]
self.waste = []
self.draw_tableau()
def handle_tableau_click(self, column_index):
column = self.columns[column_index]
if not column:
return
card = column.pop()
for other_column in self.columns:
if other_column and other_column[-1].split()[1] != card.split()[1]:
other_column.append(card)
break
self.draw_tableau()

if __name__ == "__main__":
root = tk.Tk()
app = SimpleGUIOS(root)
root.mainloop()


 
Piirto ohjelman sain toimimaan lisäsin clear toiminnon sinne. Se on ratkaistu.

Tässä päivitys saa ehdottaa muokkauksia ja ideoita:

class DrawingApp:
def __init__(self, root):
self.root = root
self.root.title("Drawing App")
self.create_canvas()
def create_canvas(self):
self.canvas = tk.Canvas(self.root, bg="white", width=600, height=400)
self.canvas.pack(fill=tk.BOTH, expand=True)
self.canvas.bind("<B1-Motion>", self.paint)
button_frame = tk.Frame(self.root)
button_frame.pack(pady=5)
clear_btn = tk.Button(button_frame, text="Clear", command=self.clear_canvas)
clear_btn.pack(side=tk.LEFT, padx=5)
square_btn = tk.Button(button_frame, text="Draw Square", command=self.draw_square)
square_btn.pack(side=tk.LEFT, padx=5)
circle_btn = tk.Button(button_frame, text="Draw Circle", command=self.draw_circle)
circle_btn.pack(side=tk.LEFT, padx=5)
line_btn = tk.Button(button_frame, text="Draw Free Line", command=self.draw_line)
line_btn.pack(side=tk.LEFT, padx=5)
color_btn = tk.Button(button_frame, text="Choose Color", command=self.choose_color)
color_btn.pack(side=tk.LEFT, padx=5)
self.current_color = "black"
self.current_shape = "line"
self.last_x, self.last_y = None, None
def paint(self, event):
x, y = event.x, event.y
if self.current_shape == "line":
if self.last_x is not None and self.last_y is not None:
self.canvas.create_line(self.last_x, self.last_y, x, y, fill=self.current_color, width=2)
self.last_x, self.last_y = x, y
def clear_canvas(self):
self.canvas.delete("all")
def draw_square(self):
self.current_shape = "square"
self.canvas.bind("<Button-1>", self.create_square)
def draw_circle(self):
self.current_shape = "circle"
self.canvas.bind("<Button-1>", self.create_circle)
def draw_line(self):
self.current_shape = "line"
self.last_x, self.last_y = None, None # Reset last coordinates for free drawing
self.canvas.bind("<Button-1>", lambda event: None) # Disable click-to-create shapes
def create_square(self, event):
x1, y1 = event.x - 25, event.y - 25
x2, y2 = event.x + 25, event.y + 25
self.canvas.create_rectangle(x1, y1, x2, y2, fill=self.current_color)
def create_circle(self, event):
x, y = event.x, event.y
radius = 25
self.canvas.create_oval(x - radius, y - radius, x + radius, y + radius, fill=self.current_color)
def choose_color(self):
color = colorchooser.askcolor()[1]
if color:
self.current_color = color
 
import tkinter as tk
from tkinter import simpledialog, colorchooser, messagebox, filedialog
import os
import random
class SimpleGUIOS:
def __init__(self, root):
self.root = root
self.root.title("Simple GUI OS")
self.create_widgets()
def create_widgets(self):
# Create a frame for the menu
self.menu_frame = tk.Frame(self.root)
self.menu_frame.pack(side=tk.LEFT, fill=tk.Y, padx=10, pady=10)
# Add buttons for various applications to the menu frame
tk.Button(self.menu_frame, text='File Manager', command=self.open_file_manager).pack(pady=5)
tk.Button(self.menu_frame, text='Calculator', command=self.open_calculator).pack(pady=5)
tk.Button(self.menu_frame, text='Drawing App', command=self.open_drawing_app).pack(pady=5)
tk.Button(self.menu_frame, text='Minesweeper Game', command=self.open_minesweeper).pack(pady=5)
tk.Button(self.menu_frame, text='Text Editor', command=self.open_text_editor).pack(pady=5)
tk.Button(self.menu_frame, text='Solitaire', command=self.open_solitaire).pack(pady=5)
tk.Button(self.menu_frame, text='Exit', command=self.close_app).pack(pady=5)
# Label for welcome message
self.label = tk.Label(self.root, text="Welcome to Simple GUI OS")
self.label.pack(pady=10)
def open_file_manager(self):
file_manager_window = tk.Toplevel(self.root)
FileManager(file_manager_window)
def open_calculator(self):
calculator_window = tk.Toplevel(self.root)
Calculator(calculator_window)
def open_drawing_app(self):
drawing_window = tk.Toplevel(self.root)
DrawingApp(drawing_window)
def open_minesweeper(self):
minesweeper_window = tk.Toplevel(self.root)
Minesweeper(minesweeper_window)
def open_text_editor(self):
text_editor_window = tk.Toplevel(self.root)
TextEditor(text_editor_window)
def open_solitaire(self):
solitaire_window = tk.Toplevel(self.root)
Solitaire(solitaire_window)
def close_app(self):
self.root.quit()

class FileManager:
def __init__(self, root):
self.root = root
self.root.title("File Manager")
self.label = tk.Label(root, text="Select a folder:")
self.label.pack(pady=5)
self.folder_path = tk.Entry(root, width=50)
self.folder_path.pack(pady=5)
browse_btn = tk.Button(root, text="Browse", command=self.browse_folder)
browse_btn.pack(pady=5)
self.files_listbox = tk.Listbox(root, width=50, height=20)
self.files_listbox.pack(pady=10)
def browse_folder(self):
folder = filedialog.askdirectory()
if folder:
self.folder_path.delete(0, tk.END)
self.folder_path.insert(0, folder)
self.list_files(folder)
def list_files(self, folder):
self.files_listbox.delete(0, tk.END)
for file in os.listdir(folder):
self.files_listbox.insert(tk.END, file)

class Calculator:
def __init__(self, root):
self.root = root
self.root.title("Calculator")
self.create_widgets()
def create_widgets(self):
self.entry = tk.Entry(self.root, width=16, font=('Arial', 24), borderwidth=5)
self.entry.pack(pady=10)
button_frame = tk.Frame(self.root)
button_frame.pack()
buttons = [
'7', '8', '9', '/',
'4', '5', '6', '*',
'1', '2', '3', '-',
'0', '.', '=', '+'
]
row = 0
col = 0
for button in buttons:
action = lambda x=button: self.on_button_click(x)
tk.Button(button_frame, text=button, width=5, height=2, command=action).grid(row=row, column=col)
col += 1
if col > 3:
col = 0
row += 1
def on_button_click(self, value):
if value == '=':
try:
result = str(eval(self.entry.get()))
self.entry.delete(0, tk.END)
self.entry.insert(0, result)
except Exception as e:
self.entry.delete(0, tk.END)
self.entry.insert(0, "Error")
else:
self.entry.insert(tk.END, value)

class DrawingApp:
def __init__(self, root):
self.root = root
self.root.title("Drawing App")
self.create_canvas()
def create_canvas(self):
self.canvas = tk.Canvas(self.root, bg="white", width=600, height=400)
self.canvas.pack(fill=tk.BOTH, expand=True)
self.canvas.bind("<B1-Motion>", self.paint)
button_frame = tk.Frame(self.root)
button_frame.pack(pady=5)
clear_btn = tk.Button(button_frame, text="Clear", command=self.clear_canvas)
clear_btn.pack(side=tk.LEFT, padx=5)
square_btn = tk.Button(button_frame, text="Draw Square", command=self.draw_square)
square_btn.pack(side=tk.LEFT, padx=5)
circle_btn = tk.Button(button_frame, text="Draw Circle", command=self.draw_circle)
circle_btn.pack(side=tk.LEFT, padx=5)
line_btn = tk.Button(button_frame, text="Draw Free Line", command=self.draw_line)
line_btn.pack(side=tk.LEFT, padx=5)
color_btn = tk.Button(button_frame, text="Choose Color", command=self.choose_color)
color_btn.pack(side=tk.LEFT, padx=5)
self.current_color = "black"
self.current_shape = "line"
self.last_x, self.last_y = None, None
def paint(self, event):
x, y = event.x, event.y
if self.current_shape == "line":
if self.last_x is not None and self.last_y is not None:
self.canvas.create_line(self.last_x, self.last_y, x, y, fill=self.current_color, width=2)
self.last_x, self.last_y = x, y
def clear_canvas(self):
self.canvas.delete("all")
def draw_square(self):
self.current_shape = "square"
self.canvas.bind("<Button-1>", self.create_square)
def draw_circle(self):
self.current_shape = "circle"
self.canvas.bind("<Button-1>", self.create_circle)
def draw_line(self):
self.current_shape = "line"
self.last_x, self.last_y = None, None # Reset last coordinates for free drawing
self.canvas.bind("<Button-1>", lambda event: None) # Disable click-to-create shapes
def create_square(self, event):
x1, y1 = event.x - 25, event.y - 25
x2, y2 = event.x + 25, event.y + 25
self.canvas.create_rectangle(x1, y1, x2, y2, fill=self.current_color)
def create_circle(self, event):
x, y = event.x, event.y
radius = 25
self.canvas.create_oval(x - radius, y - radius, x + radius, y + radius, fill=self.current_color)
def choose_color(self):
color = colorchooser.askcolor()[1]
if color:
self.current_color = color
class Minesweeper:
def __init__(self, root):
self.root = root
self.root.title("Minesweeper")
self.create_board()
def create_board(self):
self.board_size = 8
self.mine_count = 10
self.buttons = {}
self.mines = set(random.sample(range(self.board_size ** 2), self.mine_count))
self.adjacent_counts = [[0 for _ in range(self.board_size)] for _ in range(self.board_size)]
for mine in self.mines:
row, col = divmod(mine, self.board_size)
for r in range(max(0, row - 1), min(self.board_size, row + 2)):
for c in range(max(0, col - 1), min(self.board_size, col + 2)):
self.adjacent_counts[r][c] += 1
for row in range(self.board_size):
for col in range(self.board_size):
btn = tk.Button(self.root, width=3, height=1)
btn.grid(row=row, column=col)
btn.bind("<Button-1>", lambda e, r=row, c=col: self.reveal_cell(r, c))
btn.bind("<Button-3>", lambda e, r=row, c=col: self.mark_mine(r, c))
self.buttons[(row, col)] = btn
def reveal_cell(self, row, col):
idx = row * self.board_size + col
if idx in self.mines:
self.buttons[(row, col)].config(text="*", bg="red")
messagebox.showinfo("Game Over", "You hit a mine!")
self.reset_game()
else:
count = self.adjacent_counts[row][col]
self.buttons[(row, col)].config(text=str(count), bg="lightgrey")
if count == 0:
self.reveal_adjacent_cells(row, col)
def reveal_adjacent_cells(self, row, col):
for r in range(max(0, row - 1), min(self.board_size, row + 2)):
for c in range(max(0, col - 1), min(self.board_size, col + 2)):
if (r, c) != (row, col):
self.reveal_cell(r, c)
def mark_mine(self, row, col):
btn = self.buttons[(row, col)]
current_text = btn.cget("text")
if current_text == "":
btn.config(text="F", fg="blue")
elif current_text == "F":
btn.config(text="")
class TextEditor:
def __init__(self, root):
self.root = root
self.root.title("Text Editor")
self.create_widgets()
def create_widgets(self):
self.text = tk.Text(self.root, wrap='word')
self.text.pack(expand=True, fill='both')
toolbar = tk.Frame(self.root)
toolbar.pack(side=tk.TOP, fill=tk.X)
bold_button = tk.Button(toolbar, text="Bold", command=self.toggle_bold)
bold_button.pack(side=tk.LEFT)
italic_button = tk.Button(toolbar, text="Italic", command=self.toggle_italic)
italic_button.pack(side=tk.LEFT)
size_button = tk.Button(toolbar, text="Change Font Size", command=self.change_font_size)
size_button.pack(side=tk.LEFT)
def toggle_bold(self):
current_tags = self.text.tag_names("sel.first")
if "bold" in current_tags:
self.text.tag_remove("bold", "sel.first", "sel.last")
else:
self.text.tag_add("bold", "sel.first", "sel.last")
self.text.tag_configure("bold", font=("Arial", 12, "bold"))
def toggle_italic(self):
current_tags = self.text.tag_names("sel.first")
if "italic" in current_tags:
self.text.tag_remove("italic", "sel.first", "sel.last")
else:
self.text.tag_add("italic", "sel.first", "sel.last")
self.text.tag_configure("italic", font=("Arial", 12, "italic"))
def change_font_size(self):
size = simpledialog.askinteger("Font Size", "Enter font size:", minvalue=1, maxvalue=100)
if size:
self.text.tag_configure("font_size", font=("Arial", size))
self.text.tag_add("font_size", "sel.first", "sel.last")

class Solitaire:
def __init__(self, root):
self.root = root
self.root.title("Solitaire")
self.setup_game()
def setup_game(self):
self.create_widgets()
self.initialize_deck()
self.deal_cards()
def create_widgets(self):
self.canvas = tk.Canvas(self.root, width=800, height=600, bg="green")
self.canvas.pack(fill=tk.BOTH, expand=True)
self.canvas.bind("<Button-1>", self.on_click)
def initialize_deck(self):
suits = ['♠', '♥', '♦', '♣']
self.deck = [f"{value} {suit}" for suit in suits for value in range(1, 14)]
random.shuffle(self.deck)
self.columns = [[] for _ in range(7)]
self.stock = []
self.waste = []
self.foundation = {suit: [] for suit in suits}
def deal_cards(self):
for i in range(7):
for j in range(i + 1):
card = self.deck.pop()
self.columns.append(card)
self.stock = self.deck
self.draw_tableau()
def draw_tableau(self):
self.canvas.delete("all")
x_offset = 50
y_offset = 50
for i, column in enumerate(self.columns):
x = x_offset + i * 100
for j, card in enumerate(column):
y = y_offset + j * 30
text = card if j == len(column) - 1 else "X"
self.canvas.create_rectangle(x, y, x + 70, y + 100, fill="white" if j == len(column) - 1 else "gray")
self.canvas.create_text(x + 35, y + 50, text=text, font=("Arial", 12))
self.canvas.create_rectangle(50, 400, 120, 470, fill="blue")
self.canvas.create_text(85, 435, text="Stock", font=("Arial", 12))
if self.waste:
self.canvas.create_rectangle(150, 400, 220, 470, fill="white")
self.canvas.create_text(185, 435, text=self.waste[-1], font=("Arial", 12))
def on_click(self, event):
x, y = event.x, event.y
if 50 <= x <= 120 and 400 <= y <= 470:
self.draw_from_stock()
return
column_clicked = (x - 50) // 100
if 0 <= column_clicked < len(self.columns):
self.handle_tableau_click(column_clicked)
def draw_from_stock(self):
if self.stock:
card = self.stock.pop()
self.waste.append(card)
else:
self.stock = self.waste[::-1]
self.waste = []
self.draw_tableau()
def handle_tableau_click(self, column_index):
column = self.columns[column_index]
if not column:
return
card = column.pop()
for other_column in self.columns:
if other_column and other_column[-1].split()[1] != card.split()[1]:
other_column.append(card)
break
self.draw_tableau()

if __name__ == "__main__":
root = tk.Tk()
app = SimpleGUIOS(root)
root.mainloop()
 
Miinaharava pelissä en saa tyhjille alueille tulemaan niitä numeroita ja piirto ohjelma muuten toimii, mutta vapaata viivaa piirtäessä se poukkoilee ja hyppii eikä tottele aloituspaikkaa? Näihin jos saan neuvoa olen kiitollinen. Koodin muotoilu ei ole ammattitasoista pyydän sen ottamaan huomioon kysyn nyt neuvoa löytyykö täältä foorumilta ihmisiä, jotka auttaa toisia? Olen kiitollinen jos joku auttaa minua.
 
Opin matkan varrella koko ajan niin varmasti jossain vaiheessa saan koodin nätimmäksi nyt opiskelen alusta alkaen olen tämän koodin opetellut kahdessa päivässä ja lukemattomia kertoja muutellut, että saan toimimaan sen kuten haluan.
 
Mine sweeper toimii enää on piirto ohjelmassa se vapaan viivan piirtäminen ongelma aktiivinen.
 
Osaako kukaan neuvoa mikä tässä piirto ohjelman koodissa pitää muuttaa, että saan vapaan viivan piirrettyä siten, että kun lopetan piirron ja piirrän toisen viivan edellinen viiva ei hyppäisi uuteen paikkaan vaan kaikki viivat olisivat omia piirroksia?

Piirto ohjelman koodi rimpsu tässä:

class DrawingApp:
def __init__(self, root):
self.root = root
self.root.title("Drawing App")
self.create_canvas()
def create_canvas(self):
self.canvas = tk.Canvas(self.root, bg="white", width=600, height=400)
self.canvas.pack(fill=tk.BOTH, expand=True)
self.canvas.bind("<B1-Motion>", self.paint)
button_frame = tk.Frame(self.root)
button_frame.pack(pady=5)
clear_btn = tk.Button(button_frame, text="Clear", command=self.clear_canvas)
clear_btn.pack(side=tk.LEFT, padx=5)
square_btn = tk.Button(button_frame, text="Draw Square", command=self.draw_square)
square_btn.pack(side=tk.LEFT, padx=5)
circle_btn = tk.Button(button_frame, text="Draw Circle", command=self.draw_circle)
circle_btn.pack(side=tk.LEFT, padx=5)
line_btn = tk.Button(button_frame, text="Draw Free Line", command=self.draw_line)
line_btn.pack(side=tk.LEFT, padx=5)
color_btn = tk.Button(button_frame, text="Choose Color", command=self.choose_color)
color_btn.pack(side=tk.LEFT, padx=5)
self.current_color = "black"
self.current_shape = "line"
self.last_x, self.last_y = None, None
def paint(self, event):
x, y = event.x, event.y
if self.current_shape == "line":
if self.last_x is not None and self.last_y is not None:
self.canvas.create_line(self.last_x, self.last_y, x, y, fill=self.current_color, width=2)
self.last_x, self.last_y = x, y
def clear_canvas(self):
self.canvas.delete("all")
self.last_x, self.last_y = None, None # Reset the last coordinates when clearing
def draw_square(self):
self.current_shape = "square"
self.canvas.bind("<Button-1>", self.create_square)
def draw_circle(self):
self.current_shape = "circle"
self.canvas.bind("<Button-1>", self.create_circle)
def draw_line(self):
self.current_shape = "line"
self.last_x, self.last_y = None, None # Reset last coordinates for free drawing
self.canvas.bind("<Button-1>", lambda event: None) # Disable click-to-create shapes
def create_square(self, event):
x1, y1 = event.x - 25, event.y - 25
x2, y2 = event.x + 25, event.y + 25
self.canvas.create_rectangle(x1, y1, x2, y2, fill=self.current_color)
def create_circle(self, event):
x, y = event.x, event.y
radius = 25
self.canvas.create_oval(x - radius, y - radius, x + radius, y + radius, fill=self.current_color)
def choose_color(self):
color = colorchooser.askcolor()[1]
if color:
self.current_color = color

 
Koodi code-tagien taakse ja sisennykset kuntoon. Ei tota sotkua jaksa kukaan lukea, kiitos.
Kuten sanoin en osaa vielä kunnolla. Onko tässä ryhmässä tapana vain vittuilla aloittaville koodin opiskelijoille? Jos minä jaksan kahlata tuota koodia läpi niin on helvetin outoa ettei kokeneempi koodaaja jaksa. Taitaa tämä ryhmä olla täynnä itseään olevia nörttejä?
 
Huomautus - keskity rakentavaan keskusteluun
On niin hiton outoa täällä kysytään neuvoa itsekin jaksan työkalulla katsoa syntax errorin tai muun risti riidan joka näyttää millä rivillä ongelma on. Täällä jengi vittuilee päin naamaa aloittavalle koodin opiskelijalle haistakaa vittu kerron kaikille miten paskasti täällä neuvotaan ja kohdellaan aloittelevia koodaajia. Ylläpidolle vinkkiä että kirjoittakaa tuonne jo alkuun koodin oltava virheetöntä älä kysy neuvoa jos et osaa koodata. Tällänen kuva täältä foorumilta tulee täytyy varoittaa muita jos kysyvät ei täältä saa kuin vittuilua!
 
Kuten sanoin en osaa vielä kunnolla.
Siis viestiä tänne kirjoittaessasi laita Python-koodi code tagien sisälle. Eli tuosta viestin kirjoituksen otsikkopalkista </> kuvake ja koodi siihen ikkunaan ja oikea kieli listasta. Joten lopputulos on esim. tällainen:

Python:
class DrawingApp:
def __init__(self, root):
self.root = root
self.root.title("Drawing App")
self.create_canvas()
def create_canvas(self):
self.canvas = tk.Canvas(self.root, bg="white", width=600, height=400)
 
Voi sitä näinkin pyytää apua, rohkea taktiikka
Mua vituttaa, että joku tulee vittuilee aloittevan opiskelijan koodin muotoa. Kun tänne liittää copy pastella ei nuo muotoilut säily editorissa sisennykset ja muotoilut on siistit. Näköjään tässä ryhmässä noviisit on täysin punainen vaate. Kuten mainitsin 2pv vasta opiskellut ja muotoilut koodin siisteys tulee kirjoittaessa. Mutta täällä osattava näköjään koodata jo valmiiksi täydellistä sen vuoksi laitoin ylläpidolle palautteen laittakaa ryhmän kuvaus jos et osaa koodata siistiä koodiä älä tule.
 
Siis viestiä tänne kirjoittaessasi laita Python-koodi code tagien sisälle. Eli tuosta viestin kirjoituksen otsikkopalkista </> kuvake ja koodi siihen ikkunaan ja oikea kieli listasta. Joten lopputulos on esim. tällainen:

Python:
class DrawingApp:
def __init__(self, root):
self.root = root
self.root.title("Drawing App")
self.create_canvas()
def create_canvas(self):
self.canvas = tk.Canvas(self.root, bg="white", width=600, height=400)
Kiitos opastuksesta yritän koko ajan oppia.
 
Siis viestiä tänne kirjoittaessasi laita Python-koodi code tagien sisälle. Eli tuosta viestin kirjoituksen otsikkopalkista </> kuvake ja koodi siihen ikkunaan ja oikea kieli listasta. Joten lopputulos on esim. tällainen:

Python:
class DrawingApp:
def __init__(self, root):
self.root = root
self.root.title("Drawing App")
self.create_canvas()
def create_canvas(self):
self.canvas = tk.Canvas(self.root, bg="white", width=600, height=400)
Eli tänne foorumiin täytyy teksti lisätä vähän samalla tapaa kuin muistiossa html koodia siin muotoilut pysyy.
 
Kuten sanoin en osaa vielä kunnolla. Onko tässä ryhmässä tapana vain vittuilla aloittaville koodin opiskelijoille? Jos minä jaksan kahlata tuota koodia läpi niin on helvetin outoa ettei kokeneempi koodaaja jaksa. Taitaa tämä ryhmä olla täynnä itseään olevia nörttejä?
Ei ollut kyse sinun koodin tulkitsemisesta, vaan siitä, että foorumilla ohjelmakoodi tulee laittaa siitä viesti-ikkunan yläpalkista löytyvään koodilohkoon. Se nimenomaan pitää koodin sisällön erillään muusta tekstistä ja luettavana, eikä myöskään sotke fontteja jne.

Kirjoita aina myös kysymyksesi selkeästi, ilman että vaadit muita tekemään kaiken työn puolestasi.

On niin hiton outoa täällä kysytään neuvoa itsekin jaksan työkalulla katsoa syntax errorin tai muun risti riidan joka näyttää millä rivillä ongelma on. Täällä jengi vittuilee päin naamaa aloittavalle koodin opiskelijalle haistakaa vittu kerron kaikille miten paskasti täällä neuvotaan ja kohdellaan aloittelevia koodaajia. Ylläpidolle vinkkiä että kirjoittakaa tuonne jo alkuun koodin oltava virheetöntä älä kysy neuvoa jos et osaa koodata. Tällänen kuva täältä foorumilta tulee täytyy varoittaa muita jos kysyvät ei täältä saa kuin vittuilua!
Vai niin. Tuollaisella asenteella ja epämääräisten viestien/kysymysten spammaamisella et saa apua sen kummemmin täältä, kuin mistään muualtakaan.

Koodi-tagi löytyy siis foorumilla tästä:

1736611972106.png


...ja tältä sen sisään upotettu Python-kieleksi merkitty koodi näyttää:
Python:
print("Lupaan jatkossa lukea foorumin ohjeet ja säännöt ja noudattaa niitä. T: HermanUkko")

Edit.
Tämä tuli nyt vähän toistona, kun en huomannut, että välissä oli tullut kasa muitakin vastauksia.
 
Viimeksi muokattu:
Eli tänne foorumiin täytyy teksti lisätä vähän samalla tapaa kuin muistiossa html koodia siin muotoilut pysyy.
Ei vaan voit lisätä Python koodia suoraan tuohon ikkunaan ja foorumi tekee nuo muotoilut ja värit. Valitse tuo </> merkki, liitä koodistasi teksti siihen avautuneeseen ikkunaan ja valikosta valitse kieleksi Python.
 
Onko tässä ryhmässä tapana vain vittuilla aloittaville koodin opiskelijoille?

Kannattaa tästä tyylistä päästä mahdollisimman nopeasti eroon jos meinaa hyväksi kehittäjäksi. Ei tule tuolla tavalla onnistumaan. Ja jos meinaat postailla viestitolkulla koodiseinämiä, niin opettele miten se pitää foorumille laittaa tai kysy jos ja kun et osaa. Nyt on monta kertaa neuvottu ja yhä edelleen ne koodioksennukset on muotoilematta. Pythonissa ne sisennykset ovat täysin oleelliset toimivuuden kannalta. Jos toivot että muut panostaa sun auttamiseen, niin sä saat panostaa siihen avun pyytämiseen.

Ja toinen neuvo: älä spämmää kymmentä viestiä peräkkäin, vaan editoi sitä edellistä. Jokaista uutta ajatusta ei tarvitse laittaa omaan uuteen viestiin kun välissä ei ole yhtään vastausta muilta.
 
Miten musta tuntuu että AP:n koodi on copy-pastea jostain valmiista tekeleestä ja nyt tuli seinä vastaan kun perusteiden hallinta mättää? Kannattaa lähteä opettelemaan koodausta huomattavasti yksinkertaisemmasta projektista kuin miinaharava ensi alkuun. Samalla oppii luettavan koodin kirjoittamista ihan itse.

 
Miten musta tuntuu että AP:n koodi on copy-pastea jostain valmiista tekeleestä ja nyt tuli seinä vastaan kun perusteiden hallinta mättää? Kannattaa lähteä opettelemaan koodausta huomattavasti yksinkertaisemmasta projektista kuin miinaharava ensi alkuun. Samalla oppii luettavan koodin kirjoittamista ihan itse.

Samalta tuo koodi minun silmääni näyttää. Ei tolla opi yhtään mitään.
 
Alistaisin kaikki alottelijat katsemaan näitä


En välttämättä alottais pythonilla ollenkaan. Ehkä JS ois paras aloitukseen. Pythonin syntaksi on vähän nurinkurinen kun se on käytännössä ainoastaan pythonissa käytössä isoista kielistä. Sit taas C tyylinen syntaksi on käytössä monessa kielessä, esim tuossa JS.
 
En välttämättä alottais pythonilla ollenkaan. Ehkä JS ois paras aloitukseen. Pythonin syntaksi on vähän nurinkurinen kun se on käytännössä ainoastaan pythonissa käytössä isoista kielistä. Sit taas C tyylinen syntaksi on käytössä monessa kielessä, esim tuossa JS.

Musta JS on huono kieli aloittaa monesta syystä. Tai ennen kaikkea historian painolastin takia.

  • pelkästään muuttujan määrittely/esittelyn voi tehdä monella tavalla jotka toimivat kummallisesti (var, let, const, tai ilman keywordiä)
  • JS:n implisiittiset tyyppimuunnokset ovat aika lailla painajaista.
  • JS:n luokat ovat todella epämääräinen ja päälleliimattu ominaisuus ja toimivat eri tavalla kuin yleensä OOP-kielissä
  • sekava ekosysteemi, paketinhallinta ja heikot standardikirjastot
  • this:n toiminta on vaikea hahmottaa
  • yhtäsuuruus ja truthy sekavia käsitteitä
  • JS:ää ajetaan keskenään vähän eri tavalla toimivissa selaimissa tai Nodessa, jossa JS toimii taas hiukan eri tavalla
  • Yhä edelleen kipuillaan eri moduulisysteemien kanssa
  • jne.

Musta Python on paljon parempi kieli aloittaa tutustuminen ohjelmointiin. JS:ää en suosittele aloituskieleksi kellekään ja osaan sitä (ja TS:ää) ihan hyvin. TS auttaa monissa asioissa ehdottomasti, muttei kaikissa.
 
Musta JS on huono kieli aloittaa monesta syystä. Tai ennen kaikkea historian painolastin takia.

  • pelkästään muuttujan määrittely/esittelyn voi tehdä monella tavalla jotka toimivat kummallisesti (var, let, const, tai ilman keywordiä)
  • JS:n implisiittiset tyyppimuunnokset ovat aika lailla painajaista.
  • JS:n luokat ovat todella epämääräinen ja päälleliimattu ominaisuus ja toimivat eri tavalla kuin yleensä OOP-kielissä
  • sekava ekosysteemi, paketinhallinta ja heikot standardikirjastot
  • this:n toiminta on vaikea hahmottaa
  • yhtäsuuruus ja truthy sekavia käsitteitä
  • JS:ää ajetaan keskenään vähän eri tavalla toimivissa selaimissa tai Nodessa, jossa JS toimii taas hiukan eri tavalla
  • Yhä edelleen kipuillaan eri moduulisysteemien kanssa
  • jne.

Musta Python on paljon parempi kieli aloittaa tutustuminen ohjelmointiin. JS:ää en suosittele aloituskieleksi kellekään ja osaan sitä (ja TS:ää) ihan hyvin. TS auttaa monissa asioissa ehdottomasti, muttei kaikissa.
Olet oikeassa. Ehkä se dart ois sitten myös. Siinä on tyypitykset ja tuo syntaksi on myös curly bracket tyylinen. Dartilla itse aloitin oman uran
 
Musta JS on huono kieli aloittaa monesta syystä. Tai ennen kaikkea historian painolastin takia.

  • pelkästään muuttujan määrittely/esittelyn voi tehdä monella tavalla jotka toimivat kummallisesti (var, let, const, tai ilman keywordiä)
  • JS:n implisiittiset tyyppimuunnokset ovat aika lailla painajaista.
  • JS:n luokat ovat todella epämääräinen ja päälleliimattu ominaisuus ja toimivat eri tavalla kuin yleensä OOP-kielissä
  • sekava ekosysteemi, paketinhallinta ja heikot standardikirjastot
  • this:n toiminta on vaikea hahmottaa
  • yhtäsuuruus ja truthy sekavia käsitteitä
  • JS:ää ajetaan keskenään vähän eri tavalla toimivissa selaimissa tai Nodessa, jossa JS toimii taas hiukan eri tavalla
  • Yhä edelleen kipuillaan eri moduulisysteemien kanssa
  • jne.

Musta Python on paljon parempi kieli aloittaa tutustuminen ohjelmointiin. JS:ää en suosittele aloituskieleksi kellekään ja osaan sitä (ja TS:ää) ihan hyvin. TS auttaa monissa asioissa ehdottomasti, muttei kaikissa.
Python on minustakin ihan kelpo kieli ohjelmoinnin opetteluun, oleellisintahan on oppia ohjelmoimaan ja saada helposti jotain aikaan. Uusia syntakseja kyllä oppii helposti. Pythonissa on sekin, että se pakottaa opettelemaan sisentämisen, olen joskus törmännyt sellaisiinkin koodiesimerkkeihin missä ei ole ollut mitään sisennystä ja sellaisen koodin hahmottaminen ja seuraaminen on huomattavasti hankalampaa kuin edes jollain asteella sisennetyn.

Itse olen aikanaan opetellut ohjelmointia C64 Basicilla ja se ei oikein ollut paras mahdollinen sekään, basicissa oppi paljon huonoja tapoja (rivinumeroiden ja goton lisäksi) joista kesti jonkun aikaa oppia pois. Itse olen vain "harrastelijakoodari" mutta täytyy sanoa että pääosin kaikkea nopeasti tehtyä työkalua tulee eniten tehtyä juuri pythonilla sen helppouden takia. Toki vuosien varrella on tullut koodailtua assembleria, C:tä sun muitakin kieliä tarpeen mukaan. Ja täytyy sanoa että C olisi varmaan ikävin kieli ensimmäiseksi ohjelmointikieleksi (assemblerin lisäksi), kauheasti pieniä asioita opeteltavana ennenkuin saa oikeastaan mitään järkevää aikaiseksi.
 
Itse aloitin kanssa Python opettelun,Helsingin yliopistolla on hyvä harjoittelu sivusto mooc.fi.
 
AMK:ssa ollessani ohjelmointi aloitettiin c:llä. Jatkot Javalla sekä C#:lla. Missään vaiheessa ei ollut Pythonia. Ehkä siihen on syynsä miksi varsinainen ohjelmointi aloitetaan olio-ohjelmoinnilla.
 
Viimeksi muokattu:
Meillä peruskoulussa aloiteltiin Pascalilla ja sitten amiksessa oli pari kurssia C:tä. Noihin aikoihin Python taisi olla vasta keksitty joten ei ihmekään että sitä ei opeteltu. Suurin osa porukasta oli kyllä ihan kuutamolla C:n kanssa kun syntaksi on ehkä vähän hankalahko ihan totaaliselle aloittelijalle, joten joku syntaksiltaan simppelimpi kieli ehkä olisi ollut parempi lähtökohta.
 

Statistiikka

Viestiketjuista
265 090
Viestejä
4 589 333
Jäsenet
75 563
Uusin jäsen
engh123

Hinta.fi

Back
Ylös Bottom