ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/deliantra/Deliantra-Client/Client.xs
(Generate patch)

Comparing deliantra/Deliantra-Client/Client.xs (file contents):
Revision 1.71 by root, Fri May 5 19:05:47 2006 UTC vs.
Revision 1.85 by root, Fri May 19 03:49:47 2006 UTC

1#ifdef _WIN32 1#ifdef _WIN32
2# define _WIN32_WINNT 0x0500 // needed to get win2000 api calls
2# include <malloc.h> 3# include <malloc.h>
4# include <windows.h>
5# pragma warning(disable:4244)
3#endif 6#endif
4 7
5#include "EXTERN.h" 8#include "EXTERN.h"
6#include "perl.h" 9#include "perl.h"
7#include "XSUB.h" 10#include "XSUB.h"
8 11
12#include <math.h>
9#include <string.h> 13#include <string.h>
10#include <stdio.h> 14#include <stdio.h>
11 15
12#include <SDL.h> 16#include <SDL.h>
17#include <SDL_endian.h>
13#include <SDL_image.h> 18#include <SDL_image.h>
14#include <SDL_mixer.h> 19#include <SDL_mixer.h>
15#include <SDL_opengl.h> 20#include <SDL_opengl.h>
16 21
17#include <glib/gmacros.h> 22#include <glib/gmacros.h>
18 23
19#include <pango/pango.h> 24#include <pango/pango.h>
20#include <pango/pangofc-fontmap.h> 25#include <pango/pangofc-fontmap.h>
21#include <pango/pangoft2.h> 26#include <pango/pangoft2.h>
27#include <pango/pangocairo.h>
22 28
23#ifndef _WIN32 29#ifndef _WIN32
24# include <sys/types.h> 30# include <sys/types.h>
25# include <sys/socket.h> 31# include <sys/socket.h>
26# include <netinet/in.h> 32# include <netinet/in.h>
63typedef Mix_Music *CFClient__MixMusic; 69typedef Mix_Music *CFClient__MixMusic;
64 70
65typedef PangoFontDescription *CFClient__Font; 71typedef PangoFontDescription *CFClient__Font;
66 72
67typedef struct cf_layout { 73typedef struct cf_layout {
68 PangoLayout *pl; 74 PangoLayout *pl; // either derived from a cairo or ft2 context
75 int rgba; // wether we use rgba (cairo) or grayscale (ft2)
76 float r, g, b, a; // default color for rgba mode
69 int base_height; 77 int base_height;
70 CFClient__Font font; 78 CFClient__Font font;
71} *CFClient__Layout; 79} *CFClient__Layout;
72 80
73static CFClient__Font default_font; 81static CFClient__Font default_font;
74static PangoContext *context; 82static PangoContext *ft2_context, *cairo_context;
75static PangoFontMap *fontmap; 83static PangoFontMap *ft2_fontmap, *cairo_fontmap;
76 84
77static void 85static void
78substitute_func (FcPattern *pattern, gpointer data) 86substitute_func (FcPattern *pattern, gpointer data)
79{ 87{
80 FcPatternAddBool (pattern, FC_HINTING , 1); 88 FcPatternAddBool (pattern, FC_HINTING , 1);
89#ifdef _WIN32
90 FcPatternAddBool (pattern, FC_AUTOHINT, 1);
91#else
81 FcPatternAddBool (pattern, FC_AUTOHINT, 0); 92 FcPatternAddBool (pattern, FC_AUTOHINT, 0);
93#endif
82} 94}
83 95
84static void 96static void
85layout_update_font (CFClient__Layout self) 97layout_update_font (CFClient__Layout self)
86{ 98{
98static void 110static void
99layout_get_pixel_size (CFClient__Layout self, int *w, int *h) 111layout_get_pixel_size (CFClient__Layout self, int *w, int *h)
100{ 112{
101 pango_layout_get_pixel_size (self->pl, w, h); 113 pango_layout_get_pixel_size (self->pl, w, h);
102 114
103 *w = (*w + 3) & ~3;
104 if (!*w) *w = 1; 115 if (!*w) *w = 1;
105 if (!*h) *h = 1; 116 if (!*h) *h = 1;
117
118 *w = (*w + 3) & ~3;
106} 119}
107 120
108typedef uint16_t mapface; 121typedef uint16_t mapface;
109 122
110typedef struct { 123typedef struct {
258 } 271 }
259 } 272 }
260} 273}
261 274
262static void 275static void
263music_finished () 276music_finished (void)
264{ 277{
265 SDL_UserEvent ev; 278 SDL_UserEvent ev;
266 279
267 ev.type = SDL_USEREVENT; 280 ev.type = SDL_USEREVENT;
268 ev.code = 0; 281 ev.code = 0;
277{ 290{
278 SDL_UserEvent ev; 291 SDL_UserEvent ev;
279 292
280 ev.type = SDL_USEREVENT; 293 ev.type = SDL_USEREVENT;
281 ev.code = 1; 294 ev.code = 1;
282 ev.data1 = channel; 295 ev.data1 = (void *)(long)channel;
283 ev.data2 = 0; 296 ev.data2 = 0;
284 297
285 SDL_PushEvent ((SDL_Event *)&ev); 298 SDL_PushEvent ((SDL_Event *)&ev);
286} 299}
287 300
398# undef const_iv 411# undef const_iv
399 }; 412 };
400 413
401 for (civ = const_iv + sizeof (const_iv) / sizeof (const_iv [0]); civ-- > const_iv; ) 414 for (civ = const_iv + sizeof (const_iv) / sizeof (const_iv [0]); civ-- > const_iv; )
402 newCONSTSUB (stash, (char *)civ->name, newSViv (civ->iv)); 415 newCONSTSUB (stash, (char *)civ->name, newSViv (civ->iv));
416}
403 417
418void
419pango_init ()
420 CODE:
421{
422 // delayed, so it can pick up new fonts added by AddFontResourceEx
404 fontmap = pango_ft2_font_map_new (); 423 ft2_fontmap = pango_ft2_font_map_new ();
405 pango_ft2_font_map_set_default_substitute ((PangoFT2FontMap *)fontmap, substitute_func, 0, 0); 424 pango_ft2_font_map_set_default_substitute ((PangoFT2FontMap *)ft2_fontmap, substitute_func, 0, 0);
406 context = pango_ft2_font_map_create_context ((PangoFT2FontMap *)fontmap); 425 ft2_context = pango_ft2_font_map_create_context ((PangoFT2FontMap *)ft2_fontmap);
426
427 cairo_fontmap = pango_cairo_font_map_get_default ();
428 cairo_context = pango_cairo_font_map_create_context ((PangoCairoFontMap *)cairo_fontmap);
407} 429}
408 430
409int 431int
410SDL_Init (U32 flags = SDL_INIT_VIDEO | SDL_INIT_AUDIO) 432SDL_Init (U32 flags = SDL_INIT_VIDEO | SDL_INIT_AUDIO)
411 433
421 SDL_GL_SetAttribute (SDL_GL_RED_SIZE, 5); 443 SDL_GL_SetAttribute (SDL_GL_RED_SIZE, 5);
422 SDL_GL_SetAttribute (SDL_GL_GREEN_SIZE, 5); 444 SDL_GL_SetAttribute (SDL_GL_GREEN_SIZE, 5);
423 SDL_GL_SetAttribute (SDL_GL_BLUE_SIZE, 5); 445 SDL_GL_SetAttribute (SDL_GL_BLUE_SIZE, 5);
424 SDL_GL_SetAttribute (SDL_GL_ALPHA_SIZE, 1); 446 SDL_GL_SetAttribute (SDL_GL_ALPHA_SIZE, 1);
425 447
448 SDL_GL_SetAttribute (SDL_GL_BUFFER_SIZE, 15);
449 SDL_GL_SetAttribute (SDL_GL_DEPTH_SIZE, 0);
450
426 SDL_GL_SetAttribute (SDL_GL_ACCUM_RED_SIZE, 0); 451 SDL_GL_SetAttribute (SDL_GL_ACCUM_RED_SIZE, 0);
427 SDL_GL_SetAttribute (SDL_GL_ACCUM_GREEN_SIZE, 0); 452 SDL_GL_SetAttribute (SDL_GL_ACCUM_GREEN_SIZE, 0);
428 SDL_GL_SetAttribute (SDL_GL_ACCUM_BLUE_SIZE, 0); 453 SDL_GL_SetAttribute (SDL_GL_ACCUM_BLUE_SIZE, 0);
429 SDL_GL_SetAttribute (SDL_GL_ACCUM_ALPHA_SIZE, 0); 454 SDL_GL_SetAttribute (SDL_GL_ACCUM_ALPHA_SIZE, 0);
430 455
431 SDL_GL_SetAttribute (SDL_GL_DOUBLEBUFFER, 1); 456 SDL_GL_SetAttribute (SDL_GL_DOUBLEBUFFER, 1);
432 SDL_GL_SetAttribute (SDL_GL_BUFFER_SIZE, 15);
433 SDL_GL_SetAttribute (SDL_GL_DEPTH_SIZE, 0);
434 457
435 SDL_EnableUNICODE (1); 458 SDL_EnableUNICODE (1);
436 SDL_EnableKeyRepeat (SDL_DEFAULT_REPEAT_DELAY, SDL_DEFAULT_REPEAT_INTERVAL); 459 SDL_EnableKeyRepeat (SDL_DEFAULT_REPEAT_DELAY, SDL_DEFAULT_REPEAT_INTERVAL);
437 460
438 m = SDL_ListModes (0, SDL_FULLSCREEN | SDL_OPENGL); 461 m = SDL_ListModes (0, SDL_FULLSCREEN | SDL_OPENGL);
501 hv_store (hv, "button", 6, newSViv (ev.button.button), 0); 524 hv_store (hv, "button", 6, newSViv (ev.button.button), 0);
502 hv_store (hv, "state", 5, newSViv (ev.button.state), 0); 525 hv_store (hv, "state", 5, newSViv (ev.button.state), 0);
503 hv_store (hv, "x", 1, newSViv (ev.button.x), 0); 526 hv_store (hv, "x", 1, newSViv (ev.button.x), 0);
504 hv_store (hv, "y", 1, newSViv (ev.button.y), 0); 527 hv_store (hv, "y", 1, newSViv (ev.button.y), 0);
505 break; 528 break;
529
530 case SDL_USEREVENT:
531 hv_store (hv, "code", 4, newSViv (ev.user.code), 0);
532 hv_store (hv, "data1", 5, newSViv ((IV)ev.user.data1), 0);
533 hv_store (hv, "data2", 5, newSViv ((IV)ev.user.data2), 0);
534 break;
506 } 535 }
507 536
508 XPUSHs (sv_2mortal (newRV_noinc ((SV *)hv))); 537 XPUSHs (sv_2mortal (newRV_noinc ((SV *)hv)));
509 } 538 }
510} 539}
511 540
512int 541int
513Mix_OpenAudio (int frequency = 22050, int format = MIX_DEFAULT_FORMAT, int channels = 1, int chunksize = 512) 542Mix_OpenAudio (int frequency = 48000, int format = MIX_DEFAULT_FORMAT, int channels = 1, int chunksize = 2048)
514 POSTCALL: 543 POSTCALL:
515 Mix_HookMusicFinished (music_finished); 544 Mix_HookMusicFinished (music_finished);
516 Mix_ChannelFinished (channel_finished); 545 Mix_ChannelFinished (channel_finished);
517 546
518void 547void
544 573
545void 574void
546add_font (char *file) 575add_font (char *file)
547 CODE: 576 CODE:
548 FcConfigAppFontAddFile (0, (const FcChar8 *)file); /* no idea wether this is required */ 577 FcConfigAppFontAddFile (0, (const FcChar8 *)file); /* no idea wether this is required */
578#ifdef _WIN32
579 // cairo... sigh... requires win2000
580 AddFontResourceEx (file, FR_PRIVATE, 0);
581#endif
549 582
550void 583void
551load_image_inline (SV *image_) 584load_image_inline (SV *image_)
552 ALIAS: 585 ALIAS:
553 load_image_file = 1 586 load_image_file = 1
680 default_font = self; 713 default_font = self;
681 714
682MODULE = CFClient PACKAGE = CFClient::Layout 715MODULE = CFClient PACKAGE = CFClient::Layout
683 716
684CFClient::Layout 717CFClient::Layout
685new (SV *class, int base_height = MIN_FONT_HEIGHT) 718new (SV *class, int rgba = 0)
686 CODE: 719 CODE:
687 New (0, RETVAL, 1, struct cf_layout); 720 New (0, RETVAL, 1, struct cf_layout);
688 RETVAL->pl = pango_layout_new (context); 721
689 RETVAL->base_height = base_height; 722 RETVAL->pl = pango_layout_new (rgba ? cairo_context : ft2_context);
723 RETVAL->rgba = rgba;
724 RETVAL->r = 1.;
725 RETVAL->g = 1.;
726 RETVAL->b = 1.;
727 RETVAL->a = 1.;
728 RETVAL->base_height = MIN_FONT_HEIGHT;
690 RETVAL->font = 0; 729 RETVAL->font = 0;
730
691 pango_layout_set_wrap (RETVAL->pl, PANGO_WRAP_WORD_CHAR); 731 pango_layout_set_wrap (RETVAL->pl, PANGO_WRAP_WORD_CHAR);
692 pango_layout_set_font_description (RETVAL->pl, default_font); 732 layout_update_font (RETVAL);
693 OUTPUT: 733 OUTPUT:
694 RETVAL 734 RETVAL
695 735
696void 736void
697DESTROY (CFClient::Layout self) 737DESTROY (CFClient::Layout self)
698 CODE: 738 CODE:
699 g_object_unref (self->pl); 739 g_object_unref (self->pl);
700 Safefree (self); 740 Safefree (self);
701 741
742int
743is_rgba (CFClient::Layout self)
744 CODE:
745 RETVAL = self->rgba;
746 OUTPUT:
747 RETVAL
748
702void 749void
703set_text (CFClient::Layout self, SV *text_) 750set_text (CFClient::Layout self, SV *text_)
704 CODE: 751 CODE:
705{ 752{
706 STRLEN textlen; 753 STRLEN textlen;
724 CODE: 771 CODE:
725 RETVAL = newSVpv (pango_layout_get_text (self->pl), 0); 772 RETVAL = newSVpv (pango_layout_get_text (self->pl), 0);
726 SvUTF8_on (RETVAL); 773 SvUTF8_on (RETVAL);
727 OUTPUT: 774 OUTPUT:
728 RETVAL 775 RETVAL
776
777void
778set_foreground (CFClient::Layout self, float r, float g, float b, float a = 1.)
779 CODE:
780 self->r = r;
781 self->g = g;
782 self->b = b;
783 self->a = a;
729 784
730void 785void
731set_font (CFClient::Layout self, CFClient::Font font = 0) 786set_font (CFClient::Layout self, CFClient::Font font = 0)
732 CODE: 787 CODE:
733 if (self->font != font) 788 if (self->font != font)
749set_width (CFClient::Layout self, int max_width = -1) 804set_width (CFClient::Layout self, int max_width = -1)
750 CODE: 805 CODE:
751 pango_layout_set_width (self->pl, max_width < 0 ? max_width : max_width * PANGO_SCALE); 806 pango_layout_set_width (self->pl, max_width < 0 ? max_width : max_width * PANGO_SCALE);
752 807
753void 808void
809set_indent (CFClient::Layout self, int indent)
810 CODE:
811 pango_layout_set_indent (self->pl, indent * PANGO_SCALE);
812
813void
814set_spacing (CFClient::Layout self, int spacing)
815 CODE:
816 pango_layout_set_spacing (self->pl, spacing * PANGO_SCALE);
817
818void
819set_ellipsise (CFClient::Layout self, int ellipsise)
820 CODE:
821 pango_layout_set_ellipsize (self->pl,
822 ellipsise == 1 ? PANGO_ELLIPSIZE_START
823 : ellipsise == 2 ? PANGO_ELLIPSIZE_MIDDLE
824 : ellipsise == 3 ? PANGO_ELLIPSIZE_END
825 : PANGO_ELLIPSIZE_NONE
826 );
827
828void
829set_single_paragraph_mode (CFClient::Layout self, int spm)
830 CODE:
831 pango_layout_set_single_paragraph_mode (self->pl, !!spm);
832
833void
754size (CFClient::Layout self) 834size (CFClient::Layout self)
755 PPCODE: 835 PPCODE:
756{ 836{
757 int w, h; 837 int w, h;
758 838
791render (CFClient::Layout self) 871render (CFClient::Layout self)
792 PPCODE: 872 PPCODE:
793{ 873{
794 SV *retval; 874 SV *retval;
795 int w, h; 875 int w, h;
796 FT_Bitmap bitmap;
797 876
798 layout_get_pixel_size (self, &w, &h); 877 layout_get_pixel_size (self, &w, &h);
799 878
879 if (self->rgba)
880 {
881 cairo_surface_t *surface;
882 cairo_t *cairo;
883
884 retval = newSV (w * h * 4);
885 SvPOK_only (retval);
886 SvCUR_set (retval, w * h * 4);
887
888 memset (SvPVX (retval), 0, w * h * 4);
889
890 surface = cairo_image_surface_create_for_data (
891 (void*)SvPVX (retval), CAIRO_FORMAT_ARGB32, w, h, w * 4);
892 cairo = cairo_create (surface);
893 cairo_set_source_rgba (cairo, self->r, self->g, self->b, self->a);
894
895 pango_cairo_show_layout (cairo, self->pl);
896
897 cairo_destroy (cairo);
898 cairo_surface_destroy (surface);
899
900 // what a mess, and its premultiplied, too :(
901 {
902 uint32_t *p = (uint32_t *)SvPVX (retval);
903 uint32_t *e = p + w * h;
904
905 while (p < e)
906 {
907 uint32_t rgba = *p;
908 rgba = (rgba >> 24) | (rgba << 8);
909 rgba = SDL_SwapBE32 (rgba);
910 *p++ = rgba;
911 }
912 }
913
914 EXTEND (SP, 5);
915 PUSHs (sv_2mortal (newSViv (w)));
916 PUSHs (sv_2mortal (newSViv (h)));
917 PUSHs (sv_2mortal (retval));
918 PUSHs (sv_2mortal (newSViv (GL_RGBA)));
919 PUSHs (sv_2mortal (newSViv (GL_RGBA)));
920 }
921 else
922 {
923 FT_Bitmap bitmap;
924
800 retval = newSV (w * h); 925 retval = newSV (w * h);
801 SvPOK_only (retval); 926 SvPOK_only (retval);
802 SvCUR_set (retval, w * h); 927 SvCUR_set (retval, w * h);
803 928
804 bitmap.rows = h; 929 bitmap.rows = h;
805 bitmap.width = w; 930 bitmap.width = w;
806 bitmap.pitch = w; 931 bitmap.pitch = w;
807 bitmap.buffer = (unsigned char*)SvPVX (retval); 932 bitmap.buffer = (unsigned char*)SvPVX (retval);
808 bitmap.num_grays = 256; 933 bitmap.num_grays = 256;
809 bitmap.pixel_mode = FT_PIXEL_MODE_GRAY; 934 bitmap.pixel_mode = FT_PIXEL_MODE_GRAY;
810 935
811 memset (bitmap.buffer, 0, w * h); 936 memset (bitmap.buffer, 0, w * h);
812 937
813 pango_ft2_render_layout (&bitmap, self->pl, 0 * PANGO_SCALE, 0 * PANGO_SCALE); 938 pango_ft2_render_layout (&bitmap, self->pl, 0 * PANGO_SCALE, 0 * PANGO_SCALE);
814 939
815 EXTEND (SP, 3); 940 EXTEND (SP, 5);
816 PUSHs (sv_2mortal (newSViv (w))); 941 PUSHs (sv_2mortal (newSViv (w)));
817 PUSHs (sv_2mortal (newSViv (h))); 942 PUSHs (sv_2mortal (newSViv (h)));
818 PUSHs (sv_2mortal (retval)); 943 PUSHs (sv_2mortal (retval));
944 PUSHs (sv_2mortal (newSViv (GL_ALPHA)));
945 PUSHs (sv_2mortal (newSViv (GL_ALPHA)));
946 }
819} 947}
820 948
821MODULE = CFClient PACKAGE = CFClient::Texture 949MODULE = CFClient PACKAGE = CFClient::Texture
822 950
823void 951void
824draw_quad (SV *self, float x, float y, float w = 0, float h = 0) 952draw_quad (SV *self, float x, float y, float w = 0, float h = 0)
825 PROTOTYPE: $$$;$$ 953 PROTOTYPE: $$$;$$
954 ALIAS:
955 draw_quad_alpha = 1
956 draw_quad_alpha_premultiplied = 2
826 CODE: 957 CODE:
827{ 958{
828 HV *hv = (HV *)SvRV (self); 959 HV *hv = (HV *)SvRV (self);
829 float s = SvNV (*hv_fetch (hv, "s", 1, 1)); 960 float s = SvNV (*hv_fetch (hv, "s", 1, 1));
830 float t = SvNV (*hv_fetch (hv, "t", 1, 1)); 961 float t = SvNV (*hv_fetch (hv, "t", 1, 1));
835 { 966 {
836 w = SvNV (*hv_fetch (hv, "w", 1, 1)); 967 w = SvNV (*hv_fetch (hv, "w", 1, 1));
837 h = SvNV (*hv_fetch (hv, "h", 1, 1)); 968 h = SvNV (*hv_fetch (hv, "h", 1, 1));
838 } 969 }
839 970
971 if (ix)
972 {
973 glEnable (GL_BLEND);
974 glBlendFunc (ix == 1 ? GL_SRC_ALPHA : GL_ONE, GL_ONE_MINUS_SRC_ALPHA);
975 }
976
840 glBindTexture (GL_TEXTURE_2D, name); 977 glBindTexture (GL_TEXTURE_2D, name);
978
841 if (wrap_mode) { 979 if (wrap_mode)
980 {
842 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT); 981 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);
843 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT); 982 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);
844 } 983 }
984
845 glBegin (GL_QUADS); 985 glBegin (GL_QUADS);
846 glTexCoord2f (0, 0); glVertex2f (x , y ); 986 glTexCoord2f (0, 0); glVertex2f (x , y );
847 glTexCoord2f (0, t); glVertex2f (x , y + h); 987 glTexCoord2f (0, t); glVertex2f (x , y + h);
848 glTexCoord2f (s, t); glVertex2f (x + w, y + h); 988 glTexCoord2f (s, t); glVertex2f (x + w, y + h);
849 glTexCoord2f (s, 0); glVertex2f (x + w, y ); 989 glTexCoord2f (s, 0); glVertex2f (x + w, y );
850 glEnd (); 990 glEnd ();
991
992 if (ix)
993 glDisable (GL_BLEND);
851} 994}
852 995
853MODULE = CFClient PACKAGE = CFClient::Map 996MODULE = CFClient PACKAGE = CFClient::Map
854 997
855CFClient::Map 998CFClient::Map
1378 const_iv (GL_ONE_MINUS_DST_ALPHA), 1521 const_iv (GL_ONE_MINUS_DST_ALPHA),
1379 const_iv (GL_RGB), 1522 const_iv (GL_RGB),
1380 const_iv (GL_RGBA), 1523 const_iv (GL_RGBA),
1381 const_iv (GL_UNSIGNED_BYTE), 1524 const_iv (GL_UNSIGNED_BYTE),
1382 const_iv (GL_ALPHA), 1525 const_iv (GL_ALPHA),
1526 const_iv (GL_LUMINANCE),
1383 const_iv (GL_FLOAT), 1527 const_iv (GL_FLOAT),
1384 const_iv (GL_UNSIGNED_INT_8_8_8_8_REV), 1528 const_iv (GL_UNSIGNED_INT_8_8_8_8_REV),
1385 const_iv (GL_COMPILE), 1529 const_iv (GL_COMPILE),
1386 const_iv (GL_TEXTURE_1D), 1530 const_iv (GL_TEXTURE_1D),
1387 const_iv (GL_TEXTURE_2D), 1531 const_iv (GL_TEXTURE_2D),
1476void glEnd () 1620void glEnd ()
1477 1621
1478void glColor (float r, float g, float b, float a = 1.0) 1622void glColor (float r, float g, float b, float a = 1.0)
1479 PROTOTYPE: @ 1623 PROTOTYPE: @
1480 CODE: 1624 CODE:
1481 glColor4ub (r * 255., g * 255., b * 255., a * 255.); 1625 glColor4ub (MIN ((int)(r * 255.f), 255),
1626 MIN ((int)(g * 255.f), 255),
1627 MIN ((int)(b * 255.f), 255),
1628 MIN ((int)(a * 255.f), 255));
1482 1629
1483void glVertex (float x, float y, float z = 0.) 1630void glVertex (float x, float y, float z = 0.)
1484 CODE: 1631 CODE:
1485 glVertex3f (x, y, z); 1632 glVertex3f (x, y, z);
1486 1633

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines