|
Download
FAQ History |
|
API
Search Feedback |
Understanding the Image Map Example
The
cardemoapplication now includes a custom image map component on theImageMap.jsppage. This image map displays a map of the world. When the user clicks on one of a particular set of regions in the map, the application sets the locale in theFacesContextto the language spoken in the selected region. The hot spots of the map are: the United States, Spanish-speaking Central and South America, France, and Germany.Why Use JavaServer Faces Technology to Implement an Image Map?
JavaServer Faces technology is an ideal framework to use for implementing this kind of image map because it can perform the work that must be done on the server without requiring you to create a server-side image map.
In general, client-side image maps are preferred over server-side image maps for a few reasons. One reason is that the client-side image map allows the browser to provide immediate feedback when a user positions her mouse over a hot spot. Another reason is that client-side image maps perform better because they don't require round-trips to the server. However, in some situations, your image map might need to access the server to retrieve some data or to change the appearance of non-form controls, which a client-side image map cannot do.
The image map custom component--because it uses JavaServer Faces technology--has the best of both style of image maps: It can handle the parts of the application that need to be performed on the server, while allowing the other parts of the application to be performed on the client side.
Understanding the Rendered HTML
Here is an abbreviated version of the form part of the HTML page that the application needs to render:
<form METHOD="post" ACTION="/cardemo/faces/..."> <table> <tr> <td> Welcome to JavaServer Faces</td></tr> <tr><td> <img id="mapImage" src="world.jpg" usemap="#worldMap"> <map name="worldMap"> <area shape="poly" coords="6,15,6,28,2,30,6,34,13,28,17,..." onclick="document.forms[0].selectedArea.value= 'NAmericas'; document.forms[0].submit()" onmouseover="document.forms[0].mapImage.src= 'world_namer.jpg';" onmouseout="document.forms[0].mapImage.src= 'world.jpg';" alt="NAmericas"> ... <input type="hidden" name="selectedArea"></map> </td></tr> </table> </form>The
imgtag associates an image (world.jpg) with an image map, referenced in theusemapattribute value.The
maptag specifies the image map and contains a set ofareatags.Each
areatag specifies a region of the image map. Theonmouseover,onmouseout, andonmouseclickattributes define which JavaScript code is executed when these events occur. When the user moves her mouse over a region, theonmouseoverfunction associated with the region displays the map with that region highlighted. When the user moves her mouse out of a region, theonmouseoutfunction redisplays the original image. If the user clicks on a region, theonclickfunction sets the value of theinputtag to the id of the selected area and submits the page.The
inputtag represents a hidden control that stores the value of the currently-selected area between client/server exchanges so that the server-side component classes can retrieve the value.The server side objects retrieve the value of
selectedAreaand set the locale in theFacesContextaccording to what region was selected.Understanding the JSP Page
Here is an abbreviated form of the JSP page that the image map component will use to generate the HTML page shown in the previous section:
<f:use_faces> <h:form formName="imageMapForm" > ... <h:graphic_image id="mapImage" url="/world.jpg" usemap="#worldMap" /> <d:map id="worldMap" currentArea="NAmericas" > <f:action_listener type="cardemo.ImageMapEventHandler" /> <d:area id="NAmericas" valueRef="NA" onmouseover="/cardemo/world_namer.jpg" onmouseout="/cardemo/world.jpg" /> ... </d:map> ... </h:form> </f:use_faces>The
action_listenertag nested inside themaptag causes theImageMapEventHandlerto be registered on the component corresponding tomap. This handler changes the locale according to the area selected from the image map. The way this event is handled is explained more in Handling Events for Custom Components.Notice that the
areatags do not contain any of the JavaScript, coordinate, or shape data that is displayed on the HTML page. The JavaScript is generated by theAreaRendererclass. Theonmouseoverandonmouseoutattribute values indicate the image to be loaded when these events occur. How the JavaScript is generated is explained more in Performing Encoding.The coordinate, shape, and alt data are obtained through the
valueRefattribute, whose value refers to an attribute in application scope. The value of this attribute is a model object, which stores the coordinate, shape, and alt data. How these model objects are stored in the application scope is explained more in Simplifying the JSP Page.Simplifying the JSP Page
One of the primary goals of JavaServer Faces technology is ease-of-use. This includes separating out the code from the page so that a wider range of page authors can easily contribute to the Web development process. For this reason, all JavaScript is rendered by the component classes rather than being included in the page.
Ease-of-use also includes compartmentalizing the tasks of developing a Web application. For example, rather than requiring the page author to hardcode the coordinates of the hot spots in the page, the application should allow the coordinates to be retrieved from a database or generated by one of the many image map tools available.
In a JavaServer Faces application, data such as coordinates would be retrieved via a model object from the
valueRefattribute. However, the shape and coordinates of a hotspot should be defined together because the coordinates are interpreted differently depending on what shape the hotspot is. Since a component'svalueRefcan only be bound to one property, thevalueRefattribute cannot refer to both the shape and the coordinates.To solve this problem, the application encapsulates all of this information in a set of
ImageAreaobjects. These objects are initialized into application scope by the Managed Bean Facility (Managed Bean Creation). Here is part of the managed-bean declaration for theImageAreabean corresponding to the South America hotspot:<managed-bean> ... <managed-bean-name>SA</managed-bean-name> <managed-bean-class> components.model.ImageArea </managed-bean-class> <managed-bean-scope>application</managed-bean-scope> <managed-property> <property-name>shape</property-name> <value>poly</value> </managed-property> <managed-property> <property-name>alt</property-name> <value>SAmerica</value> </managed-property> <managed-property> <property-name>coords</property-name> <value>89,217,95,100...</value> </managed-property> </managed-bean>For more information on initializing managed beans with the Managed Bean Facility, see section Creating Model Objects.
The
valueRefattributes of theareatags refer to the beans in the application scope, as shown in thisareatag fromImageMap.jsp:<d:area id="NAmericas"valueRef="NA" onmouseover="/cardemo/world_namer.jpg" onmouseout="/cardemo/world.jpg" />To reference the
ImageAreamodel object values from the component class, you need to callgetvalueReffrom your component class. This returns the name of the attribute that stores theImageAreaobject associated with the tag being processed. Next, you need to pass the attribute to thegetValueRefmethod of theUtilclass, which is a reference implementation helper class that contains various factories for resources. This will return aValueBinding, which uses the expression from thevalueRefattribute to locate theImageAreaobject containing the values associated with the currentUIAreacomponent. Here is the line fromAreaRendererthat does all of this:
ImageAreais just a simple bean, so you can access the shape, coordinates, and alt values by calling the appropriate accessor methods ofImageArea. Performing Encoding explains how to do this in theAreaRendererclass.Summary of the Application Classes
Table 22-2 summarizes all of the classes needed to implement the image map component.
AreaTagandMapTagare located in<JWSDP_HOME>/jsf/samples/components/src/components/taglib/.
UIAreaandUIMapare located in<JWSDP_HOME>/jsf/samples/components/src/components/components/.
AreaRendereris located in<JWSDP_HOME>/jsf/samples/components/src/components/renderkit/.
ImageAreais located in<JWSDP_HOME>/jsf/samples/components/src/components/model/.
ImageMapEventHandleris located in<JWSDP_HOME>/jsf/samples/cardemo/src/cardemo/.
|
Download
FAQ History |
|
API
Search Feedback |
All of the material in The Java(TM) Web Services Tutorial is copyright-protected and may not be published in other works without express written permission from Sun Microsystems.