Blob Blame History Raw
--- control-center-2.15.92/libkbdraw/keyboard-drawing.c.primary	2006-08-24 22:04:09.000000000 -0400
+++ control-center-2.15.92/libkbdraw/keyboard-drawing.c	2006-08-24 22:07:38.000000000 -0400
@@ -719,9 +719,22 @@
   printf ("outlines: %p(%d)\n", shape->outlines, shape->num_outlines);
 #endif
 
-  for (i = 0; i < 1 /* shape->num_outlines */ ; i++)
-    draw_outline (drawing, shape->outlines + i, color, key->angle,
-                  key->origin_x, key->origin_y);
+  /* draw the primary outline */
+  draw_outline (drawing, shape->primary ? shape->primary : shape->outlines, 
+		color, key->angle, key->origin_x, key->origin_y);
+#if 0
+  /* don't draw other outlines for now, since
+   * the text placement does not take them into account 
+   */
+  for (i = 0; i < shape->num_outlines; i++)
+    {
+      if (shape->outlines + i == shape->approx ||
+	  shape->outlines + i == shape->primary)
+	continue;
+      draw_outline (drawing, shape->outlines + i, NULL, 
+		    key->angle, key->origin_x, key->origin_y);
+    }
+#endif
 
   draw_key_label (drawing, key->keycode, key->angle, key->origin_x,
                   key->origin_y, shape->bounds.x2, shape->bounds.y2);
@@ -850,10 +863,22 @@
   shape = drawing->xkb->geom->shapes + shape_doodad->shape_ndx;
   color = drawing->colors + shape_doodad->color_ndx;
 
+  /* draw the primary outline filled */
+  draw_outline (drawing, shape->primary ? shape->primary : shape->outlines, 
+		color, doodad->angle,
+		doodad->origin_x + shape_doodad->left,
+		doodad->origin_y + shape_doodad->top);
+
+  /* stroke the other outlines */
   for (i = 0; i < shape->num_outlines; i++)
-    draw_outline (drawing, shape->outlines + i, color, doodad->angle,
-                  doodad->origin_x + shape_doodad->left,
-                  doodad->origin_y + shape_doodad->top);
+    {
+      if (shape->outlines + i == shape->approx ||
+	  shape->outlines + i == shape->primary) 
+	continue;
+      draw_outline (drawing, shape->outlines + i, NULL, doodad->angle,
+		    doodad->origin_x + shape_doodad->left,
+		    doodad->origin_y + shape_doodad->top);
+    }
 }
 
 static void