Алфавит языка. Синтаксис установи соответствие между арифметическими операциями и результатами их выполнения.
64**0.5 2**5 21/3 18/3.0 6.0 7 8.0 32
назад проверить
Ответы на вопрос:
Конечно, я готов вам доделать код для рисования многоугольника и выбора цвета. Вот исправленный код:
```python
from tkinter import *
from tkinter.colorchooser import askcolor
root = Tk()
canvas = Canvas(root, width=400, height=400, bg='white')
canvas.pack()
canvas.old_coords = None
polygon = None
bgcolor = 'white'
def paint_color():
global bgcolor
color = askcolor(title="Choose color")[1]
if color:
bgcolor = color
def paint(event):
global polygon
if canvas.old_coords:
x1, y1 = canvas.old_coords
x2, y2 = event.x, event.y
canvas.create_line(x1, y1, x2, y2, fill=bgcolor)
canvas.old_coords = x2, y2
else:
canvas.old_coords = event.x, event.y
if polygon:
canvas.delete(polygon)
coords = list(canvas.coords(canvas.find_all()[0]))[:-2]
coords = [(coords[i], coords[i+1]) for i in range(0, len(coords), 2)]
coords.append((event.x, event.y))
polygon = canvas.create_polygon(coords, outline=bgcolor, fill='', width=3)
def clear():
canvas.delete('all')
def save():
x = root.winfo_rootx() + canvas.winfo_x()
y = root.winfo_rooty() + canvas.winfo_y()
x1 = x + canvas.winfo_width()
y1 = y + canvas.winfo_height()
ImageGrab.grab().crop((x, y, x1, y1)).save("screenshot.png")
button_color = Button(root, text="Color", command=paint_color)
button_color.pack(side=LEFT, padx=5)
button_clear = Button(root, text="Clear", command=clear)
button_clear.pack(side=LEFT, padx=5)
button_save = Button(root, text="Save", command=save)
button_save.pack(side=LEFT, padx=5)
canvas.bind('<B1-Motion>', paint)
root.mainloop()
```
Изменения включают добавление кнопки "Color" для выбора цвета, которая вызывает диалоговое окно выбора цвета. Также изменен код для окраски многоугольника - теперь цвет можно выбирать через глобальную переменную `bgcolor`.
По поводу кнопки "Save", проблема заключается в том, что вы сохраняете весь холст, включая фон и кнопки. Вместо этого нужно сохранять только рисунок, который находится на холсте. Для этого можно использовать модуль `PIL`:
```python
from PIL import ImageGrab
def save():
x = root.winfo_rootx() + canvas.winfo_x()
y = root.winfo_rooty() + canvas.winfo_y()
x1 = x + canvas.winfo_width()
y1 = y + canvas.winfo_height()
ImageGrab.grab().crop((x, y, x1, y1)).save("screenshot.png")
```
Этот код только сохраняет область, занимаемую холстом.
Популярно: Информатика
-
matherfather19.01.2023 03:42
-
mygalmaksim24.07.2020 09:28
-
miro4ka454606.07.2021 04:27
-
Крутая19502301.04.2022 20:52
-
ВладВишня11.02.2023 22:49
-
nazar22117.02.2023 19:49
-
Nickbb01.05.2023 20:25
-
Olga2000466621.03.2022 01:16
-
НикаЛисовская17.11.2020 21:17
-
nholodok40027.08.2021 02:39