Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / xsp / System / Web / UI / HtmlControls / HtmlInputImage.cs / 1 / HtmlInputImage.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HtmlInputImage.cs * * Copyright (c) 2000 Microsoft Corporation */ namespace System.Web.UI.HtmlControls { using System; using System.Collections; using System.Collections.Specialized; using System.Globalization; using System.ComponentModel; using System.Web; using System.Web.UI; using System.Security.Permissions; ////// [ DefaultEvent("ServerClick"), SupportsEventValidation, ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class HtmlInputImage : HtmlInputControl, IPostBackDataHandler, IPostBackEventHandler { private static readonly object EventServerClick = new object(); private int _x; private int _y; /* * Creates an intrinsic Html INPUT type=image control. */ public HtmlInputImage() : base("image") { } ////// The ///class defines the /// methods, properties and events for the HtmlInputImage control. This class allows /// programmatic access to the HTML <input type= /// image> element on the server. /// /// /* * Align property. */ [ WebCategory("Appearance"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) ] public string Align { get { string s = Attributes["align"]; return((s != null) ? s : String.Empty); } set { Attributes["align"] = MapStringAttributeToString(value); } } ////// Gets or sets the image /// alignment within the form's content flow. /// ////// /* * Alt property. */ [ WebCategory("Appearance"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), Localizable(true) ] public string Alt { get { string s = Attributes["alt"]; return((s != null) ? s : String.Empty); } set { Attributes["alt"] = MapStringAttributeToString(value); } } ////// Gets or sets the alternative text /// that the browser should display if the image is either unavailable or has not /// been downloaded yet. /// ////// /* * Border property, size of border in pixels. */ [ WebCategory("Appearance"), DefaultValue(-1), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) ] public int Border { get { string s = Attributes["border"]; return((s != null) ? Int32.Parse(s, CultureInfo.InvariantCulture) : -1); } set { Attributes["border"] = MapIntegerAttributeToString(value); } } ////// Gets or sets the /// border width, in pixels, around the image. /// ////// /* * Src property. */ [ WebCategory("Appearance"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), UrlProperty() ] public string Src { get { string s = Attributes["src"]; return((s != null) ? s : String.Empty); } set { Attributes["src"] = MapStringAttributeToString(value); } } ////// Gets or sets the location of /// the image file relative to the page on which it is displayed. /// ////// [ WebCategory("Behavior"), DefaultValue(true), ] public virtual bool CausesValidation { get { object b = ViewState["CausesValidation"]; return((b == null) ? true : (bool)b); } set { ViewState["CausesValidation"] = value; } } [ WebCategory("Behavior"), DefaultValue(""), WebSysDescription(SR.PostBackControl_ValidationGroup) ] public virtual string ValidationGroup { get { string s = (string)ViewState["ValidationGroup"]; return((s == null) ? String.Empty : s); } set { ViewState["ValidationGroup"] = value; } } ///Gets or sets whether pressing the button causes page validation to fire. This defaults to True so that when /// using validation controls, the validation state of all controls are updated when the button is clicked, both /// on the client and the server. Setting this to False is useful when defining a cancel or reset button on a page /// that has validators. ////// [ WebCategory("Action"), WebSysDescription(SR.HtmlInputImage_OnServerClick) ] public event ImageClickEventHandler ServerClick { add { Events.AddHandler(EventServerClick, value); } remove { Events.RemoveHandler(EventServerClick, value); } } ////// Occurs on the server when a user clicks an ////// control. /// /// /// /* * This method is invoked just prior to rendering. * Register requires handling postback to determine if image has been clicked. */ protected internal override void OnPreRender(EventArgs e) { base.OnPreRender(e); if (Page != null) { if (!Disabled) Page.RegisterRequiresPostBack(this); if (CausesValidation) Page.RegisterPostBackScript(); } } ////// /* * Method used to raise the OnServerClick event. */ protected virtual void OnServerClick(ImageClickEventArgs e) { ImageClickEventHandler handler = (ImageClickEventHandler)Events[EventServerClick]; if (handler != null) handler(this, e); } ////// Raised on the server when a user clicks an ////// control. /// /// /// /* * Method of IPostBackEventHandler interface to raise events on post back. * HtmlInputImage fires an OnServerClick event. */ void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) { RaisePostBackEvent(eventArgument); } ////// /// protected virtual void RaisePostBackEvent(string eventArgument) { if (CausesValidation) { Page.Validate(ValidationGroup); } OnServerClick(new ImageClickEventArgs(_x, _y)); } ////// /// /* * Method of IPostBackDataHandler interface to process posted data. * The image control will check to see if the x and y values were posted, * which indicates that the image was clicked by the user. The image * control will then register with the Page that it wants to raise an event * during the event processing phase. */ bool IPostBackDataHandler.LoadPostData(string postDataKey, NameValueCollection postCollection) { return LoadPostData(postDataKey, postCollection); } protected virtual bool LoadPostData(string postDataKey, NameValueCollection postCollection) { string postX = postCollection[RenderedNameAttribute + ".x"]; string postY = postCollection[RenderedNameAttribute + ".y"]; if (postX != null && postY != null && postX.Length > 0 && postY.Length > 0) { ValidateEvent(UniqueID); _x = Int32.Parse(postX, CultureInfo.InvariantCulture); _y = Int32.Parse(postY, CultureInfo.InvariantCulture); Page.RegisterRequiresRaiseEvent(this); } return false; } ////// /// /* * Method of IPostBackDataHandler interface which is invoked whenever posted data * for a control has changed. */ void IPostBackDataHandler.RaisePostDataChangedEvent() { RaisePostDataChangedEvent(); } ////// /// protected virtual void RaisePostDataChangedEvent() { } /* * Override to render unique name attribute. * The name attribute is owned by the framework. */ ////// /// protected override void RenderAttributes(HtmlTextWriter writer) { PreProcessRelativeReferenceAttribute(writer, "src"); if (Page != null) { Util.WriteOnClickAttribute( writer, this, true, false, (CausesValidation && Page.GetValidators(ValidationGroup).Count > 0), ValidationGroup); } base.RenderAttributes(writer); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- /* * HtmlInputImage.cs * * Copyright (c) 2000 Microsoft Corporation */ namespace System.Web.UI.HtmlControls { using System; using System.Collections; using System.Collections.Specialized; using System.Globalization; using System.ComponentModel; using System.Web; using System.Web.UI; using System.Security.Permissions; ////// [ DefaultEvent("ServerClick"), SupportsEventValidation, ] [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] [AspNetHostingPermission(SecurityAction.InheritanceDemand, Level=AspNetHostingPermissionLevel.Minimal)] public class HtmlInputImage : HtmlInputControl, IPostBackDataHandler, IPostBackEventHandler { private static readonly object EventServerClick = new object(); private int _x; private int _y; /* * Creates an intrinsic Html INPUT type=image control. */ public HtmlInputImage() : base("image") { } ////// The ///class defines the /// methods, properties and events for the HtmlInputImage control. This class allows /// programmatic access to the HTML <input type= /// image> element on the server. /// /// /* * Align property. */ [ WebCategory("Appearance"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) ] public string Align { get { string s = Attributes["align"]; return((s != null) ? s : String.Empty); } set { Attributes["align"] = MapStringAttributeToString(value); } } ////// Gets or sets the image /// alignment within the form's content flow. /// ////// /* * Alt property. */ [ WebCategory("Appearance"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), Localizable(true) ] public string Alt { get { string s = Attributes["alt"]; return((s != null) ? s : String.Empty); } set { Attributes["alt"] = MapStringAttributeToString(value); } } ////// Gets or sets the alternative text /// that the browser should display if the image is either unavailable or has not /// been downloaded yet. /// ////// /* * Border property, size of border in pixels. */ [ WebCategory("Appearance"), DefaultValue(-1), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden) ] public int Border { get { string s = Attributes["border"]; return((s != null) ? Int32.Parse(s, CultureInfo.InvariantCulture) : -1); } set { Attributes["border"] = MapIntegerAttributeToString(value); } } ////// Gets or sets the /// border width, in pixels, around the image. /// ////// /* * Src property. */ [ WebCategory("Appearance"), DefaultValue(""), DesignerSerializationVisibility(DesignerSerializationVisibility.Hidden), UrlProperty() ] public string Src { get { string s = Attributes["src"]; return((s != null) ? s : String.Empty); } set { Attributes["src"] = MapStringAttributeToString(value); } } ////// Gets or sets the location of /// the image file relative to the page on which it is displayed. /// ////// [ WebCategory("Behavior"), DefaultValue(true), ] public virtual bool CausesValidation { get { object b = ViewState["CausesValidation"]; return((b == null) ? true : (bool)b); } set { ViewState["CausesValidation"] = value; } } [ WebCategory("Behavior"), DefaultValue(""), WebSysDescription(SR.PostBackControl_ValidationGroup) ] public virtual string ValidationGroup { get { string s = (string)ViewState["ValidationGroup"]; return((s == null) ? String.Empty : s); } set { ViewState["ValidationGroup"] = value; } } ///Gets or sets whether pressing the button causes page validation to fire. This defaults to True so that when /// using validation controls, the validation state of all controls are updated when the button is clicked, both /// on the client and the server. Setting this to False is useful when defining a cancel or reset button on a page /// that has validators. ////// [ WebCategory("Action"), WebSysDescription(SR.HtmlInputImage_OnServerClick) ] public event ImageClickEventHandler ServerClick { add { Events.AddHandler(EventServerClick, value); } remove { Events.RemoveHandler(EventServerClick, value); } } ////// Occurs on the server when a user clicks an ////// control. /// /// /// /* * This method is invoked just prior to rendering. * Register requires handling postback to determine if image has been clicked. */ protected internal override void OnPreRender(EventArgs e) { base.OnPreRender(e); if (Page != null) { if (!Disabled) Page.RegisterRequiresPostBack(this); if (CausesValidation) Page.RegisterPostBackScript(); } } ////// /* * Method used to raise the OnServerClick event. */ protected virtual void OnServerClick(ImageClickEventArgs e) { ImageClickEventHandler handler = (ImageClickEventHandler)Events[EventServerClick]; if (handler != null) handler(this, e); } ////// Raised on the server when a user clicks an ////// control. /// /// /// /* * Method of IPostBackEventHandler interface to raise events on post back. * HtmlInputImage fires an OnServerClick event. */ void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) { RaisePostBackEvent(eventArgument); } ////// /// protected virtual void RaisePostBackEvent(string eventArgument) { if (CausesValidation) { Page.Validate(ValidationGroup); } OnServerClick(new ImageClickEventArgs(_x, _y)); } ////// /// /* * Method of IPostBackDataHandler interface to process posted data. * The image control will check to see if the x and y values were posted, * which indicates that the image was clicked by the user. The image * control will then register with the Page that it wants to raise an event * during the event processing phase. */ bool IPostBackDataHandler.LoadPostData(string postDataKey, NameValueCollection postCollection) { return LoadPostData(postDataKey, postCollection); } protected virtual bool LoadPostData(string postDataKey, NameValueCollection postCollection) { string postX = postCollection[RenderedNameAttribute + ".x"]; string postY = postCollection[RenderedNameAttribute + ".y"]; if (postX != null && postY != null && postX.Length > 0 && postY.Length > 0) { ValidateEvent(UniqueID); _x = Int32.Parse(postX, CultureInfo.InvariantCulture); _y = Int32.Parse(postY, CultureInfo.InvariantCulture); Page.RegisterRequiresRaiseEvent(this); } return false; } ////// /// /* * Method of IPostBackDataHandler interface which is invoked whenever posted data * for a control has changed. */ void IPostBackDataHandler.RaisePostDataChangedEvent() { RaisePostDataChangedEvent(); } ////// /// protected virtual void RaisePostDataChangedEvent() { } /* * Override to render unique name attribute. * The name attribute is owned by the framework. */ ////// /// protected override void RenderAttributes(HtmlTextWriter writer) { PreProcessRelativeReferenceAttribute(writer, "src"); if (Page != null) { Util.WriteOnClickAttribute( writer, this, true, false, (CausesValidation && Page.GetValidators(ValidationGroup).Count > 0), ValidationGroup); } base.RenderAttributes(writer); } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SystemNetHelpers.cs
- SecurityHelper.cs
- TypeUtils.cs
- WindowsScrollBarBits.cs
- mediaclock.cs
- WebPermission.cs
- AlgoModule.cs
- BufferedWebEventProvider.cs
- TypeSystemProvider.cs
- BitArray.cs
- TextRange.cs
- ExpressionBuilder.cs
- XmlDictionaryString.cs
- XmlValidatingReaderImpl.cs
- StreamWithDictionary.cs
- TimeSpanMinutesConverter.cs
- TextBoxAutomationPeer.cs
- XmlJsonReader.cs
- GuidConverter.cs
- InvalidOperationException.cs
- BridgeDataRecord.cs
- PackWebRequest.cs
- GridViewRowCollection.cs
- xdrvalidator.cs
- SynchronizedKeyedCollection.cs
- SectionInput.cs
- RadioButtonList.cs
- ContextStack.cs
- SizeIndependentAnimationStorage.cs
- RSAPKCS1SignatureFormatter.cs
- MethodImplAttribute.cs
- TemplatedWizardStep.cs
- LineBreakRecord.cs
- EntityTypeBase.cs
- ToolboxItemFilterAttribute.cs
- TableRow.cs
- CookielessData.cs
- ResolveMatchesMessage11.cs
- EventProxy.cs
- LogRecordSequence.cs
- TagPrefixAttribute.cs
- DataBindingHandlerAttribute.cs
- AssociationSetEnd.cs
- MetricEntry.cs
- FocusChangedEventArgs.cs
- ValueUnavailableException.cs
- AssemblyNameProxy.cs
- XmlQueryType.cs
- DBProviderConfigurationHandler.cs
- SmiEventSink_Default.cs
- OdbcEnvironment.cs
- SourceLocationProvider.cs
- CodeRegionDirective.cs
- WinEventTracker.cs
- WebPartConnectionsConnectVerb.cs
- ProfileProvider.cs
- EntityDataSourceContextDisposingEventArgs.cs
- MyContact.cs
- ProcessInputEventArgs.cs
- DataServiceRequestException.cs
- FileDialog_Vista_Interop.cs
- MultiDataTrigger.cs
- IteratorFilter.cs
- RealizationContext.cs
- CodeAccessPermission.cs
- SqlDataSource.cs
- WpfWebRequestHelper.cs
- DefaultSerializationProviderAttribute.cs
- DoubleAnimationUsingKeyFrames.cs
- SQLInt16.cs
- StateManagedCollection.cs
- AspNetHostingPermission.cs
- DateTimeFormatInfoScanner.cs
- RotateTransform3D.cs
- BufferedStream.cs
- SslStreamSecurityElement.cs
- ReliableMessagingVersionConverter.cs
- SecurityUtils.cs
- SrgsRulesCollection.cs
- StyleSheetRefUrlEditor.cs
- XmlILCommand.cs
- ErrorWebPart.cs
- AttributeSetAction.cs
- InvalidPipelineStoreException.cs
- MimePart.cs
- ParagraphVisual.cs
- PrintingPermission.cs
- AuthenticationSection.cs
- RelationshipNavigation.cs
- _Rfc2616CacheValidators.cs
- StreamWithDictionary.cs
- AssemblyCollection.cs
- WindowsTooltip.cs
- RecommendedAsConfigurableAttribute.cs
- CodePrimitiveExpression.cs
- DataRow.cs
- ParameterBuilder.cs
- ObjectQueryExecutionPlan.cs
- SpellerHighlightLayer.cs
- LazyTextWriterCreator.cs