page contents

C# tablelayoutpanel 无法删除填充/边距

本文讲述了C# tablelayoutpanel 无法删除填充/边距!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

attachments-2022-09-k2LwS6a46331084f21c88.png本文讲述了C# tablelayoutpanel 无法删除填充/边距!具有很好的参考价值,希望对大家有所帮助。一起跟随六星小编过来看看吧,具体如下:

基本上,我在删除 tablelayoutpanel 中控件之间的填充/边距时遇到了问题。

我已将 tablelayoutpanel 的边距和内边距设置为 0。 Cellborderstyle 是无。

添加的控件的边距和内边距都设置为 0。

然而,神秘的边缘不断出现。有什么帮助吗?

在这里尝试了这 2 种解决方案以及网络上的其他各种解决方案,但没有一个可以消除两者之间的间距。

在 VS2010、.net 4.5 上运行

Form1.cs

usingSystem;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;

namespace Multiply {
    public partial class Form1 : Form {
        public Form1() {
            InitializeComponent();
            LoadBoard(10, 10);
        }

    private void LoadBoard(int col, int row) {
        board.ColumnCount = col;
        board.RowCount = row;
        board.BorderStyle = BorderStyle.FixedSingle;

        float colSize = 100f / col;
        float rowSize = 100f / row;

        board.ColumnStyles[0].SizeType = SizeType.Percent;
        board.ColumnStyles[0].Width = colSize;
        board.RowStyles[0].SizeType = SizeType.Percent;
        board.RowStyles[0].Height = rowSize;


        for (int x = 0; x < col; x++)
            board.ColumnStyles.Add(new ColumnStyle(SizeType.Percent, colSize));

        for (int x = 0; x < row; x++) {
            board.RowStyles.Add(new RowStyle(SizeType.Percent, rowSize));
            for (int y = 0; y < col; y++) {
                board.Controls.Add(CreateButton( x + "," + y ), y, x);
            }
            Console.WriteLine(x);
        }

    }

    private Button CreateButton(string text) {
        Button a = new Button();
        a.Text = text;
        a.Dock = DockStyle.Fill;
        a.Margin = new Padding(0);
        a.Padding = new Padding(0);
        return a;
    }
}
}

设计师

class Form1 {
        /// <summary>
        /// Required designer variable.
        /// </summary>
        private System.ComponentModel.IContainer components = null;

        /// <summary>
        /// Clean up any resources being used.
        /// </summary>
        /// <param name="disposing">true if managed resources should be disposed; otherwise, false.</param>
        protected override void Dispose(bool disposing) {
            if (disposing && (components != null)) {
                components.Dispose();
            }
            base.Dispose(disposing);
        }

        #region Windows Form Designer generated code

        /// <summary>
        /// Required method for Designer support - do not modify
        /// the contents of this method with the code editor.
        /// </summary>
        private void InitializeComponent() {
            this.board = new System.Windows.Forms.TableLayoutPanel();
            this.SuspendLayout();
            // 
            // board
            // 
            this.board.ColumnCount = 1;
            this.board.ColumnStyles.Add(new System.Windows.Forms.ColumnStyle(System.Windows.Forms.SizeType.Percent, 25F));
            this.board.Dock = System.Windows.Forms.DockStyle.Top;
            this.board.Location = new System.Drawing.Point(0, 0);
            this.board.Margin = new System.Windows.Forms.Padding(0);
            this.board.Name = "board";
            this.board.RowCount = 1;
            this.board.RowStyles.Add(new System.Windows.Forms.RowStyle(System.Windows.Forms.SizeType.Absolute, 20F));
            this.board.Size = new System.Drawing.Size(368, 223);
            this.board.TabIndex = 0;
            // 
            // Form1
            // 
            this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F);
            this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font;
            this.ClientSize = new System.Drawing.Size(368, 391);
            this.Controls.Add(this.board);
            this.Name = "Form1";
            this.Text = "Form1";
            this.ResumeLayout(false);

        }

        #endregion

        private System.Windows.Forms.TableLayoutPanel board;
    }
}


【解决方案1】:

你追错了,这个差距是Button控件造成的,不是TableLayoutPanel造成的。当您使用设计器将按钮放在表单上时,您可以清楚地看到一些东西,注意选择矩形和按钮表面之间的间隙。

您需要修改按钮以摆脱它或使用不同类型的控件。最简单的方法是让它变平:

private Control CreateButton(string text) {
        var a = new Button();
        a.FlatStyle = FlatStyle.Flat;
        a.FlatAppearance.BorderSize = 0;   // optional
        // etc...
    }

如果您想查看网格,请删除 BorderSize 分配。

【解决方案2】:

我在TableLayoutPanel中使用不同的控件时遇到了同样的问题

你可以这样做

  1. 转到设计视图
  2. 点击属性
  3. 转到列,当您单击列旁边的文本框时,文本框的最右侧会出现一个按钮 (...),单击它
  4. 会出现一个弹出窗口,选择 AutoSize(而不是 Absolute 或 Percentage)。
  5. 在 Show: 的同一窗口中选择 Rows 并再次选择 Autosize。
  6. 点击确定就完成了。

更多相关技术内容咨询欢迎前往并持续关注六星社区了解详情。

想高效系统的学习Python编程语言,推荐大家关注一个微信公众号:Python编程学习圈。每天分享行业资讯、技术干货供大家阅读,关注即可免费领取整套Python入门到进阶的学习资料以及教程,感兴趣的小伙伴赶紧行动起来吧。

attachments-2022-05-rLS4AIF8628ee5f3b7e12.jpg

  • 发表于 2022-09-26 10:03
  • 阅读 ( 397 )
  • 分类:C/C++开发

你可能感兴趣的文章

相关问题

0 条评论

请先 登录 后评论
轩辕小不懂
轩辕小不懂

2403 篇文章

作家榜 »

  1. 轩辕小不懂 2403 文章
  2. Pack 1131 文章
  3. 小柒 1046 文章
  4. Nen 576 文章
  5. 王昭君 209 文章
  6. 文双 71 文章
  7. 小威 64 文章
  8. Cara 36 文章