2011-05-10 76 views
2

我試圖實現我自己的自定義DataGridView列。我使用下面的代碼完成了這個。從此MSDN頁面借用和修改:http://msdn.microsoft.com/en-us/library/system.windows.forms.idatagridvieweditingcontrol.aspx處理自定義DataGridView列的大小調整事件

我卡在哪裏是如何通知usercontrol ucFolderBrowser gridviewcolumn已被調整大小,並需要相應地進行調整?

class FolderGridViewColumn : DataGridViewColumn 
{ 
    public FolderGridViewColumn() : base(new FolderCell()) 
    { 
    } 

    public override DataGridViewCell CellTemplate 
    { 
     get 
     { 
      return base.CellTemplate; 
     } 
     set 
     { 
      // Ensure that the cell used for the template is a FolderCell. 
      if (value != null && 
       !value.GetType().IsAssignableFrom(typeof(FolderCell))) 
      { 
       throw new InvalidCastException("Must be a FolderCell"); 
      } 
      base.CellTemplate = value; 
     } 
    } 
} 

class FolderCell : DataGridViewTextBoxCell 
{ 
    public FolderCell() : base() 
    { 
     //this.Style.Format = "";  //Can set format 
    } 

    public override void InitializeEditingControl(int rowIndex, object initialFormattedValue, DataGridViewCellStyle dataGridViewCellStyle) 
    { 
     base.InitializeEditingControl(rowIndex, initialFormattedValue, dataGridViewCellStyle); 

     FolderEditingControl ctl = DataGridView.EditingControl as FolderEditingControl; 

     // Use the default row value when Value property is null. 
     if (this.Value == null) 
     { 
      ctl.Text = (string)this.DefaultNewRowValue; 
     } 
     else 
     { 
      ctl.Text = (string)this.Value; 
     } 
    } 
    public override Type EditType 
    { 
     get 
     { 
      // Return the type of the editing control that FolderCell uses. 
      return typeof(FolderEditingControl); 
     } 
    } 
    public override Type ValueType 
    { 
     get 
     { 
      // Return the type of the value that FolderBrowserCell contains. 

      return typeof(string); 
     } 
    } 
    public override object DefaultNewRowValue 
    { 
     get 
     { 
      //default value. 
      return string.Empty; 
     } 
    } 
} 

class FolderEditingControl : ucFolderBrowser, IDataGridViewEditingControl 
{ 
    DataGridView dataGridView; 
    private bool valueChanged = false; 
    int rowIndex; 

    public FolderEditingControl() { } 

    // Implements the IDataGridViewEditingControl.EditingControlFormattedValue 
    // property. 
    public object EditingControlFormattedValue 
    { 
     get 
     { 
      return this.Text; 
     } 
     set 
     {    
      this.Text = (string) value; 
     } 
    } 

    // Implements the 
    // IDataGridViewEditingControl.GetEditingControlFormattedValue method. 
    public object GetEditingControlFormattedValue(DataGridViewDataErrorContexts context) 
    { 
     return this.EditingControlFormattedValue; 
    } 

    // Implements the 
    // IDataGridViewEditingControl.ApplyCellStyleToEditingControl method. 
    public void ApplyCellStyleToEditingControl(DataGridViewCellStyle dataGridViewCellStyle) 
    { 
     this.Font = dataGridViewCellStyle.Font; 
     this.ForeColor = dataGridViewCellStyle.ForeColor; 
     this.BackColor = dataGridViewCellStyle.BackColor; 
    } 

    // Implements the IDataGridViewEditingControl.EditingControlRowIndex 
    // property. 
    public int EditingControlRowIndex 
    { 
     get 
     { 
      return rowIndex; 
     } 
     set 
     { 
      rowIndex = value; 
     } 
    } 

    // Implements the IDataGridViewEditingControl.EditingControlWantsInputKey 
    // method. 
    public bool EditingControlWantsInputKey(Keys key, bool dataGridViewWantsInputKey) 
    { 
     // Let the textbox handle the keys listed. 
     switch (key & Keys.KeyCode) 
     { 
      case Keys.Left: 
      case Keys.Right: 
      case Keys.Home: 
      case Keys.End: 
      default: 
       return !dataGridViewWantsInputKey; 
     } 
    } 

    // Implements the IDataGridViewEditingControl.PrepareEditingControlForEdit 
    // method. 
    public void PrepareEditingControlForEdit(bool selectAll) 
    { 
     // No preparation needs to be done. 
    } 

    // Implements the IDataGridViewEditingControl 
    // .RepositionEditingControlOnValueChange property. 
    public bool RepositionEditingControlOnValueChange 
    { 
     get 
     { 
      return false; 
     } 
    } 

    // Implements the IDataGridViewEditingControl 
    // .EditingControlDataGridView property. 
    public DataGridView EditingControlDataGridView 
    { 
     get 
     { 
      return dataGridView; 
     } 
     set 
     { 
      dataGridView = value; 
     } 
    } 

    // Implements the IDataGridViewEditingControl 
    // .EditingControlValueChanged property. 
    public bool EditingControlValueChanged 
    { 
     get 
     { 
      return valueChanged; 
     } 
     set 
     { 
      valueChanged = value; 
     } 
    } 

    // Implements the IDataGridViewEditingControl 
    // .EditingPanelCursor property. 
    public Cursor EditingPanelCursor 
    { 
     get 
     { 
      return base.Cursor; 
     } 
    } 

    protected override void OnTextChanged(EventArgs e) 
    { 
     // Notify the DataGridView that the contents of the cell 
     // have changed. 
     valueChanged = true; 
     this.EditingControlDataGridView.NotifyCurrentCellDirty(true); 
     base.OnTextChanged(e); 
    } 
} 

public partial class ucFolderBrowser : UserControl 
{ 
    public ucFolderBrowser() 
    { 
     InitializeComponent(); 
    } 

    public override string Text 
    { 
     get 
     { 
      return txtPath.Text; 
     } 
     set 
     { 
      txtPath.Text = value; 
     } 
    } 

    /// <summary> 
    /// Required method for Designer support - do not modify 
    /// the contents of this method with the code editor. 
    /// </summary> 
    private void InitializeComponent() 
    { 
     this.txtPath = new System.Windows.Forms.TextBox(); 
     this.btnBrowse = new System.Windows.Forms.Button(); 
     this.SuspendLayout(); 
     // 
     // txtPath 
     // 
     this.txtPath.Location = new System.Drawing.Point(0, 0); 
     this.txtPath.Name = "txtPath"; 
     this.txtPath.Size = new System.Drawing.Size(100, 20); 
     this.txtPath.TabIndex = 0; 
     // 
     // btnBrowse 
     // 
     this.btnBrowse.Location = new System.Drawing.Point(100, -1); 
     this.btnBrowse.Name = "btnBrowse"; 
     this.btnBrowse.Size = new System.Drawing.Size(30, 21); 
     this.btnBrowse.TabIndex = 1; 
     this.btnBrowse.Text = "..."; 
     this.btnBrowse.UseVisualStyleBackColor = true; 
     this.btnBrowse.Click += new System.EventHandler(this.btnBrowse_Click); 
     // 
     // ucFolderBrowser 
     // 
     this.AutoScaleDimensions = new System.Drawing.SizeF(6F, 13F); 
     this.AutoScaleMode = System.Windows.Forms.AutoScaleMode.Font; 
     this.Controls.Add(this.btnBrowse); 
     this.Controls.Add(this.txtPath); 
     this.Name = "ucFolderBrowser"; 
     this.Size = new System.Drawing.Size(129, 20); 
     this.ResumeLayout(false); 
     this.PerformLayout(); 

    } 
} 
+0

你的意思是你想調整基於網格大小的usercontrol自身? – V4Vendetta 2011-05-10 04:32:46

+0

正確!顯然有時候這些列會改變大小,所以我希望得到通知並相應地處理事件。 – 2011-05-10 04:42:14

回答

0

原來,解決方案是使用usercontrols resize事件 - 當DataGridView列的大小調整時,此事件會觸發。

然後我意識到我甚至不需要處理resize事件,因爲我可以停靠兩個控件。