| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057 |
- // Permission is hereby granted, free of charge, to any person obtaining
- // a copy of this software and associated documentation files (the
- // "Software"), to deal in the Software without restriction, including
- // without limitation the rights to use, copy, modify, merge, publish,
- // distribute, sublicense, and/or sell copies of the Software, and to
- // permit persons to whom the Software is furnished to do so, subject to
- // the following conditions:
- //
- // The above copyright notice and this permission notice shall be
- // included in all copies or substantial portions of the Software.
- //
- // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
- // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
- // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
- // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
- // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
- // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
- // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
- //
- // Copyright (c) 2004 Novell, Inc.
- //
- // Authors:
- // Peter Bartok [email protected]
- //
- // Based on work by:
- // Aleksey Ryabchuk [email protected]
- // Alexandre Pigolkine [email protected]
- // Dennis Hayes [email protected]
- // Jaak Simm [email protected]
- // John Sohn [email protected]
- //
- // $Revision: 1.20 $
- // $Modtime: $
- // $Log: Control.cs,v $
- // Revision 1.20 2004/08/11 15:13:32 pbartok
- // - Now properly reparents windows
- //
- // Revision 1.19 2004/08/11 14:37:11 pbartok
- // - Duh!
- //
- // Revision 1.18 2004/08/11 13:47:22 pbartok
- // - Rewrote the collection stuff. Might not be as fast now, not keeping
- // the number of children around and accessible directly, but it's more
- // straightforward
- //
- // Revision 1.17 2004/08/10 18:32:10 jordi
- // throw ontextchange event
- //
- // Revision 1.16 2004/08/10 17:43:04 pbartok
- // - Added more to the still unfinished Dock/Anchor layout code
- //
- // Revision 1.15 2004/08/10 15:08:05 jackson
- // Control will now handle the buffering code, so each control does not have to implement this.
- //
- // Revision 1.14 2004/08/09 22:11:25 pbartok
- // - Added incomplete dock layout code
- // - Added support for mouse wheel
- //
- // Revision 1.13 2004/08/09 17:25:56 jackson
- // Use new color names
- //
- // Revision 1.12 2004/08/09 15:54:51 jackson
- // Get default properties from the theme.
- //
- // Revision 1.11 2004/08/06 21:30:56 pbartok
- // - Fixed recursive loop when resizing
- // - Improved/fixed redrawing on expose messages
- //
- // Revision 1.10 2004/08/06 15:53:39 jordi
- // X11 keyboard navigation
- //
- // Revision 1.9 2004/08/04 21:14:26 pbartok
- // - Fixed Invalidation bug (calculated wrong client area)
- // - Added ClientSize setter
- //
- // Revision 1.8 2004/08/04 20:11:24 pbartok
- // - Added Invalidate handling
- //
- // Revision 1.7 2004/07/27 10:38:17 jordi
- // changes to be able to run winforms samples
- //
- // Revision 1.6 2004/07/19 19:09:42 jordi
- // label control re-written: added missing functionlity, events, and properties
- //
- // Revision 1.5 2004/07/19 16:49:23 jordi
- // fixes SetBounds logic
- //
- // Revision 1.4 2004/07/19 07:29:35 jordi
- // Call RefreshWindow only if the window has created
- //
- // Revision 1.3 2004/07/15 17:03:35 jordi
- // added basic mouse handeling events
- //
- // Revision 1.2 2004/07/13 15:31:45 jordi
- // commit: new properties and fixes form size problems
- //
- // Revision 1.1 2004/07/09 05:21:25 pbartok
- // - Initial check-in
- //
- //
- // NOT COMPLETE
- using System;
- using System.Drawing;
- using System.ComponentModel;
- using System.Collections;
- using System.Diagnostics;
- using System.Threading;
- using System.Runtime.InteropServices;
- namespace System.Windows.Forms
- {
- public class Control : Component, ISynchronizeInvoke, IWin32Window
- {
- #region Local Variables
- // Basic
- internal Rectangle bounds; // bounding rectangle for control
- internal object creator_thread; // thread that created the control
- internal ControlNativeWindow window; // object for native window handle
- internal string name; // for object naming
- // State
- internal bool has_focus; // true if control has focus
- internal bool is_visible; // true if control is visible
- internal bool is_enabled; // true if control is enabled (usable/not grayed out)
- internal int tab_index; // position in tab order of siblings
- internal bool is_disposed; // has the window already been disposed?
- internal Size window_size; // size of the window (including decorations)
- internal Size client_size; // size of the client area (window excluding decorations)
- internal ControlStyles control_style; // win32-specific, style bits for control
- // Visuals
- internal Color foreground_color; // foreground color for control
- internal Color background_color; // background color for control
- internal Image background_image; // background image for control
- internal Font font; // font for control
- internal string text; // window/title text for control
- // Layout
- internal AnchorStyles anchor_style; // anchoring requirements for our control
- internal DockStyle dock_style; // docking requirements for our control (supercedes anchoring)
- internal int prev_width; // previous width of the control; required for anchoring
- internal int prev_height; // previous height of our control; required for anchoring
- internal Size prev_size;
- // to be categorized...
- static internal Hashtable controls; // All of the applications controls, in a flat list
- internal ControlCollection child_controls; // our children
- internal Control parent; // our parent control
- internal AccessibleObject accessibility_object; // object that contains accessibility information about our control
- internal BindingContext binding_context; // TODO
- internal RightToLeft right_to_left; // drawing direction for control
- internal int layout_suspended;
- private Graphics dc_mem;
- private Bitmap bmp_mem;
- #endregion // Local Variables
- #region Private Classes
- // This helper class allows us to dispatch messages to Control.WndProc
- internal class ControlNativeWindow : NativeWindow {
- private Control control;
- public ControlNativeWindow(Control control) : base() {
- this.control=control;
- }
- protected override void WndProc(ref Message m) {
- control.WndProc(ref m);
- }
- }
- #endregion
-
- #region Public Classes
- public class ControlCollection : IList, ICollection, ICloneable, IEnumerable {
- #region ControlCollection Local Variables
- private ArrayList list;
- private Control owner;
- #endregion // ControlCollection Local Variables
- #region ControlCollection Public Constructor
- public ControlCollection(Control owner) {
- this.owner=owner;
- this.list=new ArrayList();
- }
- #endregion
- #region ControlCollection Public Instance Properties
- public int Count {
- get {
- return list.Count;
- }
- }
- public bool IsReadOnly {
- get {
- return list.IsReadOnly;
- }
- }
- public virtual Control this[int index] {
- get {
- if (index < 0 || index >= list.Count) {
- throw new ArgumentOutOfRangeException("index", index, "ControlCollection does not have that many controls");
- }
- return (Control)list[index];
- }
- }
- #endregion // ControlCollection Public Instance Properties
-
- #region ControlCollection Private Instance Methods
- public virtual void Add(Control value) {
- for (int i=0; i<list.Count; i++) {
- if (list[i]==value) {
- // Do we need to do anything here?
- return;
- }
- }
- list.Add(value);
- value.Parent=owner;
- }
-
- public virtual void AddRange(Control[] controls) {
- for (int i=0; i<controls.Length; i++) {
- Add(controls[i]);
- }
- }
- public virtual void Clear() {
- owner.SuspendLayout();
- list.Clear();
- owner.ResumeLayout();
- }
- public virtual bool Contains(Control value) {
- return list.Contains(value);
- }
- public void CopyTo(Array array, int index) {
- list.CopyTo(array, index);
- }
- public override bool Equals(object other) {
- if (other is ControlCollection && (((ControlCollection)other).owner==this.owner)) {
- return(true);
- } else {
- return(false);
- }
- }
- public int GetChildIndex(Control child) {
- return GetChildIndex(child, false);
- }
- public int GetChildIndex(Control child, bool throwException) {
- int index;
- index=list.IndexOf(child);
- if (index==-1 && throwException) {
- throw new ArgumentException("Not a child control", "child");
- }
- return index;
- }
- public IEnumerator GetEnumerator() {
- return list.GetEnumerator();
- }
- public override int GetHashCode() {
- return base.GetHashCode();
- }
- public int IndexOf(Control control) {
- return list.IndexOf(control);
- }
- public virtual void Remove(Control value) {
- list.Remove(value);
- }
- public void RemoveAt(int index) {
- if (index<0 || index>=list.Count) {
- throw new ArgumentOutOfRangeException("index", index, "ControlCollection does not have that many controls");
- }
- list.RemoveAt(index);
- }
- public void SetChildIndex(Control child, int newIndex) {
- int old_index;
- old_index=list.IndexOf(child);
- if (old_index==-1) {
- throw new ArgumentException("Not a child control", "child");
- }
- if (old_index==newIndex) {
- return;
- }
- RemoveAt(old_index);
- if (newIndex>list.Count) {
- list.Add(child);
- } else {
- list.Insert(newIndex, child);
- }
- }
- #endregion // ControlCollection Private Instance Methods
- #region ControlCollection Interface Properties
- object IList.this[int index] {
- get {
- if (index<0 || index>=list.Count) {
- throw new ArgumentOutOfRangeException("index", index, "ControlCollection does not have that many controls");
- }
- return this[index];
- }
- set {
- if (!(value is Control)) {
- throw new ArgumentException("Object of type Control required", "value");
- }
- list[index]=(Control)value;
- }
- }
- bool IList.IsFixedSize {
- get {
- return false;
- }
- }
- bool IList.IsReadOnly {
- get {
- return list.IsReadOnly;
- }
- }
- bool ICollection.IsSynchronized {
- get {
- return list.IsSynchronized;
- }
- }
- object ICollection.SyncRoot {
- get {
- return list.SyncRoot;
- }
- }
- #endregion // ControlCollection Interface Properties
- #region ControlCollection Interface Methods
- int IList.Add(object value) {
- if (value == null) {
- throw new ArgumentNullException("value", "Cannot add null controls");
- }
- if (!(value is Control)) {
- throw new ArgumentException("Object of type Control required", "value");
- }
- return list.Add(value);
- }
- bool IList.Contains(object value) {
- if (!(value is Control)) {
- throw new ArgumentException("Object of type Control required", "value");
- }
- return this.Contains((Control) value);
- }
- int IList.IndexOf(object value) {
- if (!(value is Control)) {
- throw new ArgumentException("Object of type Control required", "value");
- }
- return this.IndexOf((Control) value);
- }
- void IList.Insert(int index, object value) {
- if (!(value is Control)) {
- throw new ArgumentException("Object of type Control required", "value");
- }
- list.Insert(index, value);
- }
- void IList.Remove(object value) {
- if (!(value is Control)) {
- throw new ArgumentException("Object of type Control required", "value");
- }
- list.Remove(value);
- }
- void ICollection.CopyTo(Array array, int index) {
- if (list.Count>0) {
- list.CopyTo(array, index);
- }
- }
- Object ICloneable.Clone() {
- ControlCollection clone = new ControlCollection(this.owner);
- clone.list=(ArrayList)list.Clone(); // FIXME: Do we need this?
- return clone;
- }
- #endregion // ControlCollection Interface Methods
- }
- #endregion // ControlCollection Class
-
- #region Public Constructors
- public Control() {
- creator_thread = Thread.CurrentThread;
- controls = new Hashtable();
- child_controls = CreateControlsInstance();
- bounds = new Rectangle(0, 0, DefaultSize.Width, DefaultSize.Height);
- window_size = new Size(DefaultSize.Width, DefaultSize.Height);
- client_size = new Size(DefaultSize.Width, DefaultSize.Height);
- prev_size = client_size;
- is_visible = true;
- is_disposed = false;
- is_enabled = true;
- has_focus = false;
- layout_suspended = 0;
- parent = null;
- background_image = null;
- }
- public Control(Control parent, string text) : this() {
- Text=text;
- Parent=parent;
- }
- public Control(Control parent, string text, int left, int top, int width, int height) : this() {
- Parent=parent;
- Left=left;
- Top=top;
- Width=width;
- Height=height;
- Text=text;
- }
- public Control(string text) : this() {
- Text=text;
- }
- public Control(string text, int left, int top, int width, int height) : this() {
- Left=left;
- Top=top;
- Width=width;
- Height=height;
- Text=text;
- }
- #endregion // Public Constructors
- #region Public Static Properties
- public static Color DefaultBackColor {
- get {
- return ThemeEngine.Current.DefaultControlBackColor;
- }
- }
- public static Font DefaultFont {
- get {
- return ThemeEngine.Current.DefaultFont;
- }
- }
- public static Color DefaultForeColor {
- get {
- return ThemeEngine.Current.DefaultControlForeColor;
- }
- }
- public static Keys ModifierKeys {
- get {
- return XplatUI.State.ModifierKeys;
- }
- }
- public static MouseButtons MouseButtons {
- get {
- return XplatUI.State.MouseButtons;
- }
- }
- public static Point MousePosition {
- get {
- return XplatUI.State.MousePosition;
- }
- }
- #endregion // Public Static Properties
- #region Public Instance Properties
- public AccessibleObject AccessibilityObject {
- get {
- if (accessibility_object==null) {
- accessibility_object=CreateAccessibilityInstance();
- }
- return accessibility_object;
- }
- }
- public string AccessibleDefaultActionDescription {
- get {
- return AccessibilityObject.default_action;
- }
- set {
- AccessibilityObject.default_action=value;
- }
- }
- public string AccessibleDescription {
- get {
- return AccessibilityObject.description;
- }
- set {
- AccessibilityObject.description=value;
- }
- }
- public string AccessibleName {
- get {
- return AccessibilityObject.Name;
- }
- set {
- AccessibilityObject.Name=value;
- }
- }
- public AccessibleRole AccessibleRole {
- get {
- return AccessibilityObject.role;
- }
- set {
- AccessibilityObject.role=value;
- }
- }
- public virtual bool AllowDrop {
- get {
- return XplatUI.State.DropTarget;
- }
- set {
- XplatUI.State.DropTarget=value;
- }
- }
- public virtual AnchorStyles Anchor {
- get {
- return anchor_style;
- }
- set {
- anchor_style=value;
- }
- }
- public virtual Color BackColor {
- get {
- if (background_color.IsEmpty) {
- if (parent!=null) {
- return parent.BackColor;
- }
- return DefaultBackColor;
- }
- return background_color;
- }
- set {
- background_color=value;
- Refresh();
- }
- }
- public virtual Image BackgroundImage {
- get {
- return background_image;
- }
- set {
- if (background_image!=value) {
- background_image=value;
- OnBackgroundImageChanged(EventArgs.Empty);
- }
- }
- }
- public virtual BindingContext BindingContext {
- get {
- throw new NotImplementedException();
- }
- set {
- throw new NotImplementedException();
- }
- }
- public int Bottom {
- get {
- return bounds.Y+bounds.Height;
- }
- }
- public Rectangle Bounds {
- get {
- return this.bounds;
- }
- set {
- SetBounds(value.Left, value.Top, value.Width, value.Height, BoundsSpecified.All);
- }
- }
- public bool CanFocus {
- get {
- throw new NotImplementedException();
- }
- }
- public bool CanSelect {
- get {
- throw new NotImplementedException();
- }
- }
- public bool Capture {
- get {
- throw new NotImplementedException();
- }
- set {
- throw new NotImplementedException();
- }
- }
- public bool CausesValidation {
- get {
- throw new NotImplementedException();
- }
- set {
- throw new NotImplementedException();
- }
- }
- public Rectangle ClientRectangle {
- get {
- return new Rectangle(0, 0, client_size.Width, client_size.Height);
- }
- }
- public Size ClientSize {
- get {
- return client_size;
- }
- set {
- this.SetClientSizeCore(value.Width, value.Height);
- }
- }
- public String CompanyName {
- get {
- return "Mono Project, Novell, Inc.";
- }
- }
- public bool ContainsFocus {
- get {
- throw new NotImplementedException();
- }
- }
- #if notdef
- public virtual ContextMenu ContextMenu {
- get {
- throw new NotImplementedException();
- }
- set {
- throw new NotImplementedException();
- }
- }
- #endif
- public ControlCollection Controls {
- get {
- return this.child_controls;
- }
- }
- public bool Created {
- get {
- throw new NotImplementedException();
- }
- }
- #if notdef
- public virtual Cursor Cursor {
- get {
- throw new NotImplementedException();
- }
- set {
- throw new NotImplementedException();
- }
- }
- public ControlBidingsCollection DataBindings {
- get {
- throw new NotImplementedException();
- }
- }
- #endif
- public virtual Rectangle DisplayRectangle {
- get {
- return ClientRectangle;
- }
- }
- public bool Disposing {
- get {
- throw new NotImplementedException();
- }
- }
- public virtual DockStyle Dock {
- get { return dock_style;}
- set {
- if (dock_style == value)
- return;
- dock_style = value;
- OnDockChanged(EventArgs.Empty);
- }
- }
- public bool Enabled {
- get {
- return is_enabled;
- }
- set {
- is_enabled = value;
- }
- }
- public virtual bool Focused {
- get {
- return this.has_focus;
- }
- set {
- throw new NotImplementedException();
- }
- }
- public virtual Font Font {
- get {
- if (font != null) {
- return font;
- }
- if (Parent != null && Parent.Font != null) {
- return Parent.Font;
- }
- return DefaultFont;
- }
- set {
- font=value;
- Refresh();
- }
- }
- public virtual Color ForeColor {
- get {
- if (foreground_color.IsEmpty) {
- if (parent!=null) {
- return parent.ForeColor;
- }
- return DefaultForeColor;
- }
- return foreground_color;
- }
- set {
- foreground_color=value;
- Refresh();
- }
- }
- public bool IsDisposed {
- get {
- return this.is_disposed;
- }
- }
- public bool IsHandleCreated {
- get {
- if ((window!=null) && (window.Handle!=IntPtr.Zero)) {
- return true;
- }
- return false;
- }
- }
- public string Name {
- get {
- return this.name;
- }
- set {
- this.name=value;
- }
- }
- public Control Parent {
- get {
- return this.parent;
- }
- set {
- if (parent!=value) {
- if (parent!=null) {
- parent.Controls.Remove(this);
- }
- parent=value;
- if (!parent.Controls.Contains(this)) {
- parent.Controls.Add(this);
- }
- XplatUI.SetParent(Handle, value.Handle);
- }
- }
- }
- public IntPtr Handle { // IWin32Window
- get
- {
- if (!IsHandleCreated) {
- CreateHandle();
- }
- return window.Handle;
- }
- }
- public bool InvokeRequired { // ISynchronizeInvoke
- get {
- if (creator_thread!=Thread.CurrentThread) {
- return true;
- }
- return false;
- }
- }
- public bool Visible {
- get {
- return this.is_visible;
- }
- set {
- if (value!=is_visible) {
- is_visible=value;
- XplatUI.SetVisible(Handle, value);
- }
- }
- }
- public virtual string Text {
- get {
- return this.text;
- }
- set {
- if (text!=value) {
- text=value;
- XplatUI.Text(Handle, text);
- OnTextChanged (EventArgs.Empty);
- }
- }
- }
- public int Left {
- get {
- return this.bounds.X;
- }
- set {
- SetBounds(value, bounds.Y, bounds.Width, bounds.Height, BoundsSpecified.X);
- }
- }
- public int Top {
- get {
- return this.bounds.Y;
- }
- set {
- SetBounds(bounds.X, value, bounds.Width, bounds.Height, BoundsSpecified.Y);
- }
- }
- public int Width {
- get {
- return this.bounds.Width;
- }
- set {
- SetBounds(bounds.X, bounds.Y, value, bounds.Height, BoundsSpecified.Width);
- }
- }
- public int Height {
- get {
- return this.bounds.Height;
- }
- set {
- SetBounds(bounds.X, bounds.Y, bounds.Width, value, BoundsSpecified.Height);
- }
- }
- public Point Location {
- get {
- return new Point(bounds.X, bounds.Y);
- }
- set {
- SetBounds(value.X, value.Y, bounds.Width, bounds.Height, BoundsSpecified.Location);
- }
- }
- public Size Size {
- get {
- return new Size(Width, Height);
- }
- set {
- SetBounds(bounds.X, bounds.Y, value.Width, value.Height, BoundsSpecified.Size);
- }
- }
-
- public int TabIndex {
- get {
- return tab_index;
- }
- set {
- tab_index = value;
- }
- }
- #endregion // Public Instance Properties
- internal Graphics DeviceContext {
- get { return dc_mem; }
- }
- internal Bitmap ImageBuffer {
- get { return bmp_mem; }
- }
- internal void CreateBuffers (int width, int height)
- {
- if (dc_mem != null)
- dc_mem.Dispose ();
- if (bmp_mem != null)
- bmp_mem.Dispose ();
- bmp_mem = new Bitmap (width, height, System.Drawing.Imaging.PixelFormat.Format32bppArgb);
- dc_mem = Graphics.FromImage (bmp_mem);
- }
- #region Protected Instance Properties
- protected virtual CreateParams CreateParams {
- get {
- CreateParams create_params = new CreateParams();
- create_params.Caption = Text;
- create_params.X = Left;
- create_params.Y = Top;
- create_params.Width = Width;
- create_params.Height = Height;
- create_params.ClassName = XplatUI.DefaultClassName;
- create_params.ClassStyle = 0;
- create_params.ExStyle = 0;
- create_params.Param = 0;
- if (parent!=null) {
- create_params.Parent = parent.Handle;
- }
- create_params.Style = (int)WindowStyles.WS_OVERLAPPED;
- if (is_visible) {
- create_params.Style |= (int)WindowStyles.WS_VISIBLE;
- }
- return create_params;
- }
- }
- protected virtual ImeMode DefaultImeMode {
- get {
- return ImeMode.Inherit;
- }
- }
- protected virtual Size DefaultSize {
- get {
- return new Size(100, 23);
- }
- }
- #endregion // Protected Instance Properties
- #region Public Instance Methods
- public bool Contains(Control ctl) {
- Control current;
- current=ctl;
- while (current!=null) {
- if (current==ctl) {
- return true;
- }
- current=current.parent;
- }
- return false;
- }
- public void CreateControl() {
- Control child;
- CreateHandle();
- for (int i=0; i<child_controls.Count; i++) {
- child_controls[i].CreateControl();
- }
- OnCreateControl();
- }
- public virtual void Refresh() {
- if (IsHandleCreated == true)
- XplatUI.RefreshWindow(window.Handle);
- }
- public void SetBounds(int x, int y, int width, int height) {
- SetBounds(x, y, width, height, BoundsSpecified.All);
- }
- public void SetBounds(int x, int y, int width, int height, BoundsSpecified bounds_specified) {
- if ((bounds_specified & BoundsSpecified.X) != BoundsSpecified.X) {
- x = Left;
- }
- if ((bounds_specified & BoundsSpecified.Y) != BoundsSpecified.Y) {
- y = Top;
- }
- if ((bounds_specified & BoundsSpecified.Width)!= BoundsSpecified.Width) {
- width = Width;
- }
- if ((bounds_specified & BoundsSpecified.Height) != BoundsSpecified.Height) {
- height = Height;
- }
- if (IsHandleCreated) {
- XplatUI.MoveWindow(Handle, x, y, width, height);
- }
- UpdateBounds(x, y, width, height);
- }
- public void Show() {
- if (!IsHandleCreated) {
- this.CreateHandle();
- }
- this.Visible=true;
- }
- public object Invoke(Delegate method) { // ISynchronizeInvoke
- return Invoke(method, null);
- }
- public object Invoke(Delegate method, object[] args) { // ISynchronizeInvoke
- IAsyncResult result;
- result=BeginInvoke(method, args);
- return EndInvoke(result);
- }
- public IAsyncResult BeginInvoke(Delegate method) { // ISynchronizeInvoke
- return BeginInvoke(method, null);
- }
- protected virtual AccessibleObject CreateAccessibilityInstance() {
- return new AccessibleObject(this);
- }
- protected virtual ControlCollection CreateControlsInstance() {
- return new ControlCollection(this);
- }
- protected void UpdateBounds() {
- int x;
- int y;
- int width;
- int height;
- XplatUI.GetWindowPos(this.Handle, out x, out y, out width, out height);
- UpdateBounds(x, y, width, height);
- }
- protected void UpdateBounds(int x, int y, int width, int height) {
- bool moved = false;
- bool resized = false;
- // Generate required notifications
- if ((this.bounds.X!=x) || (this.bounds.Y!=y)) {
- moved=true;
- }
- if ((this.Bounds.Width!=width) || (this.Bounds.Height!=height)) {
- resized=true;
- }
- bounds.X=x;
- bounds.Y=y;
- bounds.Width=width;
- bounds.Height=height;
- #if notdef
- if (IsHandleCreated) {
- XplatUI.SetWindowPos(Handle, bounds);
- }
- #endif
- if (moved) {
- OnLocationChanged(EventArgs.Empty);
- }
- if (resized) {
- OnSizeChanged(EventArgs.Empty);
- }
- }
- protected void UpdateBounds(int x, int y, int width, int height, int clientWidth, int clientHeight) {
- UpdateBounds(x, y, width, height);
- }
- public void Invalidate() {
- Invalidate(new Rectangle(0, 0, bounds.Width, bounds.Height), false);
- }
- public void Invalidate(bool invalidateChildren) {
- Invalidate(new Rectangle(0, 0, bounds.Width, bounds.Height), invalidateChildren);
- }
- public void Invalidate(System.Drawing.Rectangle rc) {
- Invalidate(rc, false);
- }
- public void Invalidate(System.Drawing.Rectangle rc, bool invalidateChildren) {
- if (!IsHandleCreated || !is_visible) {
- return;
- }
- XplatUI.Invalidate(Handle, rc, false);
- if (invalidateChildren) {
- for (int i=0; i<child_controls.Count; i++) child_controls[i].Invalidate();
- }
- }
- public void Invalidate(System.Drawing.Region region) {
- Invalidate(region, false);
- }
- [MonoTODO]
- public void Invalidate(System.Drawing.Region region, bool invalidateChildren) {
- throw new NotImplementedException();
- // FIXME - should use the GetRegionScans function of the region to invalidate each area
- if (invalidateChildren) {
- for (int i=0; i<child_controls.Count; i++) child_controls[i].Invalidate();
- }
- }
- [MonoTODO("BeginInvoke() : Figure out a cross-platform way to handle this")]
- public IAsyncResult BeginInvoke(Delegate method, object[] args) { // ISynchronizeInvoke
- IAsyncResult result = null;
- return result;
- }
- [MonoTODO]
- public object EndInvoke(IAsyncResult async_result) { // ISynchronizeInvoke
- object result = null;
- return result;
- }
- public void PerformLayout() {
- PerformLayout(null, null);
- }
- public void PerformLayout(Control affectedControl, string affectedProperty) {
- LayoutEventArgs levent = new LayoutEventArgs(affectedControl, affectedProperty);
- if (layout_suspended>0) {
- return;
- }
- // Prevent us from getting messed up
- layout_suspended++;
- // Perform all Dock and Anchor calculations
- try {
- Control child;
- AnchorStyles anchor;
- Rectangle space;
- space=this.DisplayRectangle;
- // Deal with docking
- for (int i=0; i < child_controls.Count; i++) {
- child=child_controls[i];
- switch (child.Dock) {
- case DockStyle.None: {
- // Do nothing
- break;
- }
- case DockStyle.Left: {
- child.SetBounds(space.Left, space.Y, child.Width, space.Height);
- space.X+=child.Width;
- space.Width-=child.Width;
- break;
- }
- case DockStyle.Top: {
- child.SetBounds(space.Left, space.Y, space.Width, child.Height);
- space.Y+=child.Height;
- space.Height-=child.Height;
- break;
- }
-
- case DockStyle.Right: {
- child.SetBounds(space.Right-child.Width, space.Y, child.Width, space.Height);
- space.Width-=child.Width;
- break;
- }
- case DockStyle.Bottom: {
- child.SetBounds(space.Left, space.Bottom-child.Height, space.Width, child.Height);
- space.Height-=child.Height;
- break;
- }
- case DockStyle.Fill: {
- child.SetBounds(space.Left, space.Top, space.Width, space.Height);
- space.Width=0;
- space.Height=0;
- break;
- }
- }
- }
- space=this.DisplayRectangle;
- // Deal with anchoring
- for (int i=0; i < child_controls.Count; i++) {
- int left;
- int top;
- int width;
- int height;
- int diff_width;
- int diff_height;
- child=child_controls[i];
- anchor=child.Anchor;
- left=child.Left-space.Left;
- top=child.Top-space.Top;
- width=prev_size.Width-child.Width-child.Left;
- height=prev_size.Height-child.Height-child.Top;
- diff_width=space.Width-prev_size.Width;
- diff_height=space.Height-prev_size.Height;
- prev_size.Width=space.Width;
- prev_size.Height=space.Height;
- // If the control is docked we don't need to do anything
- if (child.Dock != DockStyle.None) {
- continue;
- }
- if ((anchor & AnchorStyles.Left) !=0 ) {
- if ((anchor & AnchorStyles.Right) != 0) {
- // Anchoring to left and right
- width=width+diff_width;
- } else {
- ; // nothing to do
- }
- } else if ((anchor & AnchorStyles.Right) != 0) {
- left+=diff_width;
- } else {
- left+=diff_width/2;
- }
- if ((anchor & AnchorStyles.Top) !=0 ) {
- if ((anchor & AnchorStyles.Bottom) != 0) {
- height+=diff_height;
- } else {
- ; // nothing to do
- }
- } else if ((anchor & AnchorStyles.Bottom) != 0) {
- top+=diff_height;
- } else {
- top+=diff_height/2;
- }
- // Sanity
- if (width < 0) {
- width=0;
- }
- if (height < 0) {
- height=0;
- }
- child.SetBounds(left, top, width, height);
- }
- // Let everyone know
- OnLayout(levent);
- }
- // Need to make sure we decremend layout_suspended
- finally {
- layout_suspended--;
- }
- }
- public void ResumeLayout()
- {
- ResumeLayout (true);
- }
- public void ResumeLayout(bool peformLayout)
- {
- layout_suspended--;
-
- if (layout_suspended > 0 || peformLayout == false)
- return;
- PerformLayout();
- }
-
- public void SuspendLayout()
- {
- layout_suspended++;
- }
- [MonoTODO]
- protected virtual void WndProc(ref Message m) {
- EventArgs e = new EventArgs();
- #if debug
- Console.WriteLine("Received message {0}", m);
- #endif
- switch((Msg)m.Msg) {
- #if notyet
- // Mouse handling
- case Msg.WM_LBUTTONDBLCLK: throw new NotImplementedException(); break;
- case Msg.WM_RBUTTONDOWN: throw new NotImplementedException(); break;
- case Msg.WM_RBUTTONUP: throw new NotImplementedException(); break;
- case Msg.WM_RBUTTONDBLCLK: throw new NotImplementedException(); break;
- case Msg.WM_MOUSEHOVER: throw new NotImplementedException(); break;
- case Msg.WM_MOUSELEAVE: throw new NotImplementedException(); break;
-
- // Keyboard handling
- case Msg.WM_CHAR: throw new NotImplementedException(); break;
- case Msg.WM_KEYDOWN: throw new NotImplementedException(); break;
- case Msg.WM_KEYUP: throw new NotImplementedException(); break;
- #endif
- // Window management
- case Msg.WM_WINDOWPOSCHANGED: {
- UpdateBounds();
- DefWndProc(ref m);
- break;
- }
- case Msg.WM_PAINT: {
- Rectangle rect;
- PaintEventArgs paint_event;
- paint_event = XplatUI.PaintEventStart(Handle);
- OnPaint(paint_event);
- XplatUI.PaintEventEnd(Handle);
- DefWndProc(ref m);
- break;
- }
-
- case Msg.WM_ERASEBKGND:{
- if (GetStyle (ControlStyles.UserPaint)){
- PaintEventArgs eraseEventArgs = new PaintEventArgs (Graphics.FromHdc (m.WParam), new Rectangle (new Point (0,0),Size));
- OnPaintBackground (eraseEventArgs);
- m.Result = (IntPtr)1;
- }
- else {
- m.Result = (IntPtr)0;
- DefWndProc (ref m);
- }
-
- break;
- }
-
- case Msg.WM_LBUTTONUP: {
- int clicks = 1;
-
- OnMouseUp (new MouseEventArgs (FromParamToMouseButtons ((int) m.WParam.ToInt32()),
- clicks,
- LowOrder ((int) m.LParam.ToInt32 ()), HighOrder ((int) m.LParam.ToInt32 ()),
- 0));
- break;
- }
-
- case Msg.WM_LBUTTONDOWN: {
- int clicks = 1;
-
- OnMouseDown (new MouseEventArgs (FromParamToMouseButtons ((int) m.WParam.ToInt32()),
- clicks, LowOrder ((int) m.LParam.ToInt32 ()), HighOrder ((int) m.LParam.ToInt32 ()),
- 0));
-
- break;
- }
- case Msg.WM_MOUSEWHEEL: {
- int clicks = 1;
- OnMouseWheel (new MouseEventArgs (FromParamToMouseButtons ((int) m.WParam.ToInt32()),
- clicks, LowOrder ((int) m.LParam.ToInt32 ()), HighOrder ((int) m.LParam.ToInt32 ()),
- HighOrder(m.WParam.ToInt32())));
- break;
- }
-
- case Msg.WM_MOUSEMOVE: {
- int clicks = 1;
- OnMouseMove (new MouseEventArgs (FromParamToMouseButtons ((int) m.WParam.ToInt32()),
- clicks,
- LowOrder ((int) m.LParam.ToInt32 ()), HighOrder ((int) m.LParam.ToInt32 ()),
- 0));
- break;
- }
-
- case Msg.WM_SIZE: {
- UpdateBounds (bounds.X, bounds.Y, LowOrder ((int) m.LParam.ToInt32 ()),
- HighOrder ((int) m.LParam.ToInt32 ()));
-
- DefWndProc(ref m);
- break;
- }
- case Msg.WM_KEYDOWN: {
- if (!ProcessKeyEventArgs (ref m))
- DefWndProc (ref m);
- break;
- }
- case Msg.WM_KEYUP: {
- if (!ProcessKeyEventArgs (ref m))
- DefWndProc (ref m);
- break;
- }
-
- #if notyet
- case Msg.WM_WINDOWPOSCHANGED: throw new NotImplementedException(); break;
- case Msg.WM_SYSCOLORCHANGE: throw new NotImplementedException(); break;
-
- #endif
- default:
- DefWndProc(ref m);
- break;
- }
-
-
-
- }
- #endregion // Public Instance Methods
- #region // Protected Instance Methods
- protected virtual void CreateHandle() {
- if (IsDisposed) {
- throw new ObjectDisposedException(Name);
- }
- if (IsHandleCreated) {
- return;
- }
- if (window==null) {
- window = new ControlNativeWindow(this);
- window.CreateHandle(CreateParams);
- }
- if (window.Handle!=IntPtr.Zero) {
- if (!controls.Contains(window.Handle)) {
- controls.Add(window.Handle, this);
- }
- creator_thread = Thread.CurrentThread;
- OnHandleCreated(EventArgs.Empty);
- }
- }
- protected virtual void DefWndProc(ref Message m) {
- window.DefWndProc(ref m);
- }
- protected virtual void DestroyHandle() {
- if (IsHandleCreated) {
- if (Handle != IntPtr.Zero) {
- controls.Remove(Handle);
- }
- if (window != null) {
- window.DestroyHandle();
- }
- }
- }
- protected virtual bool ProcessKeyEventArgs (ref Message msg)
- {
- KeyEventArgs key_event;
- switch (msg.Msg) {
- case (int)Msg.WM_KEYDOWN: {
- key_event = new KeyEventArgs ((Keys)msg.WParam.ToInt32 ());
- OnKeyDown (key_event);
- return key_event.Handled;
- }
- case (int)Msg.WM_KEYUP: {
- key_event = new KeyEventArgs ((Keys)msg.WParam.ToInt32 ());
- OnKeyUp (key_event);
- return key_event.Handled;
- }
- default:
- break;
- }
- return false;
- }
- protected virtual bool IsInputKey (Keys keyData)
- {
- return false;
- }
- protected virtual bool ProcessDialogKey (Keys keyData)
- {
- if (parent != null)
- return Parent.ProcessDialogKey (keyData);
- return false;
- }
- protected bool GetStyle(ControlStyles flag) {
- return (control_style & flag) != 0;
- }
- protected virtual bool ProcessDialogChar(char charCode) {
- throw new NotImplementedException();
- }
- protected virtual bool ProcessMnemonic(char charCode) {
- throw new NotImplementedException();
- }
- protected void RecreateHandle() {
- IEnumerator child = child_controls.GetEnumerator();
- if (IsHandleCreated) {
- DestroyHandle();
- CreateHandle();
- // FIXME ZOrder?
- while (child.MoveNext()) {
- ((Control)child.Current).RecreateHandle();
- }
- }
- }
- protected virtual void ScaleCore(float dx, float dy) {
- throw new NotImplementedException();
- }
- protected virtual void Select(bool directed, bool forward) {
- throw new NotImplementedException();
- }
- protected virtual void SetClientSizeCore(int x, int y) {
- bounds.Width=x;
- bounds.Height=y;
- XplatUI.MoveWindow(Handle, bounds.X, bounds.Y, bounds.Width, bounds.Height);
- }
- protected void SetStyle(ControlStyles flag, bool value) {
- if (value) {
- control_style |= flag;
- } else {
- control_style &= ~flag;
- }
- }
- #endregion // Public Instance Methods
- #region Private Instance Methods
- #endregion // Private Instance Methods
- #region Private Instance Methods
- internal virtual void DoDefaultAction() {
- // Only here to be overriden by our actual controls; this is needed by the accessibility class
- }
- #endregion // Private Instance Methods
- #region OnXXX methods
- protected virtual void OnBackColorChanged(EventArgs e) {
- if (BackColorChanged!=null) BackColorChanged(this, e);
- for (int i=0; i<child_controls.Count; i++) child_controls[i].OnParentBackColorChanged(e);
- }
- protected virtual void OnBackgroundImageChanged(EventArgs e) {
- if (BackgroundImageChanged!=null) BackgroundImageChanged(this, e);
- for (int i=0; i<child_controls.Count; i++) child_controls[i].OnParentBackgroundImageChanged(e);
- }
- protected virtual void OnBindingContextChanged(EventArgs e) {
- if (BindingContextChanged!=null) BindingContextChanged(this, e);
- for (int i=0; i<child_controls.Count; i++) child_controls[i].OnParentBindingContextChanged(e);
- }
- protected virtual void OnCausesValidationChanged(EventArgs e) {
- if (CausesValidationChanged!=null) CausesValidationChanged(this, e);
- }
- protected virtual void OnChangeUICues(UICuesEventArgs e) {
- if (CausesValidationChanged!=null) CausesValidationChanged(this, e);
- }
- protected virtual void OnClick(EventArgs e) {
- if (Click!=null) Click(this, e);
- }
- protected virtual void OnContextMenuChanged(EventArgs e) {
- if (ContextMenuChanged!=null) ContextMenuChanged(this, e);
- }
- protected virtual void OnControlAdded(ControlEventArgs e) {
- if (ControlAdded!=null) ControlAdded(this, e);
- }
- protected virtual void OnControlRemoved(ControlEventArgs e) {
- if (ControlRemoved!=null) ControlRemoved(this, e);
- }
- protected virtual void OnCreateControl() {
- }
- protected virtual void OnCursorChanged(EventArgs e) {
- if (CursorChanged!=null) CursorChanged(this, e);
- }
- protected virtual void OnDockChanged(EventArgs e) {
- if (DockChanged!=null) DockChanged(this, e);
- }
- protected virtual void OnDoubleClick(EventArgs e) {
- if (DoubleClick!=null) DoubleClick(this, e);
- }
- protected virtual void OnDragDrop(DragEventArgs drgevent) {
- if (DragDrop!=null) DragDrop(this, drgevent);
- }
- protected virtual void OnDragEnter(DragEventArgs drgevent) {
- if (DragEnter!=null) DragEnter(this, drgevent);
- }
- protected virtual void OnDragLeave(EventArgs e) {
- if (DragLeave!=null) DragLeave(this, e);
- }
- protected virtual void OnDragOver(DragEventArgs drgevent) {
- if (DragOver!=null) DragOver(this, drgevent);
- }
- protected virtual void OnEnabledChanged(EventArgs e) {
- if (EnabledChanged!=null) EnabledChanged(this, e);
- for (int i=0; i<child_controls.Count; i++) child_controls[i].OnParentEnabledChanged(e);
- }
- protected virtual void OnEnter(EventArgs e) {
- if (Enter!=null) Enter(this, e);
- }
- protected virtual void OnFontChanged(EventArgs e) {
- if (FontChanged!=null) FontChanged(this, e);
- }
- protected virtual void OnForeColorChanged(EventArgs e) {
- if (ForeColorChanged!=null) ForeColorChanged(this, e);
- for (int i=0; i<child_controls.Count; i++) child_controls[i].OnParentForeColorChanged(e);
- }
- protected virtual void OnGiveFeedback(GiveFeedbackEventArgs gfbevent) {
- if (GiveFeedback!=null) GiveFeedback(this, gfbevent);
- }
-
- protected virtual void OnGotFocus(EventArgs e) {
- if (GotFocus!=null) GotFocus(this, e);
- }
- protected virtual void OnHandleCreated(EventArgs e) {
- if (HandleCreated!=null) HandleCreated(this, e);
- }
- protected virtual void OnHandleDestroyed(EventArgs e) {
- if (HandleDestroyed!=null) HandleDestroyed(this, e);
- }
- protected virtual void OnHelpRequested(HelpEventArgs hevent) {
- if (HelpRequested!=null) HelpRequested(this, hevent);
- }
- protected virtual void OnImeModeChanged(EventArgs e) {
- if (ImeModeChanged!=null) ImeModeChanged(this, e);
- }
- protected virtual void OnInvalidated(InvalidateEventArgs e) {
- if (Invalidated!=null) Invalidated(this, e);
- }
- protected virtual void OnKeyDown(KeyEventArgs e) {
- if (KeyDown!=null) KeyDown(this, e);
- }
- protected virtual void OnKeyUp(KeyEventArgs e) {
- if (KeyUp!=null) KeyUp(this, e);
- }
- protected virtual void OnLayout(LayoutEventArgs levent) {
- if (Layout!=null) Layout(this, levent);
- }
- protected virtual void OnLeave(EventArgs e) {
- if (Leave!=null) Leave(this, e);
- }
- protected virtual void OnLocationChanged(EventArgs e) {
- if (LocationChanged!=null) LocationChanged(this, e);
- }
- protected virtual void OnLostFocus(EventArgs e) {
- if (LostFocus!=null) LostFocus(this, e);
- }
- protected virtual void OnMouseDown(MouseEventArgs e) {
- if (MouseDown!=null) MouseDown(this, e);
- }
- protected virtual void OnMouseEnter(EventArgs e) {
- if (MouseEnter!=null) MouseEnter(this, e);
- }
- protected virtual void OnMouseHover(EventArgs e) {
- if (MouseHover!=null) MouseHover(this, e);
- }
- protected virtual void OnMouseLeave(EventArgs e) {
- if (MouseLeave!=null) MouseLeave(this, e);
- }
- protected virtual void OnMouseMove(MouseEventArgs e) {
- if (MouseMove!=null) MouseMove(this, e);
- }
- protected virtual void OnMouseUp(MouseEventArgs e) {
- if (MouseUp!=null) MouseUp(this, e);
- }
- protected virtual void OnMouseWheel(MouseEventArgs e) {
- if (MouseWheel!=null) MouseWheel(this, e);
- }
- protected virtual void OnMove(EventArgs e) {
- if (Move!=null) Move(this, e);
- }
- protected virtual void OnNotifyMessage(Message m) {
- // Override me!
- }
- protected virtual void OnPaint(PaintEventArgs e) {
- if (Paint!=null) Paint(this, e);
- }
- protected virtual void OnPaintBackground(PaintEventArgs pevent) {
- // Override me!
- }
- protected virtual void OnParentBackColorChanged(EventArgs e) {
- if (background_color.IsEmpty && background_image==null) {
- Invalidate();
- OnBackColorChanged(e);
- }
- }
- protected virtual void OnParentBackgroundImageChanged(EventArgs e) {
- if (background_color.IsEmpty && background_image==null) {
- Invalidate();
- OnBackgroundImageChanged(e);
- }
- }
- protected virtual void OnParentBindingContextChanged(EventArgs e) {
- if (binding_context==null) {
- binding_context=Parent.binding_context;
- OnBindingContextChanged(e);
- }
- }
- protected virtual void OnParentChanged(EventArgs e) {
- if (ParentChanged!=null) ParentChanged(this, e);
- }
- protected virtual void OnParentEnabledChanged(EventArgs e) {
- if ((is_enabled && !Parent.is_enabled) || (!is_enabled && Parent.is_enabled)) {
- is_enabled=false;
- Invalidate();
- EnabledChanged(this, e);
- }
- }
- protected virtual void OnParentFontChanged(EventArgs e) {
- if (font==null) {
- Invalidate();
- OnFontChanged(e);
- }
- }
- protected virtual void OnParentForeColorChanged(EventArgs e) {
- if (foreground_color.IsEmpty) {
- Invalidate();
- OnForeColorChanged(e);
- }
- }
- protected virtual void OnParentRightToLeftChanged(EventArgs e) {
- if (right_to_left==RightToLeft.Inherit) {
- Invalidate();
- OnRightToLeftChanged(e);
- }
- }
- protected virtual void OnParentVisibleChanged(EventArgs e) {
- if (is_visible!=Parent.is_visible) {
- is_visible=false;
- Invalidate();
- OnVisibleChanged(e);
- }
- }
- protected virtual void OnQueryContinueDrag(QueryContinueDragEventArgs e) {
- if (QueryContinueDrag!=null) QueryContinueDrag(this, e);
- }
- protected virtual void OnResize(EventArgs e) {
- if (Resize!=null) Resize(this, e);
- PerformLayout();
- }
- protected virtual void OnRightToLeftChanged(EventArgs e) {
- if (RightToLeftChanged!=null) RightToLeftChanged(this, e);
- for (int i=0; i<child_controls.Count; i++) child_controls[i].OnParentRightToLeftChanged(e);
- }
- protected virtual void OnSizeChanged(EventArgs e) {
- OnResize(e);
- if (SizeChanged!=null) SizeChanged(this, e);
- }
- protected virtual void OnStyleChanged(EventArgs e) {
- if (StyleChanged!=null) StyleChanged(this, e);
- }
- protected virtual void OnSystemColorsChanged(EventArgs e) {
- if (SystemColorsChanged!=null) SystemColorsChanged(this, e);
- }
- protected virtual void OnTabIndexChanged(EventArgs e) {
- if (TabIndexChanged!=null) TabIndexChanged(this, e);
- }
- protected virtual void OnTabStopChanged(EventArgs e) {
- if (TabStopChanged!=null) TabStopChanged(this, e);
- }
- protected virtual void OnTextChanged(EventArgs e) {
- if (TextChanged!=null) TextChanged(this, e);
- }
- protected virtual void OnValidated(EventArgs e) {
- if (Validated!=null) Validated(this, e);
- }
- protected virtual void OnValidating(System.ComponentModel.CancelEventArgs e) {
- if (Validating!=null) Validating(this, e);
- }
- protected virtual void OnVisibleChanged(EventArgs e) {
- if (VisibleChanged!=null) VisibleChanged(this, e);
- }
- #endregion // OnXXX methods
- #region Events
- public event EventHandler BackColorChanged;
- public event EventHandler BackgroundImageChanged;
- public event EventHandler BindingContextChanged;
- public event EventHandler CausesValidationChanged;
- public event UICuesEventHandler ChangeUICues;
- public event EventHandler Click;
- public event EventHandler ContextMenuChanged;
- public event ControlEventHandler ControlAdded;
- public event ControlEventHandler ControlRemoved;
- public event EventHandler CursorChanged;
- public event EventHandler DockChanged;
- public event EventHandler DoubleClick;
- public event DragEventHandler DragDrop;
- public event DragEventHandler DragEnter;
- public event EventHandler DragLeave;
- public event DragEventHandler DragOver;
- public event EventHandler EnabledChanged;
- public event EventHandler Enter;
- public event EventHandler FontChanged;
- public event EventHandler ForeColorChanged;
- public event GiveFeedbackEventHandler GiveFeedback;
- public event EventHandler GotFocus;
- public event EventHandler HandleCreated;
- public event EventHandler HandleDestroyed;
- public event HelpEventHandler HelpRequested;
- public event EventHandler ImeModeChanged;
- public event InvalidateEventHandler Invalidated;
- public event KeyEventHandler KeyDown;
- public event KeyPressEventHandler KeyPress;
- public event KeyEventHandler KeyUp;
- public event LayoutEventHandler Layout;
- public event EventHandler Leave;
- public event EventHandler LocationChanged;
- public event EventHandler LostFocus;
- public event MouseEventHandler MouseDown;
- public event EventHandler MouseEnter;
- public event EventHandler MouseHover;
- public event EventHandler MouseLeave;
- public event MouseEventHandler MouseMove;
- public event MouseEventHandler MouseUp;
- public event MouseEventHandler MouseWheel;
- public event EventHandler Move;
- public event PaintEventHandler Paint;
- public event EventHandler ParentChanged;
- public event QueryAccessibilityHelpEventHandler QueryAccessibilityHelp;
- public event QueryContinueDragEventHandler QueryContinueDrag;
- public event EventHandler Resize;
- public event EventHandler RightToLeftChanged;
- public event EventHandler SizeChanged;
- public event EventHandler StyleChanged;
- public event EventHandler SystemColorsChanged;
- public event EventHandler TabIndexChanged;
- public event EventHandler TabStopChanged;
- public event EventHandler TextChanged;
- public event EventHandler Validated;
- public event CancelEventHandler Validating;
- public event EventHandler VisibleChanged;
- #endregion // Events
-
- #region Private Methods
- internal static int LowOrder (int param)
- {
- return (param & 0xffff);
- }
- internal static int HighOrder (int param)
- {
- return (param >> 16);
- }
-
- internal static MouseButtons FromParamToMouseButtons (int param)
- {
- MouseButtons buttons = MouseButtons.None;
-
- if ((param & (int) MsgButtons.MK_LBUTTON) != 0)
- buttons |= MouseButtons.Left;
-
- if ((param & (int) MsgButtons.MK_MBUTTON) != 0)
- buttons |= MouseButtons.Middle;
-
- if ((param & (int) MsgButtons.MK_RBUTTON) != 0)
- buttons |= MouseButtons.Right;
-
- return buttons;
- }
- #endregion
- }
- }
|