Logo
  • Main Page
  • Related Pages
  • Modules
  • Classes
  • Files

mmsfb_blit_rgb24_to_argb.cpp

Go to the documentation of this file.
00001 /***************************************************************************
00002  *   Copyright (C) 2005-2007 Stefan Schwarzer, Jens Schneider,             *
00003  *                           Matthias Hardt, Guido Madaus                  *
00004  *                                                                         *
00005  *   Copyright (C) 2007-2008 BerLinux Solutions GbR                        *
00006  *                           Stefan Schwarzer & Guido Madaus               *
00007  *                                                                         *
00008  *   Copyright (C) 2009-2013 BerLinux Solutions GmbH                       *
00009  *                                                                         *
00010  *   Authors:                                                              *
00011  *      Stefan Schwarzer   <stefan.schwarzer@diskohq.org>,                 *
00012  *      Matthias Hardt     <matthias.hardt@diskohq.org>,                   *
00013  *      Jens Schneider     <jens.schneider@diskohq.org>,                   *
00014  *      Guido Madaus       <guido.madaus@diskohq.org>,                     *
00015  *      Patrick Helterhoff <patrick.helterhoff@diskohq.org>,               *
00016  *      René Bählkow       <rene.baehlkow@diskohq.org>                     *
00017  *                                                                         *
00018  *   This library is free software; you can redistribute it and/or         *
00019  *   modify it under the terms of the GNU Lesser General Public            *
00020  *   License version 2.1 as published by the Free Software Foundation.     *
00021  *                                                                         *
00022  *   This library is distributed in the hope that it will be useful,       *
00023  *   but WITHOUT ANY WARRANTY; without even the implied warranty of        *
00024  *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU     *
00025  *   Lesser General Public License for more details.                       *
00026  *                                                                         *
00027  *   You should have received a copy of the GNU Lesser General Public      *
00028  *   License along with this library; if not, write to the                 *
00029  *   Free Software Foundation, Inc.,                                       *
00030  *   51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA            *
00031  **************************************************************************/
00032 
00033 #include "mmsgui/fb/mmsfbconv.h"
00034 
00035 #ifdef __HAVE_PF_RGB24__
00036 #ifdef __HAVE_PF_ARGB__
00037 
00038 #include <cstring>
00039 #include "mmstools/mmstools.h"
00040 
00041 void mmsfb_blit_rgb24_to_argb(MMSFBSurfacePlanes *src_planes, int src_height, int sx, int sy, int sw, int sh,
00042                               MMSFBSurfacePlanes *dst_planes, int dst_height, int dx, int dy) {
00043     // first time?
00044     static bool firsttime = true;
00045     if (firsttime) {
00046         printf("DISKO: Using accelerated conversion RGB24 to ARGB.\n");
00047         firsttime = false;
00048     }
00049 
00050     // get the first source ptr/pitch
00051     unsigned char *src = (unsigned char *)src_planes->ptr;
00052     int src_pitch = src_planes->pitch;
00053 
00054     // get the first destination ptr/pitch
00055     unsigned int *dst = (unsigned int *)dst_planes->ptr;
00056     int dst_pitch = dst_planes->pitch;
00057 
00058     // prepare...
00059     int src_pitch_pix = src_pitch / 3;
00060     int dst_pitch_pix = dst_pitch >> 2;
00061     src+= (sx + sy * src_pitch_pix) * 3;
00062     dst+= dx + dy * dst_pitch_pix;
00063 
00064     // check the surface range
00065     if (dst_pitch_pix - dx < sw - sx)
00066         sw = dst_pitch_pix - dx - sx;
00067     if (dst_height - dy < sh - sy)
00068         sh = dst_height - dy - sy;
00069     if ((sw <= 0)||(sh <= 0))
00070         return;
00071 
00072     unsigned char *src_end = src + (src_pitch_pix * sh) * 3;
00073     int src_pitch_diff = (src_pitch_pix - sw) * 3;
00074     int dst_pitch_diff = dst_pitch_pix - sw;
00075     int sww = sw * 3;
00076 
00077     // for all lines
00078     while (src < src_end) {
00079         // for all pixels in the line
00080         unsigned char *line_end = src + sww;
00081         while (src < line_end) {
00082             // store source to destination
00083             *dst = 0xff000000 | ((*src)<<16) | ((*(src+1))<<8) | *(src+2);
00084             dst++;
00085             src+=3;
00086         }
00087 
00088         // go to the next line
00089         src+= src_pitch_diff;
00090         dst+= dst_pitch_diff;
00091     }
00092 }
00093 
00094 #endif
00095 #endif

Generated by doxygen