Welcome, Guest. Please login or register. Did you miss your activation email?

Author Topic: [SOLVED] Thread acting differently than in SDL  (Read 5324 times)

0 Members and 1 Guest are viewing this topic.

jValdron

  • Newbie
  • *
  • Posts: 5
    • View Profile
[SOLVED] Thread acting differently than in SDL
« on: September 07, 2011, 08:15:28 pm »
Hello from Canada! (French Canadian, but nope not a "Quebecois")

I'm new to SFML, as of today. I'm porting my SDL application to SFML 1.6 for performance reasons. A simple 1080p video is rendering about 4x faster in SFML.

So, I got a problem with my threads... I'm not really an expert with C++ nor an expert with multi-threading.

The problem is that I create and launch a thread in the constructor of one of my classes, but my main loop (in which the object is created, hence the constructor called), doesn't display the RenderWindow until the thread is finished. Which is the reason I want to have threads.

So here is an example of my situation (not the exact code, but you'll understand):

main.cpp
Code: [Select]

new Scene();

while(App->IsRunning())
{
    ... my render stuff, that only starts after the thread is terminated (so after the FadeInThread method is done) ...    
}


Scene.cpp
Code: [Select]

Scene::Scene(sf::RenderWindow* Window, float Length)
{
   
    ... some code ...

    this->fadeIn();
   
}

void Scene::FadeIn()
{

    this->Opacity = 0;
    sf::Thread Thread(FadeInWrap, this);
    Thread.Launch();
    // SDL : SDL_CreateThread(FadeInWrap, this);

}

// This is a static method.
void FadeInWrap(void* Scn)
{
    ((Scene*) Scn)->FadeInThread();
}

void Scene::FadeInThread()
{
 
    float Delay = 0.007;
   
    while(this->Opacity < 255)
    {
        this->Opacity++;
        sf::Sleep(Delay);
        // SDL: SDL_Delay(Delay); (Delay was an int calculated differently)
    }
   
}


I know the static to non-static method is kinda weird, but only way I found out in SDL.

There's not much of a difference between a thread in SDL and in SFML, as far as I can see. Just don't understand why it doesn't continue the main execution while performing an operation in a thread.

Basically, if I launch my application, there's a 1.785 second delay because of the FadeInThread.

Could anyone help me out? I'm currently using the SDL_Thread, it works along SFML, but why import and use a huge library when SFML could do that for me.

Groogy

  • Hero Member
  • *****
  • Posts: 1469
    • MSN Messenger - groogy@groogy.se
    • View Profile
    • http://www.groogy.se
    • Email
[SOLVED] Thread acting differently than in SDL
« Reply #1 on: September 07, 2011, 08:25:26 pm »
Can you reproduce the problem in an minimal example?

From what I can see it looks like you have the window created in one thread but used in another right? Does the creating thread use the window for anything at the same time? Did you remember to activate the window's context in the new thread?
Developer and Maker of rbSFML and Programmer at Paradox Development Studio

jValdron

  • Newbie
  • *
  • Posts: 5
    • View Profile
[SOLVED] Thread acting differently than in SDL
« Reply #2 on: September 07, 2011, 08:35:29 pm »
I don't use the window in the other thread, just modify a variable so that in my main rendering loop, it changes the opacity.

I must be the one that didn't understood something somewhere... but I just create a quick sample of the problem:

main.cpp
Code: [Select]

#include <iostream>
#include <SFML/Graphics.hpp>

 
int Opacity = 255;
bool Running = true;

void FadeInThread(void* Data)
{
 
    float Delay = 0.007;
   
    while(Opacity <= 255)
    {
        std::cout << "Fade is at " << Opacity << std::endl;
        Opacity++;
        sf::Sleep(Delay);
    }
   
    std::cout << "Thread terminated" << std::endl;
   
}

void FadeIn()
{

    Opacity = 0;
    sf::Thread Thread(FadeInThread);
    Thread.Launch();

}

int main()
{
   
    sf::RenderWindow App(sf::VideoMode(800, 600, 32), "SFML Window");

    // Usually this is a video, or image, or text that I fade in and out
    sf::Image Image(200, 200, sf::Color(0, 255, 0, Opacity));
    sf::Sprite Sprite;
    Sprite.SetImage(Image);
   
    FadeIn();
   
    while(Running)
    {
       
        // Start - Non related event handling stuff
        sf::Event Event;
        while(App.GetEvent(Event))
        {
            if(Event.Type == sf::Event::Closed || (Event.Type == sf::Event::KeyPressed) && (Event.Key.Code == sf::Key::Escape))
            {
                Running = false;
            }
        }
        // End - Non related event handling stuff
       
        App.Clear();

        // Here I apply the opacity to the image, so that it "fades in"
        Sprite.SetColor(sf::Color(0, 255, 0, Opacity));
        App.Draw(Sprite);
       
        App.Display();
       
    }
   
    return 0;
   
}

Groogy

  • Hero Member
  • *****
  • Posts: 1469
    • MSN Messenger - groogy@groogy.se
    • View Profile
    • http://www.groogy.se
    • Email
[SOLVED] Thread acting differently than in SDL
« Reply #3 on: September 07, 2011, 08:41:37 pm »
On my phone so can't test it but looks like it should run.

Also threads for this is way overkill! Use the delta time for animations!
Developer and Maker of rbSFML and Programmer at Paradox Development Studio

Laurent

  • Administrator
  • Hero Member
  • *****
  • Posts: 32498
    • View Profile
    • SFML's website
    • Email
[SOLVED] Thread acting differently than in SDL
« Reply #4 on: September 07, 2011, 08:56:28 pm »
The sf::Thread object has to remain alive as long as the thread function runs. The destructor of sf::Thread calls Wait(). So declaring a sf::Thread instance locally to a function has no effect.

But you definitely don't need a thread for this, you can handle the fading in your main loop.
Laurent Gomila - SFML developer

jValdron

  • Newbie
  • *
  • Posts: 5
    • View Profile
[SOLVED] Thread acting differently than in SDL
« Reply #5 on: September 08, 2011, 03:12:14 pm »
Thanks, definitely gives me an insight on how thread works. I did change everything to a delta time like technique. All good now, no more SDL :)