public ViewDrawRibbonGroupMaskedTextBox(KryptonRibbon ribbon,
KryptonRibbonGroupMaskedTextBox ribbonMaskedTextBox,
NeedPaintHandler needPaint)
{
Debug.Assert(ribbon != null);
Debug.Assert(ribbonMaskedTextBox != null);
Debug.Assert(needPaint != null);
// Remember incoming references
_ribbon = ribbon;
_ribbonMaskedTextBox = ribbonMaskedTextBox;
_needPaint = needPaint;
_currentSize = _ribbonMaskedTextBox.ItemSizeCurrent;
// Hook into the masked textbox events
_ribbonMaskedTextBox.MouseEnterControl += new EventHandler(OnMouseEnterControl);
_ribbonMaskedTextBox.MouseLeaveControl += new EventHandler(OnMouseLeaveControl);
// Associate this view with the source component (required for design time selection)
Component = _ribbonMaskedTextBox;
if (_ribbon.InDesignMode)
{
// At design time we need to know when the user right clicks the masked textbox
ContextClickController controller = new ContextClickController();
controller.ContextClick += new MouseEventHandler(OnContextClick);
MouseController = controller;
}
// Create controller needed for handling focus and key tip actions
_controller = new MaskedTextBoxController(_ribbon, _ribbonMaskedTextBox, this);
SourceController = _controller;
KeyController = _controller;
// We need to rest visibility of the masked textbox for each layout cycle
_ribbon.ViewRibbonManager.LayoutBefore += new EventHandler(OnLayoutAction);
_ribbon.ViewRibbonManager.LayoutAfter += new EventHandler(OnLayoutAction);
// Define back reference to view for the masked text box definition
_ribbonMaskedTextBox.MaskedTextBoxView = this;
// Give paint delegate to masked textbox so its palette changes are redrawn
_ribbonMaskedTextBox.ViewPaintDelegate = needPaint;
// Hook into changes in the ribbon custom definition
_ribbonMaskedTextBox.PropertyChanged += new PropertyChangedEventHandler(OnMaskedTextBoxPropertyChanged);
}