Hacker News new | past | comments | ask | show | jobs | submit login

> It reminds me of a lot of the attitudes surrounding C++ when I was first learning it-- yes, it's more lines of code, but that doesn't mean it can't be a fine place for a beginner to start learning.

Sure, but Vulkan really feels like another level of complexity. OpenGL is simple in comparison.




Programming anything non trivial in OpenGL that is intended to be used on a variety of GPU's in an efficient manner, is a royal pain in the butt. This is because of the black box that opengl provides. This makes things simpler but I'd rather deal with the complexity of the API, rather than "hope and prey" style programming that opengl accepts (encourages).


It may feel like it, but when you consider all of OpenGL's versions and extensions where it quickly becomes an ugly mess, that feeling disappears.

Vulkan feels more like a breath of fresh air in comparison, and its still higher level than the APIs we get on consoles.

I find it much simpler to architect engines with Vulkan in mind than OpenGL.


Well, libraries and frameworks have solved problems like that before and probably will again.


Low level graphics programming is tough, specialist work. Imagine a relatively simple stateful API layer over the top of this stuff, widely adopted and with an open spec. We could call it the Open Graphics Library, or OpenGL for short.


Well, as I understand it the issue with OpenGL was that it was very high-level without an option to drop to a lower level on demand since it was implemented in a complex GPU driver. This meant that drivers mostly had to guess what the intention was, and be optimized for e.g. specific games inside of the driver. With Vukan and a high-level library, you would have the option of dropping down to a lower level if you want and making those optimisations yourself. Keeping the complexity inside of the library, not the driver means you can modify it as you wish.


And a horribly painful codebase that is a horror to work with.

Nowadays people are more comfortable with having objects that represent something, and executing operations on them, than having to bind an object to a global variable, execute a global procedure, and unbinding it.


You think so? I think people like to call functions with comprehensible arguments.

I don't agree that people like to bind an object to a global variable, execute a global procedure, and unbind it. Does that sound like the API of anyone's dreams? The binding and unbinding sounds like pure overhead to me.

I understand that very high performance and easy API may not be achievable, but seriously, the modern graphics APIs are hard to love.


> I don't agree that people like to bind an object to a global variable, execute a global procedure, and unbind it. Does that sound like the API of anyone's dreams? The binding and unbinding sounds like pure overhead to me.

Isn't that how OpenGL works?


Not in the old days, no.

glColor3f( 1,0,0 );

glBegin( GL_POLYGON );

glVertex3f( 0,0,0 );

glVertex3f( 1,1,0 );

glVertex3f( 1,2,0 );

glEnd();


That's exactly the global state I am complaining about.

The current polygonal environment is a global state variable.

The current vertex is a globally set variable (as you'll notice once you try to set textures and colors, becayse glVertex3f just sets a global variable), etc.

Try throwing two threads at this, you'll get hilarious results, and there's no way to propeely fix this.

And OpenGL 1.0 to 1.5 and then 2.0 made it even worse.

You allocate a buffer, fine.

But to write to it, you first bind the buffer to a global variable, then use a call writing to a global variable.


> The current vertex is a globally set variable (as you'll notice once you try to set textures and colors, becayse glVertex3f just sets a global variable), etc.

Bad example. glVertex3f is the one function (among the various glColor, glMultiTexCoord etc.) which doesn't set global state. It actually triggers a vertex to be sent (which takes its attributes from the global state you mentioned).

But all this is pretty moot, because it's not how OpenGL has been meant to be used in ages. Use the core profile, where these functions don't even exist any more.

> You allocate a buffer, fine.

> But to write to it, you first bind the buffer to a global variable, then use a call writing to a global variable.

Also outdated, though not by quite as much. Direct state access (DSA) has been a thing for a pretty long time, now.


> Also outdated, though not by quite as much. Direct state access (DSA) has been a thing for a pretty long time, now.

If it just worked for everything...

Even in 4.5 there's many functions that have no direct state version yet, and many others were only introduced in 4.4 and 4.5 (meaning it won't be really compatible anywhere).

For me, the #1 advantage of Vulkan is having DSA for everything, just working.


> Even in 4.5 there's many functions that have no direct state version yet

Which ones are you missing in particular?


I think this might be a misunderstanding, I said that Vulkan (with complicated calls, but no shared state whatsoever) is far preferrable to OpenGL (no complicated calls, but all procedures only operate on global state).


You are right! I'm sorry, I misread your sentence and missed the 'than' that changes the meaning! My bad.


I personally think the OpenGL4.5 new functions, and Vulkan, are quite nice in readability actually.

In contrast, older OpenGL with the global state is the pure horror, and even 4.5 has lots of that still.


Except when all you have to debug it is a black screen.

Graphics work is tricky, you need everything to line up just right or stuff renders in ways that don't lend well to understanding what went wrong. When you put a framework abstraction in between that it can be really difficult to find out exactly what went wrong.




Consider applying for YC's Spring batch! Applications are open till Feb 11.

Guidelines | FAQ | Lists | API | Security | Legal | Apply to YC | Contact

Search: