From a731e612b6b58ef8fbbee02457150aaf3a570563 Mon Sep 17 00:00:00 2001 From: Matthew Allum Date: Fri, 25 Mar 2005 17:22:10 +0000 Subject: [PATCH] See ChangeLog --- ChangeLog | 11 ++++++ cltr-photo-grid.c | 95 ++++++++++++++++++++++------------------------- cltr-photo-grid.h | 2 +- cltr.c | 81 ++++++++++++++++++++++------------------ 4 files changed, 101 insertions(+), 88 deletions(-) diff --git a/ChangeLog b/ChangeLog index fe54fc6da..61f757241 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,14 @@ +2005-03-25 mallum,,, + + * cltr-photo-grid.c: (cltr_photo_grid_cell_new), + (ctrl_photo_grid_get_zoomed_coords), (cltr_photo_grid_redraw), + (cltr_photo_grid_new): + * cltr-photo-grid.h: + * cltr.c: (cltr_window_new), (idle_cb), (main): + Use GL matrices in a saner way. + Add random rotation to picts + Random minor tweaks + 2005-03-24 mallum,,, * Makefile: diff --git a/cltr-photo-grid.c b/cltr-photo-grid.c index 5e3998e42..7d176d248 100644 --- a/cltr-photo-grid.c +++ b/cltr-photo-grid.c @@ -37,6 +37,8 @@ cltr_photo_grid_cell_new(ClutterPhotoGrid *grid, CLTR_DBG ("loaded %s at %ix%i", filename, neww, newh); + cell->angle = 6.0 - (rand()%12); + return cell; } @@ -69,48 +71,16 @@ static void ctrl_photo_grid_get_zoomed_coords(ClutterPhotoGrid *grid, int x, int y, - float zoom, float *tx, float *ty) { - int max_x = grid->n_cols-1; - - /* XXX figure out what magic 2.0 value comes from */ - - /* - *tx = (float)( (max_x-x) - 1.0 ) * 2.0; - *ty = (float)( y - 1.0 ) * 2.0; - */ - /* - 3x3 0,0 -> 2,-2 - - 5x5 0,0 -> - *tx = 4.0; - *ty = -4.0; - - 4x4 0,0 -> 3.0, -3.0 + * figure out translate co-ords for the cell at x,y to get translated + * so its centered for glScale to zoom in on it. */ - /* - float trange = ((float)(grid->n_cols - 1.0) * 2.0); - float xrange = (float)grid->n_cols - 1.0; - */ - - /* - *tx = ((max_x-x) * (trange/xrange)) - (trange/2); - *ty = (y * (trange/xrange)) - (trange/2); - */ - - /* assumes rows = cols */ - - *tx = ((max_x-x) * 2.0) - (grid->n_cols - 1.0); - *ty = (y * 2.0) - (grid->n_cols - 1.0); - - /* - *tx = ((max_x-x) * (grid->zoom_max/2.0)) - (grid->n_cols - 1.0); - *ty = (y * (grid->zoom_max/2.0)) - (grid->n_cols - 1.0); - */ + *tx = (float)grid->cell_width * (grid->zoom_max) * x * -1.0; + *ty = (float)grid->cell_height * (grid->zoom_max) * y * -1.0; } void @@ -155,7 +125,7 @@ cltr_photo_grid_navigate(ClutterPhotoGrid *grid, ctrl_photo_grid_cell_to_coords(grid, grid->cell_active, &x, &y); - ctrl_photo_grid_get_zoomed_coords(grid, x, y, zoom, + ctrl_photo_grid_get_zoomed_coords(grid, x, y, &grid->view_max_x, &grid->view_max_y); @@ -292,6 +262,12 @@ cltr_photo_grid_redraw(ClutterPhotoGrid *grid) glDisable(GL_LIGHTING); glDisable(GL_DEPTH_TEST); + glEnable(GL_BLEND); + + glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); + + glEnable(GL_POLYGON_SMOOTH); + /* Assume zoomed out */ zoom = grid->zoom_min; trans_x = grid->view_min_x; @@ -402,10 +378,15 @@ cltr_photo_grid_redraw(ClutterPhotoGrid *grid) thumb_w -= (2 * ew_border); thumb_h -= (2 * ns_border); + /* x1 = x + ew_border; y1 = y + ns_border; + */ - x2 = x1 + thumb_w; + x1 = x + ((grid->cell_width - thumb_w)/2); + y1 = y + ((grid->cell_height - thumb_h)/2); + + x2 = x1 + thumb_w; y2 = y1 + thumb_h; tx = (float) pixb->width / grid->tex_w; @@ -413,18 +394,27 @@ cltr_photo_grid_redraw(ClutterPhotoGrid *grid) glPushMatrix(); -#if 0 - glRotatef ( 45.0, x1+(thumb_w/2) - 320, 0.0 /*y2+(thumb_h/2) - 240*/, 0.0); -#endif + /* Translate origin to rotation point ( photo center ) */ + glTranslatef( x1 + ((x2-x1)/2), y1 + ((y2-y1)/2), 0.0); + + /* Rotate around Z axis */ + glRotatef ( cell->angle, 0.0, 0.0, 1.0); + /* Border - why need tex disabled ? */ glDisable(GL_TEXTURE_2D); if (cell_item == grid->cell_active && grid->state == CLTR_PHOTO_GRID_STATE_BROWSE) glColor4f(1.0, 1.0, 1.0, 1.0); else - glColor4f(0.8, 0.8, 0.8, 1.0); - glRecti(x1-2, y1-2, x2+2, y2+2); + glColor4f(0.9, 0.95, 0.95, 1.0); + + /* Draw with origin in center of photo */ + + glRecti(-(thumb_w/2)-4, -(thumb_h/2)-4, + (thumb_w/2)+4, (thumb_h/2)+ns_border); + glEnable(GL_TEXTURE_2D); + glEnable(GL_SMOOTH); glBindTexture(GL_TEXTURE_2D, grid->texs[i]); @@ -443,13 +433,14 @@ cltr_photo_grid_redraw(ClutterPhotoGrid *grid) */ { glBegin (GL_QUADS); - glTexCoord2f (tx, ty); glVertex2i (x2, y2); - glTexCoord2f (0, ty); glVertex2i (x1, y2); - glTexCoord2f (0, 0); glVertex2i (x1, y1); - glTexCoord2f (tx, 0); glVertex2i (x2, y1); + glTexCoord2f (tx, ty); glVertex2i ((thumb_w/2), (thumb_h/2)); + glTexCoord2f (0, ty); glVertex2i (-(thumb_w/2), (thumb_h/2)); + glTexCoord2f (0, 0); glVertex2i (-(thumb_w/2), -(thumb_h/2)); + glTexCoord2f (tx, 0); glVertex2i ((thumb_w/2), -(thumb_h/2)); glEnd (); } + /* back to regular non translated matrix */ glPopMatrix(); cell_item = g_list_next(cell_item); @@ -489,7 +480,6 @@ cltr_photo_grid_new(ClutterWindow *win, const gchar *imgs_path) { ClutterPhotoGrid *grid = NULL; - int x,y; grid = util_malloc0(sizeof(ClutterPhotoGrid)); @@ -511,13 +501,13 @@ cltr_photo_grid_new(ClutterWindow *win, grid->zoom_step = 0.05; grid->zoom = 1.0; */ - grid->zoom_min = 0.8; + grid->zoom_min = 1.0; grid->view_min_x = 0.0; grid->view_min_y = 0.0; /* Assmes cols == rows */ - grid->zoom_max = /* 1.0 + */ (float) (n_rows * 1.0); + grid->zoom_max = /* 1.0 + */ (float) (n_rows * 1.0) - 0.3; /* Below needs to go else where - some kind of texture manager/helper */ @@ -531,12 +521,15 @@ cltr_photo_grid_new(ClutterWindow *win, grid->cell_active = g_list_first(grid->cells_tail); + /* ctrl_photo_grid_cell_to_coords(grid, grid->cell_active, &x, &y); - ctrl_photo_grid_get_zoomed_coords(grid, grid->zoom_min, + + ctrl_photo_grid_get_zoomed_coords(grid, grid->zoom_max, x, y, &grid->view_max_x, &grid->view_max_y); + */ cltr_photo_grid_redraw(grid); return grid; diff --git a/cltr-photo-grid.h b/cltr-photo-grid.h index a2fc892c4..38ca3200a 100644 --- a/cltr-photo-grid.h +++ b/cltr-photo-grid.h @@ -20,7 +20,7 @@ ClutterPhotoGridState; struct ClutterPhotoGridCell { Pixbuf *pixb; - + float angle; }; struct ClutterPhotoGrid diff --git a/cltr.c b/cltr.c index 0b72b1e7d..4dcf0643d 100644 --- a/cltr.c +++ b/cltr.c @@ -213,29 +213,15 @@ cltr_window_new(int width, int height) glXMakeCurrent(CltrCntx.xdpy, win->xwin, CltrCntx.gl_context); + /* All likely better somewhere else */ + + /* view port */ glViewport (0, 0, width, height); + glMatrixMode (GL_PROJECTION); + glLoadIdentity (); + glOrtho (0, width, height, 0, -1, 1); /* 2d */ glMatrixMode (GL_MODELVIEW); glLoadIdentity (); - glClearColor (0xff, 0xff, 0xff, 0xff); - glClearDepth (1.0f); - - /* Move to redraw ? - glDisable (GL_DEPTH_TEST); - glDepthMask (GL_FALSE); - glDisable (GL_CULL_FACE); - glShadeModel (GL_FLAT); - glHint (GL_PERSPECTIVE_CORRECTION_HINT, GL_FASTEST); - - glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); - glEnable(GL_BLEND); - */ - - glLoadIdentity (); - glOrtho (0, width, height, 0, -1, 1); - - glMatrixMode (GL_PROJECTION); - - /* likely better somewhere elese */ glEnable (GL_TEXTURE_2D); glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_MAG_FILTER, GL_NEAREST); @@ -258,6 +244,41 @@ cltr_main_loop() } +gboolean +test_idle_cb(gpointer data) +{ + static float angle = 0.0; + + glClear(GL_COLOR_BUFFER_BIT); + glClearColor( 0.6, 0.6, 0.62, 1.0); + + glColor3f(0.0, 0.0, 0.0); + + glTranslatef( 0.0, 0.0, 0.0); + + /* get a copy of our untranformed matrix */ + glPushMatrix(); + + /* Translate origin to rotation point */ + glTranslatef( 320.0, 240.0, 0.0); + + /* Rotate around Z axis */ + glRotatef ( angle, 0.0, 0.0, 1.0); + + /* Draw tranformed rect with origin at center */ + glRecti(-50, -50, 50, 50); + + /* Reset our un transformed matrix */ + glPopMatrix(); + + glRecti(-50, -50, 50, 50); + + angle += 0.1; + + glXSwapBuffers(CltrCntx.xdpy, (Window)data); + + return TRUE; +} gboolean @@ -265,10 +286,6 @@ idle_cb(gpointer data) { ClutterPhotoGrid *grid = (ClutterPhotoGrid *)data; - /* - if (grid->state != CLTR_PHOTO_GRID_STATE_BROWSE - && grid->state != CLTR_PHOTO_GRID_STATE_ZOOMED) - */ cltr_photo_grid_redraw(grid); return TRUE; @@ -291,7 +308,7 @@ main(int argc, char **argv) win = cltr_window_new(640, 480); - grid = cltr_photo_grid_new(win, 3, 3, argv[1]); + grid = cltr_photo_grid_new(win, 4, 4, argv[1]); Grid = grid; /* laaaaaazy globals */ @@ -299,23 +316,15 @@ main(int argc, char **argv) g_idle_add(idle_cb, grid); + // g_idle_add(test_idle_cb, (gpointer)win->xwin); + XFlush(CltrCntx.xdpy); - XMapWindow(CltrCntx.xdpy, grid->parent->xwin); + XMapWindow(CltrCntx.xdpy, win->xwin); XFlush(CltrCntx.xdpy); cltr_main_loop(); - /* - { - for (;;) - { - cltr_photo_grid_redraw(grid); - XFlush(CltrCntx.xdpy); - } - } - */ - return 0; }