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.72 by root, Fri May 5 19:10:16 2006 UTC vs.
Revision 1.86 by root, Fri May 19 16:43:56 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 = (void *)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
419 SDL_Rect **m; 441 SDL_Rect **m;
420 442
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, 16);
447
448 SDL_GL_SetAttribute (SDL_GL_BUFFER_SIZE, 64);
449 SDL_GL_SetAttribute (SDL_GL_DEPTH_SIZE, 0);
425 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);
514 XPUSHs (sv_2mortal (newRV_noinc ((SV *)hv))); 537 XPUSHs (sv_2mortal (newRV_noinc ((SV *)hv)));
515 } 538 }
516} 539}
517 540
518int 541int
519Mix_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)
520 POSTCALL: 543 POSTCALL:
521 Mix_HookMusicFinished (music_finished); 544 Mix_HookMusicFinished (music_finished);
522 Mix_ChannelFinished (channel_finished); 545 Mix_ChannelFinished (channel_finished);
523 546
524void 547void
550 573
551void 574void
552add_font (char *file) 575add_font (char *file)
553 CODE: 576 CODE:
554 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
555 582
556void 583void
557load_image_inline (SV *image_) 584load_image_inline (SV *image_)
558 ALIAS: 585 ALIAS:
559 load_image_file = 1 586 load_image_file = 1
643} 670}
644 671
645void 672void
646error (char *message) 673error (char *message)
647 CODE: 674 CODE:
675 fprintf (stderr, "ERROR: %s\n", message);
648#ifdef _WIN32 676#ifdef _WIN32
649 MessageBox (0, message, "Crossfire+ Error", MB_OK | MB_ICONERROR | MB_SETFOREGROUND); 677 MessageBox (0, message, "Crossfire+ Error", MB_OK | MB_ICONERROR);
650#else
651 fprintf (stderr, "ERROR: %s\n", message);
652#endif 678#endif
653 679
654void 680void
655fatal (char *message) 681fatal (char *message)
656 CODE: 682 CODE:
683 fprintf (stderr, "FATAL: %s\n", message);
657#ifdef _WIN32 684#ifdef _WIN32
658 MessageBox (0, message, "Crossfire+ Fatal Error", MB_OK | MB_ICONERROR | MB_SETFOREGROUND); 685 MessageBox (0, message, "Crossfire+ Fatal Error", MB_OK | MB_ICONERROR);
659#else
660 fprintf (stderr, "FATAL: %s\n", message);
661#endif 686#endif
662 exit (1); 687 exit (1);
663 688
664MODULE = CFClient PACKAGE = CFClient::Font 689MODULE = CFClient PACKAGE = CFClient::Font
665 690
686 default_font = self; 711 default_font = self;
687 712
688MODULE = CFClient PACKAGE = CFClient::Layout 713MODULE = CFClient PACKAGE = CFClient::Layout
689 714
690CFClient::Layout 715CFClient::Layout
691new (SV *class, int base_height = MIN_FONT_HEIGHT) 716new (SV *class, int rgba = 0)
692 CODE: 717 CODE:
693 New (0, RETVAL, 1, struct cf_layout); 718 New (0, RETVAL, 1, struct cf_layout);
694 RETVAL->pl = pango_layout_new (context); 719
695 RETVAL->base_height = base_height; 720 RETVAL->pl = pango_layout_new (rgba ? cairo_context : ft2_context);
721 RETVAL->rgba = rgba;
722 RETVAL->r = 1.;
723 RETVAL->g = 1.;
724 RETVAL->b = 1.;
725 RETVAL->a = 1.;
726 RETVAL->base_height = MIN_FONT_HEIGHT;
696 RETVAL->font = 0; 727 RETVAL->font = 0;
728
697 pango_layout_set_wrap (RETVAL->pl, PANGO_WRAP_WORD_CHAR); 729 pango_layout_set_wrap (RETVAL->pl, PANGO_WRAP_WORD_CHAR);
698 pango_layout_set_font_description (RETVAL->pl, default_font); 730 layout_update_font (RETVAL);
699 OUTPUT: 731 OUTPUT:
700 RETVAL 732 RETVAL
701 733
702void 734void
703DESTROY (CFClient::Layout self) 735DESTROY (CFClient::Layout self)
704 CODE: 736 CODE:
705 g_object_unref (self->pl); 737 g_object_unref (self->pl);
706 Safefree (self); 738 Safefree (self);
707 739
740int
741is_rgba (CFClient::Layout self)
742 CODE:
743 RETVAL = self->rgba;
744 OUTPUT:
745 RETVAL
746
708void 747void
709set_text (CFClient::Layout self, SV *text_) 748set_text (CFClient::Layout self, SV *text_)
710 CODE: 749 CODE:
711{ 750{
712 STRLEN textlen; 751 STRLEN textlen;
730 CODE: 769 CODE:
731 RETVAL = newSVpv (pango_layout_get_text (self->pl), 0); 770 RETVAL = newSVpv (pango_layout_get_text (self->pl), 0);
732 SvUTF8_on (RETVAL); 771 SvUTF8_on (RETVAL);
733 OUTPUT: 772 OUTPUT:
734 RETVAL 773 RETVAL
774
775void
776set_foreground (CFClient::Layout self, float r, float g, float b, float a = 1.)
777 CODE:
778 self->r = r;
779 self->g = g;
780 self->b = b;
781 self->a = a;
735 782
736void 783void
737set_font (CFClient::Layout self, CFClient::Font font = 0) 784set_font (CFClient::Layout self, CFClient::Font font = 0)
738 CODE: 785 CODE:
739 if (self->font != font) 786 if (self->font != font)
755set_width (CFClient::Layout self, int max_width = -1) 802set_width (CFClient::Layout self, int max_width = -1)
756 CODE: 803 CODE:
757 pango_layout_set_width (self->pl, max_width < 0 ? max_width : max_width * PANGO_SCALE); 804 pango_layout_set_width (self->pl, max_width < 0 ? max_width : max_width * PANGO_SCALE);
758 805
759void 806void
807set_indent (CFClient::Layout self, int indent)
808 CODE:
809 pango_layout_set_indent (self->pl, indent * PANGO_SCALE);
810
811void
812set_spacing (CFClient::Layout self, int spacing)
813 CODE:
814 pango_layout_set_spacing (self->pl, spacing * PANGO_SCALE);
815
816void
817set_ellipsise (CFClient::Layout self, int ellipsise)
818 CODE:
819 pango_layout_set_ellipsize (self->pl,
820 ellipsise == 1 ? PANGO_ELLIPSIZE_START
821 : ellipsise == 2 ? PANGO_ELLIPSIZE_MIDDLE
822 : ellipsise == 3 ? PANGO_ELLIPSIZE_END
823 : PANGO_ELLIPSIZE_NONE
824 );
825
826void
827set_single_paragraph_mode (CFClient::Layout self, int spm)
828 CODE:
829 pango_layout_set_single_paragraph_mode (self->pl, !!spm);
830
831void
760size (CFClient::Layout self) 832size (CFClient::Layout self)
761 PPCODE: 833 PPCODE:
762{ 834{
763 int w, h; 835 int w, h;
764 836
797render (CFClient::Layout self) 869render (CFClient::Layout self)
798 PPCODE: 870 PPCODE:
799{ 871{
800 SV *retval; 872 SV *retval;
801 int w, h; 873 int w, h;
802 FT_Bitmap bitmap;
803 874
804 layout_get_pixel_size (self, &w, &h); 875 layout_get_pixel_size (self, &w, &h);
805 876
877 if (self->rgba)
878 {
879 cairo_surface_t *surface;
880 cairo_t *cairo;
881
882 retval = newSV (w * h * 4);
883 SvPOK_only (retval);
884 SvCUR_set (retval, w * h * 4);
885
886 memset (SvPVX (retval), 0, w * h * 4);
887
888 surface = cairo_image_surface_create_for_data (
889 (void*)SvPVX (retval), CAIRO_FORMAT_ARGB32, w, h, w * 4);
890 cairo = cairo_create (surface);
891 cairo_set_source_rgba (cairo, self->r, self->g, self->b, self->a);
892
893 pango_cairo_show_layout (cairo, self->pl);
894
895 cairo_destroy (cairo);
896 cairo_surface_destroy (surface);
897
898 // what a mess, and its premultiplied, too :(
899 {
900 uint32_t *p = (uint32_t *)SvPVX (retval);
901 uint32_t *e = p + w * h;
902
903 while (p < e)
904 {
905 uint32_t rgba = *p;
906 rgba = (rgba >> 24) | (rgba << 8);
907 rgba = SDL_SwapBE32 (rgba);
908 *p++ = rgba;
909 }
910 }
911
912 EXTEND (SP, 5);
913 PUSHs (sv_2mortal (newSViv (w)));
914 PUSHs (sv_2mortal (newSViv (h)));
915 PUSHs (sv_2mortal (retval));
916 PUSHs (sv_2mortal (newSViv (GL_RGBA)));
917 PUSHs (sv_2mortal (newSViv (GL_RGBA)));
918 }
919 else
920 {
921 FT_Bitmap bitmap;
922
806 retval = newSV (w * h); 923 retval = newSV (w * h);
807 SvPOK_only (retval); 924 SvPOK_only (retval);
808 SvCUR_set (retval, w * h); 925 SvCUR_set (retval, w * h);
809 926
810 bitmap.rows = h; 927 bitmap.rows = h;
811 bitmap.width = w; 928 bitmap.width = w;
812 bitmap.pitch = w; 929 bitmap.pitch = w;
813 bitmap.buffer = (unsigned char*)SvPVX (retval); 930 bitmap.buffer = (unsigned char*)SvPVX (retval);
814 bitmap.num_grays = 256; 931 bitmap.num_grays = 256;
815 bitmap.pixel_mode = FT_PIXEL_MODE_GRAY; 932 bitmap.pixel_mode = FT_PIXEL_MODE_GRAY;
816 933
817 memset (bitmap.buffer, 0, w * h); 934 memset (bitmap.buffer, 0, w * h);
818 935
819 pango_ft2_render_layout (&bitmap, self->pl, 0 * PANGO_SCALE, 0 * PANGO_SCALE); 936 pango_ft2_render_layout (&bitmap, self->pl, 0 * PANGO_SCALE, 0 * PANGO_SCALE);
820 937
821 EXTEND (SP, 3); 938 EXTEND (SP, 5);
822 PUSHs (sv_2mortal (newSViv (w))); 939 PUSHs (sv_2mortal (newSViv (w)));
823 PUSHs (sv_2mortal (newSViv (h))); 940 PUSHs (sv_2mortal (newSViv (h)));
824 PUSHs (sv_2mortal (retval)); 941 PUSHs (sv_2mortal (retval));
942 PUSHs (sv_2mortal (newSViv (GL_ALPHA)));
943 PUSHs (sv_2mortal (newSViv (GL_ALPHA)));
944 }
825} 945}
826 946
827MODULE = CFClient PACKAGE = CFClient::Texture 947MODULE = CFClient PACKAGE = CFClient::Texture
828 948
829void 949void
830draw_quad (SV *self, float x, float y, float w = 0, float h = 0) 950draw_quad (SV *self, float x, float y, float w = 0, float h = 0)
831 PROTOTYPE: $$$;$$ 951 PROTOTYPE: $$$;$$
952 ALIAS:
953 draw_quad_alpha = 1
954 draw_quad_alpha_premultiplied = 2
832 CODE: 955 CODE:
833{ 956{
834 HV *hv = (HV *)SvRV (self); 957 HV *hv = (HV *)SvRV (self);
835 float s = SvNV (*hv_fetch (hv, "s", 1, 1)); 958 float s = SvNV (*hv_fetch (hv, "s", 1, 1));
836 float t = SvNV (*hv_fetch (hv, "t", 1, 1)); 959 float t = SvNV (*hv_fetch (hv, "t", 1, 1));
841 { 964 {
842 w = SvNV (*hv_fetch (hv, "w", 1, 1)); 965 w = SvNV (*hv_fetch (hv, "w", 1, 1));
843 h = SvNV (*hv_fetch (hv, "h", 1, 1)); 966 h = SvNV (*hv_fetch (hv, "h", 1, 1));
844 } 967 }
845 968
969 if (ix)
970 {
971 glEnable (GL_BLEND);
972 glBlendFunc (ix == 1 ? GL_SRC_ALPHA : GL_ONE, GL_ONE_MINUS_SRC_ALPHA);
973 glEnable (GL_ALPHA_TEST);
974 glAlphaFunc (GL_GREATER, 0.01f);
975 }
976
846 glBindTexture (GL_TEXTURE_2D, name); 977 glBindTexture (GL_TEXTURE_2D, name);
978
847 if (wrap_mode) { 979 if (wrap_mode)
980 {
848 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT); 981 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_S, GL_REPEAT);
849 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT); 982 glTexParameteri (GL_TEXTURE_2D, GL_TEXTURE_WRAP_T, GL_REPEAT);
850 } 983 }
984
851 glBegin (GL_QUADS); 985 glBegin (GL_QUADS);
852 glTexCoord2f (0, 0); glVertex2f (x , y ); 986 glTexCoord2f (0, 0); glVertex2f (x , y );
853 glTexCoord2f (0, t); glVertex2f (x , y + h); 987 glTexCoord2f (0, t); glVertex2f (x , y + h);
854 glTexCoord2f (s, t); glVertex2f (x + w, y + h); 988 glTexCoord2f (s, t); glVertex2f (x + w, y + h);
855 glTexCoord2f (s, 0); glVertex2f (x + w, y ); 989 glTexCoord2f (s, 0); glVertex2f (x + w, y );
856 glEnd (); 990 glEnd ();
991
992 if (ix)
993 {
994 glDisable (GL_ALPHA_TEST);
995 glDisable (GL_BLEND);
996 }
857} 997}
858 998
859MODULE = CFClient PACKAGE = CFClient::Map 999MODULE = CFClient PACKAGE = CFClient::Map
860 1000
861CFClient::Map 1001CFClient::Map
1384 const_iv (GL_ONE_MINUS_DST_ALPHA), 1524 const_iv (GL_ONE_MINUS_DST_ALPHA),
1385 const_iv (GL_RGB), 1525 const_iv (GL_RGB),
1386 const_iv (GL_RGBA), 1526 const_iv (GL_RGBA),
1387 const_iv (GL_UNSIGNED_BYTE), 1527 const_iv (GL_UNSIGNED_BYTE),
1388 const_iv (GL_ALPHA), 1528 const_iv (GL_ALPHA),
1529 const_iv (GL_INTENSITY),
1530 const_iv (GL_LUMINANCE),
1531 const_iv (GL_LUMINANCE_ALPHA),
1389 const_iv (GL_FLOAT), 1532 const_iv (GL_FLOAT),
1390 const_iv (GL_UNSIGNED_INT_8_8_8_8_REV), 1533 const_iv (GL_UNSIGNED_INT_8_8_8_8_REV),
1391 const_iv (GL_COMPILE), 1534 const_iv (GL_COMPILE),
1392 const_iv (GL_TEXTURE_1D), 1535 const_iv (GL_TEXTURE_1D),
1393 const_iv (GL_TEXTURE_2D), 1536 const_iv (GL_TEXTURE_2D),
1482void glEnd () 1625void glEnd ()
1483 1626
1484void glColor (float r, float g, float b, float a = 1.0) 1627void glColor (float r, float g, float b, float a = 1.0)
1485 PROTOTYPE: @ 1628 PROTOTYPE: @
1486 CODE: 1629 CODE:
1487 glColor4ub (r * 255., g * 255., b * 255., a * 255.); 1630 glColor4ub (MIN ((int)(r * 255.f), 255),
1631 MIN ((int)(g * 255.f), 255),
1632 MIN ((int)(b * 255.f), 255),
1633 MIN ((int)(a * 255.f), 255));
1488 1634
1489void glVertex (float x, float y, float z = 0.) 1635void glVertex (float x, float y, float z = 0.)
1490 CODE: 1636 CODE:
1491 glVertex3f (x, y, z); 1637 glVertex3f (x, y, z);
1492 1638

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines