More fixes to viewer repainting - Federico
Этот коммит содержится в:
родитель
7f8b2fde99
Коммит
a65ce95420
@ -1,3 +1,11 @@
|
|||||||
|
1998-03-11 Federico Mena Quintero <federico@nuclecu.unam.mx>
|
||||||
|
|
||||||
|
* gmc-chargrid.c (update_strip): Doh. Fixed painting of
|
||||||
|
background rectangles.
|
||||||
|
(gmc_char_grid_expose): Fixed off-by-one errors in area
|
||||||
|
calculation. Ripped off the code from gtkterm to do this :-)
|
||||||
|
(free_attrs): New internal convenience function.
|
||||||
|
|
||||||
Thu Mar 12 00:08:06 1998 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
Thu Mar 12 00:08:06 1998 Miguel de Icaza <miguel@nuclecu.unam.mx>
|
||||||
|
|
||||||
* gview.c (view_percent): Added status display.
|
* gview.c (view_percent): Added status display.
|
||||||
|
@ -143,6 +143,28 @@ gmc_char_grid_new (void)
|
|||||||
return GTK_WIDGET (cgrid);
|
return GTK_WIDGET (cgrid);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
free_attrs (GmcCharGrid *cgrid)
|
||||||
|
{
|
||||||
|
int i;
|
||||||
|
struct attr *attrs;
|
||||||
|
|
||||||
|
attrs = ATTRS (cgrid);
|
||||||
|
|
||||||
|
if (!cgrid->attrs)
|
||||||
|
return;
|
||||||
|
|
||||||
|
for (i = 0; i < (cgrid->width * cgrid->height); i++) {
|
||||||
|
if (attrs[i].fg)
|
||||||
|
g_free (attrs[i].fg);
|
||||||
|
|
||||||
|
if (attrs[i].bg)
|
||||||
|
g_free (attrs[i].bg);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_free (attrs);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gmc_char_grid_destroy (GtkObject *object)
|
gmc_char_grid_destroy (GtkObject *object)
|
||||||
{
|
{
|
||||||
@ -156,8 +178,7 @@ gmc_char_grid_destroy (GtkObject *object)
|
|||||||
if (cgrid->chars)
|
if (cgrid->chars)
|
||||||
g_free (cgrid->chars);
|
g_free (cgrid->chars);
|
||||||
|
|
||||||
if (cgrid->attrs)
|
free_attrs (cgrid);
|
||||||
g_free (cgrid->attrs);
|
|
||||||
|
|
||||||
if (cgrid->font)
|
if (cgrid->font)
|
||||||
gdk_font_unref (cgrid->font);
|
gdk_font_unref (cgrid->font);
|
||||||
@ -285,7 +306,7 @@ update_strip (GmcCharGrid *cgrid, int x, int y, int width)
|
|||||||
TRUE,
|
TRUE,
|
||||||
(first + x) * cgrid->char_width,
|
(first + x) * cgrid->char_width,
|
||||||
y * cgrid->char_height,
|
y * cgrid->char_height,
|
||||||
cgrid->char_width,
|
cgrid->char_width * (i - first),
|
||||||
cgrid->char_height);
|
cgrid->char_height);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -331,7 +352,9 @@ static gint
|
|||||||
gmc_char_grid_expose (GtkWidget *widget, GdkEventExpose *event)
|
gmc_char_grid_expose (GtkWidget *widget, GdkEventExpose *event)
|
||||||
{
|
{
|
||||||
GmcCharGrid *cgrid;
|
GmcCharGrid *cgrid;
|
||||||
|
GdkRectangle *area;
|
||||||
int x1, y1, x2, y2;
|
int x1, y1, x2, y2;
|
||||||
|
gint w, h;
|
||||||
|
|
||||||
g_return_val_if_fail (widget != NULL, FALSE);
|
g_return_val_if_fail (widget != NULL, FALSE);
|
||||||
g_return_val_if_fail (GMC_IS_CHAR_GRID (widget), FALSE);
|
g_return_val_if_fail (GMC_IS_CHAR_GRID (widget), FALSE);
|
||||||
@ -340,13 +363,27 @@ gmc_char_grid_expose (GtkWidget *widget, GdkEventExpose *event)
|
|||||||
if (GTK_WIDGET_DRAWABLE (widget)) {
|
if (GTK_WIDGET_DRAWABLE (widget)) {
|
||||||
cgrid = GMC_CHAR_GRID (widget);
|
cgrid = GMC_CHAR_GRID (widget);
|
||||||
|
|
||||||
x1 = event->area.x / cgrid->char_width;
|
area = &event->area;
|
||||||
y1 = event->area.y / cgrid->char_height;
|
|
||||||
|
|
||||||
x2 = (event->area.x + event->area.width) / cgrid->char_width;
|
/* This logic is shamelessly ripped from gtkterm :-) - Federico */
|
||||||
y2 = (event->area.y + event->area.height) / cgrid->char_height;
|
|
||||||
|
|
||||||
update_region (cgrid, x1, y1, (x2 - x1) + 1, (y2 - y1));
|
if (area->width > 1)
|
||||||
|
area->width--;
|
||||||
|
else if (area->x > 0)
|
||||||
|
area->x--;
|
||||||
|
|
||||||
|
if (area->height > 1)
|
||||||
|
area->height--;
|
||||||
|
else if (area->y > 0)
|
||||||
|
area->y--;
|
||||||
|
|
||||||
|
x1 = area->x / cgrid->char_width;
|
||||||
|
y1 = area->y / cgrid->char_height;
|
||||||
|
|
||||||
|
x2 = (area->x + area->width) / cgrid->char_width;
|
||||||
|
y2 = (area->y + area->height) / cgrid->char_height;
|
||||||
|
|
||||||
|
update_region (cgrid, x1, y1, (x2 - x1) + 1, (y2 - y1) + 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
return FALSE;
|
return FALSE;
|
||||||
@ -401,7 +438,6 @@ gmc_char_grid_put_char (GmcCharGrid *cgrid, int x, int y, GdkColor *fg, GdkColor
|
|||||||
{
|
{
|
||||||
char *chars;
|
char *chars;
|
||||||
struct attr *attrs;
|
struct attr *attrs;
|
||||||
int idx;
|
|
||||||
|
|
||||||
g_return_if_fail (cgrid != NULL);
|
g_return_if_fail (cgrid != NULL);
|
||||||
g_return_if_fail (GMC_IS_CHAR_GRID (cgrid));
|
g_return_if_fail (GMC_IS_CHAR_GRID (cgrid));
|
||||||
@ -410,10 +446,8 @@ gmc_char_grid_put_char (GmcCharGrid *cgrid, int x, int y, GdkColor *fg, GdkColor
|
|||||||
|| (y < 0) || (y >= cgrid->height))
|
|| (y < 0) || (y >= cgrid->height))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
idx = y * cgrid->width + x;
|
chars = CHARS (cgrid) + (y * cgrid->width + x);
|
||||||
|
attrs = ATTRS (cgrid) + (y * cgrid->width + x);
|
||||||
chars = CHARS (cgrid) + idx;
|
|
||||||
attrs = ATTRS (cgrid) + idx;
|
|
||||||
|
|
||||||
*chars = ch;
|
*chars = ch;
|
||||||
|
|
||||||
@ -458,7 +492,7 @@ gmc_char_grid_put_text (GmcCharGrid *cgrid, int x, int y, GdkColor *fg, GdkColor
|
|||||||
{
|
{
|
||||||
char *chars;
|
char *chars;
|
||||||
struct attr *attrs;
|
struct attr *attrs;
|
||||||
int i, pos, idx;
|
int i, pos;
|
||||||
|
|
||||||
g_return_if_fail (cgrid != NULL);
|
g_return_if_fail (cgrid != NULL);
|
||||||
g_return_if_fail (GMC_IS_CHAR_GRID (cgrid));
|
g_return_if_fail (GMC_IS_CHAR_GRID (cgrid));
|
||||||
@ -590,14 +624,13 @@ gmc_char_grid_real_size_changed (GmcCharGrid *cgrid, guint width, guint height)
|
|||||||
if ((width == cgrid->width) && (height == cgrid->height))
|
if ((width == cgrid->width) && (height == cgrid->height))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
cgrid->width = width;
|
|
||||||
cgrid->height = height;
|
|
||||||
|
|
||||||
if (cgrid->chars)
|
if (cgrid->chars)
|
||||||
g_free (cgrid->chars);
|
g_free (cgrid->chars);
|
||||||
|
|
||||||
if (cgrid->attrs)
|
free_attrs (cgrid);
|
||||||
g_free (cgrid->attrs);
|
|
||||||
|
cgrid->width = width;
|
||||||
|
cgrid->height = height;
|
||||||
|
|
||||||
chars = g_new (char, width * height);
|
chars = g_new (char, width * height);
|
||||||
cgrid->chars = chars;
|
cgrid->chars = chars;
|
||||||
|
Загрузка…
Ссылка в новой задаче
Block a user