Есть ли способ центрировать виджет холста в окне? - PullRequest
2 голосов
/ 20 июня 2019

Я строю шахматную программу, используя Tkinker / Python.Я пытаюсь выровнять доску по центру окна, чтобы я мог разместить снятые фигуры рядом с доской.Есть идеи?

from tkinter import *
root=Tk()

class Board():  
    def drawboard():


        dark="#643c22"
        light="#faeac6"

        canvas=Canvas(root, width=920, height=720,)
        canvas.pack( fill=BOTH)
        colour=light
        for row in range(8):
            if colour==dark:
                colour=light
            else:
               colour=dark 
            for column in range(8):
                x1 = (column * 90)
                y1 = ((7-row)* 90)
                x2 = x1 + 90
                y2 = y1 + 90
                canvas.create_rectangle(x1, y1, x2, y2, fill=colour)

                if colour==dark:
                    colour=light
                else:
                    colour=dark


Board.drawboard()


root.mainloop()

Я ожидаю, что он выровнен по центру, но выровнен по левому краю.

1 Ответ

0 голосов
/ 20 июня 2019

Созданный вами класс - это просто контейнер для некоторых функций ... Возможно, вам нужно прочитать немного об объектно-ориентированном питоне и ознакомиться с его спецификой. Я переписал ваш класс Board в качестве примера; он наследуется от tk.Tk и поэтому является tkinter root.

Что касается размещения различных виджетов, я добавил правую и левую рамку, чтобы центрировать холст, представляющий доску шашек.

получается так:

import tkinter as tk


class Board(tk.Tk):

    colours = ["#643c22", "#faeac6"]

    def __init__(self, n=8):
        super().__init__()
        self.n = n
        self.left_frame = tk.Frame(self)
        self.left_frame.grid(row=0, column=0, rowspan=8, padx=100)
        self.right_frame = tk.Frame(self)
        self.right_frame.grid(row=0, column=10, rowspan=8)
        self.canvas = tk.Canvas(self, width=920, height=720, )
        self.canvas.grid(row=0, column=1, columnspan=8, rowspan=8)
        self.board = [[None for row in range(n)] for col in range(n)]
        self.current_colour_ndx = 0

    def _swap_colours(self):
        self.current_colour_ndx = (self.current_colour_ndx + 1) % 2

    def drawboard(self):

        for col in range(self.n):
            self._swap_colours()
            for row in range(self.n):
                x1 = col * 90
                y1 = (7-row) * 90
                x2 = x1 + 90
                y2 = y1 + 90
                colour = self.colours[self.current_colour_ndx]
                self.board[row][col] = self.canvas.create_rectangle(x1, y1, x2, y2, fill=colour)
                self._swap_colours()


if __name__ == '__main__':

    board = Board()
    board.drawboard()
    board.mainloop()

enter image description here

...