2017-04-05 36 views
0

DataGridViewをカスタムペイントしようとしていますが、DataGridViewをスクロールした直後に表示するのに問題があります。私の細胞の向こう側に現れる線があります。問題は、コントロールがスクロールされたときにペイントイベントがセルを再描画していないように見えるため、フォームの端に描画されたセルが一度スクロールされて中央に再描画されないことです。トラブルシューティングスクロール可能なDataGridview

DataGridViewの端にあるセルの一部が表示されず、完全に表示されているかのように描画していますが、アプリケーションが表示されないようにすることで、問題を解決できます。

私の質問は、私が部分的に表示されたセルのセルペイントを調整できるようにDataGridViewをペイントする良い方法はありますか?私は他の質問を見て、他のペイントイベントを使ってみましたが、私は何かを得ることができませんでした。

ここに私が話している問題を示す簡単なプログラムがあります。

public partial class Form1 : Form 
{ 
    public Form1() 
    { 
     InitializeComponent(); 

     for (int i = 0; i < 256; i++) 
      dataGridView1.Rows.Add(new object[] { string.Format("Test_text_{0}", i) }); 

     dataGridView1.Paint += DataGridView1_Paint; 
     dataGridView1.CellPainting += (s, e) => { if (e.RowIndex > 0 && e.ColumnIndex >= 0) e.Handled = true; }; 
    } 

    private void DataGridView1_Paint(object sender, PaintEventArgs e) 
    { 
     Rectangle rect; 

     using (Brush gridBrush = new SolidBrush(dataGridView1.GridColor), 
      cellBrush = new SolidBrush(dataGridView1.DefaultCellStyle.BackColor), 
      textBrush = new SolidBrush(dataGridView1.DefaultCellStyle.ForeColor)) 
     { 
      using (Pen gridLinePen = new Pen(gridBrush)) 
      { 
       for (int row = 0; row < dataGridView1.Rows.Count; row++) 
       { 
        if (!dataGridView1.Rows[row].Displayed) 
         continue; 

        if (dataGridView1.Rows[row].Cells[0].Value != null) 
        { 
         //draw cell 
         rect = dataGridView1.GetCellDisplayRectangle(0, row, true);//Setting cutOverflow to false removes lines 
         e.Graphics.FillRectangle(cellBrush, rect); 
         e.Graphics.DrawLine(gridLinePen, rect.Left, rect.Bottom - 1, rect.Right - 1, rect.Bottom - 1); 
         e.Graphics.DrawLine(gridLinePen, rect.Right - 1, rect.Top, rect.Right - 1, rect.Bottom); 

         //add text 
         e.Graphics.DrawString(dataGridView1.Rows[row].Cells[0].Value.ToString(), 
          dataGridView1.DefaultCellStyle.Font, textBrush, rect.X + 4, rect.Y + 4); 
        } 
        else 
         //handle empty rows 
         e.Graphics.FillRectangle(gridBrush, dataGridView1.GetCellDisplayRectangle(0, row, true)); 
       } 
      } 
     } 
    } 
} 

デザイナーコード

partial 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.dataGridView1 = new System.Windows.Forms.DataGridView(); 
     this.Column1 = new System.Windows.Forms.DataGridViewTextBoxColumn(); 
     ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).BeginInit(); 
     this.SuspendLayout(); 
     // 
     // dataGridView1 
     // 
     this.dataGridView1.ColumnHeadersHeightSizeMode = System.Windows.Forms.DataGridViewColumnHeadersHeightSizeMode.AutoSize; 
     this.dataGridView1.Columns.AddRange(new System.Windows.Forms.DataGridViewColumn[] { 
     this.Column1}); 
     this.dataGridView1.Location = new System.Drawing.Point(46, 36); 
     this.dataGridView1.Name = "dataGridView1"; 
     this.dataGridView1.Size = new System.Drawing.Size(184, 428); 
     this.dataGridView1.TabIndex = 0; 
     // 
     // Column1 
     // 
     this.Column1.HeaderText = "Column1"; 
     this.Column1.Name = "Column1"; 
     // 
     // Form1 
     // 
     this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); 
     this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; 
     this.ClientSize = new System.Drawing.Size(281, 522); 
     this.Controls.Add(this.dataGridView1); 
     this.Name = "Form1"; 
     this.Text = "Form1"; 
     ((System.ComponentModel.ISupportInitialize)(this.dataGridView1)).EndInit(); 
     this.ResumeLayout(false); 

    } 

    #endregion 

    private System.Windows.Forms.DataGridView dataGridView1; 
    private System.Windows.Forms.DataGridViewTextBoxColumn Column1; 
} 

は、ここであなたが実行し

dataGridView1.CellPainting += (s, e) => 
    { if (e.RowIndex > 0 && e.ColumnIndex >= 0) e.Handled = true; }; 

を書き込むことによって、セル画を無効にしているスクリーンショット

enter image description here

+1

DGVのScrollイベントを無効にしてみてください! – TaW

+0

それは動作します。ありがとう! –

+0

または[これを使う](http://stackoverflow.com/questions/13999781/tearing-in-my-animation-on-winforms-c-sharp) – TaW

答えて

1

PaintCellPaintingイベントの両方が、DataGridViewがスクロールされる前に表示されなかったセルの部分だけをペイントしていたという問題がありました。 ScrollイベントでDataGridView全体を強制的に再描画するようにして、この問題を解決できました。

dataGridView1.Scroll += (s, e) => dataGridView1.Invalidate(); 
0

ですPaintイベントの代わりにCellPaintingイベントのセルペインティング。

+0

私はペイントしているセルのセルペイントを無効にしました'Paint'イベントです。私は個々のセルを除いて同じコードを使って 'CellPainting'イベントを使ってみましたが、私は同じ結果を得ます。 (そして、私のアプリケーションでは、いくつかの行に隣接する列に参加する必要があるので、可能であれば、 'Paint'イベントまたはPre/Post行の描画イベントの1つを使用することをお勧めします) –

+0

このSOソリューションは、 DataGridViewセルペインティングがスクロールで完全に機能していません。](0120-338-805) –

+1

... orr this [スクロールするとDataGridView.Paintスミアを処理してセルを結合しました](https://social.msdn。 microsoft.com/Forums/windows/en-US/baca9e53-d927-4020-87af-6da08f1c991e/merged-cells-by-handling-datagridviewpaint-smears-when-scrolled?forum=winformsapplications) –

関連する問題