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 00037 #include <cstring> 00038 #include "mmstools/mmstools.h" 00039 00040 void mmsfb_blit_rgb24_to_rgb24(MMSFBSurfacePlanes *src_planes, int src_height, int sx, int sy, int sw, int sh, 00041 MMSFBSurfacePlanes *dst_planes, int dst_height, int dx, int dy) { 00042 // first time? 00043 static bool firsttime = true; 00044 if (firsttime) { 00045 printf("DISKO: Using accelerated copy RGB24 to RGB24.\n"); 00046 firsttime = false; 00047 } 00048 00049 // get the first source ptr/pitch 00050 unsigned char *src = (unsigned char *)src_planes->ptr; 00051 int src_pitch = src_planes->pitch; 00052 00053 // get the first destination ptr/pitch 00054 unsigned char *dst = (unsigned char *)dst_planes->ptr; 00055 int dst_pitch = dst_planes->pitch; 00056 00057 // prepare... 00058 int dst_pitch_pix = dst_pitch / 3; 00059 src+= sx*3 + sy * src_pitch; 00060 dst+= dx*3 + dy * dst_pitch; 00061 00062 // check the surface range 00063 if (dst_pitch_pix - dx < sw - sx) 00064 sw = dst_pitch_pix - dx - sx; 00065 if (dst_height - dy < sh - sy) 00066 sh = dst_height - dy - sy; 00067 if ((sw <= 0)||(sh <= 0)) 00068 return; 00069 00070 unsigned char *src_end = src + src_pitch * sh; 00071 int line_len = sw * 3; 00072 00073 // for all lines 00074 while (src < src_end) { 00075 // copy the line 00076 memcpy(dst, src, line_len); 00077 00078 // go to the next line 00079 src+= src_pitch; 00080 dst+= dst_pitch; 00081 } 00082 } 00083 00084 #endif