How do I output 3D images to my 3D TV?

后端 未结 2 1332
余生分开走
余生分开走 2021-02-05 22:42

I have a 3D TV and feel that I would be shirking my responsibilities (as a geek) if I didn\'t at least try to make it display pretty 3D images of my own creation!

I\'ve

相关标签:
2条回答
  • 2021-02-05 23:07

    Because you have a passive 3D TV, it's likely that the left and right eye views are rendered on alternate scan lines. (or perhaps on alternate pixels in a checkerboard pattern)

    Thus your mission is to render the left-eye view to the even numbered scan lines, and the right eye view to the odd numbered scan lines (or vice versa). This can be accomplished either via OpenGL stencil operations, or, more modernly, using custom fragment shaders.

    This way, you can avoid the whole quad-buffered video card/GL_BACK_LEFT/GL_BACK_RIGHT approach described by datenwolf. And you want to avoid that approach, as I have never encountered a video driver that directs quad-buffered stereo 3D to an actual 3D TV.

    I agree with datenwolf's advice that you should use asymmetric frustum shift rather than scene rotation to generate the right and left eye viewpoints.

    0 讨论(0)
  • 2021-02-05 23:21

    The main problem is, getting your GPU to send a stereoscopic format. In the case of a HDMI connection this will not work without the help of a driver. If you have a professional grade GPU (Quadro, FireGL), then they likely support OpenGL quadbuffers, i.e. you get framebuffers for the left and right eye, both back and front:

    glDrawBuffer(GL_BACK_LEFT);
    render_left_eye();
    
    glDrawBuffer(GL_BACK_RIGHT);
    render_right_eye();
    
    glDrawBuffer(GL_BACK); // renders to both eyes simultanously
    render_screen_level_and_nonstereoscopic();
    
    SwapBuffers();
    

    Unfortunately OpenGL quad buffer is considered professional grade stuff.

    Instead NVidia (at least) provides a customary stereoscopy library plus some extensions to control it. The main reasoning is, that shared fragments are to be rendered only once and then sent to both eyes with the appropirate parallax applied. However from my semi-professional experiences with stereoscopy¹, these kinds of semi-/automatic stereoscopifications just don't cut it. Stereoscopy requires tight control of the whole "production" pipeline, otherwise you're screwed. With Elephants Dream I went as far as modifying the renderer's core code.

    I sent the people at the 3D devision at NVidia some case scenarios where you need exact control over the stereoscopy process, and I hope they will see the light and give access to quad buffer stereo also on consumer grade hardware.

    Note that I understand the basics of how 3D works (render the same image twice from 2 different angles, one for each eye)

    Actually you don't render from two different angles but with a shifted parallax and lens shift. Otherwise you get some trapezoidal/keystone distortion in the horizontal, which are very, very unpleasant to watch (in fact I now think that in the stereoscopic rendering process one should slightly diverge the optical axes – i.e. doing the complete contrary to what one would naively do – and "over"compensate with lens shift, I'm currently preparing a small study about this, but still need to gather my testing and control groups).


    1: heck, I'm the guy who single-handedly stereographed Elephants Dream, rendered it and got it an award at a 3D movie festival.

    0 讨论(0)
提交回复
热议问题