Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

OTAbitmap.c

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 #include <stdio.h>
00058 #include <stdlib.h>
00059 #include <string.h>
00060 #include <errno.h>
00061 
00062 #include "gwlib/gwlib.h"
00063 #include "OTAbitmap.h"
00064 
00065 
00066 
00067 /* create empty OTAbitmap */
00068 
00069 OTAbitmap *OTAbitmap_create_empty(void)
00070 {
00071     OTAbitmap *new;
00072 
00073     new = gw_malloc(sizeof(OTAbitmap));
00074     memset(new, 0, sizeof(OTAbitmap));
00075     return new;
00076 }
00077 
00078 void OTAbitmap_delete(OTAbitmap *pic)
00079 {
00080     gw_free(pic->ext_fields);
00081     gw_free(pic->main_image);
00082     if (pic->animated_image) {
00083     int i;
00084     for(i=0; i < pic->animimg_count; i++)
00085         gw_free(pic->animated_image[i]);
00086     gw_free(pic->animated_image);
00087     }
00088     gw_free(pic);
00089 }
00090 
00091 OTAbitmap *OTAbitmap_create(int width, int height, int depth,
00092                 Octet *data, int flags)
00093 {
00094     OTAbitmap *new;
00095     int i, j, siz, osiz;
00096     Octet val;
00097     
00098     new = OTAbitmap_create_empty();
00099 
00100     if (width > 255 || height > 255)
00101     new->infofield = 0x10;      /* set bit */
00102     else
00103     new->infofield = 0x00;
00104     
00105     new->width = width;
00106     new->height = height;
00107 
00108     siz = (width * height + 7)/8;
00109     
00110     new->main_image = gw_malloc(siz);
00111     osiz = (width+7)/8 * height;
00112     for(i=j=0; i<osiz; i++, j+=8) {
00113     val = data[i];
00114     if (flags & REVERSE) val = reverse_octet(val);  
00115     if (flags & NEGATIVE) val = ~val;
00116 
00117     if (i > 0 && i % ((width+7)/8) == 0 && width % 8 > 0)
00118         j -= 8 + width % 8;
00119 
00120     if (j % 8 == 0) {
00121         new->main_image[j/8] = val;
00122     }
00123     else {
00124         new->main_image[j/8] |= val >> (j % 8);
00125         new->main_image[j/8 + 1] = val << (8 - j % 8);
00126     }       
00127     }
00128     /* no palette nor animated images, yet */
00129     
00130     return new;
00131 }
00132 
00133 
00134 
00135 /* create Octet stream from given OTAbitmap */
00136 
00137 int OTAbitmap_create_stream(OTAbitmap *pic, Octet **stream)
00138 {
00139     Octet   tmp_header[10];
00140     int     hdr_len;
00141     int     pic_size;
00142 
00143     if (pic->infofield & 0x10) {
00144     sprintf(tmp_header, "%c%c%c%c%c%c", pic->infofield, pic->width/256,
00145         pic->width%256, pic->height/256, pic->height%256, pic->depth); 
00146     hdr_len = 6;
00147     } else {
00148     sprintf(tmp_header, "%c%c%c%c", pic->infofield,
00149         pic->width, pic->height, pic->depth);
00150     hdr_len = 4;
00151     }   
00152     
00153     pic_size = (pic->width * pic->height + 7)/8;
00154 
00155     *stream = gw_malloc(pic_size+pic_size);
00156     memcpy(*stream, tmp_header, hdr_len);
00157     memcpy(*stream + hdr_len, pic->main_image, pic_size);
00158 
00159     debug("util", 0, "picture %d x %d, stream length %d",
00160       pic->width, pic->height, hdr_len + pic_size);
00161     
00162     return (hdr_len + pic_size);
00163 }
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.