Since more people are seeing this video as a result of Unity's recent pricing change, I would like to emphasize that these are my opinions on the engine pre-4.0 update which addresses and fixes a large majority of issues I had with the engine, and adds a number of valuable features. Second, many of my concerns or wishes were also addressed by more experienced users in the comments, and were a result of my lack of experience. I hope the comments can be a good resource for anyone struggling with the same things I was. Since this video released, I have continued to use Godot. I've made 3D games, I've made 2D games, I've made simple graphics, I've made more detailed graphics. I've made VR games. I have yet to try a game idea that I felt could not be achieved with Godot.
@danielsndgamevideos Жыл бұрын
Would be great to see an updated video with the solution to some of those problems maybe xD
@sczoot6285 Жыл бұрын
@@ModernCopy? Godot is an easy 3D game engine relatively speaking
@mattlegge8538 Жыл бұрын
Yep that's why I'm here too! Maybe it's time for a 'used Godot for 200 hours' update?
@skyethemin4922 Жыл бұрын
I am cackling irl at the fact that so many game makers changed engines because of the controversy that this video reached the youtube algorithm en masse hahahahah mannn
@content8420 Жыл бұрын
I am really concerned about the 3d capabilities of godot for making my dream project. I am still trying to wake up from the trauma that unity gave me and really thinking of shifting to unreal engine 5 but I am still considering godot as an option just that I doubt I can achieve the level of quality with godot's power so far. I am talking about Genshin level quality or something similar (I am talking about my dream project so don't think I am being arrogant and thinking that I can create something that). So I don't know, I heard that Godot's lighting system is not that great and since godot is mainly used for 2d games. I just can't make up my mind and will probably go for unreal engine.
@theisavelkoul56622 жыл бұрын
"All game engines have their own special ways in which they work. Unity has MonoBehaviours. Unreal Engine has Blueprints. GameMaker has a 100 USD a year subscription fee. And Godot has nodes."
@abhishek-farswan2 жыл бұрын
LOL
@suspecm63162 жыл бұрын
Member when the subscription model "wouldn't kill the engine"? I member
@saverofthewo2 жыл бұрын
i just realised that seems like shit but thats only $8 a month
@suspecm63162 жыл бұрын
@@saverofthewo That's exactly how they get you. It's only 8$ a month but let's say you buy a perpetual license for 99$ that you can keep forever. If you use the software for a year on the subscription model you have already paid as much as you would have on the old model.
@TrekDelta2 жыл бұрын
Source Engine has Vscript
@rahn452 жыл бұрын
I think Godot being 'durable' instead of 'fragile' is the thing that allowed me to actually dive into game development. The node system is just something that clicks with my brain, because when it came to other game engines/programming languages I'd struggle just to get buttons working; among other more simple concepts I'd struggle to grasp with. You know the typical problem of following a tutorial and at the end of it learned and understand nothing of what I did. With Godot on the other hand I can follow a tutorial and actually come out the other end with actual knowledge.
@MisterPineTree Жыл бұрын
Hey man, I would like to start using Godot too, can I ask you which tutorials did you followed? Thanks
@topminator299110 ай бұрын
holy... i thought i was the only one!
@tsary_856110 ай бұрын
@@MisterPineTreeI hope this will let OP see your comment, because I’d also like to know who they watched.
@theConcernedWyvern7 ай бұрын
@tsary_8561 Brackeys has one out that I've been following and it's really good. Wayyy better than the old stuff imo. I have the same thing with Godot. I even have some prior programming classes under my belt and tooling around with minecraft modding. I've tried several engines and Godot has been the one that makes the most sense to me by far. It's so intuitive and, as someone who used to do graphic design as a hobby, the GUI just makes me so happy.
@Valcuda2 жыл бұрын
I love using Godot, because it feels like how I imagined game development would be when I was younger. Everything flows together nicely, and if I need something, I know where to look, and if I want to know what something does, I can easily look at the documentation. Unity however, feels like how I feared game development would be like when I first started. Everything is confusing, there 100 different ways to do x, but only one way actually works properly. Objects have dozens of different values, but you change one and suddenly nothing works. Unreal however, couldn't run on my high end gaming rig from 2010, so despite having a computer that could probably run it now, I've already grown too attached to Godot to even think of jumping ship.
@tubaeseries57052 жыл бұрын
as someone who started with unity i have exactly the same feeling towards godot as you have towards unity
@Reneator2 жыл бұрын
" there 100 different ways to do x, but only one way actually works properly" thats a great point. For me with godot its like "you have 100 different ways to do X but only some are better performance" stuff works but maybe not most efficiently
@LukesOffline2 жыл бұрын
As a unity Dev this hurt
@Aereto2 жыл бұрын
And now with Unity dissing developers and getting talents from an adware company, all the more reason to go to Unity.
@missfire94802 жыл бұрын
@@Aereto All of that is so out of context it's not even funny. Don't believe every headline you read, nor what people told you they "read" without reading the article. A lot of click bait and misinformation came out and unless you read the original interview and looked into the company they acquired don't go around talking about stuff you know nothing about. First off, he did in a way diss developers but not in the way you think. If you make a game for art that's fine. But if you are making a game for profit (the key context) and you don't use the tools around for you to monetize the game then yeah your an idiot. (that's the funni tag line "devs are idiots") Unity is natively supporting monetization now. Second, the company they merged with IronSource (didn't buy, no cash traded hands just their stocks turning into unity) Never made malware. They made an install wizard that was open source. Much like how you can make malware with Unity. You could make malware with this (by attaching bloat or malicious products to the install wizard. If you remember like when you download 7 zip and the wizard asks you if you wanna download all this other shit? ) They got flak for what people did with their product. Not anything they did. They no longer support said software and haven't for 5 years now. The only thing they do now is targeted ads and mobile game ad software. This is mostly for the IOS market where if you were to use a 3rd party software the game would have to ask permission on your device to show ads. and yeah, if you were making mobile games for the sole reason of making money, or if your making a game and want to get paid for your work I kind of agree. You should use the tools given to you buy Unity to make that happen. Game development has changed, sure you can release your game on steam, itch.io. Apple store or google play randomly and do no promotion and hope it blows up and by proxy you make money. The old way. Or you can go with the future and get feed back on the way your monetize game while you build it. (More so in the mobile space) Making sure ad's don't interrupt the gameplay loop etc Personally i dislike mobile games and their ads so I won't be using it. But like a lot of advanced software in unity just because I don't want it doesn't mean other people don't.
@SamuelSarette2 жыл бұрын
One of the reasons Godot's UI tools are so powerful, is because Godot's Editor is powered by Godot. It's built with those nodes.
@gytux02582 жыл бұрын
They build the editor using itself? What a flex.
@SomeRandomPiggo2 жыл бұрын
Unreal does the same, its weird!
@swordofstabbingold2 жыл бұрын
It's like how programming languages will first have a compiler in a different language, but then subsequent compilers will be made in the language itself.
@bobmcbob43992 жыл бұрын
@@swordofstabbingold Yeah that's a real trip, so cool!
@sleepymarauder41782 жыл бұрын
@@swordofstabbingold That is a process called bootstrapping and it is really nifty
@janmagtoast2 жыл бұрын
Two things that make me use this engine: - cylinder collision shapes - the node family system is absolutely bonkers and I adore it to no end
@ThatPianoNoob2 жыл бұрын
Never got deep into game development but that node system description gave me a throbbing brainer.
@D.S697 ай бұрын
@@ThatPianoNoobhaha it is awsome though
@billkillem6 ай бұрын
It actually blew my mind when instead of having to write a script to make the 2d camera follow the player, I could just make the camera a child node by dragging it underneath. I got all giddy about it lol
@TheFlyJunky2 жыл бұрын
There are a couple things about Godot's design I think you should know: 1) Single purpose principle - All nodes do one thing (ie handle themselves), there should be random nodes that only serve to have a script, and that script should only do one thing. 2) Tree Structure - Parents should know their children, but children shouldn't know their parents, otherwise use signals, using an autoload signal connector node is totally fine.
@JebacPresretac1012 жыл бұрын
If a child needs to know it's parrent, in the multiple scripts excample, "export(NodePath) var myNodeToManipulate" will work well, you can then use the get_node(myNodeToManipulate) to get the node. This also promotes code reusability.
@WizzardPowers2 жыл бұрын
Um.. wot? Why children shouldn't know their parents?
@shadrickcarrick13002 жыл бұрын
A famous saying in Godot: "Call down, Signal up."
@StiekemeHenk2 жыл бұрын
@@WizzardPowers because your parents are deprecated /j I think it has probably something to do with reusability. If u use signals then you're not relying on where your node is placed but if you reference your parent the node becomes tied to it and can't be used elsewhere as an instance for example. Keeping specificity low is often a good thing.
@P3PPING2 жыл бұрын
@@JebacPresretac101 Yeah, this is the approach I tend to use too, since it makes it sooooooo reusable like you said. I would love first class global signal support though!
@freedombrick Жыл бұрын
My favorite thing about open source programs is that it's improved on and worked on by those that use it. They know exactly what users need and want, and the issues that have, because they are them
@freedombrick Жыл бұрын
Aaaaaand I just got to the party where you said the exact same thing
@kipa_chu19 күн бұрын
It doesn't work like that. Only things that Juan wants go into the Engine. Its not community managed its Juan managed. Same for linux. What Linus wants goes into the linux kernel.
@SharyqSiddiqi2 жыл бұрын
My personal favorite creators in the Godot community is DevDuck, just makes devlogs but he displays expert use of the engine, an amazing workflow, and an overall nice way to balance work and life
@katkazam52462 жыл бұрын
DevDuck is great
@enriquepageperez1522 жыл бұрын
A nice way to balance work and life. That’s the hardest part and he’s got it so right…. !
@PresidentDawg2 жыл бұрын
You mean creator creators means 2 and you only mentioned one so it’s creator not creators
@Legocoder12342 жыл бұрын
I havent seen devduck but garbaj is also gread
@Legocoder12342 жыл бұрын
Great
@SheepUndefined Жыл бұрын
A huge tip if you're moving to godot: Go to the settings>text editor>behavior, and turn off the "Open dominant script on scene change." There's a similar option under the settings>text editor>files menu, DO NOT BE TRICKED. There's also a few other goodies like scrolling past the end of the file.
@angelosavioti4627 Жыл бұрын
thanks, this was getting me mad
@RevolutionaryOven Жыл бұрын
Awww your pic is so cute!
@miadietrich734711 ай бұрын
What's the reason for this?
@SheepUndefined11 ай бұрын
@@miadietrich7347 Because when this is on, if you have a lot of scenes you're going back and forth between, they'll always be silently clogging up your scripts panel, even when you aren't editing those scripts.
@quadangries4 ай бұрын
Thanks!!
@cameroncollins41232 жыл бұрын
I don't use get_parent() at all when programming in godot. imo that is bad practice. Create a group for certain nodes and in the main node/top node in the hierarchy. Just call get_tree().get_nodes_in_group() and it returns all the nodes that you need in that specific group as an array. Like the spawners that you showed. Higher up nodes should connect lower nodes in the hierarchy, so they aren't dependent on higher nodes being there. This will prevent your game from crashing. Lower nodes should never connect themselves to higher nodes. I used to do the same thing you did with singletons and storing nodes. But then, I read a godot design pattern somewhere that made my workflow much easier and faster. You could also get_children() and check to see what group the children are in as well.
@saul85102 жыл бұрын
smart thinking, get_child or parent is expensive as you have to find that node, in a group it already knows who is the group because there not much..
@cameroncollins41232 жыл бұрын
@@saul8510 Even if it's expensive get_child/get_children is still worth it because you'll only be using it once usually in _ready(). If you create a instance later on. You'll already have all the information you need to make the proper connections. Appreciate it!
@cameroncollins41232 жыл бұрын
But we're lucky we got groups. Makes things a whole lot easier.
@udippatel61472 жыл бұрын
exactly, when splitting up nodes to be modular and self-contained, get_parent() has no place in the code. it was never meant to be used heavily in any godot project.
@brandonlunchbag2 жыл бұрын
Thank you
@aethernia-strategycardgame72832 жыл бұрын
It's crazy how far Godot has become in all these years. Especially 3D and its performance got improved by Godot 4.0 by a lot which just makes it so much more fun, motivating and promising to work in 3D using our lovely engine. I am very excited about how Godot will evolve from here on, since it is also getting the recognition it definitely deserves. Great video and great channel. 🙂
@jarbarsi2 жыл бұрын
As I'm watching this video, I know you mentioned things will change in godot 4.0, so here's a list of things you mention that I know for a fact have already been changed in godot 4.0 - Physics have been completely rewritten from scratch, so they shouldn't feel nearly as janky - 3D audio and audio in general has been overhauled, so most of the issues/jank there will get much better - Shader compilation has been reworked so that, while performance will still drop a bit while they compile, the engine won't grind to a complete hault waiting for the job to finish - As you said, the options for 3d are already great, but it's getting even better, multiple options global illumination, deferred rendering, etc - Some things with the way ui options are displayed have been changed to be a little less confusing, mainly, the options displayed are based on the node's parent, so options that are overridden by a node's parent container won't be displayed - Also on ui, if I remember correctly the default ui theme is now based on the engine's ui theme, so it doesn't immediately look _as_ terrible, still not perfect and probably should be reskinned to match your game's theme anyway - Godot's search engine has improved significantly, which means that the intellisense in the code editor is significantly better than what it was, prioritizing commonly used methods/variables and showing results even if you make a typo I probably missed a lot, because I was typing this list very lazily as I watched and haven't exactly been glued to the development of the engine. Great video by the way, hope that more people get to see it 👍
@RenderingUser2 жыл бұрын
also dont forget the engine being able to make more than one window instead of fake overlays thats the best ui thing that happened to godot in a while
@parsar.k.p13372 жыл бұрын
So pretty much every issue discussed in this video is fixed.
@woopslap2 жыл бұрын
whens it coming out
@jarbarsi2 жыл бұрын
@@woopslap it's coming out some time this year, no official release date from what I've seen. Recently it entered feature freeze (nothing new is being added, now focusing on bug fixing), and will be entering the beta phase soon™.
@fanb15362 жыл бұрын
@@jarbarsi Hi, any idea if anything else notable from this list specifically is being backported to 3.5?
@WH1T3_No1SE Жыл бұрын
You really need to make a sequel to this video
@redstoneparadox2 жыл бұрын
12:50 It should be noted that anything in yellow is not an error. It's like an IDE making an unused variable grey, except slightly more obnoxious. And with regards to autocompletion of nodes, Godot basically treats scripts as an anonymous class by default; you can kind of remedy this by using `class_name` on your scripts to give them a proper name, but that requires instance checking and such. GDScript in the past has been more oriented towards duck-typing, but they did start moving towards more static typing in later 3.0 releases.
@reepusvanguard Жыл бұрын
I appreciate how often godot updates and how the devs actually listen to their community.
@WeeGerGai Жыл бұрын
Partially because the community are the devs :)
@Oneiroi010 ай бұрын
And the Community became the Devs so they can improve their own Game. Basically a healthy Relationship.
@whaive2 жыл бұрын
Intellisense in godot I agree it is not the best, but a really handy feature that I like, is that you can ctrl + click on a method/variable you just wrote, and it will open a tab in godot explaining what that method does, and it is really helpful and it saves you a lot of time, instead of going into your browser and manually searching for that method in the documentation!
@HoloTheDrunk2 жыл бұрын
While it's by no means bad to praise good features, this is a thing that has existed in most decent code editors and IDEs for years, it's nothing specific to Godot.
@RenderingUser2 жыл бұрын
@@HoloTheDrunk normally clicking that in an ide takes you to the definition of that method in my experience but godot goes to documentation
@HoloTheDrunk2 жыл бұрын
@@RenderingUser Yes, the specific Ctrl+click binding is usually to go to the definition or usages, the feature is just invoked differently. Heck, even my fairly vanilla Neovim can instantly get me the documentation of anything from a Rust package I have imported by just pressing Shift+k.
@RenderingUser2 жыл бұрын
@@HoloTheDrunk wait can i hav ur nvim config?
@BeatemupMaster2 жыл бұрын
Never know that, thanks!
@samathythemanathy8112 Жыл бұрын
Would be great to get a refresh on this topic with Godot 4.1. I also really appreciated the more niche memes, seeing that Aperture and Black Mesa chart was something else!
@rungeon832 жыл бұрын
I have used Unity for years, gamemaker, XNA c# etc and honestly Godot is the only engine that i ENJOY using, alot of the issues LazyAlarm had I was like "oh but I know an easy fix for that!" or an option that was missed. One thing I find really odd about Godot is the community, it's so lovely and I've had nothing but positive people, I have no doubt there are awful people everywhere.. but I've never had that horrible elite nerdy hate for not knowing something that was "DUUH so easy duuuhhh" easy. lol
@sslaxx2 жыл бұрын
Eh, there are a few bad apples out there, seen some of them. But the community is definitely a good one.
@rungeon832 жыл бұрын
@@sslaxx oh I have no doubt. I wonder as it gets more popular the bad voices are always the loudest.
@samdavepollard2 жыл бұрын
i don't have a ton of experience with godot and its community but what you describe seems like the same vibe i always get from the blender community; i guess it's an open source thing - people want the project to succeed and one of the ways they can help bring that about is to help other users if they can
@sslaxx2 жыл бұрын
@@rungeon83 Human nature, it seems alas.
@alexaleman162 жыл бұрын
Damn i been missing out i used eeverything else for years now hadnt even heard of godot till now something tells me im gonna finally be stoked lol
@notcreatorguy2 жыл бұрын
5:02 Godot has "Update Continuously" in Editor > Editor Settings > Interface > Editor and turn on Update Continuously. It works for moving stuff around like you described, however I've found that it doesn't work if you're updating properties on materials. It's definitely not an apparent feature and certainly located in a place most beginners would never look but it is there
@ASecondGuy2 жыл бұрын
The autocompletion sucks but you can somewhat improve it with class_name and typed vars. So making "class_name Player" in the player script and "var player : Player" in Ref. If you want to know about some function you can just Ctrl+Klick an it opens the offline documentation on the right page and line. (works better than lookup symbol for me for some reason) Instead of many get_parent you can use get_node("../../../../node") or the short form $"../../../../node" or use find_parent(). Or like the tooltip suggested at 11:40 Use "/root/" to get all the way to the top of the scene tree. The NodePath export can be restricted but it is some complicated stuff with _get_property_list() so that is too complicated I agree. 12:04 hurts to look at. Use a group or search for them in _ready(). Ex: var gate := [] func _ready(): for c in get_children(): if c.name.begins_with("EnemieSpawner"): gate.push_back(c) I hope I could help.
@LazyAlarm2 жыл бұрын
I know when my code is bad, but I don’t always know how to fix it. This comment is very helpful! Thank you.
@redstonemedia6652 жыл бұрын
sus
@Drejzer2 жыл бұрын
@@spiceywolf though I think it doesn't work on multithreaded code. Or at least didn't work a year ago (not sure about right now).
@prydzen2 жыл бұрын
Just use vscode for programming godot
@Hurtdeer Жыл бұрын
a bug caused my audio to tear when you were complaining about the audio tearing and i briefly thought you made a 500 iq joke
@drawnsequence Жыл бұрын
This video fires me up. As someone who just doesn't know where to look for solid basics on maneuvering Godot, this made exploring and what to look for soo much better. Thanks for the fantastic vid!
@christophernoneya46352 жыл бұрын
My biggest criticisms with godot that are still valid having worked with 4 is just how annoying the actual project architecture is. When you get into larger projects it starts feeling like I spend as much time contriving ways for nodes to communicate with eachother properly than I was writing new nodes. Groups are a godsend but signals start feeling pretty limited imo. Its just a sideeffect of their node structure vs entity-component
@OWnIshiiTrolling Жыл бұрын
Unity recently committing sudoku might benefit the godot community quite a bit
@ops38926 ай бұрын
Sudoku the game
@dugtrioramen2 жыл бұрын
26:05 For UI you want to mainly use Containers, which automatically position things. It'll ignore all those margins/anchor properties, and the only thing that'll matter are size flags (for stretching, centering, etc). There was even a recent proposal to just flat out remove anchors margins & grow direction and just have containers instead. Probably won't happen but it's a good indicator of how much better Containers are
@pablu38802 жыл бұрын
What you are trying to do at Minute 29:08 is actually possible. There is a Func Type which you can use like a variable and Invoke it.
@squiddotmid Жыл бұрын
it's over a year later... but ".call" could also do this! it basically works like this: some_node.call("myMethodName", ["argument1", "argument2"]) you could even call a method in the same script with "self.call(method_name)"
@raphaeld92702 жыл бұрын
11:46 You can use get_node("../../../../path/from/there") instead of calling get_parent a lot, but in general, parent should no about children but not the other way around. We often say "Call down, Signal up" which means, connect the signal that your child will emit to the function the parent or other nodes will call each time that child is emitting that signal. That allow to reuse the child a lot more easily, or even swap it out later for another with a similar signal setup without too much of a hassle.
@panhoracy82542 жыл бұрын
When it comes to shader compilation lags. Lookup ubershader in next Godot update (3.5 that is on release candidate stage), it is meant to fix that exact problem
@selgesel2 жыл бұрын
Like many others suggested, hitting Ctrl+Space to force autocompletion can help ease the headaches, and adding type hints, class_name statements, using the colon equals operator (e.g. := which basically tries to infer the type) when getting onready references to child nodes can help Godot figure out what it can fill in a lot. But there's a catch to using the class_name statement in Godot 3.x and it's circular dependencies. If you have two scripts A.gd and B.gd with class_name statements (e.g. class_name A, class_name B), and try to get cross references against each other (e.g. "var a: A = ..." in B.gd and "var b: B = ..." in A.gd) you won't be able to compile/build the game; in which case you'll have to forego the corresponding type hints from one of the scripts. Fortunately this is fixed in Godot 4 which is fast approaching beta.
@NathanOnline2 жыл бұрын
Really great video! As someone who knows nothing about Godot this gave me a pretty good intro to what’s it’s like using it and what you have to look out for later on
@bunnyblake38852 жыл бұрын
Setting up VSCode as the default Godot script editor was an extremely good decision. Also, intellisense / smart completion works better if you explicitly set the type of your variables, i.e. write "counter : int = 0" instead of "counter = 0".
@BluecoreG2 жыл бұрын
when you like python but the rest of the entire freaking world wants a strong typed language. Thank goodness you can use c# with godot
@StillCisTho42 Жыл бұрын
Great time for a second part trying Godot 4, it could really help people making the jump from Unity.
@LukasSkywalker_2 жыл бұрын
I was afraid of changing to C# on godot but is not that hard. You got the typing, brackets, etc and the documentation is really good. After some time you get used to see a GDScript code on a tutorial and see how it will be in C#.
@realMenta2 жыл бұрын
I started using godot because it looked like a good all round engine, easy to understand and mostly because it was open source and Free :) Having a blast of an experience with godot, I'm really glad that I started making games.
@GoGameDeveloper2 жыл бұрын
4:52 They added that option in Godot 4, if run your scene you will see there is a little camera icon called 'project camera override' click on it and will let you move your editor camera inside the game :)
@daniishere10092 жыл бұрын
When Godot 4 is releasing through?
@ShVanesMusic2 жыл бұрын
@@daniishere1009 I hope this second half of year
@daniishere10092 жыл бұрын
@@ShVanesMusic I think it will going to be released early next year as they Godot have not release any type of statement that it is going to be released this year.
@cmyk89642 жыл бұрын
It’s already in Godot 3.
@Curt-0001 Жыл бұрын
I know this is older now, but Godot Docs specifically state if you need to access up a tree more than a few levels, you're proooobably doing something wrong. @11:30
@AzurePain2 жыл бұрын
You can improve the autocomplete settings (idle parse and code complete delays, type hints) in the Editor > Editor settings > General tab > Text editor section > Completion. Type hints will show you the types each code complete entry is :) . It's just not on by default, no idea why. You can shorten/lengthen the suggestion delays to your liking as well.
@sslaxx2 жыл бұрын
Are you aware you can synchronise scene and script changes from the "Debug" menu? Not sure if this would do everything you may want it to, but it should cover most of it. And people? Well, I noticed Jakefriend, Miziziziz and the PlayWithFurcifer couple, but there's also Jotson (Gravity Ace), Jitspoe (a former AAA dev who's now using Godot to make Fist of the Forgotten). There's MrEliptik (Dashpong), Lentsius and ValiantCheese (Hive Time, Bat Egg, Bonesweeper), and Tim Krief. It's a growing community out there!
@TheSicklyWizard Жыл бұрын
Not gonna lie. Felt a touch surreal seeing my videos thumbnail in this tutorial when im trying to learn godot XD
@zitronekoma302 жыл бұрын
11:43 use relative nodepaths 12:17 The thing is, these issues come up when you try to fight godots design philosophy, you almost never actually need public references if you're using signals correctly. Scope is very important here and it should not pose any problems when approaching it the right way. I had the same issues, coming from unity and trying to force godot to work as unity does. Good video overall tho!
@gustavobovo82782 жыл бұрын
Loved the vídeo bro. Really fun, probably was hell to edit it all together lol. Subbed, keep up the amazing work.
@AdamWong2 жыл бұрын
Great video. For those curious, the negative axis thing is a standard in computer graphics and OpenGL. If we fix x and y to grow larger as you move right and up, then when finding than orthogonal basis vector using a right handed system you end up with a z that grows larger as it moves towards us, meaning we look down the z axis in a negative direction. Long winded way of saying, the name derives from the linear algebra and math
@trys10studios Жыл бұрын
Currently studying Linear Algebra and find that interesting lol. I am finally getting a Comp Sci degree and looking into Godot (over Unity in which I have many years of experience) for game projects.
@maxfarouk3407 Жыл бұрын
Funny how suddenly this is all being recommended to me now. KZbin fueling the fire....
@Mgbeatz_Icrowdx Жыл бұрын
this video is very interesting based on what Unity is going through right now
@Outfrost Жыл бұрын
For debugging, I find it immensely useful (and straightforward) to display text within the game window every frame. That way I can always see the current value of something, without spamming the output log or scrolling through thousands of lines. I make an autoload scene which is a CanvasLayer (set up so it always draws above other stuff), I add a Label to it, and I make a tiny script that lets other nodes write text to it. You made a lot of valid criticisms of Godot, and as a seasoned user I've run into most of the same issues myself! I like your balanced takes, and I'm sure many of us in the community feel the same, as complaints turn into GitHub issues, which then turn into pull requests with fixes and improvements.
@trippyparrot92812 жыл бұрын
For your first point, the workflow, what I found to make an awesome difference for me was when I discovered that when clicking on the thre dots in the upper right corner, you can layer your optionwindows differently. Takes a bit of fiddeling, but I always use it to make the signals-tab appear above instead of behing the node.config-tab. Nothing bug, but it GREATLY improved my own workflow, maybe it will work for you too. Otherwise keep up the great work haha!
@IgorTverdokhleb Жыл бұрын
Interesting video! We are also working with Godot on the Mechanic 8230 project. Welcome to everyone who decided to switch to this wonderful engine and good luck with your projects! ;)
@notrickzdumbo2 жыл бұрын
On the autocomplete side of things it has an icon to the side telling you if its a function, an object etc. If its a function the icon will be the ".f()" thing.
@thomaseubank15032 жыл бұрын
18:15 Now that is a useful tip! How many times have I tried to move something only to move its collision shape alone because I had forgotten to save the branch as a scene. Edit 20:37 On the blender side you can create the collision shape by duplicating the object/landscape/whatever, adding "-colonly" to the end of the name where the period goes, and then putting that object as a child of the object that you want to import with a collision shape. Note that this only works if there are no animations whatsoever.
@vast6342 жыл бұрын
The unity world axes (Z forward, Y up) makes much more sense, and comes from the early days of GL rendering. Where the rendered image can be constructed in a 2D manner with x/y coordinates like a graph, and optionally with a z coordinate using a depth value and showing a 3D scene using perspective rendering. The whole "z buffer" thing shows that in classic graphics rendering z is "forward", eg into the scene.
@bitofalice11 ай бұрын
You've convinced me to learn Godot, thanks! I don't have time for this, GOSH
@joshuaanderson66092 жыл бұрын
It's always interesting to see the issues people have with Godot and knowing that it already has an easier way to do it. The thing is, you need to have read the documentation to know about it. For example, the collision mesh generation problem (where you have to manually generate them when the mesh is changed) can actually be automated pretty easily. The simplest way is to add '-col' or '-colonly' to the mesh that should have collisions, and boom Godot creates collisions at import automatically. Godot's documentation in my experience is very good in many places, but is still a bit lacking sometimes and can occasionally be hard to find what you need. Like you said as well, I've been using Godot for a while and have a lot of experience, but there's still new stuff I find out about and play with, and to me that's kinda part of the fun.
@Reneator2 жыл бұрын
Great video, great editing, watched till the end! Keep it up!
@bodamat2 жыл бұрын
I completely agree with you and I taught Godot just like you. Fortunately, most of the problems will be solved in Godot 4.0, but we still have to wait until the release :) I tried Unreal more than Unity, so Godot was in some ways very similar to Unreal and learning Godot was very easy for me. I still love and maybe even adore Godot. Yes, he has a lot of problems and sometimes few tools, but I really have complete control over my game and I can do things that I can't do anywhere else. Also, I always feel that my ideas for improving Godot are really being listened to, and some are even being implemented. How can this not please? :) I feel like I'm growing up in GameDev with Godot and I'm learning a lot of new things and my interest in it is higher. I don't know why, but it's cool :) To sum up, I may praise Godot, but it was convenient for me and it does not mean that everyone should take and use it. Each person will have their own tool and their own engine, which may seem simple and intuitive. Welcome to the world of Godot if anyone decides to give it a try;)
@hero3bash2 жыл бұрын
If you're not working on a serious project you can already start using Godot 4. It's in alpha but I personally haven't experience any serious bugs while working on a project.
@bodamat2 жыл бұрын
@@hero3bash unfortunately my project at first for web, so I can’t change right now. But thanks for advice. I also tested Godot 4.0 alpha every time and yes, it becomes more stable and more feature reach
@kerosine28962 жыл бұрын
I don't make games just yet, but I just wanted to say this video was super well made!I loved the editing, it was fun but not too meme-focused
@MirceaKitsune2 жыл бұрын
I always found that Unity is very slow for 3D at least on Linux. Godot is as good if not surely better in my book. I could never imagine using software that isn't FOSS today, anything that's corporate and centralized I simply don't feel I own and can rely on. So glad this beautiful engine is here.
@INRamos13 Жыл бұрын
This is a great video, I really enjoyed how you delicered all of this too. I then watched some more of your videos, and you now have a new subscriber.
@creeloper27 Жыл бұрын
4:00 and 9:25 update on this, godot is getting a feature that will allow to detach components and adjust them more around v4.1 if I rember correctly.
@theovanclay74282 жыл бұрын
Something I would recommend getting a good grasp on is how to build custom resource types. If you create a script that inherits from Resource and then give it a class_name you can then RClick in your file system browser add New Resource... using their wizard, search for your custom name and then you can create a kind of prefab of a class that you've created that can be adjusted in the editor even at runtime via export variables. This is especially great if you are working with a team and want people to test adjustments without touching the code. To give an example suppose you have an enemy class that you set up as a resource. With export variables for the stat blocks of the enemy, a set of exports for different scripts like movement, combat-class etc, a set of exports for the model used and colors to modulate them with. You could then set up an editor layout that had the filesystem browser and the Inspector as the only things on screen and a team member who has no coding experience could drag and drop the scripts, models from the filesystem browser and adjust the stat block and colors with the interface in the inspector and create and save/test 100's of variations of enemy designs. This is especially great when building a game like a tactics, sidescroll or jrpg game where you plan to reuse assets and just adjust color and stats to denote a different strength or Eliteness of an enemy.
@kaojaicam2 жыл бұрын
Such a great video! I hope you continue to make content like this the amount of love you put into it really shines! I learned a lot from this video I had no idea Godot treated 2d and 3d so differently. That makes me even more excited to use it tbh
@gamedevwithdrew2 жыл бұрын
I loved this video essay. About the lack of tutorials, I feel as if I was compelled to make my own just so new people did not have to end up like I did!
@bencornelisse11862 жыл бұрын
ive been watching every video of yours all day, the quality of your content is amazing. please keep making more videos
@MarcoDeRosa08 Жыл бұрын
I just started learning game dev, I'm a total beginner and I chose Unity, but this video really made me realize how complicated Unity is, maybe I'll try out Godot
@AkaNoBaka Жыл бұрын
As someone who was always curious about making games but was completely overwhelmed and felt pushed away by engine's like Unity & Unreal because there is hundreds of different things going on all over, Godot has finally been my breath of fresh air from the very first step of opening an example project. Everything is so digestible and easy to understand, even the scripting language. For the first time ever I was able to make my own changes and play around without needing to be lead or follow a tutorial. 110% recommend trying out Godot for a beginner and beyond
@gladiumcaeli11 ай бұрын
Unity isn't as complicated as he makes it out to be, people just like to complain about Unity3D. Unity does have its issues especially with the price change recently, but for making games it's a great game engine. Pokemon go, hearthstone, Cup head all great games made using Unity. Saying all that I do think Godot is a great engine just they both have their pros and cons
@angrychild290913 күн бұрын
@@gladiumcaeliscartch
Жыл бұрын
10:39 in the dropdown menu icon it indicates which element is the count entity in the left icon. You can see the icon represents .f(), which stands for a function.
@XRWorkout2 жыл бұрын
The way I usually update meshes is Close all scenes that use the object Go to the glb file in the import tab click on reimport Then open the glb file (you don't need to inherit that time just click open anyway) Then when you open the scene that derives from it it should already be updated. That works most of the time
@anthonynguyen2661 Жыл бұрын
i like how even tho im not a game dev yet this still ended up in my recommendation, truly says alot about the current situation.
@bigboyart12 жыл бұрын
I have no prior experience in coding in general, and as such I have no context for any other game engines. The limited experience I've had with Godot so far has been really really good. I love how it feels to interact with. The nodes are really fun to work with so far.
@Barakon2 жыл бұрын
You have been far more helpful than other tutorial series I’ve watch lmao.
@wayatvideos21422 жыл бұрын
Recent news involving Unity Industries had lead me to try Godot. Like you, Godot has been on my back-burner for a while, and now I have the push to finally go for it. Hopefully I can maintain my C# roots with the mono-version.
@ben256dev2 жыл бұрын
I love that you had relevant and interesting b-roll all the way through
@winstonyallow2 жыл бұрын
As for regenerating collision shapes on reimport: If you use a file format that preserves the internal mesh names then you can use hints to tell godot what to do with the mesh. For example you can let the name end in "-col" in blender so that godot will generate collision data for it. There is a lot of such hints, for example "-rigid" for rigid bodies and "-navmesh" to generate navigation data.
@pilotdawn16612 ай бұрын
If for no other reason, the "if !accurate() function at the beginning was hilarious and "return True" !!! Subscribed and Liked =) And the rest of the video was great too
@purple_fox_arts2 жыл бұрын
24:50 Wait a second...You don't need to use Vector3 to move in 2D. I've allways used Vector2 and it never got me into any Problems
@whobitmyneck2 жыл бұрын
He probably meant in unity
@AjTolly Жыл бұрын
Man you used the song from NSMBW, World 7 Sky Land, that's amazing! I love it and it's so nostalgic, thanks for that! I didn't remember that beautiful song.
@MewPurPur2 жыл бұрын
5:03 Have you seen Debug > Synchronize Scene/Script changes? (from the top menu)
@LazyAlarm2 жыл бұрын
That's similar to what mean. In Unity, when you make scene changes while the game is running, they get reverted upon closing the game. I like that ability to make impermanent changes on the fly.
@Imirui4 ай бұрын
11:26 To get the player variables to appear in the autofill, you have to have the scene with the object you're editing open in it. For example, if you want the player variables to appear in it, you have to have a scene with the object you're editing and the player as a child of it. Outside of that it will not know what sorcery you're talking about when you want to know the player's health.
@Sancarn2 жыл бұрын
I once tried making a RTS in godot, it didn't go at all well 😂 I am a programmer on the other hand, and mainly just found the lack of a good coding environment a big loss. I also wanted to procedurally generate terrain which appeared to be a nightmare... I feel a large portion of that was due to my inexperience at the time, and possibly lack of motivation to put the time into fixing the issues though.
@neolordie Жыл бұрын
what do you think about godot today ?
@Sancarn Жыл бұрын
@@neolordie honestly, haven't explored much since. I mainly develop automation and data solutions, not games
@Faunarr Жыл бұрын
@@Sancarn Honestly, anything that's missing in the engine can be solved with dlls, buffers, and extending the engine yourself. It seems like a lot has improved with the engine honestly though.
@Sancarn Жыл бұрын
@@Faunarr Probably yeah, does complicate the build process of course, especially if you're building for multi-platform.
@Faunarr Жыл бұрын
@@Sancarn right right. But at the same time. A build process is a more minor thing and only really requires you to get it right once before you develop and automate the script for it. Multi-platform is definitely an issue that needs to be taken account for. But even so, its more of a one time logistical issue that can definitely be fixed. As long as you design the architecture for it well. You should in theory have minimal problems. Oh and also, there's no shame in using other tools too. Such as blender for terrain generation. You don't have to do everything in godot. Hope my reply isn't annoying
@mrhiblo Жыл бұрын
"Adding in objects doesn't feel like filling in a spreadsheet but rather digging through a lego bin" has to be one to the best ways I've ever heard someone explain the concept of nodes in Godot
@DUNESDAY_ART Жыл бұрын
Not me over here finding this video now knowing Godot exists and now low-key want to try it
@shinyivyflare89287 ай бұрын
Bro this is me 7 months later looking at this like... 👀👀
@badunius_code2 жыл бұрын
11:30 it works like a charm when you use strict typing. As in Ref: Player = null
@jadedplover18512 жыл бұрын
Godot may not have any syntax or type enforcing but I enjoy that it still allows for c-like syntax and typing if you so please. You can type annotate any variable or parameter this a colon followed by the type and you can use curley braces, semi-colons and brackets around branching conditionals just like you can in c# if you so please for readability.
@uglydinosaur60482 жыл бұрын
Thank you so much! I wondered what game engine I should start learning first to engage in game development and not be stunned and eventually burned out because of engine overloaded by features, unwanted by newbie game developer like myself. You've just opened my eyes and made me want to start learning Godot. Really look forward to further development of the platform!
@jowanspooner87332 жыл бұрын
A few things: Very nice video, have been using godot for a couple of years now (as a hobby) and always liked the program and it's community. Here are two things I noticed: - While running the game, you can actually move things in the editor, and they will update their position in the game. - In 4.0 the script editor (as well as most other parts of godot) can be in a separate window. Maybe that helps, have a nice day everyone
@Ver2ion Жыл бұрын
One day I opened a Unity game i had been making for 6 months and it was completely broken out of no where, and then it just stopped opening. Fragile is the exact reason i stopped using unity & switched to gamemaker for 2d and godot for 3d, i even used source control.
@lazi212 жыл бұрын
Can't wait for Godot to reach critical mass regarding users and features. I really wonder what the first game will be that I really wanna play that is made in Godot :)
@NOPerative2 жыл бұрын
Racked you up some views there fella! Quarter million - nice. GODOT HYPE!
@BT293HG Жыл бұрын
Welcome back everyone, we all know why we are here
@treybilbo3385 Жыл бұрын
great video, very grounded and not from the perspective of a pro who knows everything already, thyanks!
@jatoxo2 жыл бұрын
You don't get suggestions sometimes because the engine doesn't know what type of node you're dealing with, the result of get_node is a Node so it only suggest functions for the Node class, even if that Node could be your Player with it's own function. So to get suggestions you can actually static type in Godot using colons like in Kotlin. "var thing : Timer = get_node("Timer")" and now you can get specific functions of the Timer class suggested
@JamesJLetourneau6 ай бұрын
Eloquent and articulate. Impeccable delivery my friend. Truly
@content8420 Жыл бұрын
I am here after the stunt Unity3d pull a few days ago about the installs.✌️
@-Name-here-2 жыл бұрын
32:40 about the console ports issue: godot just released that some of the original founders are making a non open source project to run alongside godot and this allows them to handle console publishing for you. Last I heard they said they’d have something out(the company(w4) is making other things, so idk what they’d be releasing) in a couple weeks, but we’ll see. Overall very happy I switched to godot! I started on ue4(not knowing anything) then I decided to try unity and just learn code, then back to ue4 for awhile, then back to unity, then finally godot. I tried switching from godot to stride in hopes of getting better graphics, but overall they were the same and I like the godot workflow much more.
@MelvinG24 Жыл бұрын
This video came perfectly after Unity new terms and conditions
@themore-you-know2 жыл бұрын
Also, adding to what SgtChilli said about SinglePurposePrinciple and TreeStructure: if you have some spare time and cash, get your hands on "Code Complete, 2nd edition". It's a big book about programming that is language agnostic, and everything Godot-related will suddenly make a whole lot more sense. Godot is built on OOP (Object Oriented Programming), with polymorphism, decoupling, etc. in mind. Once you read that book, you'll be able to apply the mindset to both your Godot hobby and almost any job. Very distant example: SinglePurposePrinciple is great in workshops where low cost tools keep getting misplaced and lead to expensive wasted time searching for it, so by multiplier the number of low cost tools to "1 per work station, w/ only 1 purpose", you get to eliminate the employees' time sinks and confusion for the cost of a single low cost tool (a quick math check will let you know how much time saved is needed to recup the tool's purchasing cost).
@Xenro662 жыл бұрын
I've tried Unity so, so many times but I always found it way too overwhelming. I'm not exactly a good programmer, but I can sorta work my way around my favourite IDE (and the only one I can use), Processing. Downloaded Godot bout 2 years ago, tried it for like 30 mins and promptly gave up thinking I'd never be able to make the game I wish to make because I'm too stupid to learn. After watching the entire video, I think I'll give it another shot. Hopefully this time I can get past the v0.0.1a pre-alpha stage of game development and not have to write absolutely everything from scratch like I would in Processing.
@leeramer1712 жыл бұрын
Hi Xenro66, Your comment made me think of myself. I too did what you did. I was looking for a game engine that I could eventually use to do a multiplayer game. I tried leaning basic way back, was not very good in math, and never thought I would be able to program. Tried learning some javascript but did not get very far. Tried Unity, even worse. Manged to do a little bit with an online type of game enfine but was limited. Finally came back to Godot about a year later and set myself to learn the GDscript with all the tutorials. It really is not that hard to learn. Takes time, but you can do it.
@johnoneill95903 ай бұрын
I'm like 5 hours into Godot and this video was a exactly what I needed to see for someone with almost zero experience in using an engine. It lets me know what challenges I should expect to go through for the next bit - maybe you've helped speedrun the experience. So Thanks!
@КостяКиндалюк2 жыл бұрын
25:30 Playing in Ping-Pong by changing window size is so funny xD
@noxmore2 жыл бұрын
Just found your channel, this video is quite entertaining and well-made! i'm surprised you don't have more subscribers
@daviddeedev2 жыл бұрын
Nice to see other new game dev KZbinrs like myself entering the slog! I'll definitely be staying around to see what you do next... Cheers! 😎