Thanks for watching guys, hope you enjoyed the video! Next episode is already available for Patrons on www.patreon.com/posts/23069412 ❤️
@joebravo42246 жыл бұрын
Why bother with the event system, and so on from the very beginning, when you can just start printing a triangle on the screen with glfw and glad and gradually add functionality? It will be more interesting to the viewer and they will get more practical knowledge than to clutter their heads with non-priority things like a event system. All I see in this series is just a trash-talking for the half of a video. But, in any case, unsubbed. Best regards
@sablanex6 жыл бұрын
@@joebravo4224 It needs to be done at some point no matter what. From experience I prefer having most of the side components done, so when the writing of the actual engine starts, I don't have to stop to write something else that's required to continue. You clearly have no ambition to make anything, other than copy-pasting stuff. The point of this series is to actually teach stuff, not just sit here and write some code and be done. "clutter their heads with non-priority things like a event system" - I hate to break it to you, but the engine will just be a lifeless piece of shit without an event system, it wont function in any meaningful way whatsoever. I don't think you've any idea of how any of this works, I suggest you watch the videos so that you can prevent making a fool of yourself in the future.
@CyberWolf7556 жыл бұрын
TheChernoProject Didnt get to watch the video yet, but I wanted to tell you that you missed a perfect opportunity for your video. You could have added 3 red exclamation marks above your head like in Metal Gear Solid when the enemy sees you as the thumbnail image :D
@dsasilentsound6 жыл бұрын
This format is nice!
@martinbiroscak34876 жыл бұрын
Hello TheCherno, could you please explain to me why do we need a class for EventDispatcher, even though it is just one function essentially? Thank you very much if you answer.
@isaacmuscat50823 жыл бұрын
For anyone struggling like me, *(T*)&m_Event casts the m_Event reference from an Event to T. The order of operations is & then (T*) then *. First, &m_Event gets the memory address of of m_Event (now it's type Event*). Second, this Event* gets casted to a T* using (T*) (now it's type T*). Last, this T* gets dereferenced into a T with *(object from second step). Hope this helps.
@phee3D2 жыл бұрын
thx, if anyone's confused as to why we are casting the memory address of the event to a T*, I think its because we want to get the child event of the event , m_Event is an object of type Event but we want to get the child event such as WindowResize
@duyataksis5210 Жыл бұрын
Any reason he doesn't use `static_cast(m_Event)` instead of this monstrosity?
@theo-dr2dz Жыл бұрын
Say you have two unrelated classes: class Mouse { //... }; class Airplane { //... }; Of course it doesn't make sense to turn a Mouse into an Airplane. So casting a Mouse into an Airplane won't work: Mouse m{}; auto a1 = static_cast(m); // won't compile It also won't work for pointers: auto a2 = static_cast(&m); // won't compile This is a feature, not a bug. Casting a type into an unrelated type is undefined behaviour. If it were allowed, it would probably crash the program but it might also keep running with garbage data. That makes for an interesting debugging experience. Doing things like this is typically a bug and the compiler tries to protect you from doing that. Casting a Mouse into an Airpland might be possible in your situation. If so, you can add a converting constructor: class Airplane { public: Airplane (Mouse m) {//....} }; Now the conversion will work: mouse m; auto a = static_cast(m); // compiles now But he goes one step further: he does it in a template. He tries to convert an Event into some type T. The compiler has no way of telling what T is. It might be something that can be created out of an Event. But it might just as well be something like unsigned char. So the compiler won't allow it. But he still wants to do it, because _he_ knows that he will use the template only with types that can be created out of an Event Of course, if by accident he uses the template with a type T that can't be created out of an Event, he's in trouble and it's undefined behaviour. So he uses a dirty hack. In fact, it's two dirty hacks. The first one is that he knows that pointers to any type are essentially the same thing: it's essentially an int filled with a memory address. But the C++ type system still won't let you cast a pointer into a pointer of an unrelated type. So he uses the second dirty hack: C does allow that. The C-cast goes roughshod over the type system and just reinterprrets a pointer to Event into a pointer to T. It can do that, because it knows that both pointers have the same size and layout. So he takes a pointer to Event, uses C to cast that pointer into a pointer to T and then dereferences that pointer into a T. Effectively he has turned an Event into a T. What he could have done: 1- use a concept to restrict T to only those types that are acceptable and create conversions for all those types. Or use a concept that only allows types that are constructable out of an Event (slightly different way of doing it, but boils down to the same behaviour).This will work and it is safe: any "wrong" type wil be caught by the concept and will not compile. But concepts is a C++20 feature and this video was made before 2020. 2- use OO. Make Event the superclass and all eventtypes derived classes. Now use polymorphism to create the correct eventtype. This will work and it is type-safe. Drawbacks are that polymorphism works through pointer indirection (in fact his hack is kind of what polymorphism does under the hood) and it's a runtime mechanism. That implies a runtime performance hit at a very performance-critical bit of code. 3- use a union. Make Event a union of eventtypes. Communicate (through an enum) which eventtype is the present one. Now the user can pick the right eventtype. This is how SFML does it. Drawback: it's not type-safe. If the user takes (by mistake) the wrong union member, it's undefined behaviour. 3- use a variant. std::variant is a fancy union that adds type-safety. If the user takes the wrong variant alternative, it's not undefined behaviour as with a union, but it will throw an exception. But variant is a C++17 feature and I think he uses C++14 for this project.
@FODrive Жыл бұрын
omg thanks so much!
@theo-dr2dz Жыл бұрын
In this situation, I think the variant approach is by far the best one. It has no runtime cost and it's typesafe. So (this is a simplified example) in a keyboard event you want to communicate the keycode, in a mouse event the button used and the mouse coordinates and in a window resize event the new windowsize. struct Keyboard_event { int keycode; } struct Mouse_event { enum class Button { None, Left, Middle, Right }; Button button; int x; int y; } struct Resize_event { int new_width; int new_height; } struct Event { enum class Type { Keyboard, Mouse, Resize }; using Data = std::variant; // there will be more in real code Type type; Data data; } Now, the type var of Event tells you which event you have, the data var holds the data. Ypu can simply switch on the type. void process_event (Event& ev) { switch (ev.type) { case Event::Type::Keyboard: { // extra block to localise data variable, it has a different type in each branch auto data = std::get(ev.data); // do stuff } break; case Event::Type::Mouse: { auto data = std::get(ev.data); // do stuff; } break; case Event::Type::Resize: { auto data = std::get(ev.data); // do stuff; } break; } } This is type-safe: if for some reason (a bug) the event does not contain a Keyboard_event when type == Event::Type::Keyboard, or if you try to extract another event type than there really is, you will get a bad_variant_access exception. This is easy to spot and debug. There is no undefined behaviour, there is no chance of the program running on with garbage data. I would advice against using this type-punning thing. In modern C++ there is almost always a better way to do it. Most of the time this will be std::variant. I say "almost" because the words "always" and "never" are dangerous: there will probably be some obscure situation that's different.
@PenguinMaths5 жыл бұрын
I prefer the old format, it's much more difficult to follow along this way. Also it's helpful to see you make mistakes because it's likely that many of your viewers will make the same mistake. For example, you changed the premake file but didn't mention this until the end, so either you can't build the project until the end of the video or you have to fix it yourself and possibly diverge from how you did it which could potentially cause problems later down the line from having discrepancies that you forget about.
@leonidlazaryev43926 жыл бұрын
To be honest I liked previous format much more. In my opinion real-time decision making is something "you want to watch", code reading on the other hand is something that not really require a "host".
@rifuathaboobakuru Жыл бұрын
Agreed
@stfoggy124 Жыл бұрын
i disagree a host for code reading can be quite helpful for walkthrough, thought i do agree the old format is quite a bit more thorough
@Yorgarazgreece6 жыл бұрын
I'd rather watch longer episodes, even if they hit 1-2 hour marks. you could split them
@prezadent16 жыл бұрын
Watch at .25 speed. You're welcome.
@b0570nk45 жыл бұрын
totally agree - when you see the reasoning behind some architectual decision you learn it deeper than just when you see it as a final result which you forget within a minute
@sarex336 жыл бұрын
This is allot harder to follow. I liked the way how your old way was so hans on. I felt like i was there when you wrote the code, and therefore i understood alot more.
@briggsmedia40456 жыл бұрын
At some point you have to force yourself to write using your own noggin, just so you dont have to follow along verbose. Like i slaved over my first REAL program that you type in a std::string - which has an algorithm to sort it and add * signs when you preform multiplication without a sign - remove white spaces - find ')' work back to '(' - etc - etc.. it frucked my head for a long time while i was still learning, and im very glad i forced myself to write it myself. because my brain is now A LOT better and more comfortable with writing triple nested for loops with switch cases that call different functions and move pointers around, in a way i wouldnt be comfortable with if i just followed along.
@EdwinCloudRE6 жыл бұрын
I agree, it was much easier to follow along and learn the old way.. to hear the thought process and actually follow along
@krupt59953 жыл бұрын
Nah the new method is slapping. It sqves a lot of time and he gets to explain everything a lot clearer. In the older videos many of the things he did were not even being mentioned.
@sarex333 жыл бұрын
@@krupt5995 Hi, a lot has changed in the 3 years i wrote this comment. I am glad his current style suits you and your learning style.
@krupt59953 жыл бұрын
@@sarex33 Did he changed it back to the old one?
@jishanahamed85928 ай бұрын
This doesn't work for me: inline std::ostream& operator
@brichearnaud53148 ай бұрын
This! Thank you kind sir. This can be fixed by doing HZ_TRACE(e.ToString()) as well instead of HZ_TRACE(e), not sure which one is better (I would say yours though)
@jishanahamed85928 ай бұрын
@@brichearnaud5314 yup, using e.ToString() would work too, but the whole point of that inline function was to make sure whenever 'e' is logged, it should be treated as 'e.ToString()'.
@snifles32247 ай бұрын
broo tysm, was actually getting mad at chatGPT for not being able to help me lmao
@TanyaSravan6 ай бұрын
Thank you so much for this fix, but could you pls explain how this works
@KAZAMAPILOT5 ай бұрын
thanks
@YuhaoLu6 жыл бұрын
I enjoy the behind scene planning videos as much as the coding ones. That's what make the whole series stand out from most took for granted tutorials. Keep the great work, thank you~
@Robert-bw6jk6 жыл бұрын
Would it be possible to just record when you write code (no comment needed) and just upload those as "coding the HAZEL" as its own playlist? Then you can have these explanatory videos where you have these comments. I really like to follow along and code side by side with videos, It takes out the big project feeling that is overwhelming. Otherwise, keep up the good work.
@cactus92775 жыл бұрын
this
@pxolqopt35974 жыл бұрын
Did he return to actually coding the engine with us? Im only this far into the series
@sparkinex10544 жыл бұрын
Best idea here.
@darthvader84694 жыл бұрын
@@pxolqopt3597
@ananttiwari13374 жыл бұрын
@@darthvader8469
@svizcay3 жыл бұрын
I totally understand the reason why you can't continue with the old format when so many lines of code are needed but by including the live coding segment it helps us to understand better the different decisions you took and not just the final result. There are some nuances that you might not realize are important to mention given your vastly experience as a c++ developer but a for a newcomer might create a lot of struggle. Just as an example, I didn't realize until late that you used a scoped enum only for EventType but an old fashion enum for EventCategory. Trying to use scoped enums as flags in c++ was not as easy for me as in c# where I just need to add a decorator to the enum. Overloading bitwise operators for each enum used as flag didn't seem right to me and had to look for a macro (which also I don't completely like). Anyway, thanks a lot for the series. I'm really learning a lot by following it.
@hokhyt5 жыл бұрын
When I have a stable income (maybe after graduating), I will definitely join your Patreon. What you are doing is simply amazing. Thank so much for everything!
@jonphillips40826 жыл бұрын
I don't mind the new format, it's kinda appealing! It's more streamline, clean, concise-"already tested", but either way love your work!
@daegonicagaming Жыл бұрын
For anyone following along. IF you get a warning saying the class needs to have dll interface. Just add the following code to the file where you set your log output text. #pragma warning(push) #pragma warning(disable:4251) ^^^This at the top with the other pragma that is there then below the last share_ptr still within the brackets add #pragma warning(pop) This doesn't fix it, but it makes it so you don't see it in the console while building.
@andylt016 жыл бұрын
The new format definitely helps to outline the ideas and implementation more succinctly and efficiently at a high level. I feel, however, this is harder to understand the lower levels, as the learner. When you explain something in this fashion a key piece of information can get missed by the viewer who does not have the concept, or code intricacies, fully mapped in their brain yet (.. me ..). I always find I realize things as I write them and you are describing an idea. This is often in a "Oh, ok. I get why that is like that and it makes sense now" fashion. I think I can still get that from this method, but it's far more cumbersome for the viewer/learner, in my personal opinion. I will probably have to watch this video multiple times to fully get it and copy it. That said, I understand you wanting to keep your sanity and so I am happy to follow however you proceed. If it's more time for me but it benefits the series as a whole the juice may be worth the squeeze. This is amazing work.
@NuLuumo7 ай бұрын
I'm following along and at around 31:00, trying UG_TRACE(e) throws an error: Severity Code Description Project File Line Suppression State Details Error C2079 '_' uses undefined struct 'fmt::v10::detail::type_is_unformattable_for' Umgebung C:\dev\Umgebung\Umgebung\vendor\spdlog\include\spdlog\fmt\bundled\core.h 2593 I'm unsure as to why it worked for Cherno. I was able to get it working by doing UG_TRACE(e.ToString());
@thegreatdanish878128 күн бұрын
You, sir, are a gentleman and a scholar! If anyone knows the why of this, please do illuminate.
@kplays_60006 жыл бұрын
I personally prefer watching you write the code - but I don't mind this format!
@johnmark-ps8jy4 жыл бұрын
Thanks for the tutorial its really great. However, i prefer watching a 5hour video you typing the code than what you just did. I still appreciate keep up the good job.
@quarzasiphix Жыл бұрын
fact lol
@Walkietalkye6 жыл бұрын
If you're following along in linux or using a different compiler than the one in Visual Studio, remove the concatenation of the first line of the EVENT_CLASS_TYPE. Instead of return EventType::##type; it's return EventType::type;
@axeldahlberg70435 жыл бұрын
Great, thanks! :)
@nighma5 жыл бұрын
Yes indeed GCC will understand 2 tokens intead of 3 ;)
@jovanmaksimovic11914 жыл бұрын
Thanks!
@jovanmaksimovic11914 жыл бұрын
Thanks!
@fmgjcoppens2 жыл бұрын
@@jovanmaksimovic1191 Thanks! This indeed solved my issue on macOS/M1 using CLion with clang and Intel's icpc.
@TheKaosNano6 жыл бұрын
I'd definitely enjoy longer episodes! That being said, the new format is SIGNIFICANTLY better then the old format. Your ability to explain the systems you've written are so much more concise, and more thorough. My only two remarks are the following: 1) Potentially putting some sort of class separator in between each class when putting them in the same file (a simple //---------------------------// would be fine) to help the readability a bit more. 2) Writing and demonstrating a more detailed driver. It would have perfected the video to have seen a proper demonstration of your event system and the event dispatcher (even if it was hardcoding the events and such).
@RealZetItUp5 жыл бұрын
I'd prefer the older videos, this seems weird to follow the thought process, had to watch some parts several times due to Speed and scrolling. Just my thoughts, really liked the old style
@ArtanisITA4 жыл бұрын
I hope the series will switch back to live coding soon, it's way more difficult (and not fun) to follow in this fashion. I very much prefer to follow while you code and explain. I'll try to follow along with this method, but I'm afraid I will drop out as I don't enjoy this format :(
@csgowoes63192 жыл бұрын
Unfortunately, this is where the series lost me - I am just not experienced enough and simply keying in great blocks of code doesn't help me much. Cherno's videos are awesome but probably need to go back to something more basic with more step-by-step explanation...
@teacup30005 жыл бұрын
I really liked that coding part because everyone sees what you thought in that moment and which order you chose. Hopping from top to bottom can be really confusing. But I saw that you found a way in between to show some code and still provide some live coding. Thats a good compromise I think.
@snom3ad6 жыл бұрын
I personally like this format, for the people who say it's hard to follow I definitely see it being harder to follow than him typing out the code. However, I personally believe that this is a better learning format, because it forces you to go back to the material. I watched the episode first, then decided to code everything you showed based solely on what I remembered from the first run and it ended up being a surprisingly good learning experience. There were moments where I got stuck, some I managed to pull through, others I had to go back to the video to refresh my memory.
@whythosenames6 жыл бұрын
I like it more if you type the code in the video because you can learn a lot better how to write a game Engine than if you have typed it offscreen. I think at some point you will have finished the game Engine but still be showing the code you have written years ago
@rickygable6 жыл бұрын
Love the new format mate, this series is the bomb
@tttopcattt4 жыл бұрын
Great video, a moot point (lost in time) but watching you type the code is better for my own reference. But regardless, these video are pure-gold! Thank you for providing them.
@TheAlaninator8566 жыл бұрын
Cherno - Turning aspirations into professions!
@nobytes24 жыл бұрын
BTW: Diff should be done in the beginning, so people can add those files, make changes without having to just dump the whole commit. I'd like to state the obvious as others have stated from what I can see in the comments. Videos up until now where not about just typing code and taking time, I think most of us don't care how long the videos are anyways. They were about typing code, and seeing what that code does, add some more, and see the outcome. Make a mistake, learn from it. You've taken all of that with this new approach of just explaining written, working code. Up until this video I felt like I learned tons, and felt connected to the project. I understand all this four classes would have taken a long time to write. Don't get me wrong, I still enjoy this video, it just feels way different.
@bryandavis30725 жыл бұрын
Hey all! If you run into this error: Severity Code Description Project File Line Suppression State Error C2338 don't know how to format the type, include fmt/ostream.h if it provides an operator
@teunmansfelt54804 жыл бұрын
Dear sir, you saved me hours of painstaking headscratchers. Thank you very much!
@CKVR_Incorporated7 ай бұрын
I did all this but I still have the error why?
@Harbobimus5 ай бұрын
@@CKVR_Incorporated Any chance you worked it out?
@joelincz83142 жыл бұрын
Thanks, fully understand why you chose this format. As for me I find the commit on github for this video and retype it all myself because when I type things myself I learn it better and I see what I do not fully understand then watch the video with the explanation. This way I get to learn it. I understand why a lot of people prefer the old format, it's basically a lazy way to learn it especially when you are not super comfortable with C/C++ (basically being lazy and I am also lazy but eager to learn).
@nrgamepoint31323 жыл бұрын
To explain some bigger process as a overview then this style of explaining is we wanted. We can quickly grasp the architecture and flow of that concept.u saved my time a lot.thanks buddy.keep post something about windows event log apis like eventsubscribe events and how to consume or render events stuffs like that.thankyou
@zeekiezeke5 жыл бұрын
This format is much better for people already familiar with programming and c++. If they're not, then they should be watching one of the other series first.
@tomatoturtule3 ай бұрын
Bro. If I know how to program in C++ I would never touched or watch this game engine series in the first place. Since following along his tutorial is just same as not creating my engine and just become the spectator in this series. And this format is better for anyone that already have enough knowledge in C++ but just want to plagiarism but doesn't have the gut or creativity to create their own engine. Or to lazy to read the book about game engine architecture. But because I have no clue about programming and refer to every line of code that Cherno code to his C++ series, I am able to understand better what software engineer of game engine is and how they make them and subsequently C++ knowledge. So this format is pretty much hindered the progress of small scope of the viewers that have no clue but have motivation to learn C++ through this series.
@mazazaza112 ай бұрын
@@tomatoturtule nobodys gonna read 1000 pages of a book for this lol
@tomatoturtule2 ай бұрын
@@mazazaza11 You are. First sentence is enough to get the attention.
@mazazaza112 ай бұрын
@@tomatoturtule technically it aint plagarism because its more of a course, you obviously can get inspired by the code, no diff then searching through stack overflow
@bacontf26 жыл бұрын
Not a fan of the new format. I'm all for hour-long videos or splitting it into parts, but this took me two hours or so to get down because I was constantly pausing when you had certain classes etc. on screen and copying it down before/after you explain it. It feels to me like it shortens the time/effort it takes to make the video/series, at the expense of the viewer's time, which is a shame because I had been looking forward to this series because your thought process of explaining code as you go is hard to come by and is the reason I subscribed to this channel in the first place.
@lisandroCT6 жыл бұрын
You should use the GitHub repository for that.
@bacontf26 жыл бұрын
@@lisandroCT That's only really useful for troubleshooting - and that's when he remembers to update it when the video comes out.
@kenamreemas32956 жыл бұрын
last time I was this early, GTX 20 series were actually a promising upgrade!
@fanisdeli6 жыл бұрын
repeatCount should definitely be there. Using it, someone can easily delay the repeat from happening or, on your example, gradually increase how fast you're scrolling through the menu
@aaronvancuren79462 жыл бұрын
I really like this format! Since I’m a few years behind I’ll be interesting to see which format prevailed lol
@matt-g-recovers4 жыл бұрын
I was absolutely loving doing this alongside building a "game" in Unreal for Android. Very insightful for why Unreal does this or that. However I reached this video and stopped. Maybe lost steam from the format change, but honestly I think the size of this undertaking was finally sinking in lol. Still what an amazing series, I hope I can chug along!
@animfix28406 жыл бұрын
I really liked the old format, but I also like this. Maybe you could record you typing out the code and then make a time lapse of it while you are explaining it.
@balkanrhapsody6 жыл бұрын
Very nice format, it saves time, and lets us do the typing when pausing :) If I may, an opinion: I don't like too much the fact that the event system seems to have alot of repeating code. Why couldn't we just make function pointers or some sort of delegates like in C# where the client can hook up to any event he/she wants exposed by the app ? Thanks, keep up the good work
@enderger5308 Жыл бұрын
While following this tutorial loosely (using Rust and architecting the engine quite differently), I actually managed to get something pretty generic working. In essence, reflection via Rust's std::any is used to implement an EventManager type (to decouple it from the main application) which has a map of event types to a set of dynamically typed handlers that is queried whenever an event is dispatched. It seems like a fairly elegant model for the event system, only requiring 1 HashMap lookup to get the set of events to loop over, 1 to insert a new event type, 1 to remove an event, 2 to add an event handler, and 2 to remove said handler.
@toxicore11906 жыл бұрын
Actually I'd like you typing all that out much more, however I understand that this would cost you much more time At least the style you present the code should change a bit, maybe border it by darkening the rest surrounding the specific code block or something like that? I find it much harder to follow this way, because your mouse movement is much to quick
@Destroyer199419955 жыл бұрын
Watching you write the code is much better.
@pianochess18826 жыл бұрын
Great, keep the videos coming :) Maybe it’s time to make that emun class video in the c++ series
@avinatan62196 жыл бұрын
New format is better in my opinion. It takes a bit to get used to it but once you do, there is no problem to get the relevant changes from the repo. Then the video itself can focus more on the explanation flow instead of getting stuck at the actual coding.
@YouTikki5 жыл бұрын
Are there any benefits of using #define BIT(x) (1
@obinator90655 жыл бұрын
constexpr is more C++y, also inline is advisable for function declarations, but not in this context ;)
@seditt51465 жыл бұрын
constexpr is not always Compiletime where as #define runs before the Compiler does anything else replacing all occurrences with the expression. There is no guarantee that constexpr will be performed at Compile time. In this case it almost surely will but you can never really know unless you do some funky stuff with constexpr to trigger a compile error if its not run at compile time.
@randyfelts46256 жыл бұрын
Here's a thought, record your "offline" coding sessions and, occasionally, stub in a speeded up section of coding with a summary voice-over. It could clarify some sections of code when necessary.
@NullSpace16 жыл бұрын
That would be amazing if he could do that! But I'm concerned that may be asking too much. I can't imagine anything more ideal for the student though.
@pikmin40006 жыл бұрын
I don't quite understand the using EventFn = std::function; Why is using there and what does the function pointer used for?
@ryanmeyers38635 жыл бұрын
Took me a while to figure that out also, look up "Alias Template"
@VoidAshen3 жыл бұрын
in other words: "EventFn func" becomes std::function func
@dr_j0nes5 жыл бұрын
I would prefer to see you writing the code. The reason is that it's overwhelming when I see all the new code at once. Also seeing the order you wrote the code matters to me. You could just fast forward the physical writing of the code and explain what it does in the same time.
@sankar94835 жыл бұрын
I am getting addicted to your videos.. :)
@supremedeity90034 жыл бұрын
Best way to follow along is to first watch the video to know what is happening then go to the github repo and open the code for the specific episode and then gloss over the code yourself and try to code it. i dont like this style but this is easier for cherno + much more can be covered this way. dont give hate for this he is giving these tutorials for free
@milo200602 жыл бұрын
This format that you explain things is ok.
@aimanal-eryani78095 жыл бұрын
This format is better than the previous one. Good job!
@TheHomerForEver4 жыл бұрын
so i guess this could be used for all sorts of communications between different parts of the engine, right? Also for interactions between different objects, such as collisions. Because this seems a little too complicated just for handling input...
@cicciobombo74966 жыл бұрын
I'm ok with this new format, but i feel it would be easier to understand if you pasted the code as you speak, that way the episodes would still be short and it would be easier to follow the whole process.
@jannesopanen80324 ай бұрын
Also liked the format as it was before.
@b0570nk45 жыл бұрын
32:55 in terms of clarity, isn't it better practice to prefer MyEnumType::MyEnumValue rather than just MyEnumValue? (line 20 - e.IsInCategory(EventCategoryApplication))
@wjrasmussen6662 жыл бұрын
I really wish you would like in the description to the "previous video" if you are going to say that.
@universalsoldier275 жыл бұрын
Hey The Cherno, I know I'm a year late to this series but I want to give my feedback here. Videos up to this point were very helpful as a beginner. It was somewhat difficult to switch to this style at first but it actually *forced me to learn* more about git (btw not complaining about learning git, it is so helpful) so that I could go back to the state you had for this episode and learn what you were coding at that time. I do need to learn about diffs still and how to use them effectively. But I still got a similar effect as the early videos by simply typing it all out from your repository then watching the explanation a couple times, checking errors and such. I'm attempting to make a big career change and following this series is helping me learn so much about C++.
@marklinton45676 жыл бұрын
Both formats have their ups and downs. The new format is nice in that it takes away the normal mistakes and course corrections of development, letting you just discuss the finished solution. Though it also denies viewers the chance to learn from those course corrections or compile errors.
@voicev84263 жыл бұрын
just got to watch this series, (a bit too late i know)), absolutely love this format, it's a shame many people in the comments don't
@bobtong91233 жыл бұрын
for whatever reason, i says i have a error for importing core.h in event.h Does anyone know how to fix that?
@yusufketen46743 жыл бұрын
My solution is appending "Hazel/src" to includedirs of project "Hazel" after spdlog include. includedirs { "%{prj.name}/vendor/spdlog/include", "Hazel/src" }
@thereisnofridge55932 жыл бұрын
I used the generateprojects bat file and it fixed the issue for me
@b0570nk45 жыл бұрын
i dont understand the line 72 at 21:49 (event dispatcher), can someone explain? also the T::GetStaticType() - considering the T could be just any class, we can pass in MyAwesomeDog class - how would that behave? showing a compilation error that MyAwesomeDog class doesn't have GetStaticType() declared/defined? Isn't it possible to take advantage of c++ concepts/constraints? (or that is in c++20 only? not sure now)
@F1sen3 жыл бұрын
this new format pretty much means that we are supposed to copy paste from your github and then just sit here and listen as you talk through it.. idk for me i preferred the old way better but we are at your mercy Cherno and cheers, trying to leave constructive feedback not hating
@jbanosga985 жыл бұрын
The EVENT_CLASS_TYPE(type) doesn't work for me, it says the enum class is undefined, I don't really undersand why this happens
@FalcoArwing4 жыл бұрын
same thing here, I can complie it but it doesn't show up like in the video and Intellisense also doesn't recognise any of the EventType enums. Are you using VS2019?
@krumss4 жыл бұрын
For EVENT_CLASS_TYPE , i always get the error "identifier "category" undefined". How can I fix the problem and why doesn't Cherno's code have that problem?
@obi1jim3165 жыл бұрын
Another video down. I keep hoping it will get easier for me, it hasn't. I'm grateful the Cherno makes is good at explaining things like this for people like me. I'm still in this. The Cherno's new way of doing his videos caught me by surprise. I really liked it when he was typing the code as he did the video; typing the code myself as I watched, I can tell it is a burden while typing, teaching and planning at the same time. Besides, he's generous enough to share his knowledge with us, so I shouldn't complain. In another note, the fact that I can keep up means that anyone can do it too, or maybe I don't give myself enough credit. But the more videos I finish and code up, the more confident I become. Don't give up, we've made it this far. I'll see you on the next video's comment section.
@3angleboi2 жыл бұрын
Old format was waaaay better imo. But I still like it and it seems like you enjoy it so there's no problem.
@ИльяЯкубович-ц8т3 ай бұрын
can someone tell me what is the name of the theme of visual studio
@Tiogar605 жыл бұрын
Hey! For some reason when i start the engine my logger isn't showing me the actual name of what is calling the log, it just shows % n, anyone knows what i might have done wrong?
@Dante30854 жыл бұрын
Quick Question about "inline": When he for example writes "inline float GetXOffset() const { return m_XOffset; }" in MouseScrolledEvent in the MouseEvent.h Header file, writing the inline specifier is optional, right ? The compiler is going to inline the function purely based on the fact that he implemented it directly in the Header file, correct ?
@admin-questersworld54006 жыл бұрын
MouseOver event should be added as well
@cicciobombo74966 жыл бұрын
You spoiling us with all these uploads Can't complain pls don't stop
@Maxyjof Жыл бұрын
why you can use "hazel/Core.h",but i only can use "../Core.h"???and when i use pch file, the code will display error lines but it can still run, just not good as look...
@GreenHerbsGame4 жыл бұрын
someone says dont put the STL in dll because the size of container is diffrent from various compiler or something .. should we include stl in dll?
@javsolo3 жыл бұрын
Why are we making the function pointer take in a generic if we know it's going to be an Event type?
@koungmeng5 жыл бұрын
Isn't the MousePressedEvent and MouseReleasedEvent are in the MouseButtonCategory (EventCategoryMouseButton) ?
@n0block4 жыл бұрын
Can somebody please explain what "*(T*)&m_Event" does ?
@nikoszervo4 жыл бұрын
What you're looking for is called: Reference typecasting (C++ reference typecasting). the func() function takes as an argument a T& . In the Dispatcher class though, m_Event is type of Event& !!! So in order to pass it in the func() function, we must cast it first into a T&. When casting a reference into another reference is a little more compilated that casting raw pointers. You must get the memory address of the reference variable, then cast it to the appropriate type (in the example T), and then get the reference value back. *(T*)&m_Event : &m_Event give us the memory address of the m_Event which is a memory address which holds the actual reference of m_Event as defined in the Dispatcher class. then (T*) casts that reference to T. Finally, we get the value of the address which is basically a reference, but now it points to a T&. It's ok to be confused. If you know how type casting works with raw pointers, ( for example int *array = (int *)malloc(...) ) then casting a refernce in c++ is being achieved by the following formula: some_ref_var = *(TYPE*)&some_other_ref_var ; for example: char &some_other_ref_var; int &some_ref_var = *(int*)&some_other_ref_var ; TheCherno has a C++ video explaining it better than me :p
@avinashthakur802 жыл бұрын
Why EventType is "enum class" while EventCategory is "enum" only ? I guess there's a functional difference as if it were a personal preference , both would be same type.
@hasanalattar95613 жыл бұрын
Why enum event category isnt class enum .. while its the case for event type
@stfoggy124 Жыл бұрын
is there a way to avoid c# and just use c++ for scripting
@CoinedBeatz4 жыл бұрын
quick question: why is the GetEventType function not static and returns the event type directly?
@Spartan5996 Жыл бұрын
Hey I have a question, in your code you use polymorphism to get the name and event category of each class, but whould it not be better if the name, event_category,... of each event are stored as data ?
@darkmethods91496 жыл бұрын
Personally I think you should have split this up into two or more videos. The first video would just cover the core of the event system in the old format with just one event. The others would be quick incremental videos introducing extensions and new concepts. I know you don't want this to take ten years but event systems can be quite foreign to some so starting simple and mutating slowly through multiple videos would really help people out. Ideally if broken up the videos might only be 5-15 minutes long but there would just be more of them.
@lewiskarani88657 ай бұрын
Severity Code Description Project File Line Suppression State Details Error C3861 'GetStaticType': identifier not found Hazel C:\dev\Hazel\Hazel\src\Events\ApplicationEvent.h 44 How do I solvce this error
@dmattism6 жыл бұрын
why you make EventDispatcher as a class? I think it is just function that takes event and event handler
@marcstephens21005 жыл бұрын
i don't understand why the function GetStaticType is static. His explanation is not clear to me. Can anyone help?
@ezioauditore76365 жыл бұрын
Static means it stays in memory for the entire time a program is ran or else it would be immediately deleted soon after: what is called an rValue. What GetStaticType() would do is help resource management because it only needs to be created once per classes that inherit from Class Event. Then all GetEventType() would need to do would be to ask its class type what EventType it should have and then return it.
@marcstephens21005 жыл бұрын
Thank you. Makes total sense.
@manojstriker3 жыл бұрын
I am newbie. Can you tell me where events.h file implementation cpp files🙄
@citrusqiao3425 жыл бұрын
Why HZ_TRACE(e) works? Shouldn't it be HZ_TRACE(e.ToString())? Is there some kind of MACRO to auto ToString()? -------- EDIT: Suddenly I understand. It's due to this: inline std::ostream& operator
@RaneMstSage5 ай бұрын
I am not sure why but it seems to not work now. so something may have changed with the include of the logging but doing e.ToString works.
@JoshuaKisb6 жыл бұрын
what the difference between enum class and just enum
@toxicore11906 жыл бұрын
`enum class` (synonymous to `enum struct`) has stronger type-checking than just `enum`, therefore if you have eg. some function taking such an `enum class`-type you can't just pass an integer instead, with `enum` you could.. converting it back to an integer also takes an extra step, overall it's less error prone, but sometimes not suited (I am not sure if you can or them together for example)..
@Str33tF1ght16 жыл бұрын
its also scoped
@Ascaron50 Жыл бұрын
Why did you write GetXOffset() and GetYOffset() in the ToString() method in MouseScrollEvent and not GetX() and GetY() in ToString() in MouseMovedEvent ?
@xtriangleboi Жыл бұрын
he was probably thinking some other stuff so he wrote it that way, not like it makes any difference of the generated code anyway
@adib68 Жыл бұрын
Really late to the party, but learning and enjoying a lot anyway. Thank you for this. In Event.h, this static method: #define EVENT_CLASS_TYPE(type) \ static EventType GetStaticType() { return EventType::type; } \ ... could be a public static const instead? const static EventType classEventType = EventType::type; \ A public static const does not violate encapsulation. It's not a bad practice and also avoids a function call. What do you think?
@BlackJar726 жыл бұрын
This format is good for me -- I'm more concerned with the "why's," more with the architecture and its rationale than the specifics. Not everyone may agree, but there are already tons of series on the specifics of rendering and other engine sub-systems.
@GohersWay4 жыл бұрын
Hey Jared hope you are well, and if you don't mind may i ask what coding pattern is cherno using and can you recommend a book as well a tutorial which can help me understand this event system, I am having hard time grasping where he started his code and how he gradually updated his code to this event system to make it better why is writing this code like that. I am newbie, I understand the theory behind from his previous video but i don't get the code. Cherno lost me on the bit shift even though I understand the bit shift itself ( obviously i youtube it :D ) but i don't get this even system at all.
@nikoszervo5 жыл бұрын
on GCC the preprocessing ##type does not work. I used EventType::type instead of EventType::##type and gcc compiles it. So what is that ## does anyways? Anyone knows?
@sathvikhegde362 жыл бұрын
Was following this on linux and was having the same issue, thank you for the solution!
@RikCross4 жыл бұрын
Hi, love this series but finding things much harder in this video now that I can't follow along. I used Git and added diff code, but get the following error: In file included from ApplicationEvent.h:3:0: Event.h:27:87: error: pasting "::" and "WindowResize" does not give a valid preprocessing token CLASS_TYPE(type) static EventType GetStaticType() { return EventType::##type; }\ Has anyone else seen this? Any ideas what I'm doing wrong? Thanks in advance!
@jakubwegrzyn37986 жыл бұрын
Why don't you use enum class instead of enum?
@jamesmnguyen6 жыл бұрын
The behave the same to the computer, the only difference is to the programmer. First, in an enum class, the members don't pollute the outside namespace (which you might want, then use just an enum). Second, enum class members can't be implicitly converted to an integer.
@axeldahlberg70435 жыл бұрын
Yes, I don't see why eventtype is enum class but eventcategory is plain enum. Anyone has an idea?
@08kadean4 жыл бұрын
@@axeldahlberg7043 Late reply here (I'm just going through the series now), but the reason I think is that enum implicitly converts its values to type int, while enum class doesn't do that. And here, we actually need the EventCategory values to be ints anyway so we can do the bitwise-and on them against the int returned from GetCategoryFlags() later in the IsInCategory() function.
@runetimon6 жыл бұрын
Changes format to reduce video length, still makes a 35 minute video. Never change haha
@axeldahlberg70435 жыл бұрын
Why is GetEventType in the macro EVENT_CLASS_TYPE virtual? Is it needed?
@sb-zn4um3 жыл бұрын
this please, I'm wondering the same
@Tech_Code127-7610 ай бұрын
I prefer the old style of these videos. People who agree 👇
@CasparRubin6 жыл бұрын
setup video? ;)
@JackPunter20126 жыл бұрын
Go to the playlist. It's the first couple vids iirc
@CasparRubin6 жыл бұрын
@@JackPunter2012 I mean hardware, desk, chair etc. not software... =)