Home | History | Annotate | Download | only in html
      1 <HTML
      2 ><HEAD
      3 ><TITLE
      4 >SDL_CreateCursor</TITLE
      5 ><META
      6 NAME="GENERATOR"
      7 CONTENT="Modular DocBook HTML Stylesheet Version 1.76b+
      8 "><LINK
      9 REL="HOME"
     10 TITLE="SDL Library Documentation"
     11 HREF="index.html"><LINK
     12 REL="UP"
     13 TITLE="Video"
     14 HREF="video.html"><LINK
     15 REL="PREVIOUS"
     16 TITLE="SDL_WarpMouse"
     17 HREF="sdlwarpmouse.html"><LINK
     18 REL="NEXT"
     19 TITLE="SDL_FreeCursor"
     20 HREF="sdlfreecursor.html"></HEAD
     21 ><BODY
     22 CLASS="REFENTRY"
     23 BGCOLOR="#FFF8DC"
     24 TEXT="#000000"
     25 LINK="#0000ee"
     26 VLINK="#551a8b"
     27 ALINK="#ff0000"
     28 ><DIV
     29 CLASS="NAVHEADER"
     30 ><TABLE
     31 SUMMARY="Header navigation table"
     32 WIDTH="100%"
     33 BORDER="0"
     34 CELLPADDING="0"
     35 CELLSPACING="0"
     36 ><TR
     37 ><TH
     38 COLSPAN="3"
     39 ALIGN="center"
     40 >SDL Library Documentation</TH
     41 ></TR
     42 ><TR
     43 ><TD
     44 WIDTH="10%"
     45 ALIGN="left"
     46 VALIGN="bottom"
     47 ><A
     48 HREF="sdlwarpmouse.html"
     49 ACCESSKEY="P"
     50 >Prev</A
     51 ></TD
     52 ><TD
     53 WIDTH="80%"
     54 ALIGN="center"
     55 VALIGN="bottom"
     56 ></TD
     57 ><TD
     58 WIDTH="10%"
     59 ALIGN="right"
     60 VALIGN="bottom"
     61 ><A
     62 HREF="sdlfreecursor.html"
     63 ACCESSKEY="N"
     64 >Next</A
     65 ></TD
     66 ></TR
     67 ></TABLE
     68 ><HR
     69 ALIGN="LEFT"
     70 WIDTH="100%"></DIV
     71 ><H1
     72 ><A
     73 NAME="SDLCREATECURSOR"
     74 ></A
     75 >SDL_CreateCursor</H1
     76 ><DIV
     77 CLASS="REFNAMEDIV"
     78 ><A
     79 NAME="AEN2487"
     80 ></A
     81 ><H2
     82 >Name</H2
     83 >SDL_CreateCursor&nbsp;--&nbsp;Creates a new mouse cursor.</DIV
     84 ><DIV
     85 CLASS="REFSYNOPSISDIV"
     86 ><A
     87 NAME="AEN2490"
     88 ></A
     89 ><H2
     90 >Synopsis</H2
     91 ><DIV
     92 CLASS="FUNCSYNOPSIS"
     93 ><A
     94 NAME="AEN2491"
     95 ></A
     96 ><P
     97 ></P
     98 ><PRE
     99 CLASS="FUNCSYNOPSISINFO"
    100 >#include "SDL.h"</PRE
    101 ><P
    102 ><CODE
    103 ><CODE
    104 CLASS="FUNCDEF"
    105 >SDL_Cursor *<B
    106 CLASS="FSFUNC"
    107 >SDL_CreateCursor</B
    108 ></CODE
    109 >(Uint8 *data, Uint8 *mask, int w, int h, int hot_x, int hot_y);</CODE
    110 ></P
    111 ><P
    112 ></P
    113 ></DIV
    114 ></DIV
    115 ><DIV
    116 CLASS="REFSECT1"
    117 ><A
    118 NAME="AEN2497"
    119 ></A
    120 ><H2
    121 >Description</H2
    122 ><P
    123 >Create a cursor using the specified <TT
    124 CLASS="PARAMETER"
    125 ><I
    126 >data</I
    127 ></TT
    128 > and <TT
    129 CLASS="PARAMETER"
    130 ><I
    131 >mask</I
    132 ></TT
    133 > (in MSB format).
    134 The cursor width must be a multiple of 8 bits.</P
    135 ><P
    136 >The cursor is created in black and white according to the following:
    137 <DIV
    138 CLASS="INFORMALTABLE"
    139 ><A
    140 NAME="AEN2503"
    141 ></A
    142 ><P
    143 ></P
    144 ><TABLE
    145 BORDER="1"
    146 CLASS="CALSTABLE"
    147 ><THEAD
    148 ><TR
    149 ><TH
    150 ALIGN="LEFT"
    151 VALIGN="TOP"
    152 >Data / Mask</TH
    153 ><TH
    154 ALIGN="LEFT"
    155 VALIGN="TOP"
    156 >Resulting pixel on screen</TH
    157 ></TR
    158 ></THEAD
    159 ><TBODY
    160 ><TR
    161 ><TD
    162 ALIGN="LEFT"
    163 VALIGN="TOP"
    164 >0 / 1</TD
    165 ><TD
    166 ALIGN="LEFT"
    167 VALIGN="TOP"
    168 >White</TD
    169 ></TR
    170 ><TR
    171 ><TD
    172 ALIGN="LEFT"
    173 VALIGN="TOP"
    174 >1 / 1</TD
    175 ><TD
    176 ALIGN="LEFT"
    177 VALIGN="TOP"
    178 >Black</TD
    179 ></TR
    180 ><TR
    181 ><TD
    182 ALIGN="LEFT"
    183 VALIGN="TOP"
    184 >0 / 0</TD
    185 ><TD
    186 ALIGN="LEFT"
    187 VALIGN="TOP"
    188 >Transparent</TD
    189 ></TR
    190 ><TR
    191 ><TD
    192 ALIGN="LEFT"
    193 VALIGN="TOP"
    194 >1 / 0</TD
    195 ><TD
    196 ALIGN="LEFT"
    197 VALIGN="TOP"
    198 >Inverted color if possible, black if not.</TD
    199 ></TR
    200 ></TBODY
    201 ></TABLE
    202 ><P
    203 ></P
    204 ></DIV
    205 ></P
    206 ><P
    207 >Cursors created with this function must be freed with
    208 <A
    209 HREF="sdlfreecursor.html"
    210 >SDL_FreeCursor</A
    211 >.</P
    212 ></DIV
    213 ><DIV
    214 CLASS="REFSECT1"
    215 ><A
    216 NAME="AEN2524"
    217 ></A
    218 ><H2
    219 >Example</H2
    220 ><PRE
    221 CLASS="PROGRAMLISTING"
    222 >/* Stolen from the mailing list */
    223 /* Creates a new mouse cursor from an XPM */
    224 
    225 
    226 /* XPM */
    227 static const char *arrow[] = {
    228   /* width height num_colors chars_per_pixel */
    229   "    32    32        3            1",
    230   /* colors */
    231   "X c #000000",
    232   ". c #ffffff",
    233   "  c None",
    234   /* pixels */
    235   "X                               ",
    236   "XX                              ",
    237   "X.X                             ",
    238   "X..X                            ",
    239   "X...X                           ",
    240   "X....X                          ",
    241   "X.....X                         ",
    242   "X......X                        ",
    243   "X.......X                       ",
    244   "X........X                      ",
    245   "X.....XXXXX                     ",
    246   "X..X..X                         ",
    247   "X.X X..X                        ",
    248   "XX  X..X                        ",
    249   "X    X..X                       ",
    250   "     X..X                       ",
    251   "      X..X                      ",
    252   "      X..X                      ",
    253   "       XX                       ",
    254   "                                ",
    255   "                                ",
    256   "                                ",
    257   "                                ",
    258   "                                ",
    259   "                                ",
    260   "                                ",
    261   "                                ",
    262   "                                ",
    263   "                                ",
    264   "                                ",
    265   "                                ",
    266   "                                ",
    267   "0,0"
    268 };
    269 
    270 static SDL_Cursor *init_system_cursor(const char *image[])
    271 {
    272   int i, row, col;
    273   Uint8 data[4*32];
    274   Uint8 mask[4*32];
    275   int hot_x, hot_y;
    276 
    277   i = -1;
    278   for ( row=0; row&#60;32; ++row ) {
    279     for ( col=0; col&#60;32; ++col ) {
    280       if ( col % 8 ) {
    281         data[i] &#60;&#60;= 1;
    282         mask[i] &#60;&#60;= 1;
    283       } else {
    284         ++i;
    285         data[i] = mask[i] = 0;
    286       }
    287       switch (image[4+row][col]) {
    288         case 'X':
    289           data[i] |= 0x01;
    290           mask[i] |= 0x01;
    291           break;
    292         case '.':
    293           mask[i] |= 0x01;
    294           break;
    295         case ' ':
    296           break;
    297       }
    298     }
    299   }
    300   sscanf(image[4+row], "%d,%d", &#38;hot_x, &#38;hot_y);
    301   return SDL_CreateCursor(data, mask, 32, 32, hot_x, hot_y);
    302 }</PRE
    303 ></DIV
    304 ><DIV
    305 CLASS="REFSECT1"
    306 ><A
    307 NAME="AEN2527"
    308 ></A
    309 ><H2
    310 >See Also</H2
    311 ><P
    312 ><A
    313 HREF="sdlfreecursor.html"
    314 ><TT
    315 CLASS="FUNCTION"
    316 >SDL_FreeCursor</TT
    317 ></A
    318 >,
    319 <A
    320 HREF="sdlsetcursor.html"
    321 ><TT
    322 CLASS="FUNCTION"
    323 >SDL_SetCursor</TT
    324 ></A
    325 >,
    326 <A
    327 HREF="sdlshowcursor.html"
    328 ><TT
    329 CLASS="FUNCTION"
    330 >SDL_ShowCursor</TT
    331 ></A
    332 ></P
    333 ></DIV
    334 ><DIV
    335 CLASS="NAVFOOTER"
    336 ><HR
    337 ALIGN="LEFT"
    338 WIDTH="100%"><TABLE
    339 SUMMARY="Footer navigation table"
    340 WIDTH="100%"
    341 BORDER="0"
    342 CELLPADDING="0"
    343 CELLSPACING="0"
    344 ><TR
    345 ><TD
    346 WIDTH="33%"
    347 ALIGN="left"
    348 VALIGN="top"
    349 ><A
    350 HREF="sdlwarpmouse.html"
    351 ACCESSKEY="P"
    352 >Prev</A
    353 ></TD
    354 ><TD
    355 WIDTH="34%"
    356 ALIGN="center"
    357 VALIGN="top"
    358 ><A
    359 HREF="index.html"
    360 ACCESSKEY="H"
    361 >Home</A
    362 ></TD
    363 ><TD
    364 WIDTH="33%"
    365 ALIGN="right"
    366 VALIGN="top"
    367 ><A
    368 HREF="sdlfreecursor.html"
    369 ACCESSKEY="N"
    370 >Next</A
    371 ></TD
    372 ></TR
    373 ><TR
    374 ><TD
    375 WIDTH="33%"
    376 ALIGN="left"
    377 VALIGN="top"
    378 >SDL_WarpMouse</TD
    379 ><TD
    380 WIDTH="34%"
    381 ALIGN="center"
    382 VALIGN="top"
    383 ><A
    384 HREF="video.html"
    385 ACCESSKEY="U"
    386 >Up</A
    387 ></TD
    388 ><TD
    389 WIDTH="33%"
    390 ALIGN="right"
    391 VALIGN="top"
    392 >SDL_FreeCursor</TD
    393 ></TR
    394 ></TABLE
    395 ></DIV
    396 ></BODY
    397 ></HTML
    398 >