Code:
/ 4.0 / 4.0 / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / Web / UI / WebControls / ImageMap.cs / 1305376 / ImageMap.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.ComponentModel; using System.Globalization; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.Util; using System.Web; ////// [ DefaultEvent("Click"), DefaultProperty("HotSpots"), ParseChildren(true, "HotSpots"), SupportsEventValidation, ] public class ImageMap : Image, IPostBackEventHandler { private static readonly object EventClick = new object(); private bool _hasHotSpots; private HotSpotCollection _hotSpots; [ Browsable(true), EditorBrowsableAttribute(EditorBrowsableState.Always) ] public override bool Enabled { get { return base.Enabled; } set { base.Enabled = value; } } ///ImageMap class. Provides support for multiple /// region-defined actions within an image. ////// [ WebCategory("Behavior"), WebSysDescription(SR.ImageMap_HotSpots), DesignerSerializationVisibility(DesignerSerializationVisibility.Content), NotifyParentProperty(true), PersistenceMode(PersistenceMode.InnerDefaultProperty) ] public HotSpotCollection HotSpots { get { if (_hotSpots == null) { _hotSpots = new HotSpotCollection(); if (IsTrackingViewState) { ((IStateManager)_hotSpots).TrackViewState(); } } return _hotSpots; } } ///Gets the HotSpotCollection with defines the regions of ImageMap hot spots. ////// [ WebCategory("Behavior"), DefaultValue(HotSpotMode.NotSet), WebSysDescription(SR.HotSpot_HotSpotMode), ] public virtual HotSpotMode HotSpotMode { get { object obj = ViewState["HotSpotMode"]; return (obj == null) ? HotSpotMode.NotSet : (HotSpotMode)obj; } set { if (value < HotSpotMode.NotSet || value > HotSpotMode.Inactive) { throw new ArgumentOutOfRangeException("value"); } ViewState["HotSpotMode"] = value; } } ///Gets or sets the HotSpotMode to either postback or navigation. ////// [ WebCategory("Behavior"), DefaultValue(""), WebSysDescription(SR.HotSpot_Target), ] public virtual string Target { get { object value = ViewState["Target"]; return (value == null)? String.Empty : (string)value; } set { ViewState["Target"] = value; } } ///Gets or sets the name of the window for navigation. ////// [ Category("Action"), WebSysDescription(SR.ImageMap_Click) ] public event ImageMapEventHandler Click { add { Events.AddHandler(EventClick, value); } remove { Events.RemoveHandler(EventClick, value); } } ///The event raised when a hotspot is clicked. ////// /// protected override void AddAttributesToRender(HtmlTextWriter writer) { base.AddAttributesToRender(writer); if (_hasHotSpots) { writer.AddAttribute(HtmlTextWriterAttribute.Usemap, "#ImageMap" + ClientID, false); } } ///Overridden to add the "usemap" attribute the the image tag. /// Overrides WebControl.AddAttributesToRender. ////// protected override void LoadViewState(object savedState) { object baseState = null; object[] myState = null; if (savedState != null) { myState = (object[])savedState; if (myState.Length != 2) { throw new ArgumentException(SR.GetString(SR.ViewState_InvalidViewState)); } baseState = myState[0]; } base.LoadViewState(baseState); if ((myState != null) && (myState[1] != null)) { ((IStateManager)HotSpots).LoadViewState(myState[1]); } } ///Restores view-state information that was saved by SaveViewState. /// Implements IStateManager.LoadViewState. ////// protected virtual void OnClick(ImageMapEventArgs e) { ImageMapEventHandler clickHandler = (ImageMapEventHandler)Events[EventClick]; if (clickHandler != null) { clickHandler(this, e); } } ///Called when the user clicks the ImageMap. ////// /// protected internal override void Render(HtmlTextWriter writer) { if (Enabled && !IsEnabled && SupportsDisabledAttribute) { // We need to do the cascade effect on the server, because the browser // only renders as disabled, but doesn't disable the functionality. writer.AddAttribute(HtmlTextWriterAttribute.Disabled, "disabled"); } _hasHotSpots = ((_hotSpots != null) && (_hotSpots.Count > 0)); base.Render(writer); if (_hasHotSpots) { string fullClientID = "ImageMap" + ClientID; writer.AddAttribute(HtmlTextWriterAttribute.Name, fullClientID); writer.AddAttribute(HtmlTextWriterAttribute.Id, fullClientID); writer.RenderBeginTag(HtmlTextWriterTag.Map); HotSpotMode mapMode = HotSpotMode; if (mapMode == HotSpotMode.NotSet) { mapMode = HotSpotMode.Navigate; } HotSpotMode spotMode; int hotSpotIndex = 0; string controlTarget = Target; foreach (HotSpot item in _hotSpots) { writer.AddAttribute(HtmlTextWriterAttribute.Shape, item.MarkupName, false); writer.AddAttribute(HtmlTextWriterAttribute.Coords, item.GetCoordinates()); spotMode = item.HotSpotMode; if (spotMode == HotSpotMode.NotSet) { spotMode = mapMode; } if (spotMode == HotSpotMode.PostBack) { // Make sure the page has a server side form if we are posting back if (Page != null) { Page.VerifyRenderingInServerForm(this); } if ((RenderingCompatibility < VersionUtil.Framework40) || IsEnabled) { string eventArgument = hotSpotIndex.ToString(CultureInfo.InvariantCulture); writer.AddAttribute(HtmlTextWriterAttribute.Href, Page.ClientScript.GetPostBackClientHyperlink(this, eventArgument, true)); } } else if (spotMode == HotSpotMode.Navigate) { if ((RenderingCompatibility < VersionUtil.Framework40) || IsEnabled) { String resolvedUrl = ResolveClientUrl(item.NavigateUrl); writer.AddAttribute(HtmlTextWriterAttribute.Href, resolvedUrl); } // Use HotSpot target first, if not specified, use ImageMap's target string target = item.Target; if (target.Length == 0) target = controlTarget; if (target.Length > 0) writer.AddAttribute(HtmlTextWriterAttribute.Target, target); } else if (spotMode == HotSpotMode.Inactive) { writer.AddAttribute("nohref", "true"); } writer.AddAttribute(HtmlTextWriterAttribute.Title, item.AlternateText); writer.AddAttribute(HtmlTextWriterAttribute.Alt, item.AlternateText); string s = item.AccessKey; if (s.Length > 0) { writer.AddAttribute(HtmlTextWriterAttribute.Accesskey, s); } int n = item.TabIndex; if (n != 0) { writer.AddAttribute(HtmlTextWriterAttribute.Tabindex, n.ToString(NumberFormatInfo.InvariantInfo)); } writer.RenderBeginTag(HtmlTextWriterTag.Area); writer.RenderEndTag(); ++hotSpotIndex; } writer.RenderEndTag(); // Map } } ///Sends server control content to a provided HtmlTextWriter, which writes the content /// to be rendered to the client. /// Overrides Control.Render. ////// protected override object SaveViewState() { object baseState = base.SaveViewState(); object hotSpotsState = null; if ((_hotSpots != null) && (_hotSpots.Count > 0)) { hotSpotsState = ((IStateManager)_hotSpots).SaveViewState(); } if ((baseState != null) || (hotSpotsState != null)) { object[] savedState = new object[2]; savedState[0] = baseState; savedState[1] = hotSpotsState; return savedState; } return null; } ///Saves any server control view-state changes that have /// occurred since the time the page was posted back to the server. /// Implements IStateManager.SaveViewState. ////// protected override void TrackViewState() { base.TrackViewState(); if (_hotSpots != null) { ((IStateManager)_hotSpots).TrackViewState(); } } #region Implementation of IPostBackEventHandler ///Causes the tracking of view-state changes to the server control. /// Implements IStateManager.TrackViewState. ////// /// void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) { RaisePostBackEvent(eventArgument); } ///Notifies the server control that caused the postback that /// it should handle an incoming post back event. /// Implements IPostBackEventHandler. ////// /// protected virtual void RaisePostBackEvent(string eventArgument) { ValidateEvent(UniqueID, eventArgument); string postBackValue = null; if (eventArgument != null && _hotSpots != null) { int hotSpotIndex = Int32.Parse(eventArgument, CultureInfo.InvariantCulture); if (hotSpotIndex >= 0 && hotSpotIndex < _hotSpots.Count) { HotSpot hotSpot = _hotSpots[hotSpotIndex]; HotSpotMode mode = hotSpot.HotSpotMode; if (mode == HotSpotMode.NotSet) { mode = HotSpotMode; } if (mode == HotSpotMode.PostBack) { postBackValue = hotSpot.PostBackValue; } } } // Ignore invalid indexes silently(VSWhidbey 185738) if (postBackValue != null) { OnClick(new ImageMapEventArgs(postBackValue)); } } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //Notifies the server control that caused the postback that /// it should handle an incoming post back event. /// Implements IPostBackEventHandler. ///// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.UI.WebControls { using System; using System.ComponentModel; using System.Globalization; using System.Web.UI; using System.Web.UI.WebControls; using System.Web.Util; using System.Web; ////// [ DefaultEvent("Click"), DefaultProperty("HotSpots"), ParseChildren(true, "HotSpots"), SupportsEventValidation, ] public class ImageMap : Image, IPostBackEventHandler { private static readonly object EventClick = new object(); private bool _hasHotSpots; private HotSpotCollection _hotSpots; [ Browsable(true), EditorBrowsableAttribute(EditorBrowsableState.Always) ] public override bool Enabled { get { return base.Enabled; } set { base.Enabled = value; } } ///ImageMap class. Provides support for multiple /// region-defined actions within an image. ////// [ WebCategory("Behavior"), WebSysDescription(SR.ImageMap_HotSpots), DesignerSerializationVisibility(DesignerSerializationVisibility.Content), NotifyParentProperty(true), PersistenceMode(PersistenceMode.InnerDefaultProperty) ] public HotSpotCollection HotSpots { get { if (_hotSpots == null) { _hotSpots = new HotSpotCollection(); if (IsTrackingViewState) { ((IStateManager)_hotSpots).TrackViewState(); } } return _hotSpots; } } ///Gets the HotSpotCollection with defines the regions of ImageMap hot spots. ////// [ WebCategory("Behavior"), DefaultValue(HotSpotMode.NotSet), WebSysDescription(SR.HotSpot_HotSpotMode), ] public virtual HotSpotMode HotSpotMode { get { object obj = ViewState["HotSpotMode"]; return (obj == null) ? HotSpotMode.NotSet : (HotSpotMode)obj; } set { if (value < HotSpotMode.NotSet || value > HotSpotMode.Inactive) { throw new ArgumentOutOfRangeException("value"); } ViewState["HotSpotMode"] = value; } } ///Gets or sets the HotSpotMode to either postback or navigation. ////// [ WebCategory("Behavior"), DefaultValue(""), WebSysDescription(SR.HotSpot_Target), ] public virtual string Target { get { object value = ViewState["Target"]; return (value == null)? String.Empty : (string)value; } set { ViewState["Target"] = value; } } ///Gets or sets the name of the window for navigation. ////// [ Category("Action"), WebSysDescription(SR.ImageMap_Click) ] public event ImageMapEventHandler Click { add { Events.AddHandler(EventClick, value); } remove { Events.RemoveHandler(EventClick, value); } } ///The event raised when a hotspot is clicked. ////// /// protected override void AddAttributesToRender(HtmlTextWriter writer) { base.AddAttributesToRender(writer); if (_hasHotSpots) { writer.AddAttribute(HtmlTextWriterAttribute.Usemap, "#ImageMap" + ClientID, false); } } ///Overridden to add the "usemap" attribute the the image tag. /// Overrides WebControl.AddAttributesToRender. ////// protected override void LoadViewState(object savedState) { object baseState = null; object[] myState = null; if (savedState != null) { myState = (object[])savedState; if (myState.Length != 2) { throw new ArgumentException(SR.GetString(SR.ViewState_InvalidViewState)); } baseState = myState[0]; } base.LoadViewState(baseState); if ((myState != null) && (myState[1] != null)) { ((IStateManager)HotSpots).LoadViewState(myState[1]); } } ///Restores view-state information that was saved by SaveViewState. /// Implements IStateManager.LoadViewState. ////// protected virtual void OnClick(ImageMapEventArgs e) { ImageMapEventHandler clickHandler = (ImageMapEventHandler)Events[EventClick]; if (clickHandler != null) { clickHandler(this, e); } } ///Called when the user clicks the ImageMap. ////// /// protected internal override void Render(HtmlTextWriter writer) { if (Enabled && !IsEnabled && SupportsDisabledAttribute) { // We need to do the cascade effect on the server, because the browser // only renders as disabled, but doesn't disable the functionality. writer.AddAttribute(HtmlTextWriterAttribute.Disabled, "disabled"); } _hasHotSpots = ((_hotSpots != null) && (_hotSpots.Count > 0)); base.Render(writer); if (_hasHotSpots) { string fullClientID = "ImageMap" + ClientID; writer.AddAttribute(HtmlTextWriterAttribute.Name, fullClientID); writer.AddAttribute(HtmlTextWriterAttribute.Id, fullClientID); writer.RenderBeginTag(HtmlTextWriterTag.Map); HotSpotMode mapMode = HotSpotMode; if (mapMode == HotSpotMode.NotSet) { mapMode = HotSpotMode.Navigate; } HotSpotMode spotMode; int hotSpotIndex = 0; string controlTarget = Target; foreach (HotSpot item in _hotSpots) { writer.AddAttribute(HtmlTextWriterAttribute.Shape, item.MarkupName, false); writer.AddAttribute(HtmlTextWriterAttribute.Coords, item.GetCoordinates()); spotMode = item.HotSpotMode; if (spotMode == HotSpotMode.NotSet) { spotMode = mapMode; } if (spotMode == HotSpotMode.PostBack) { // Make sure the page has a server side form if we are posting back if (Page != null) { Page.VerifyRenderingInServerForm(this); } if ((RenderingCompatibility < VersionUtil.Framework40) || IsEnabled) { string eventArgument = hotSpotIndex.ToString(CultureInfo.InvariantCulture); writer.AddAttribute(HtmlTextWriterAttribute.Href, Page.ClientScript.GetPostBackClientHyperlink(this, eventArgument, true)); } } else if (spotMode == HotSpotMode.Navigate) { if ((RenderingCompatibility < VersionUtil.Framework40) || IsEnabled) { String resolvedUrl = ResolveClientUrl(item.NavigateUrl); writer.AddAttribute(HtmlTextWriterAttribute.Href, resolvedUrl); } // Use HotSpot target first, if not specified, use ImageMap's target string target = item.Target; if (target.Length == 0) target = controlTarget; if (target.Length > 0) writer.AddAttribute(HtmlTextWriterAttribute.Target, target); } else if (spotMode == HotSpotMode.Inactive) { writer.AddAttribute("nohref", "true"); } writer.AddAttribute(HtmlTextWriterAttribute.Title, item.AlternateText); writer.AddAttribute(HtmlTextWriterAttribute.Alt, item.AlternateText); string s = item.AccessKey; if (s.Length > 0) { writer.AddAttribute(HtmlTextWriterAttribute.Accesskey, s); } int n = item.TabIndex; if (n != 0) { writer.AddAttribute(HtmlTextWriterAttribute.Tabindex, n.ToString(NumberFormatInfo.InvariantInfo)); } writer.RenderBeginTag(HtmlTextWriterTag.Area); writer.RenderEndTag(); ++hotSpotIndex; } writer.RenderEndTag(); // Map } } ///Sends server control content to a provided HtmlTextWriter, which writes the content /// to be rendered to the client. /// Overrides Control.Render. ////// protected override object SaveViewState() { object baseState = base.SaveViewState(); object hotSpotsState = null; if ((_hotSpots != null) && (_hotSpots.Count > 0)) { hotSpotsState = ((IStateManager)_hotSpots).SaveViewState(); } if ((baseState != null) || (hotSpotsState != null)) { object[] savedState = new object[2]; savedState[0] = baseState; savedState[1] = hotSpotsState; return savedState; } return null; } ///Saves any server control view-state changes that have /// occurred since the time the page was posted back to the server. /// Implements IStateManager.SaveViewState. ////// protected override void TrackViewState() { base.TrackViewState(); if (_hotSpots != null) { ((IStateManager)_hotSpots).TrackViewState(); } } #region Implementation of IPostBackEventHandler ///Causes the tracking of view-state changes to the server control. /// Implements IStateManager.TrackViewState. ////// /// void IPostBackEventHandler.RaisePostBackEvent(string eventArgument) { RaisePostBackEvent(eventArgument); } ///Notifies the server control that caused the postback that /// it should handle an incoming post back event. /// Implements IPostBackEventHandler. ////// /// protected virtual void RaisePostBackEvent(string eventArgument) { ValidateEvent(UniqueID, eventArgument); string postBackValue = null; if (eventArgument != null && _hotSpots != null) { int hotSpotIndex = Int32.Parse(eventArgument, CultureInfo.InvariantCulture); if (hotSpotIndex >= 0 && hotSpotIndex < _hotSpots.Count) { HotSpot hotSpot = _hotSpots[hotSpotIndex]; HotSpotMode mode = hotSpot.HotSpotMode; if (mode == HotSpotMode.NotSet) { mode = HotSpotMode; } if (mode == HotSpotMode.PostBack) { postBackValue = hotSpot.PostBackValue; } } } // Ignore invalid indexes silently(VSWhidbey 185738) if (postBackValue != null) { OnClick(new ImageMapEventArgs(postBackValue)); } } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.Notifies the server control that caused the postback that /// it should handle an incoming post back event. /// Implements IPostBackEventHandler. ///
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- FolderBrowserDialog.cs
- AbandonedMutexException.cs
- BindingCollection.cs
- BindingGroup.cs
- RoleBoolean.cs
- TrustSection.cs
- CustomValidator.cs
- CodeCompileUnit.cs
- HandlerFactoryWrapper.cs
- SafeBitVector32.cs
- DataGridViewRow.cs
- ParentUndoUnit.cs
- FamilyMapCollection.cs
- NegotiateStream.cs
- TextRunProperties.cs
- BitmapEffectRenderDataResource.cs
- Package.cs
- RichTextBoxConstants.cs
- AsyncOperation.cs
- DeferredElementTreeState.cs
- PageClientProxyGenerator.cs
- UnSafeCharBuffer.cs
- EFAssociationProvider.cs
- BevelBitmapEffect.cs
- ExpressionEditor.cs
- PrivilegeNotHeldException.cs
- LinqDataSourceEditData.cs
- RewritingPass.cs
- XmlUtf8RawTextWriter.cs
- SizeKeyFrameCollection.cs
- TargetControlTypeCache.cs
- ReadOnlyCollectionBase.cs
- InputBinding.cs
- TabletDeviceInfo.cs
- SqlNodeAnnotation.cs
- ControlCachePolicy.cs
- TraceContext.cs
- InputLangChangeRequestEvent.cs
- ThaiBuddhistCalendar.cs
- AspNetHostingPermission.cs
- RequestStatusBarUpdateEventArgs.cs
- NamedPipeTransportElement.cs
- FixedTextPointer.cs
- Slider.cs
- GCHandleCookieTable.cs
- EventHandlerService.cs
- SmtpTransport.cs
- Quaternion.cs
- SynchronizationLockException.cs
- HttpRequestWrapper.cs
- GroupPartitionExpr.cs
- LoaderAllocator.cs
- XmlCountingReader.cs
- TextServicesDisplayAttribute.cs
- _PooledStream.cs
- PointHitTestResult.cs
- BamlRecords.cs
- ObjectFactoryCodeDomTreeGenerator.cs
- TemplateBaseAction.cs
- EventLogPermission.cs
- MatrixAnimationUsingPath.cs
- TextPenaltyModule.cs
- versioninfo.cs
- FloatAverageAggregationOperator.cs
- Table.cs
- RangeValidator.cs
- PerformanceCountersElement.cs
- DataServiceHost.cs
- DataGridViewEditingControlShowingEventArgs.cs
- XXXOnTypeBuilderInstantiation.cs
- Utils.cs
- StateWorkerRequest.cs
- RbTree.cs
- ProfileSettings.cs
- DoubleCollectionConverter.cs
- COM2IPerPropertyBrowsingHandler.cs
- Stacktrace.cs
- ErasingStroke.cs
- Vector3DCollection.cs
- ApplicationProxyInternal.cs
- Substitution.cs
- CheckableControlBaseAdapter.cs
- RuntimeHelpers.cs
- VersionPair.cs
- EventProvider.cs
- SByteStorage.cs
- SharedStatics.cs
- GridSplitterAutomationPeer.cs
- CfgRule.cs
- ThicknessAnimationUsingKeyFrames.cs
- DataViewManagerListItemTypeDescriptor.cs
- ObjectPropertyMapping.cs
- StructureChangedEventArgs.cs
- OnOperation.cs
- TextCompositionManager.cs
- FilteredDataSetHelper.cs
- TextTreeInsertUndoUnit.cs
- FusionWrap.cs
- InvalidOleVariantTypeException.cs
- DetailsViewModeEventArgs.cs