summaryrefslogtreecommitdiffstats
path: root/scene/resources/3d
Commit message (Collapse)AuthorAgeFilesLines
* Merge commit godotengine/godot@f128f383e892865379cb8b14e7bcc9858efe2973Spartan3222024-11-2722-12/+389
|\
| * Add ShadowCastingSetting to MeshLibrary / GridMap itemssmix82024-11-272-0/+38
| | | | | | | | Adds ShadowCastingSetting to MeshLibrary / GridMap items.
| * Add CollisionShape3D custom debug coloursJamie Greunbaum2024-11-2620-12/+351
| | | | | | | | | | | | | | This allows changing the display colour of a CollisionShape3D node on a per-shape basis. It also adds the ability to display a solid coloured preview of a CollisionShape3D. Closes https://github.com/godotengine/godot-proposals/issues/906
* | Merge commit godotengine/godot@d09d82d433b03bb3773fd2a8cc8d6ccc2f8739ceSpartan3222024-11-261-0/+169
|\|
| * Optimize mesh generation by preventing unneeded shape recalculationsCarson Bates2024-11-211-0/+169
| | | | | | | | Co-authored-by: Sequoia Haynes <supersequoia11@gmail.com>
* | Merge commit godotengine/godot@cb411fa960f0b7fdbd97dcdb4c90f9346360ee0eSpartan3222024-11-121-1/+1
|\|
| * Core: Integrate `Ref::instantiate` where possibleThaddeus Crews2024-11-101-1/+1
| |
* | Merge commit godotengine/godot@87318a2fb7fffeb72adca934e31915be077c3d1fSpartan3222024-11-062-19/+86
|\|
| * Rewrite index optimization code for maximum efficiencyArseny Kapoulkine2024-11-042-19/+86
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | While all the previous fixes to optimizeVertexCache invocation fixed the vertex transform efficiency, the import code still was missing two crucial recommendations from meshoptimizer documentation: - All meshes should be optimized for vertex cache (this reorders vertices for maximum fetch efficiency) - When LODs are used with a shared vertex buffer, the vertex order should be generated by doing a vertex fetch optimization on the concatenated index buffer from coarse to fine LODs; this maximizes fetch efficiency for coarse LODs The last point is especially crucial for Mali GPUs; unlike other GPUs where vertex order affects fetch efficiency but not shading, these GPUs have various shading quirks (depending on the GPU generation) that really require consecutive index ranges for each LOD, which requires the second optimization mentioned above. However all of these also help desktop GPUs and other mobile GPUs as well. Because this optimization is "global" in the sense that it affects all LODs and all vertex arrays in concert, I've taken this opportunity to isolate all optimization code in this function and pull it out of generate_lods and create_shadow_mesh; this doesn't change the vertex cache efficiency, but makes the code cleaner. Consequently, optimize_indices should be called after other functions like create_shadow_mesh / generate_lods. This required exposing meshopt_optimizeVertexFetchRemap; as a drive-by, meshopt_simplifySloppy was never used so it's not exposed anymore - this will simplify future meshopt upgrades if they end up changing the function's interface.
* | Merge commit godotengine/godot@c6c464cf9ae56e8b68620af65125dd980d0e8122Spartan3222024-11-023-295/+6
|\|
| * Merge pull request #69197 from aaronfranke/fix-tiny-convexThaddeus Crews2024-10-311-1/+1
| |\ | | | | | | | | | Fix debug line drawing with tiny convex hull mesh colliders
| | * Fix debug line drawing with tiny convex hull mesh collidersAaron Franke2024-10-301-1/+1
| | |
| * | Merge pull request #98620 from zeux/lodgen-cleanupClay John2024-10-302-294/+5
| |\ \ | | |/ | |/| LOD: Remove "Raycast Normals" and associated "Normal Split Angle" settings
| | * LOD: Remove "Raycast Normals" and associated "Normal Split Angle" settingsArseny Kapoulkine2024-10-282-294/+5
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | "Raycast Normals" was introduced in 4.4 dev and defaulted to "false". The limited testing results at the time suggested that raycasting generally reduces normal quality compared to native simplifier results, at the same time increasing vertex memory and import time. To play it safe, we introduced a setting that defaulted to false, with the goal of removing it later in 4.4 development cycle if no regressions are noticed. Since we already had three dev snapshots and no reports, this change removes the setting and associated code. "Normal Split Angle" was only used when raycast normals were enabled; this change removes it from the settings, but keeps it in the script binding for compatibility. Existing meshes import exactly the same after this change (unless they chose to override raycasting which would be surprising). split_normals helper was only used in this code path and is also removed for simplicity; it is unlikely that this code will be useful as is, as it can only regenerate normals without fixing tangents or updating positions.
* | | Merge commit godotengine/godot@8004c7524fb9f43425c4d6f614410a76678e0f7cSpartan3222024-10-303-2/+3
|\| |
| * | Merge pull request #97934 from adamscott/give-AThousandShips-a-breakThaddeus Crews2024-10-292-2/+2
| |\ \ | | |/ | |/| | | | [Codestyle] Set clang-format `RemoveSemicolon` rule to `true`
| | * Set clang-format `RemoveSemicolon` rule to `true`Adam Scott2024-10-252-2/+2
| | | | | | | | | | | | - Set clang-format `Standard` rule to `c++20`
| * | Update meshoptimizer to 0.22Arseny Kapoulkine2024-10-261-0/+1
| |/ | | | | | | | | | | | | | | | | The Godot-specific patch is just a single line now; removing this patch will likely require adjusting Godot importer code to handle error limits better. This also adds new SIMPLIFY_ options; Godot is currently not using any of these but might use SIMPLIFY_PRUNE and SIMPLIFY_SPARSE in the future.
* | Fix copyright headers referring to GodotSpartan3222024-10-2736-72/+72
| |
* | Rebrand preambles to RedotDubhghlas McLaughlin2024-10-1136-0/+72
|/ | | | | | | | | | | | | | | | | | | | | | Credits: Co-authored-by: Skogi <skogi.b@gmail.com> Co-authored-by: Spartan322 <Megacake1234@gmail.com> Co-authored-by: swashberry <swashdev@pm.me> Co-authored-by: Christoffer Sundbom <christoffer_karlsson@live.se> Co-authored-by: Dubhghlas McLaughlin <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: McDubh <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: Dubhghlas McLaughlin <103212704+mcdubhghlas@users.noreply.github.com> Co-authored-by: radenthefolf <radenthefolf@gmail.com> Co-authored-by: John Knight <80524176+Tekisasu-JohnK@users.noreply.github.com> Co-authored-by: Adam Vondersaar <adam.vondersaar@uphold.com> Co-authored-by: decryptedchaos <nixgod@gmail.com> Co-authored-by: zaftnotameni <122100803+zaftnotameni@users.noreply.github.com> Co-authored-by: Aaron Benjamin <lifeartstudios@gmail.com> Co-authored-by: wesam <108880473+wesamdev@users.noreply.github.com> Co-authored-by: Mister Puma <MisterPuma80@gmail.com> Co-authored-by: Aaron Benjamin <lifeartstudios@gmail.com> Co-authored-by: SingleError <isaaconeoneone@gmail.com> Co-authored-by: Bioblaze Payne <BioblazePayne@gmail.com>
* Implement asynchronous transfer queues, thread guards on RenderingDevice. ↵Dario2024-10-022-0/+5
| | | | | | | | | | | Add ubershaders and rework pipeline caches for Forward+ and Mobile. - Implements asynchronous transfer queues from PR #87590. - Adds ubershaders that can run with specialization constants specified as push constants. - Pipelines with specialization constants can compile in the background. - Added monitoring for pipeline compilations. - Materials and shaders can now be created asynchronously on background threads. - Meshes that are loaded on background threads can also compile pipelines as part of the loading process.
* SCons: Add unobtrusive type hints in SCons filesThaddeus Crews2024-09-251-0/+1
|
* Style: Apply new `clang-format` changesThaddeus Crews2024-09-201-3/+3
|
* Merge pull request #96880 from zeux/fix-vcache-nontriRémi Verschelde2024-09-121-2/+2
|\ | | | | | | Fix a crash in `ImporterMesh::create_shadow_mesh` for non-triangle surfaces
| * Fix a crash in ImporterMesh::create_shadow_mesh for non-triangle surfacesArseny Kapoulkine2024-09-111-2/+2
| | | | | | | | | | | | optimize_vertex_cache_func assumes the input is a triangle mesh; when an imported mesh contains points/lines/triangle strips, this code should be disabled.
* | Merge pull request #94783 from TokageItLab/validate-gltf-anim-nameRémi Verschelde2024-09-122-1/+13
|\ \ | |/ |/| | | Add validation to glTF importer for Blendshape and Animation
| * Add validation to glTF importer for Blendshape and AnimationSilc 'Tokage' Renew2024-07-262-1/+13
| |
* | Cleanup of raw `nullptr` checks with `Ref`A Thousand Ships2024-08-311-1/+1
| | | | | | | | Using `is_valid/null` over checks with `nullptr` or `ERR_FAIL_NULL` etc.
* | Use `MutexLock` in more placesA Thousand Ships2024-08-292-10/+4
| |
* | Merge pull request #94954 from raulsntos/mark-internal-propertiesRémi Verschelde2024-08-281-1/+1
|\ \ | | | | | | | | | Mark underscored properties as internal
| * | Mark underscored properties as internalRaul Santos2024-07-301-1/+1
| |/ | | | | | | | | | | | | | | These properties look like they were intended to be internal but they were missing the `PROPERTY_USAGE_INTERNAL` flag. - `PackedScene::_bundled` - `PortableCompressedTexture2D::_data` - `ImporterMesh::_data`
* | Merge pull request #93602 from aaronp64/inspector_latencyRémi Verschelde2024-08-221-4/+4
|\ \ | | | | | | | | | Improve Editor Inspector/Theme item lookup performance
| * | Improve Editor Inspector/Theme item lookup performanceaaronp642024-08-201-4/+4
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Changes to reduce the latency between changing node selection in the editor and seeing the new node reflected in the Inspector tab - Use Vector instead of List for ThemeOwner::get_theme_type_dependencies and related functions - Use Vector instead of List for ThemeContext::themes, set_themes(), and get_themes() - Add ClassDB:get_inheritance_chain_nocheck to get all parent/ancestor classes at once, to avoid repeated ClassDB locking overhead - Update BIND_THEME_ITEM macros and ThemeDB::update_class_instance_items to use provided StringNames for call to ThemeItemSetter, instead of creating a new StringName in each call These changes reduce the time taken by EditorInspector::update_tree by around 30-35%
* | | Add bounds function to NavigationMeshSourceGeometryDatasmix82024-08-192-0/+57
| | | | | | | | | | | | Adds get_bounds() function to NavigationMeshSourceGeometryData2D/3D to get a bounding box that covers all the geometry.
* | | NavigationPolygon: Implement get/set_polygon fast paths.Patrick Sean Klein2024-08-171-12/+7
| | |
* | | Optimize base and shadow meshes for cacheArseny Kapoulkine2024-08-162-0/+37
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Previously, vertex cache optimization was ran for the LOD meshes, but was never ran for the base mesh or for the shadow meshes, including shadow LOD chain (shadow LOD chain would sometimes get implicitly optimized for vertex cache as a byproduct of base LOD optimization, but not always). This could significantly affect the rendering performance of geometry heavy scenes, especially for depth or shadow passes where the fragment load is light.
* | | Merge pull request #94726 from BastiaanOlij/primitive_texel_size_updateRémi Verschelde2024-08-162-17/+30
|\ \ \ | | | | | | | | | | | | Make primitive meshes react to texel size change
| * | | Make primitive meshes react to texel size changeBastiaan Olij2024-07-262-17/+30
| | |/ | |/|
* | | Merge pull request #93727 from zeux/raycast-optRémi Verschelde2024-08-162-11/+24
|\ \ \ | |/ / |/| | | | | Disable normal raycaster for LOD generation by default
| * | Disable normal raycaster for LOD generation by defaultArseny Kapoulkine2024-07-022-11/+24
| |/ | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Normal raycaster makes LOD generation process >2x slower and often generates normals that look significantly worse compared to what the simplifier comes up with by default. This was likely different before last meshoptimizer upgrade, as the attribute metric was not functioning properly, but now it looks like it's doing more harm than good. This change makes it disabled by default but keeps an easy option to re-enable it per mesh using LOD parameters for now until we get more confidence and can remove the code outright. Because the long term plan would be to disable this feature entirely, the scripting API isn't changed, and it's just off-by-default there with no way to re-enable.
* / Fix LOD generation for meshes with tangents & mirrored UVsArseny Kapoulkine2024-07-231-1/+4
|/ | | | | | | | | | | | | | | | | | | | | | When UVs are mirrored in a mesh, collapsing vertices across the mirroring seam can significantly reduce quality in a way that is not apparent to the simplifier. Even if simplifier was given access to UV data, the coordinates would need to be weighted very highly to prevent these collapses, which would penalize overall quality of reasonable models. Normally, well behaved models with mirrored UVs have tangent data that is correctly mirrored, which results in duplicate vertices along the seam. The simplifier automatically recognizes that seam and preserves its structure; typically models have few edge loops where UV winding is flipped so this does not affect simplification quality much. However, pre-processing for LOD data welded vertices when UVs and normals were close, which welds these seams and breaks simplification, creating triangles with distorted UVs. We now take tangent frame sign into account when the input model has tangent data, and only weld vertices when the sign is the same.
* Fix thread-use causing navigation source geometry data corruptionsmix82024-06-212-22/+54
| | | | Fixes navigation source geometry data corruption caused by thread-use that changed vertices or indices while the source geometry data was used in a parsing process or read from by the navmesh baking.
* Use Core/Scene stringnames consistentlykobewi2024-05-131-1/+0
|
* Merge pull request #90921 from smix8/navmesh_bake_warnRémi Verschelde2024-04-221-0/+9
|\ | | | | | | Warn that navigation mesh baking from Meshes is bad for runtime performance
| * Warn that navigation mesh baking from Meshes is bad for runtime performancesmix82024-04-221-0/+9
| | | | | | | | Warns that navigation mesh baking from Meshes is bad for runtime performance.
* | Merge pull request #90935 from smix8/navdata_appendRémi Verschelde2024-04-222-8/+20
|\ \ | | | | | | | | | Add NavigationMeshSourceGeometryData append functions
| * | Add NavigationMeshSourceGeometryData append functionssmix82024-04-212-8/+20
| |/ | | | | | | Adds append functions to NavigationMeshSourceGeometryData.
* / Expose create_from_arrays in SurfaceTool and cleanup some namingLyuma2024-04-191-1/+1
|/
* Move NavigationMeshSourceGeometryData(2D/3D) to the 2D/3D subfoldersAaron Franke2024-04-152-0/+428
|
* Add HeightMapShape3D update with Image datasmix82024-04-042-0/+105
| | | | Adds HeightMapShape3D update with Image data.