有没有办法让 canvas 小部件在 window 中居中?

Is there a way to centre a canvas widget in the window?

我正在使用 Tkinker/Python 构建一个国际象棋程序。我正在尝试将棋盘对齐 window 的中心,以便我可以将取出的棋子放在棋盘旁边。有什么想法吗?

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()

我希望它排在中间,但它是靠左对齐的。

您创建的 class 只是一些功能的容器...您可能需要阅读一些有关面向对象的内容 python,并熟悉其细节。我重写了你的 class Board 作为例子;它继承自 tk.Tk,因此是 tkinter root.

就各种小部件的放置而言,我添加了一个左右框架,以便使代表棋盘的 canvas 居中。

它是这样的:

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()