ASP.NET
  Home arrow ASP.NET arrow Page 4 - ASP.NET Custom Server Controls: Cute Image...
ASP Free Forums 
.NET  
ASP  
ASP Code  
ASP.NET  
ASP.NET Code  
BrainDump  
C#  
Code Examples  
Database  
Database Code  
IIS  
Microsoft Access  
MS SQL Server  
Visual Basic.NET  
Windows Scripting  
Windows Security  
XML  
ASP Web Hosting  
ASP.NET Web Hosting 
Mobile Linux 
App Generation ROI 
Windows Web Hosting
 
IBM® developerWorks 
Sun Developer Network 
Weekly Newsletter
 
Developer Updates  
Free Website Content 
 RSS  Articles
 RSS  Forums
 RSS  All Feeds
Write For Us Get Paid 
Request Media Kit
Contact Us 
Site Map 
Privacy Policy 
Support 
 USERNAME
 
 PASSWORD
 
 
  >>> SIGN UP!  
  Lost Password? 
ASP.NET

ASP.NET Custom Server Controls: Cute Image Hover Button
By: Jagadish Chaterjee
  • Search For More Articles!
  • Disclaimer
  • Author Terms
  • Rating: 4 stars4 stars4 stars4 stars4 stars / 20
    2005-09-19

    Table of Contents:
  • ASP.NET Custom Server Controls: Cute Image Hover Button
  • Understanding the life cycle – Rendering methods
  • Understanding the life cycle – Attributes
  • Other features of the control

  • Rate this Article: Poor Best 
      ADD THIS ARTICLE TO:
      Del.ici.ous Digg
      Blink Simpy
      Google Spurl
      Y! MyWeb Furl
    Email Me Similar Content When Posted
    Add Developer Shed Article Feed To Your Site
    Email Article To Friend
    Print Version Of Article
    PDF Version Of Article
     
     
    ADVERTISEMENT


    ASP.NET Custom Server Controls: Cute Image Hover Button - Other features of the control


    (Page 4 of 4 )

    Another modification to the same control is the following code fragment.  Look it over carefully.

    Protected Overrides Sub Render(ByVal writer As System.Web.UI.HtmlTextWriter)
           If Not Page Is Nothing Then
                Page.VerifyRenderingInServerForm(Me)
           
    End If
           MyBase.Render(writer)
       End Sub

    The above implementation of the “Render” method ensures that the placement of your control should be within the “<FORM>” tag itself.  It would automatically raise an error if not placed within the “<FORM>” tag.  You should also observe the second statement, “MyBase.Render(writer)”.  It asks to proceed with rendering as usual, without considering any other issue.

    The next question would be, how did I implement “OnClick” event within my control?  The following statements at various locations made it possible:

    Public Event Click As EventHandler
    Public Sub RaisePostBackEvent(ByVal eventArgument As String)Implements System.Web.UI.IPostBackEventHandler.RaisePostBackEvent
            OnClick(EventArgs.Empty)
       
    End Sub

    Protected Overridable Sub OnClick(ByVal e As EventArgs)
           RaiseEvent Click(Me,  e)
       End Sub

    It is the concept of both eventing and delegating together.  The above statements made it possible to implement ‘postback’ing together with delegating.  I suggest you to go through OOPS in .NET, if you are not familiar with Events and Delegates.

    I implemented two more properties for “ImageOver” and “ImageOut” scenarios.  The following shows a code fragment of one of them (the other is also quite similar):

    <EditorAttribute(GetType(System.Web.UI.Design.UrlEditor), GetType(System.Drawing.Design.UITypeEditor))> _
       Property [ImageOverURL] () As String
           
    Get
               Return viewstate("ImageOverURL") & ""
           End Get
           Set (ByVal Value As String)
                viewstate("ImageOverURL") = Value
           End Set
       End Property

    You should be able to understand everything except the “<EditorAttribute..>”.  That specification is used to provide an open dialog box to select files (of images) from within the properties window during the web page design.  If you omit that, you need to provide the path of the file manually (without selection).

    Coming to the JavaScripts issue, I included two methods, “getJS4MouseOver” and “getJS4MouseOut” to emit JavaScript for every instance of the control.  The following would give you an idea of “getJS4MouseOver” (the other is also quite similar):

    Private Function getJS4MouseOver(ByVal FunctionName As String) As String
           Dim js
    As String

            js = "<script language=javascript>"
            js &= "function " & FunctionName & "() "
            js &= "{"
            js &= "  event.srcElement.style.backgroundImage='url(" & ImageOverURL & ")'; "
            js &= "}"
            js &= "</script>"

           Return js
       End Function

    I just kept on concatenating the JavaScript into a single variable, and finally returned that JavaScript back to the caller. I would suggest you use “StringBuilder” rather than simply concatenating it.

    Remarks

    This control has been developed just to initiate and show the power of custom control to control everything right from the  beginning to the end, including client-side JavaScript emission.  I didn’t quite implement all of the features of original ASP.NET Button control (as that would take a series of articles).  You just need to learn a few more interfaces and methods to implement all of the original features along with your own features. 

    I leave it to the developers to further enhance the same control.  The areas in which you can improve the control would include eventing, better JavaScript for validation, data-binding, and so on. Good luck.

    Any comments, suggestions, bugs, errors, feedback etc. are highly appreciated at jag_chat@yahoo.com.


    DISCLAIMER: The content provided in this article is not warranted or guaranteed by Developer Shed, Inc. The content provided is intended for entertainment and/or educational purposes in order to introduce to the reader key ideas, concepts, and/or product reviews. As such it is incumbent upon the reader to employ real-world tactics for security and implementation of best practices. We are not liable for any negative consequences that may result from implementing any information covered in our articles or tutorials. If this is a hardware review, it is not recommended to open and/or modify your hardware.

       · Hello guys...the next control is on its way...don't hesitate to ask for enhancements...
     

    ASP.NET ARTICLES

    - Developing a Mini ASP.NET AJAX Server Centri...
    - Disadvantages of the ASP.NET MVC Framework
    - Advantages of the ASP.NET MVC Approach
    - ASP.NET Web Forms Weaknesses
    - ASP.NET Web Forms Meets ASP.NET MVC
    - Source Code for Saving and Retrieving Data w...
    - Using GridView to Save and Retrieve Data wit...
    - Handling Dynamic Images in ASP.NET 3.5 AJAX ...
    - Retrieving Data with AJAX and the GridView C...
    - Playing with Images in ASP.NET 3.5 AJAX Appl...
    - Saving and Retrieving Data with AJAX
    - Enhancing PHP Via the ASP.NET AJAX Framework...
    - Enhancing PHP Programming with the ASP.NET A...
    - Classes and ASP.NET AJAX
    - Using ASP.NET AJAX

     
    Best Practices for Windows Vista Migration Presentation
    Dell and Microsoft recently held a series of face-to-face seminars entitled, &qu....

     
    Creating a Culture for Code Reuse
    If you oversee development teams you know that like it or not proprietary and ex....

     
    Keys to Web Application Acceleration: Advances in Delivery Systems
    Accelerate Web apps by up to 5x. Ensure significantly faster access to the Web a....

     
    Optimizing Application Monitoring
    Tired of finding out from your customers that you're offline? This white paper e....

     
    Solaris to Solaris Migration -- Migrating applications from Sun SPARC to Dell PowerEdge R900
    This comprehensive Migration Guide reviews the approach that Principled Technolo....

     




    © 2003-2009 by Developer Shed. All rights reserved. DS Cluster 1 hosted by Hostway
    Stay green...Green IT