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 #ifndef MMSFBMANAGER_H_ 00034 #define MMSFBMANAGER_H_ 00035 00036 #include "mmsgui/fb/mmsfb.h" 00037 #include "mmsconfig/mmsconfigdata.h" 00038 00039 00040 class MMSFBManager { 00041 00042 private: 00043 //! access to the config data 00044 MMSConfigData config; 00045 00046 //! have to open a virtual console? 00047 bool virtual_console; 00048 00049 //! osd layer 00050 MMSFBLayer *graphicslayer; 00051 00052 //! video layer 00053 MMSFBLayer *videolayer; 00054 00055 //! number of layers 00056 int layercount; 00057 00058 //! id of the osd layer, in one layer mode it is equal to video layer id 00059 int graphicslayerid; 00060 00061 //! id of the video layer, in one layer mode it is equal to osd layer id 00062 int videolayerid; 00063 00064 public: 00065 // constructor 00066 MMSFBManager(); 00067 00068 // destructor 00069 ~MMSFBManager(); 00070 00071 bool init(int argc, char **argv, 00072 string appl_name = "Disko Application", string appl_icon_name = "Disko Application", 00073 bool virtual_console = true, bool flip_flush = false); 00074 void release(); 00075 00076 void applySettings(); 00077 MMSFBLayer *getVideoLayer(); 00078 MMSFBLayer *getGraphicsLayer(); 00079 00080 int getLayerCount(); 00081 }; 00082 00083 // access to global mmsfbmanager 00084 extern MMSFBManager mmsfbmanager; 00085 00086 #endif /*MMSFBMANAGER_H_*/