int main() { // ask user for driver video::E_DRIVER_TYPE driverType=driverChoiceConsole(); if (driverType==video::EDT_COUNT) return 1; // create device and exit if creation failed Device = createDevice(driverType, core::dimension2d<u32>(640, 480)); if(Device == NULL) return 1; IVideoDriver *Driver = Device->getVideoDriver(); IGUIEnvironment* env = Device->getGUIEnvironment(); ISceneManager *Scene = Device->getSceneManager(); Scene->addCameraSceneNode(0, vector3df(0,10,-40), vector3df(0,0,0)); MyEventReceiver receiver; Device->setEventReceiver(&receiver); // Load fonts fonts[0] = env->getFont(FONTPATH1); fonts[1] = env->getFont(FONTPATH1); fonts[2] = env->getFont(FONTPATH2); fonts[3] = env->getFont(FONTPATH2); fonts[4] = env->getFont(FONTPATH3); fonts[5] = env->getFont(FONTPATH3); font = fonts[0]; font2 = fonts[1]; skin = env->getSkin(); skin->setFont(font); txtTrans = env->addStaticText(L"Transparency:", rect<s32>(50,20,250,40), true); IGUIScrollBar* scrollbar = env->addScrollBar(true, rect<s32>(50, 45, 250, 60), 0, 104); scrollbar->setMax(255); SColor col = env->getSkin()->getColor((EGUI_DEFAULT_COLOR)0); scrollbar->setPos(col.getAlpha()); txtLog = env->addStaticText(L"Logging ListBox:", rect<s32>(50,80,250,100), true); listbox = env->addListBox(rect<s32>(50, 110, 250, 180)); btnQuit = env->addButton(rect<s32>(10,210,100,240), 0, 101, L"Quit"); btnNew = env->addButton(rect<s32>(10,250,100,290), 0, 102, L"New Window"); btnFile = env->addButton(rect<s32>(10,300,100,340), 0, 103, L"Open File"); edtName = env->addEditBox(L"",rect<s32>(300,60,580,80)); edtName->setMax(40); edtMemo = env->addEditBox(L"",rect<s32>(300,100,580,450)); edtMemo->setMultiLine(true); edtMemo->setTextAlignment(EGUIA_UPPERLEFT, EGUIA_UPPERLEFT); lstLang = env->addListBox(rect<s32>(10, 400, 250, 470),0,120); lstLang->addItem(L"Arial"); lstLang->addItem(L"Times Roman"); lstLang->addItem(L"MS-Gothic(Japanese)"); lstLang->setSelected(0); int lastFPS = -1; while(Device->run()) { Driver->beginScene(true, true, SColor(0,64,64,128)); Scene->drawAll(); if (!lang){ font2->draw(L"Hello TrueType",rect<s32>(250,20,640,100),SColor(255,255,64,64),true); } else { font2->draw(jtxtHello,rect<s32>(250,20,640,100),SColor(255,255,64,64),true); } env->drawAll(); Driver->endScene(); int fps = Driver->getFPS(); if (lastFPS != fps) { wchar_t tmp[1024]; //snwprintf(tmp, 1024, L"Irrlicht TrueType Demo (fps:%d)", fps); swprintf(tmp, L"Irrlicht TrueType Demo (fps:%d)", fps); Device->setWindowCaption(tmp); lastFPS = fps; } } #if !defined(_IRR_COMPILE_WITH_CGUITTFONT_) for(int i= 0; i < 6; i++) { if(fonts[i] != NULL) fonts[i]->drop(); } #endif Device->drop(); return 0; }
int main() { video::E_DRIVER_TYPE driverType = driverChoiceConsole(); if (driverType==video::EDT_COUNT) return 1; IrrlichtDevice * device = createDevice(driverType, dimension2d<u32>(640, 480)); if (device == 0) return 1; // could not create selected driver. // It's sometimes of interest to know how the mouse behaves after a resize device->setResizable(true); device->setWindowCaption(L"Cursor control - Irrlicht engine tutorial"); video::IVideoDriver* driver = device->getVideoDriver(); IGUIEnvironment* env = device->getGUIEnvironment(); gui::IGUISpriteBank * SpriteBankIcons; SAppContext context; context.Device = device; rect< s32 > rectInfoStatic(10,10, 200, 200); env->addStaticText (L"Cursor state information", rectInfoStatic, true, true); rectInfoStatic.UpperLeftCorner += dimension2di(0, 15); context.InfoStatic = env->addStaticText (L"", rectInfoStatic, true, true); rect< s32 > rectEventBox(10,210, 200, 400); env->addStaticText (L"click events (new on top)", rectEventBox, true, true); rectEventBox.UpperLeftCorner += dimension2di(0, 15); context.EventBox = env->addListBox(rectEventBox); rect< s32 > rectCursorBox(210,10, 400, 250); env->addStaticText (L"cursors, click to set the active one", rectCursorBox, true, true); rectCursorBox.UpperLeftCorner += dimension2di(0, 15); context.CursorBox = env->addListBox(rectCursorBox); rect< s32 > rectSpriteBox(210,260, 400, 400); env->addStaticText (L"sprites", rectSpriteBox, true, true); rectSpriteBox.UpperLeftCorner += dimension2di(0, 15); context.SpriteBox = env->addListBox(rectSpriteBox); context.ButtonSetVisible = env->addButton( rect<s32>( 410, 20, 560, 40 ), 0, -1, L"set visible (delayed)" ); context.ButtonSetInvisible = env->addButton( rect<s32>( 410, 50, 560, 70 ), 0, -1, L"set invisible (delayed)" ); context.ButtonSimulateBadFps = env->addButton( rect<s32>( 410, 80, 560, 100 ), 0, -1, L"simulate bad FPS" ); context.ButtonSimulateBadFps->setIsPushButton(true); context.ButtonChangeIcon = env->addButton( rect<s32>( 410, 140, 560, 160 ), 0, -1, L"replace cursor icon\n(cursor+sprite must be selected)" ); // set the names for all the system cursors for ( int i=0; i < (int)gui::ECI_COUNT; ++i ) { context.CursorBox->addItem(stringw( GUICursorIconNames[i] ).c_str()); } /* Create sprites which then can be used as cursor icons. */ SpriteBankIcons = env->addEmptySpriteBank(io::path("cursor_icons")); context.SpriteBox->setSpriteBank(SpriteBankIcons); const io::path mediaPath = getExampleMediaPath(); // create one animated icon from several files array< io::path > files; files.push_back( io::path(mediaPath + "icon_crosshairs16x16bw1.png") ); files.push_back( io::path(mediaPath + "icon_crosshairs16x16bw2.png") ); files.push_back( io::path(mediaPath + "icon_crosshairs16x16bw3.png") ); files.push_back( io::path(mediaPath + "icon_crosshairs16x16bw3.png") ); files.push_back( io::path(mediaPath + "icon_crosshairs16x16bw2.png") ); SCursorSprite spriteBw; // the sprite + some additional information needed for cursors spriteBw.SpriteId = AddAnimatedIconToSpriteBank( SpriteBankIcons, driver, files, 200 ); spriteBw.SpriteBank = SpriteBankIcons; spriteBw.HotSpot = position2d<s32>(7,7); context.addIcon(L"crosshair_bw", spriteBw); // create one animated icon from one file array< rect<s32> > iconRects; iconRects.push_back( rect<s32>(0,0, 16, 16) ); iconRects.push_back( rect<s32>(16,0, 32, 16) ); iconRects.push_back( rect<s32>(0,16, 16, 32) ); iconRects.push_back( rect<s32>(0,16, 16, 32) ); iconRects.push_back( rect<s32>(16,0, 32, 16) ); SCursorSprite spriteCol; // the sprite + some additional information needed for cursors spriteCol.SpriteId = AddAnimatedIconToSpriteBank( SpriteBankIcons, driver, io::path(mediaPath + "icon_crosshairs16x16col.png"), iconRects, 200 ); spriteCol.HotSpot = position2d<s32>(7,7); spriteCol.SpriteBank = SpriteBankIcons; context.addIcon(L"crosshair_colored", spriteCol); // Create some non-animated icons rect<s32> rectIcon; SCursorSprite spriteNonAnimated(SpriteBankIcons, 0, position2d<s32>(7,7)); rectIcon = rect<s32>(0,0, 16, 16); spriteNonAnimated.SpriteId = AddIconToSpriteBank( SpriteBankIcons, driver, io::path(mediaPath + "icon_crosshairs16x16col.png"), rectIcon ); context.addIcon(L"crosshair_col1", spriteNonAnimated, false); rectIcon = rect<s32>(16,0, 32, 16); spriteNonAnimated.SpriteId = AddIconToSpriteBank( SpriteBankIcons, driver, io::path(mediaPath + "icon_crosshairs16x16col.png"), rectIcon ); context.addIcon(L"crosshair_col2", spriteNonAnimated, false); rectIcon = rect<s32>(0,16, 16, 32); spriteNonAnimated.SpriteId = AddIconToSpriteBank( SpriteBankIcons, driver, io::path(mediaPath + "icon_crosshairs16x16col.png"), rectIcon ); context.addIcon(L"crosshair_col3", spriteNonAnimated, false); MyEventReceiver receiver(context); device->setEventReceiver(&receiver); while(device->run() && driver) { // if (device->isWindowActive()) { u32 realTimeNow = device->getTimer()->getRealTime(); context.update(); driver->beginScene(video::ECBF_COLOR | video::ECBF_DEPTH, SColor(0,200,200,200)); env->drawAll(); // draw custom sprite with Irrlicht functions for comparison. It should usually look the same as the cursors. if ( context.SpriteBox ) { s32 selectedSprite = context.SpriteBox->getSelected(); if ( selectedSprite >= 0 && context.Sprites[selectedSprite].SpriteId >= 0 ) { SpriteBankIcons->draw2DSprite(u32(context.Sprites[selectedSprite].SpriteId), position2di(580, 140), 0, video::SColor(255, 255, 255, 255), 0, realTimeNow); } } driver->endScene(); } // By simulating bad fps we can find out if hardware-support for cursors works or not. If it works the cursor will move as usual,while it otherwise will just update with 2 fps now. if ( context.SimulateBadFps ) { device->sleep(500); // 2 fps } else { device->sleep(10); } } device->drop(); return 0; }
/* Ok, now for the more interesting part. First, create the Irrlicht device. As in some examples before, we ask the user which driver he wants to use for this example: */ int main() { // ask user for driver video::E_DRIVER_TYPE driverType=driverChoiceConsole(); if (driverType==video::EDT_COUNT) return 1; // create device and exit if creation failed IrrlichtDevice * device = createDevice(driverType, core::dimension2d<u32>(640, 480)); if (device == 0) return 1; // could not create selected driver. /* The creation was successful, now we set the event receiver and store pointers to the driver and to the gui environment. */ device->setWindowCaption(L"Irrlicht Engine - User Interface Demo"); device->setResizable(true); video::IVideoDriver* driver = device->getVideoDriver(); IGUIEnvironment* env = device->getGUIEnvironment(); /* To make the font a little bit nicer, we load an external font and set it as the new default font in the skin. To keep the standard font for tool tip text, we set it to the built-in font. */ IGUISkin* skin = env->getSkin(); IGUIFont* font = env->getFont("../../media/fonthaettenschweiler.bmp"); if (font) skin->setFont(font); skin->setFont(env->getBuiltInFont(), EGDF_TOOLTIP); /* We add three buttons. The first one closes the engine. The second creates a window and the third opens a file open dialog. The third parameter is the id of the button, with which we can easily identify the button in the event receiver. */ env->addButton(rect<s32>(10,240,110,240 + 32), 0, GUI_ID_QUIT_BUTTON, L"Quit", L"Exits Program"); env->addButton(rect<s32>(10,280,110,280 + 32), 0, GUI_ID_NEW_WINDOW_BUTTON, L"New Window", L"Launches a new Window"); env->addButton(rect<s32>(10,320,110,320 + 32), 0, GUI_ID_FILE_OPEN_BUTTON, L"File Open", L"Opens a file"); /* Now, we add a static text and a scrollbar, which modifies the transparency of all gui elements. We set the maximum value of the scrollbar to 255, because that's the maximal value for a color value. Then we create an other static text and a list box. */ env->addStaticText(L"Transparent Control:", rect<s32>(150,20,350,40), true); IGUIScrollBar* scrollbar = env->addScrollBar(true, rect<s32>(150, 45, 350, 60), 0, GUI_ID_TRANSPARENCY_SCROLL_BAR); scrollbar->setMax(255); // set scrollbar position to alpha value of an arbitrary element scrollbar->setPos(env->getSkin()->getColor(EGDC_WINDOW).getAlpha()); env->addStaticText(L"Logging ListBox:", rect<s32>(50,110,250,130), true); IGUIListBox * listbox = env->addListBox(rect<s32>(50, 140, 250, 210)); env->addEditBox(L"Editable Text", rect<s32>(350, 80, 550, 100)); // Store the appropriate data in a context structure. SAppContext context; context.device = device; context.counter = 0; context.listbox = listbox; // Then create the event receiver, giving it that context structure. MyEventReceiver receiver(context); // And tell the device to use our custom event receiver. device->setEventReceiver(&receiver); /* And at last, we create a nice Irrlicht Engine logo in the top left corner. */ env->addImage(driver->getTexture("../../media/irrlichtlogo2.png"), position2d<int>(10,10)); /* That's all, we only have to draw everything. */ while(device->run() && driver) if (device->isWindowActive()) { driver->beginScene(true, true, SColor(0,200,200,200)); env->drawAll(); driver->endScene(); } device->drop(); return 0; }
void MultiBouncerGame::initGUI() { //TODO: Filesystem tools //Clear file names m_MapFiles.clear(); if( !filesystem::exists( "maps" ) ) { std::cout << "Directory maps does not exist!" << std::endl; exit( EXIT_FAILURE ); } //Read bouncer and map file names filesystem::directory_iterator end; for( filesystem::directory_iterator x( "maps" ); x != end; x++ ) m_MapFiles.push_back( x->path() ); for( unsigned int x = 0; x < m_MapFiles.size(); x++ ) { ConfigStorage *conf = new ConfigStorage(); conf->parseXMLFile( m_MapFiles.at( x ).string().c_str(), "Data" ); m_MapData.push_back( conf ); } //Get gui environment //TODO: Add a better method for gui management IGUIEnvironment *gui = m_Engine->getIrrlichtDevice()->getGUIEnvironment(); //some defines for easier size definitions #define W mWinWidth #define H mWindHeight #define W2 (W/2) #define H2 (H/2) #define W4 (W/4) #define H4 (H/4) //Add main menu window m_MainMenu = gui->addWindow( recti( 20, 20, W - 20, H - 20 ), false, L"MainMenu" ); m_MainMenu->getCloseButton()->setVisible( false ); m_MainMenu->setDraggable( false ); m_MainMenu->setDrawTitlebar( false ); //Add the reconnect button mReconnectButton = gui->addButton( recti( 10, 10, 410, 60 ), m_MainMenu, -1, L"(Re)connect wiimotes" ); mReconnectButton->setVisible( m_Engine->getConfig()->get<bool>( "UseWiimotes", false ) ); //Add the bouncer list m_MapList = gui->addListBox( recti( W4, H4, 3 * W4, 3 * H4 ), m_MainMenu, -1, true ); for( unsigned int x = 0; x < m_MapFiles.size(); x++ ) m_MapList->addItem( stringw( m_MapData.at( x )->get<String>( "MapName", "No Name!" ) ).c_str() ); m_OkButton = gui->addButton( recti( W4, 3 * H4 + 10, W2 - 5, 3 * H4 + 60 ), m_MainMenu, -1, L"Start" ); m_PlayerCounter = gui->addSpinBox( L"Spieleranzahl:", recti( W2 + 4, 3 * H4 + 10, 3 * W4, 3 * H4 + 60 ), true, m_MainMenu ); m_PlayerCounter->getEditBox()->setTextAlignment( irr::gui::EGUIA_CENTER, irr::gui::EGUIA_CENTER ); m_PlayerCounter->setDecimalPlaces( 0 ); m_PlayerCounter->setRange( 1.f, 32.f ); m_PlayerCounter->setValue( 2.f ); //Create ingame gui //Upper window for scores etc. mScoreWindow = gui->addWindow( recti( 0, 0, W, 50 ) ); mScoreWindow->setDraggable( false ); mScoreWindow->setDrawTitlebar( false ); mScoreWindow->getCloseButton()->setVisible( false ); mScoreCounter = gui->addStaticText( TEXT_SCORE_ZERO, recti( W4, 0, 3 * W4, 50 ), false, false, mScoreWindow ); mScoreCounter->setTextAlignment( irr::gui::EGUIA_CENTER, irr::gui::EGUIA_CENTER ); mScoreCounter->setOverrideColor( SColor( 255, 255, 255, 255 ) ); //undefine sizes #undef W #undef H #undef W2 #undef H2 #undef W4 #undef H4 //hide all windows m_MainMenu->setVisible( false ); mScoreWindow->setVisible( false ); }
/* OK, now for the more interesting part. First, create the Irrlicht device. As in some examples before, we ask the user which driver he wants to use for this example. */ int main() { // create device and exit if creation failed IrrlichtDevice * device = createDevice(EDT_OPENGL,core::dimension2d<u32>(640, 480)); if (device == 0) return 1; // could not create selected driver. /* The creation was successful, now we set the event receiver and store pointers to the driver and to the gui environment. */ device->setWindowCaption(L"Irrlicht Engine - User Interface Demo"); device->setResizable(true); video::IVideoDriver* driver = device->getVideoDriver(); IGUIEnvironment* env = device->getGUIEnvironment(); const io::path mediaPath = getExampleMediaPath(); /* To make the font a little bit nicer, we load an external font and set it as the new default font in the skin. To keep the standard font for tool tip text, we set it to the built-in font. */ IGUISkin* skin = env->getSkin(); IGUIFont* font = env->getFont(mediaPath + "fonthaettenschweiler.bmp"); if (font) skin->setFont(font); skin->setFont(env->getBuiltInFont(), EGDF_TOOLTIP); /* We add three buttons. The first one closes the engine. The second creates a window and the third opens a file open dialog. The third parameter is the id of the button, with which we can easily identify the button in the event receiver. */ env->addButton(rect<s32>(10,240,110,240 + 32), 0, GUI_ID_QUIT_BUTTON, L"Quit", L"Exits Program"); env->addButton(rect<s32>(10,280,110,280 + 32), 0, GUI_ID_NEW_WINDOW_BUTTON, L"New Window", L"Launches a new Window"); env->addButton(rect<s32>(10,320,110,320 + 32), 0, GUI_ID_FILE_OPEN_BUTTON, L"File Open", L"Opens a file"); /* Now, we add a static text and a scrollbar, which modifies the transparency of all gui elements. We set the maximum value of the scrollbar to 255, because that's the maximal value for a color value. Then we create an other static text and a list box. */ env->addStaticText(L"Transparent Control:", rect<s32>(150,20,350,40), true); IGUIScrollBar* scrollbar = env->addScrollBar(true, rect<s32>(150, 45, 350, 60), 0, GUI_ID_TRANSPARENCY_SCROLL_BAR); scrollbar->setMax(255); scrollbar->setPos(255); setSkinTransparency( scrollbar->getPos(), env->getSkin()); // set scrollbar position to alpha value of an arbitrary element scrollbar->setPos(env->getSkin()->getColor(EGDC_WINDOW).getAlpha()); env->addStaticText(L"Logging ListBox:", rect<s32>(10,110,350,130), true); IGUIListBox * listbox = env->addListBox(rect<s32>(10, 140, 350, 210)); env->addEditBox(L"Editable Text", rect<s32>(350, 80, 550, 100)); // Store the appropriate data in a context structure. SAppContext context; context.device = device; context.counter = 0; context.listbox = listbox; // Then create the event receiver, giving it that context structure. MyEventReceiver receiver(context); // And tell the device to use our custom event receiver. device->setEventReceiver(&receiver); /* And at last, we create a nice Irrlicht Engine logo in the top left corner. */ env->addImage(driver->getTexture(mediaPath + "irrlichtlogo2.png"), position2d<int>(10,10)); /* That's all, we only have to draw everything. */ fluid_settings_t* settings; fluid_synth_t* synth = NULL; fluid_audio_driver_t* adriver = NULL; int err = 0; struct fx_data_t fx_data; // // if (argc != 3) { // fprintf(stderr, "Usage: fluidsynth_simple [soundfont] [gain]\n"); // return 1; // } // /* Create the settings object. This example uses the default * values for the settings. */ settings = new_fluid_settings(); if (settings == NULL) { fprintf(stderr, "Failed to create the settings\n"); err = 2; goto cleanup; } /* Create the synthesizer */ synth = new_fluid_synth(settings); if (synth == NULL) { fprintf(stderr, "Failed to create the synthesizer\n"); err = 3; goto cleanup; } /* Load the soundfont */ // if (fluid_synth_sfload(synth, "soundfonts/example.sf2", 1) == -1) { if (fluid_synth_sfload(synth, "soundfonts/VintageDreamsWaves-v2.sf2", 1) == -1) { // if (fluid_synth_sfload(synth, "soundfonts/VintageDreamsWaves-v2.sf3", 1) == -1) { // if (fluid_synth_sfload(synth, "soundfonts/philharmonia_violin_short.gig", 1) == -1) { //was to check and see if it had gig support but no. fprintf(stderr, "Failed to load the SoundFont\n"); err = 4; goto cleanup; } /* Fill in the data of the effects unit */ fx_data.synth = synth; fx_data.gain = 10; //atof(argv[2]); /* Create the audio driver. As soon as the audio driver is * created, the synthesizer can be played. */ fluid_settings_setstr(settings, "audio.driver", "alsa"); adriver = new_fluid_audio_driver2(settings, fx_function, (void*) &fx_data); if (adriver == NULL) { fprintf(stderr, "Failed to create the audio driver\n"); err = 5; goto cleanup; } while(device->run() && driver) if (device->isWindowActive()) { driver->beginScene(video::ECBF_COLOR | video::ECBF_DEPTH, SColor(0,200,200,200)); env->drawAll(); /* Play a note */ fluid_synth_noteon(synth, 0, 60, 100); // printf("Press \"Enter\" to stop: "); // fgetc(stdin); // printf("done\n"); driver->endScene(); } cleanup: if (adriver) { delete_fluid_audio_driver(adriver); } if (synth) { delete_fluid_synth(synth); } if (settings) { delete_fluid_settings(settings); } device->drop(); return 0; }
bool ProcTitle::OnInit(irr::IrrlichtDevice& device) { device.setWindowCaption(L"Pair - title"); //device.getCursorControl()->setVisible(false); u32 width = IrrDvc.GetDriver()->getScreenSize().Width; u32 height = IrrDvc.GetDriver()->getScreenSize().Height; scene::ISceneManager* pSmgr = IrrDvc.GetSmgr(); IVideoDriver* pDriver = IrrDvc.GetDriver(); // camera setting { irr::scene::ICameraSceneNode* pCamera = pSmgr->addCameraSceneNode(0, core::vector3df(0,0,-100), core::vector3df(0,0,0)); //f32 zNear = 1; //f32 zFar = 3000; //f32 zNear = pCamera->getNearValue(); //f32 zFar = pCamera->getFarValue(); #if 0 CMatrix4<f32> matOrtho; matOrtho.buildProjectionMatrixOrthoLH(width, height, zNear, zFar); pCamera->setProjectionMatrix(matOrtho, true); #else //CMatrix4<f32> matPerspective; //matPerspective.buildProjectionMatrixPerspectiveLH((f32)width, (f32)height, zNear, zFar); //pCamera->setProjectionMatrix(matPerspective, false); #endif } // title { m_p2DSprite = pSmgr->addBillboardSceneNode(); video::ITexture* pTexture = pDriver->getTexture("Rsrc/title.png"); m_p2DSprite->setMaterialTexture(0, pTexture); m_p2DSprite->setMaterialFlag(video::EMF_LIGHTING, false); m_p2DSprite->setMaterialFlag(video::EMF_ZBUFFER, true); m_p2DSprite->setMaterialFlag(video::EMF_ZWRITE_ENABLE, false); m_p2DSprite->setMaterialFlag(video::EMF_ANTI_ALIASING, true); m_p2DSprite->setMaterialFlag(video::EMF_BILINEAR_FILTER, true); m_p2DSprite->setSize(dimension2df((f32)width, (f32)height)); m_p2DSprite->setPosition(vector3df(0.f, 0.f, 300.f)); m_p2DSprite->setID(1004); m_p2DSprite->getMaterial(0).getTextureMatrix(0).setTextureScale(1.0f, 1.0f); // animation test //scene::ISceneNodeAnimator* pAni = pSmgr->createFlyCircleAnimator(core::vector3df(0,0,200), 20.0f); //m_p2DSprite->addAnimator(pAni); } // card { for (int i = 0; i < 3; i++) { IMeshSceneNode* pCard = pSmgr->addCubeSceneNode(); char buff[20]; sprintf_s(buff, 20, "Rsrc/card%d.png", i); video::ITexture* pTexture = pDriver->getTexture(buff); pCard->setMaterialTexture(0, pTexture); pCard->setScale(vector3df(4.f, 4.f * 1.618f, 0.1f)); pCard->setPosition(vector3df(-60.f + 60.f * i, 0.f, 0.f)); pCard->setMaterialFlag(video::EMF_LIGHTING, false); // animation test scene::ISceneNodeAnimator* pAni = pSmgr->createRotationAnimator(vector3df(0.f, 1.f, 0.f)); pCard->addAnimator(pAni); pAni->drop(); } } // mesh { IAnimatedMesh* mesh = pSmgr->getMesh("Rsrc/sydney.md2"); IAnimatedMeshSceneNode* pNode = pSmgr->addAnimatedMeshSceneNode(mesh); if (pNode) { //pNode->setScale(vector3df(10.f, 10.f, 10.f)); pNode->setMaterialFlag(EMF_LIGHTING, false); //pNode->setMaterialFlag(EMF_ZBUFFER, false); pNode->setMD2Animation(scene::EMAT_STAND); pNode->setMaterialTexture( 0, pDriver->getTexture("Rsrc/sydney.bmp") ); pNode->setPosition(vector3df(0.0f, -5.f, -55.f)); } } // button { IGUIEnvironment* env = device.getGUIEnvironment(); video::ITexture* pTexture = pDriver->getTexture("Rsrc/new_game_btn_normal.PNG"); // refcount = 1 dimension2d<u32> dim = pTexture->getOriginalSize(); s32 offsetX = width / 2 - dim.Width / 2; s32 offsetY = height - dim.Height * 3; IGUIButton* pButton = env->addButton(rect<s32>(offsetX, offsetY, offsetX + dim.Width, offsetY + dim.Height), 0, GUI_ID_START_BUTTON); pButton->setDrawBorder(false); pButton->setImage(pTexture); // refcount += 2, means when button released refcount will be 1 pButton->setUseAlphaChannel(true); // 1 will be decreased pDriver->removeAllTextures(); { ITexture* pTexture = pDriver->getTexture("Rsrc/new_game_btn_pressed.PNG"); pButton->setPressedImage(pTexture); } } // sound test IrrSnd.GetSndEngine()->play2D("Rsrc/getout.ogg", true); return true; }