ModernJava
http://www.modernminds.com
A pplet - ScrollingUpdateApplet (Version 1.1)

ScrollingUpdateApplet is an applet and a canvas class that can be used to vertically scroll text over a static background image. The text is read from a file on the host, and the host text file is subsequently read periodically for updates. If an update to the text file occurs, then the vertically scrolling text displayed by the applet is dynamically updated.
O peration

The following documentation describes how the ScrollingUpdateApplet class is used. You can also use the ScrollingUpdate canvas class if you wish to integrate vertically scrolling text with dynamic update capabilites in your own application or applet. The ScrollingUpdate class is documented separately.

ScrollingUpdateApplet.class (the applet) requires ScrollingUpdate.class (the canvas), which in turn requires NetworkTextFile.class. All of these objects are included in the download package.

During initialization, ScrollingUpdateApplet loads the GIF or JPEG image that will be used as the background image, and reads a specified file on the host to retrieve the text that is to be scrolled vertically over the image.

The are a number of parameters (documented below) that control how the text will be rendered over the background. Both the font characteristics and the location of the scroll region within the background image can be specified.

The number of words that appear on a single line in the scroll region is automatically determined based upon the font characteristics and the width of the scroll region. Because each line of text is automatically formatted, the text entered in the text file does not need to be manually formatted with carriage returns. If you wish to create a line break in the text, enter the <BR> code or the <P> code in the text file where the line break should be placed. The code should be entered on a single line or with a least one space on either side of the code. The <BR> code will place a line break in the text at the location of the code. The <P> code will insert a blank line in addition to inserting the line break.

The frequency at which the applet checks for changes to the text file can be specified, as well as whether or not a notification indicator should be displayed whenever an update check occurs.

The applet determines if the text file has been changed by reading the very first line of text in the file (the file header) and comparing it to the header that was read on the previous read. Note that the header is never displayed, so the header line in the file can be can be anything that you wish, such as the date and time that the file was last changed.

When you want to indicate that the text in the file has changed, simply modify the header and save the file. The next time that the applet checks the text file, it will find that the header has changed and will then reload and re-render the text to be scrolled.

Scrolling text can be paused by clicking anywhere within the boundries of the applet. A second click will start the text scrolling once again.
S ample

No Java Support Available If your browser supports Java, you should see a demonstration of the ScrollingUpdateApplet to the left of this text.

You can view the text file that is being read to create the scrolling text.
P arameters

Following are the HTML parameters for the applet. A parameter marked "Opt" is optional, and a parameter marked "Req" is required.

Req text The name of the text file that contains the text to be vertically scrolled.

The file must reside in the same directory as the Java applet.
Opt maxSizeKB The maximum size that the text file can be in kilobytes.

If this parameter is not specified, then the parameter value defaults to "8" (i.e. 8,192 bytes, or characters).
Opt refresh The frequency in seconds that the text file should be checked for updates.

If this parameter is not specified, then the parameter value defaults to "600" (i.e. check file every ten minutes).
Opt notifyOnRead If this parameter is set to "true", then a small red square indicator will blink in the top left corner of the screen each time that the text file is checked for updates.

If set to "false", then no indication will be displayed that the text file has been checked.

If this parameter is not specified, then the parameter value defaults to "false".
Opt font The name of the font to use when rendering the text to be scrolled.

It is recommended that only the standard fonts for Java be specified unless you are certain that the font that you specify will be available on all clients.

If this parameter is not specified, then the parameter value defaults to "TimesRoman".
Opt fontSize The size of the font used to render the text to be scrolled.

If this parameter is not specified, then the parameter value defaults to "14".
Opt fontStyle There are four valid values allowed for this parameter: "bold", "italic", "plain", or "bold+italic" (or "italic+bold").

If this parameter is not specified, then the parameter value defaults to "plain".
Opt fontColor The color of the scrolled text .

The value must be a hexadecimal RGB value. For instance "FF0000" would be red, and "888888" would be a medium gray.

If this parameter is not specified, then the text color defaults to black.
Opt justify The valid values for text justification are "left", "center", and "right".

If this parameter is not specified, then the parameter value defaults to "left".
Opt frameDelay The number of milliseconds to delay between each frame of animation (this controls how quickly the text scrolls).

If this parameter is not specified, then the parameter value defaults to "60".
Req background The file name of a GIF or JPEG image that will be drawn behind the scrolling text.

The file path is based starting with the directory in which the Java applet is located.
Opt scrollRectX The X coordinate of the top left corner of the rectangle in which the text is scrolled.

Text can be scrolled over any portion of the background image. This parameter, along with scrollRectY, defines the top left corner of the area in which the text will be scrolled.

If this parameter is not specified, then the parameter value defaults to "0" (left edge of image).
Opt scrollRectY The Y coordinate of the top left corner of the rectangle in which the text is scrolled.

Text can be scrolled over any portion of the background image. This parameter, along with scrollRectX, defines the top left corner of the area in which the text will be scrolled.

If this parameter is not specified, then the parameter value defaults to "0" (top edge of image).
Opt scrollRectW The width of the rectangle in which the text is scrolled.

Text can be scrolled over any portion of the background image. This parameter defines the total width of the area in which the text will be scrolled.

If this parameter is not specified, then the parameter value defaults to "50"
Opt scrollRectH The height of the rectangle in which the text is scrolled.

Text can be scrolled over any portion of the background image. This parameter defines the total height of the area in which the text will be scrolled.

If this parameter is not specified, then the parameter value defaults to "50"
E xample

An example of a HTML APPLET tag with all parameters for this applet is shown below.

<APPLET CODE="ScrollingUpdateApplet.class" WIDTH="150" HEIGHT="100">
<PARAM NAME="text" VALUE="TextToScroll.TXT">
<PARAM NAME="maxSizeKB" VALUE="1">
<PARAM NAME="refresh" VALUE="300">
<PARAM NAME="notifyOnRead" VALUE="true">
<PARAM NAME="font" VALUE="Courier">
<PARAM NAME="fontSize" VALUE="18">
<PARAM NAME="fontStype" VALUE="bold+italic">
<PARAM NAME="fontColor" VALUE="0F342E">
<PARAM NAME="justify" VALUE="center">
<PARAM NAME="frameDelay" VALUE="75">
<PARAM NAME="background" VALUE="Graphics/BkgndImage.JPG">
<PARAM NAME="scrollRectX" VALUE="25">
<PARAM NAME="scrollRectY" VALUE="25">
<PARAM NAME="scrollRectW" VALUE="100">
<PARAM NAME="scrollRectH" VALUE="50">
</APPLET>
D ownload

The object code for the applet ScrollingUpdateApplet and the canvas ScrollingUpdate along with a copy of this documentation are available for download.
C opyright

This documentation and the object code for ScrollingUpdateApplet and ScrollingUpdate may be copied and distributed freely for non-commercial purposes so long as neither the code nor the documentation is altered in any way. If the object code is distributed with any documentation whatsoever, then this unaltered document must accompany the code.

Copyright © 1997 by Modern Minds, Inc.