Blame SOURCES/Xaw3d-1.6.1-3Dlabel.patch

dd646b
diff -up libXaw3d-1.6.1/src/Label.c.3Dlabel libXaw3d-1.6.1/src/Label.c
dd646b
--- libXaw3d-1.6.1/src/Label.c.3Dlabel	2011-09-19 15:42:36.000000000 -0600
dd646b
+++ libXaw3d-1.6.1/src/Label.c	2012-02-25 14:44:33.766774776 -0700
dd646b
@@ -416,9 +416,16 @@ GetgrayGC(LabelWidget lw)
dd646b
 static void
dd646b
 compute_bitmap_offsets (LabelWidget lw)
dd646b
 {
dd646b
-    if (lw->label.lbm_height != 0)
dd646b
-	lw->label.lbm_y = (lw->core.height - lw->label.lbm_height) / 2;
dd646b
-    else
dd646b
+    /*
dd646b
+     * bitmap will be eventually be displayed at 
dd646b
+     * (internal_width, internal_height + lbm_y)
dd646b
+     */
dd646b
+    if (lw->label.lbm_height != 0) {
dd646b
+	lw->label.lbm_y = (lw->core.height -
dd646b
+			   (lw->threeD.shadow_width * 2 +
dd646b
+			    lw->label.internal_height * 2 +
dd646b
+			    lw->label.lbm_height)) / 2;
dd646b
+    } else
dd646b
 	lw->label.lbm_y = 0;
dd646b
 }
dd646b
 
dd646b
@@ -444,9 +451,11 @@ Initialize(Widget request, Widget new, A
dd646b
 {
dd646b
     LabelWidget lw = (LabelWidget) new;
dd646b
 
dd646b
+#if 0
dd646b
     /* disable shadows if we're not a subclass of Command */
dd646b
     if (!XtIsSubclass(new, commandWidgetClass))
dd646b
 	lw->threeD.shadow_width = 0;
dd646b
+#endif
dd646b
 
dd646b
     if (lw->label.label == NULL)
dd646b
         lw->label.label = XtNewString(lw->core.name);
dd646b
@@ -460,18 +469,20 @@ Initialize(Widget request, Widget new, A
dd646b
 
dd646b
     if (lw->core.height == 0)
dd646b
 	lw->core.height = lw->label.label_height +
dd646b
-				2 * lw->label.internal_height;
dd646b
+			  2 * lw->label.internal_height +
dd646b
+			  2 * lw->threeD.shadow_width;
dd646b
 
dd646b
     set_bitmap_info(lw);  /* req's core.height, sets label.lbm_* */
dd646b
 
dd646b
     if (lw->label.lbm_height > lw->label.label_height)
dd646b
 	lw->core.height = lw->label.lbm_height +
dd646b
-				2 * lw->label.internal_height;
dd646b
+			  2 * lw->label.internal_height;
dd646b
 
dd646b
     if (lw->core.width == 0)
dd646b
         lw->core.width = lw->label.label_width +
dd646b
-				2 * lw->label.internal_width +
dd646b
-				LEFT_OFFSET(lw);  /* req's label.lbm_width */
dd646b
+			 2 * lw->label.internal_width +
dd646b
+			 2 * lw->threeD.shadow_width +
dd646b
+			 LEFT_OFFSET(lw);	/* req's label.lbm_width */
dd646b
 
dd646b
     lw->label.label_x = lw->label.label_y = 0;
dd646b
     (*XtClass(new)->core_class.resize) ((Widget)lw);
dd646b
@@ -549,14 +560,16 @@ Redisplay(Widget gw, XEvent *event, Regi
dd646b
 	    if (w->label.depth == 1)
dd646b
 		XCopyPlane(XtDisplay(gw), pm, XtWindow(gw), gc, 0, 0,
dd646b
 			   w->label.lbm_width, w->label.lbm_height,
dd646b
-			   (int) w->label.internal_width,
dd646b
-			   (int) w->label.lbm_y,
dd646b
+			   (int) w->label.internal_width + w->threeD.shadow_width,
dd646b
+			   (int) w->label.internal_height + w->threeD.shadow_width
dd646b
+				 + w->label.lbm_y,
dd646b
 			   (unsigned long) 1L);
dd646b
 	    else
dd646b
 		XCopyArea(XtDisplay(gw), pm, XtWindow(gw), gc, 0, 0,
dd646b
 			  w->label.lbm_width, w->label.lbm_height,
dd646b
-			  (int) w->label.internal_width,
dd646b
-			  (int) w->label.lbm_y);
dd646b
+			  (int) w->label.internal_width + w->threeD.shadow_width,
dd646b
+			  (int) w->label.internal_height + w->threeD.shadow_width
dd646b
+				+ w->label.lbm_y);
dd646b
 	}
dd646b
 
dd646b
 #ifdef XAW_INTERNATIONALIZATION
dd646b
@@ -646,14 +659,17 @@ _Reposition(LabelWidget lw, Dimension wi
dd646b
             Position *dx, Position *dy)
dd646b
 {
dd646b
     Position newPos;
dd646b
-    Position leftedge = lw->label.internal_width + LEFT_OFFSET(lw);
dd646b
+    Position leftedge = lw->label.internal_width + LEFT_OFFSET(lw) +
dd646b
+			lw->threeD.shadow_width;
dd646b
+
dd646b
 
dd646b
     switch (lw->label.justify) {
dd646b
 	case XtJustifyLeft:
dd646b
 	    newPos = leftedge;
dd646b
 	    break;
dd646b
 	case XtJustifyRight:
dd646b
-	    newPos = width - lw->label.label_width - lw->label.internal_width;
dd646b
+	    newPos = width - (lw->label.label_width + lw->label.internal_width +
dd646b
+			      lw->threeD.shadow_width);
dd646b
 	    break;
dd646b
 	case XtJustifyCenter:
dd646b
 	default:
dd646b
@@ -745,17 +761,20 @@ SetValues(Widget current, Widget request
dd646b
     if (newlw->label.resize && was_resized) {
dd646b
 	if (curlw->core.height == reqlw->core.height && !checks[HEIGHT])
dd646b
 	    newlw->core.height = newlw->label.label_height +
dd646b
-				2 * newlw->label.internal_height;
dd646b
+				 2 * newlw->label.internal_height +
dd646b
+				 2 * newlw->threeD.shadow_width;
dd646b
 
dd646b
 	set_bitmap_info (newlw);  /* req's core.height, sets label.lbm_* */
dd646b
 
dd646b
 	if (newlw->label.lbm_height > newlw->label.label_height)
dd646b
 	    newlw->core.height = newlw->label.lbm_height +
dd646b
-					2 * newlw->label.internal_height;
dd646b
+				 2 * newlw->label.internal_height +
dd646b
+				 2 * newlw->threeD.shadow_width;
dd646b
 
dd646b
 	if (curlw->core.width == reqlw->core.width && !checks[WIDTH])
dd646b
 	    newlw->core.width = newlw->label.label_width +
dd646b
 				2 * newlw->label.internal_width +
dd646b
+				2 * newlw->threeD.shadow_width +
dd646b
 				LEFT_OFFSET(newlw);  /* req's label.lbm_width */
dd646b
     }
dd646b
 
dd646b
@@ -764,15 +783,20 @@ SetValues(Widget current, Widget request
dd646b
 	if (checks[HEIGHT]) {
dd646b
 	    if (newlw->label.label_height > newlw->label.lbm_height)
dd646b
 		i = newlw->label.label_height +
dd646b
-			2 * newlw->label.internal_height;
dd646b
+		    2 * newlw->label.internal_height +
dd646b
+		    2 * newlw->threeD.shadow_width;
dd646b
 	    else
dd646b
-		i = newlw->label.lbm_height + 2 * newlw->label.internal_height;
dd646b
+		i = newlw->label.lbm_height +
dd646b
+		    2 * newlw->label.internal_height +
dd646b
+		    2 * newlw->threeD.shadow_width;
dd646b
 	    if (i > newlw->core.height)
dd646b
 		newlw->core.height = i;
dd646b
 	}
dd646b
 	if (checks[WIDTH]) {
dd646b
-	    i = newlw->label.label_width + 2 * newlw->label.internal_width +
dd646b
-			LEFT_OFFSET(newlw);  /* req's label.lbm_width */
dd646b
+	    i = newlw->label.label_width +
dd646b
+		2 * newlw->label.internal_width +
dd646b
+		2 * newlw->threeD.shadow_width +
dd646b
+		LEFT_OFFSET(newlw);		    /* req's label.lbm_width */
dd646b
 	    if (i > newlw->core.width)
dd646b
 		newlw->core.width = i;
dd646b
 	}
dd646b
@@ -843,9 +867,11 @@ QueryGeometry(Widget w, XtWidgetGeometry
dd646b
     preferred->request_mode = CWWidth | CWHeight;
dd646b
     preferred->width = (lw->label.label_width +
dd646b
 			    2 * lw->label.internal_width +
dd646b
+			    2 * lw->threeD.shadow_width +
dd646b
 			    LEFT_OFFSET(lw));
dd646b
     preferred->height = lw->label.label_height +
dd646b
-			    2 * lw->label.internal_height;
dd646b
+			    2 * lw->label.internal_height +
dd646b
+			    2 * lw->threeD.shadow_width;
dd646b
     if (  ((intended->request_mode & (CWWidth | CWHeight))
dd646b
 	   	== (CWWidth | CWHeight)) &&
dd646b
 	  intended->width == preferred->width &&