1
0
mirror of https://git.FreeBSD.org/ports.git synced 2024-11-13 23:36:08 +00:00
freebsd-ports/graphics/hpscan/files/patch-ae
Joerg Wunsch 03be1bb732 A few enhancements:
. adjustable scanner intensity and contrast,
. extracted the customizable resources into Xrm resource files,
  including ``colorization'' to make the appearance prettier,
. fixed a bug in the gamma handling on truecolor displays that caused
  a core dump for me,
. taught it to register a WM_DELETE message and an icon with the
  window manager
1996-03-07 22:44:50 +00:00

661 lines
20 KiB
Plaintext

diff -u -N ../old/HPscan-co.ad ./HPscan-co.ad
--- ../old/HPscan-co.ad Thu Jan 1 01:00:00 1970
+++ ./HPscan-co.ad Thu Mar 7 21:21:14 1996
@@ -0,0 +1,46 @@
+HPscan*canvas.translations: #override\n\
+ <Key>: input() \n\
+ <Motion>: input() \n\
+ <BtnDown>: input() \n\
+ <BtnUp>: input()
+HPscan*preview.label: Preview
+HPscan*zoom.label: Zoom
+HPscan*scan.label: Scan
+HPscan*quit.label: Quit
+HPscan*resolution.label: Resolution
+HPscan*resolutionVal.borderWidth: 0
+HPscan*message.horizDistance: 40
+HPscan*message.borderWidth: 0
+HPscan*filenamelabel.label: Filename:
+HPscan*filenamelabel.borderWidth: 0
+! Should be canvas.width - 90
+HPscan*filename.width: 210
+HPscan*canvas.width: 300
+
+HPscan*intensityLabel.label: Intensity:
+HPscan*intensityLabel.borderWidth: 0
+HPscan*intensityVal.borderWidth: 0
+HPscan*intensityScrollbar.width: 120
+HPscan*intensityScrollbar.height: 15
+HPscan*intensityScrollbar.minimumThumb: 8
+HPscan*intensityScrollbar.topOfThumb: 0.5
+
+HPscan*contrastLabel.label: Contrast:
+HPscan*contrastLabel.borderWidth: 0
+HPscan*contrastVal.borderWidth: 0
+HPscan*contrastScrollbar.width: 120
+HPscan*contrastScrollbar.height: 15
+HPscan*contrastScrollbar.minimumThumb: 8
+HPscan*contrastScrollbar.topOfThumb: 0.5
+
+! some color stuff
+HPscan*form.background: cornsilk
+HPscan*canvas.background: gainsboro
+HPscan*controlform.background: light cyan
+HPscan*controlform*Label.background: light cyan
+HPscan*resolution*background: lavender
+HPscan*Command.background: navajowhite
+HPscan*quit.background: red
+HPscan*quit.foreground: yellow
+HPscan*Scrollbar.background: misty rose
+HPscan*filename*background: misty rose
diff -u -N ../old/HPscan.ad ./HPscan.ad
--- ../old/HPscan.ad Thu Jan 1 01:00:00 1970
+++ ./HPscan.ad Thu Mar 7 18:26:56 1996
@@ -0,0 +1,34 @@
+HPscan*canvas.translations: #override\n\
+ <Key>: input() \n\
+ <Motion>: input() \n\
+ <BtnDown>: input() \n\
+ <BtnUp>: input()
+HPscan*preview.label: Preview
+HPscan*zoom.label: Zoom
+HPscan*scan.label: Scan
+HPscan*quit.label: Quit
+HPscan*resolution.label: Resolution
+HPscan*resolutionVal.borderWidth: 0
+HPscan*message.horizDistance: 40
+HPscan*message.borderWidth: 0
+HPscan*filenamelabel.label: Filename:
+HPscan*filenamelabel.borderWidth: 0
+! Should be canvas.width - 90
+HPscan*filename.width: 210
+HPscan*canvas.width: 300
+
+HPscan*intensityLabel.label: Intensity:
+HPscan*intensityLabel.borderWidth: 0
+HPscan*intensityVal.borderWidth: 0
+HPscan*intensityScrollbar.width: 120
+HPscan*intensityScrollbar.height: 15
+HPscan*intensityScrollbar.minimumThumb: 8
+HPscan*intensityScrollbar.topOfThumb: 0.5
+
+HPscan*contrastLabel.label: Contrast:
+HPscan*contrastLabel.borderWidth: 0
+HPscan*contrastVal.borderWidth: 0
+HPscan*contrastScrollbar.width: 120
+HPscan*contrastScrollbar.height: 15
+HPscan*contrastScrollbar.minimumThumb: 8
+HPscan*contrastScrollbar.topOfThumb: 0.5
diff -u -N ../old/Imakefile ./Imakefile
--- ../old/Imakefile Wed Mar 6 13:25:47 1996
+++ ./Imakefile Thu Mar 7 21:22:07 1996
@@ -12,3 +12,5 @@
OBJS = main.o scsi.o scanner.o scl.o gui.o colour.o Plain.o
ComplexProgramTarget(hpscan)
+InstallAppDefaults(HPscan)
+InstallAppDefaultsLong(HPscan-co,HPscan-color)
diff -u -N ../old/colour.c ./colour.c
--- ../old/colour.c Wed Mar 6 13:25:47 1996
+++ ./colour.c Thu Mar 7 16:41:36 1996
@@ -149,6 +149,10 @@
int r_best, g_best, b_best;
unsigned long pix_best;
+ if (r > 255) r = 255;
+ if (g > 255) g = 255;
+ if (b > 255) b = 255;
+
if(screendepth == 1)
{
if(r+g+b >= 3*128)
@@ -186,9 +190,15 @@
else /* > 8 bit */
{
if(r == 255 && g == 255 && b == 255)
+ {
pix_best = white;
+ r_best = g_best = b_best = 255;
+ }
else if(r == 0 && g == 0 && b == 0)
+ {
pix_best = black;
+ r_best = g_best = b_best = 0;
+ }
else
{
r_best = ((r + 4) / 8) * 8;
diff -u -N ../old/gui.c ./gui.c
--- ../old/gui.c Wed Mar 6 13:25:47 1996
+++ ./gui.c Thu Mar 7 23:28:40 1996
@@ -16,6 +16,7 @@
#include <X11/StringDefs.h>
#include <X11/Intrinsic.h>
#include <X11/Shell.h>
+#include <X11/Xaw/Simple.h>
#include <X11/Xaw/Command.h>
#include <X11/Xaw/Label.h>
#include <X11/Xaw/Form.h>
@@ -24,16 +25,21 @@
#include <X11/Xaw/SimpleMenu.h>
#include <X11/Xaw/SmeBSB.h>
#include <X11/Xaw/SmeLine.h>
+#include <X11/Xaw/Scrollbar.h>
#include "Plain.h"
#include "gui.h"
#include "colour.h"
#include "scl.h"
+#include "hpscan.icon"
+
static Widget shell, form, controlform, canvas;
static Widget previewb, zoomb, scanb, quitb;
static Widget resolutionl, resolutionb, resolutionm, messagel;
static Widget filenamel, filenamet;
+static Widget intensitylabel, intensityscr, intensityval;
+static Widget contrastlabel, contrastscr, contrastval;
static XtAppContext app;
Display *display;
@@ -43,18 +49,48 @@
int screendepth;
static GC image_gc;
static Colormap cmap;
+static Atom delwin; /* the delete window atom */
-static int canvas_width = 300;
+static int canvas_width;
static int canvas_height;
static int resolution_list[] = {75, 100, 150, 200, 300, 400, 600};
+static int min_intensity, max_intensity, min_contrast, max_contrast;
+static int intensity, contrast;
+
static char *fallback[] = {
"*.canvas.translations: #override\\n\
<Key>: input() \\n\
<Motion>: input() \\n\
<BtnDown>: input() \\n\
- <BtnUp>: input() \\n",
+ <BtnUp>: input() ",
+ "*.preview.label: Preview",
+ "*.zoom.label: Zoom",
+ "*.scan.label: Scan",
+ "*.quit.label: Quit",
+ "*.resolution.label: Resolution",
+ "*.resolutionVal.borderWidth: 0",
+ "*.message.horizDistance: 40",
+ "*.message.borderWidth: 0",
+ "*.filenamelabel.label: Filename:",
+ "*.filenamelabel.borderWidth: 0",
+ "*.filename.width: 210",
+ "*.canvas.width: 300",
+ "*.intensityLabel.label: Intensity:",
+ "*.intensityLabel.borderWidth: 0",
+ "*.intensityVal.borderWidth: 0",
+ "*.intensityScrollbar.width: 120",
+ "*.intensityScrollbar.height: 15",
+ "*.intensityScrollbar.minimumThumb: 8",
+ "*.intensityScrollbar.topOfThumb: 0.5",
+ "*.contrastLabel.label: Contrast: ",
+ "*.contrastLabel.borderWidth: 0",
+ "*.contrastVal.borderWidth: 0",
+ "*.contrastScrollbar.width: 120",
+ "*.contrastScrollbar.height: 15",
+ "*.contrastScrollbar.minimumThumb: 8",
+ "*.contrastScrollbar.topOfThumb: 0.5",
(char *)0
};
@@ -71,8 +107,11 @@
static void scan(Widget w, XtPointer client, XtPointer call);
static void quit(Widget w, XtPointer client, XtPointer call);
static void resolution(Widget w, XtPointer client, XtPointer call);
+static void movethumb(Widget w, XtPointer client, XtPointer call);
+static void scrollthumb(Widget w, XtPointer client, XtPointer call);
-static struct raw_image *do_scan(int l, int t, int w, int h, int res,int type);
+static struct raw_image *do_scan(int l, int t, int w, int h, int res,
+ int intensity, int contrast, int type);
static XImage *make_image(struct raw_image *raw);
static int gamma_correct(int input);
static void find_box(struct raw_image *raw);
@@ -82,6 +121,14 @@
static void adjust_box(int edge, int x, int y);
static void set_message(char *message);
+static void actionHook(Widget w, XtPointer cld, String name, XEvent *xev,
+ String *params, Cardinal *num_params);
+static void GlobalProtoHandler(Widget w, XEvent *xev, String *p, Cardinal *n);
+
+static XtActionsRec actions[] = { {"GlobalProtoHandler", GlobalProtoHandler}};
+
+#define TransTableMessage "<Message>WM_PROTOCOLS : GlobalProtoHandler()"
+
static int scanner_to_canvas_x(int x);
static int scanner_to_canvas_y(int y);
static int canvas_to_scanner_x(int x);
@@ -118,20 +165,34 @@
{
Widget w;
Widget colourmap_widgets[2];
- int i;
+ int i, lo, hi;
char buf[20];
+ XtActionHookId ahid;
+ XWMHints *wmhints;
scanner_fd = fd;
shell =
- XtVaAppInitialize(&app, "Scanner", 0, 0, &argc, argv, fallback,
+ XtVaAppInitialize(&app, "HPscan", 0, 0, &argc, argv, fallback,
(String)0);
+ ahid = XtAppAddActionHook(app, actionHook, NULL);
+
display = XtDisplay(shell);
screen = XtScreen(shell);
screendepth = DefaultDepthOfScreen(screen);
root = RootWindowOfScreen(screen);
-
+
+ /* Get various values from the scanner for later processing. */
+ GetMinIntensity(scanner_fd, &min_intensity);
+ GetMaxIntensity(scanner_fd, &max_intensity);
+ intensity = (max_intensity - min_intensity) / 2 + min_intensity;
+ GetMinContrast(scanner_fd, &min_contrast);
+ GetMaxContrast(scanner_fd, &max_contrast);
+ contrast = (max_contrast - min_contrast) / 2 + min_contrast;
+ GetMaxXExtentDecipoints(scanner_fd, &scanner_width);
+ GetMaxYExtentDecipoints(scanner_fd, &scanner_height);
+
form =
XtVaCreateManagedWidget("form", formWidgetClass, shell,
(String)0);
@@ -144,14 +205,12 @@
previewb =
XtVaCreateManagedWidget("preview", commandWidgetClass, controlform,
- XtNlabel, "Preview",
(String)0);
XtAddCallback(previewb, XtNcallback, preview, (XtPointer)False);
zoomb =
XtVaCreateManagedWidget("zoom", commandWidgetClass, controlform,
XtNfromHoriz, previewb,
- XtNlabel, "Zoom",
XtNsensitive, False,
(String)0);
XtAddCallback(zoomb, XtNcallback, preview, (XtPointer)True);
@@ -159,7 +218,6 @@
scanb =
XtVaCreateManagedWidget("scan", commandWidgetClass, controlform,
XtNfromHoriz, zoomb,
- XtNlabel, "Scan",
XtNsensitive, False,
(String)0);
XtAddCallback(scanb, XtNcallback, scan, (XtPointer)0);
@@ -167,7 +225,6 @@
quitb =
XtVaCreateManagedWidget("quit", commandWidgetClass, controlform,
XtNfromHoriz, scanb,
- XtNlabel, "Quit",
(String)0);
XtAddCallback(quitb, XtNcallback, quit, (XtPointer)0);
@@ -176,7 +233,6 @@
controlform,
XtNfromVert, previewb,
XtNmenuName, "resolutionmenu",
- XtNlabel, "Resolution",
(String)0);
resolutionm =
XtVaCreatePopupShell("resolutionmenu", simpleMenuWidgetClass,
@@ -197,7 +253,7 @@
sprintf(buf, "%d dpi", final_resolution);
resolutionl =
- XtVaCreateManagedWidget("resolution", labelWidgetClass, controlform,
+ XtVaCreateManagedWidget("resolutionVal", labelWidgetClass, controlform,
XtNfromHoriz, resolutionb,
XtNfromVert, previewb,
XtNlabel, buf,
@@ -206,46 +262,103 @@
messagel =
XtVaCreateManagedWidget("message", labelWidgetClass, controlform,
XtNfromHoriz, resolutionl,
- XtNhorizDistance, 40,
XtNfromVert, previewb,
- /* Scan failed fits in the space */
- XtNlabel, " ",
+ /* Out of memory! fits in the space */
+ XtNlabel, " ",
(String)0);
filenamel =
XtVaCreateManagedWidget("filenamelabel", labelWidgetClass, controlform,
XtNfromVert, resolutionb,
- XtNlabel, "Filename:",
(String)0);
filenamet =
XtVaCreateManagedWidget("filename", asciiTextWidgetClass, controlform,
XtNfromHoriz, filenamel,
XtNfromVert, resolutionb,
- XtNwidth, canvas_width - 90, /* XXX */
XtNstring, "image.ppm",
XtNeditType, XawtextEdit,
(String)0);
- /* Create the preview area */
+ intensitylabel =
+ XtVaCreateManagedWidget("intensityLabel", labelWidgetClass,
+ controlform,
+ XtNfromVert, filenamel,
+ (String)0);
- GetMaxXExtentDecipoints(scanner_fd, &scanner_width);
- GetMaxYExtentDecipoints(scanner_fd, &scanner_height);
+ sprintf(buf, "%5d", intensity);
+ intensityval =
+ XtVaCreateManagedWidget("intensityVal", labelWidgetClass,
+ controlform,
+ XtNfromHoriz, intensitylabel,
+ XtNfromVert, filenamel,
+ XtNlabel, buf,
+ (String)0);
- canvas_height = canvas_width * ((double)scanner_height / scanner_width);
+ intensityscr =
+ XtVaCreateManagedWidget("intensityScrollbar", scrollbarWidgetClass,
+ controlform,
+ XtNfromHoriz, intensityval,
+ XtNfromVert, filenamel,
+ XtNorientation, XtorientHorizontal,
+ (String)0);
+
+ XtAddCallback(intensityscr, "jumpProc", movethumb, (XtPointer)&intensity);
+ XtAddCallback(intensityscr, "scrollProc", scrollthumb,
+ (XtPointer)&intensity);
+
+ contrastlabel =
+ XtVaCreateManagedWidget("contrastLabel", labelWidgetClass,
+ controlform,
+ XtNfromVert, intensitylabel,
+ (String)0);
+
+ sprintf(buf, "%5d", contrast);
+ contrastval =
+ XtVaCreateManagedWidget("contrastVal", labelWidgetClass,
+ controlform,
+ XtNfromHoriz, contrastlabel,
+ XtNfromVert, intensitylabel,
+ XtNlabel, buf,
+ (String)0);
+
+ contrastscr =
+ XtVaCreateManagedWidget("contrastScrollbar", scrollbarWidgetClass,
+ controlform,
+ XtNfromHoriz, contrastval,
+ XtNfromVert, intensitylabel,
+ XtNorientation, XtorientHorizontal,
+ (String)0);
+
+ XtAddCallback(contrastscr, "jumpProc", movethumb, (XtPointer)&contrast);
+ XtAddCallback(contrastscr, "scrollProc", scrollthumb,
+ (XtPointer)&contrast);
+
+ /* Create the preview area */
canvas =
XtVaCreateManagedWidget("canvas", plainWidgetClass, form,
- XtNwidth, canvas_width,
- XtNheight, canvas_height,
XtNfromVert, controlform,
+ XtNheight, 1,
(String)0);
+ XtVaGetValues(canvas,
+ XtNwidth, &canvas_width,
+ (String)0);
+ /*
+ * The width value is settable via a resource, the height value is
+ * derived from it according to the scanner's aspect ratio.
+ */
+ canvas_height = canvas_width * ((double)scanner_height / scanner_width);
+ XtVaSetValues(canvas,
+ XtNheight, canvas_height,
+ (String)0);
+
XtAddCallback(canvas, "exposeCallback", redraw, (XtPointer)0);
XtAddCallback(canvas, "inputCallback", input, (XtPointer)0);
XtVaGetValues(canvas, XtNvisual, &visual, (String)0);
XtRealizeWidget(shell);
-
+
/* Set up colour map etc */
colourmap_widgets[0] = canvas;
@@ -259,6 +372,25 @@
XSetForeground(display, image_gc, colour_match(0, 0, 0, 0, 0, 0));
XSetBackground(display, image_gc, colour_match(255, 255, 255, 0, 0, 0));
+ /* Make the `delete' window manager function happy. */
+ delwin = XInternAtom(display, "WM_DELETE_WINDOW", False);
+ XSetWMProtocols(display, XtWindow(shell), &delwin, 1);
+ XtAppAddActions(app, actions, 1);
+ XtOverrideTranslations(shell, XtParseTranslationTable(TransTableMessage));
+
+ /* Now finally, tell the WM about our icon wishes. */
+ if((wmhints = XAllocWMHints()) == NULL)
+ XtError("Out of memory.");
+ wmhints->flags = IconPixmapHint;
+ wmhints->icon_pixmap = XCreateBitmapFromData(display, XtWindow(shell),
+ hpscan_bits,
+ hpscan_width, hpscan_height);
+ XmbSetWMProperties(display, XtWindow(shell),
+ "HPscan", "HPscan",
+ argv, argc,
+ NULL, wmhints, NULL);
+ XFree(wmhints);
+
XtAppMainLoop(app);
}
@@ -420,7 +552,13 @@
prev_resolution = (canvas_width * 720) / prev_width;
raw = do_scan(prev_left, prev_top, prev_width, prev_height,
- prev_resolution, 5);
+ prev_resolution, intensity, contrast, 5);
+ if (raw == 0)
+ {
+ set_message("Out of memory!");
+ return;
+ }
+
prev_pixwidth = raw->width;
prev_pixheight = raw->height;
@@ -441,6 +579,8 @@
XtSetSensitive(zoomb, image != 0);
XtSetSensitive(scanb, image != 0);
+ free(raw->data);
+
redraw(canvas, 0, 0);
}
@@ -458,7 +598,7 @@
raw =
do_scan(box_left, box_top, box_right-box_left+1, box_bottom-box_top+1,
- final_resolution, 5);
+ final_resolution, intensity, contrast, 5);
/* Write it out as a ppm file (nice and easy!) */
@@ -474,9 +614,12 @@
fprintf(f, "P6\n%d %d\n255\n", raw->width, raw->height);
fwrite(raw->data, 1, raw->linebytes * raw->height, f);
+ free(raw->data);
fclose(f);
}
+ else
+ set_message("Out of memory!");
}
@@ -503,17 +646,82 @@
XtVaSetValues(resolutionl, XtNlabel, buf, (String)0);
}
+/*
+ * Move the thumb of a scrollbar, update the according value as we go.
+ */
+
+static void movethumb(Widget w, XtPointer client, XtPointer call)
+{
+ char buf[20];
+ float percent = *(float *)call;
+ int *val_p = (int *)client;
+
+ if (percent > 1.0)
+ percent = 1.0;
+ else if (percent < 0.0)
+ percent = 0.0;
+
+ if (val_p == &intensity) {
+ *val_p = (max_intensity - min_intensity) * percent + min_intensity;
+ sprintf(buf, "%5d", *val_p);
+ XtVaSetValues(intensityval,
+ XtNlabel, buf,
+ (String)0);
+ } else if (val_p = &contrast) {
+ *val_p = (max_contrast - min_contrast) * percent + min_contrast;
+ sprintf(buf, "%5d", *val_p);
+ XtVaSetValues(contrastval,
+ XtNlabel, buf,
+ (String)0);
+ } else
+ XtAppError(app, "unknown client in movethumb()");
+}
+
+/*
+ * Almost the same as above, but called by the scrollProc callback.
+ */
+
+static void scrollthumb(Widget w, XtPointer client, XtPointer call)
+{
+ char buf[20];
+ int position = (int)call;
+ int *val_p = (int *)client;
+ float shown, topofthumb;
+
+ XtVaGetValues(w,
+ XtNshown, &shown,
+ XtNtopOfThumb, &topofthumb,
+ (String)0);
+ topofthumb -= 0.0001 * (float)position;
+ if (topofthumb < 0.0) topofthumb = 0.0;
+ else if (topofthumb > 1.0) topofthumb = 1.0;
+ XawScrollbarSetThumb(w, topofthumb, shown);
+
+ if (val_p == &intensity) {
+ *val_p = (max_intensity - min_intensity) * topofthumb + min_intensity;
+ sprintf(buf, "%5d", *val_p);
+ XtVaSetValues(intensityval,
+ XtNlabel, buf,
+ (String)0);
+ } else if (val_p = &contrast) {
+ *val_p = (max_contrast - min_contrast) * topofthumb + min_contrast;
+ sprintf(buf, "%5d", *val_p);
+ XtVaSetValues(contrastval,
+ XtNlabel, buf,
+ (String)0);
+ } else
+ XtAppError(app, "unknown client in movethumb()");
+}
+
/*
* Perform a scan, returning an XImage (return struct is statically allocated).
*/
-static struct raw_image *do_scan(int l, int t, int w, int h, int res, int type)
+static struct raw_image *do_scan(int l, int t, int w, int h, int res,
+ int intensity, int contrast, int type)
{
static struct raw_image raw;
- if(raw.data)
- free(raw.data);
-
SetXPositionDecipoints(scanner_fd, l);
SetYPositionDecipoints(scanner_fd, t);
SetXExtentDecipoints(scanner_fd, w);
@@ -525,6 +733,9 @@
SetXResolution(scanner_fd, res);
SetYResolution(scanner_fd, res);
+ SetIntensity(scanner_fd, intensity);
+ SetContrast(scanner_fd, contrast);
+
GetPixelsPerLine(scanner_fd, &raw.width);
GetLinesPerScan(scanner_fd, &raw.height);
GetBytesPerLine(scanner_fd, &raw.linebytes);
@@ -758,6 +969,24 @@
(*((CoreClassPart *)labelWidgetClass)->expose)(messagel, 0, 0);
XFlush(display);
+}
+
+
+/*
+ * Window manager legacy.
+ */
+
+static void
+actionHook(Widget w, XtPointer cld, String name, XEvent *xev,
+ String *params, Cardinal *num_params)
+{
+}
+
+static void GlobalProtoHandler(Widget w, XEvent *xev, String *p, Cardinal *n)
+{
+ if (xev->xclient.data.l[0] == delwin) {
+ if (w == shell) exit(EXIT_SUCCESS); else XtPopdown(w);
+ }
}
/*
diff -u -N ../old/hpscan.icon ./hpscan.icon
--- ../old/hpscan.icon Thu Jan 1 01:00:00 1970
+++ ./hpscan.icon Thu Mar 7 23:22:09 1996
@@ -0,0 +1,21 @@
+#define hpscan_width 50
+#define hpscan_height 30
+static unsigned char hpscan_bits[] = {
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x64, 0x54, 0x55, 0x55, 0x55,
+ 0x55, 0x01, 0x6a, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0x00, 0x64, 0x55, 0x55,
+ 0x55, 0x55, 0x55, 0x01, 0x62, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa, 0x00, 0x34,
+ 0x55, 0x55, 0x55, 0x55, 0x55, 0x01, 0xb2, 0xaa, 0xaa, 0xaa, 0xaa, 0xaa,
+ 0x00, 0x30, 0x55, 0x55, 0x55, 0x55, 0x55, 0x01, 0x32, 0x20, 0x80, 0xaa,
+ 0xaa, 0xaa, 0x00, 0x18, 0x00, 0x00, 0x55, 0x55, 0x55, 0x01, 0xfa, 0x87,
+ 0x3f, 0xaa, 0xaa, 0xaa, 0x00, 0xf8, 0x8f, 0x7f, 0x54, 0x55, 0x55, 0x01,
+ 0x18, 0x8c, 0x61, 0xaa, 0xaa, 0xaa, 0x00, 0x0c, 0x86, 0x61, 0x54, 0x55,
+ 0x55, 0x01, 0x0c, 0xc6, 0x30, 0xaa, 0xaa, 0xaa, 0x00, 0x0c, 0xc6, 0x30,
+ 0x01, 0x00, 0x00, 0x00, 0x0c, 0xc6, 0x30, 0x00, 0x00, 0x00, 0x00, 0x06,
+ 0xc3, 0x30, 0xfc, 0xff, 0xff, 0x01, 0x06, 0x63, 0x18, 0xfe, 0xff, 0xff,
+ 0x01, 0x06, 0xe3, 0x1f, 0x07, 0x00, 0x00, 0x00, 0x06, 0xe3, 0x0f, 0x03,
+ 0x00, 0x00, 0x00, 0x00, 0x60, 0x40, 0x03, 0xef, 0xf9, 0x00, 0xaa, 0x32,
+ 0x2a, 0x9f, 0xef, 0xfb, 0x01, 0x54, 0x35, 0x55, 0xbe, 0x01, 0x9b, 0x01,
+ 0xaa, 0xb2, 0x2a, 0xb0, 0xe1, 0x9b, 0x01, 0x54, 0x31, 0x55, 0xb0, 0xe1,
+ 0x9b, 0x01, 0xaa, 0x9a, 0x2a, 0xb0, 0x61, 0x9b, 0x01, 0x54, 0x59, 0x95,
+ 0x9f, 0xef, 0x9b, 0x01, 0xaa, 0x9a, 0xaa, 0x1f, 0xef, 0x9b, 0x01, 0x00,
+ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00};