Blender
Blender
Blender is the free and open source 3D creation suite. Free to use for any purpose, forever.
312 people like this
258 Posts
10 Photos
104 Videos
0 Reviews (5.0)
Recent Updates
  • 0 Comments ·0 Shares ·83 Views
  • Projects to Look Forward to 2025
    www.blender.org
    Projects to Look Forward to 2025January 13th, 2025Development, NewsDalai Felinto html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"Planning session 2025.One of the long-standing traditions of the Blender project is to start the year announcing what to be expected in the coming period. It gets artists excited (and developers anxious) to think of everything that will be soon possible.Are we going to see new features, or a focus on stability? Improvement in long-standing areas, or investment in new tech?Last year the focus was on finishing up long-standing projects, and that was a success! All the projects announced for Q1-2024 are now available in the latest release.Projects to Look Forward to 20242025 started with the Winter of Quality project, aiming at stability and documentation of all areas of Blender. We can now shift focus to start (and finish!) brand-new projects.Some of them are regular module work, and projects previously agreed on. While others are development targets for the Blender Studio upcoming open projects, which helps with direction (and testing) in the traditional Blender fashion.The proposed projects for this year are organized into the following areas:Node SystemsIntegrate the node-systems across different workflows.Better integration across node trees will allow node groups to be shared between different types of node systems, like Geometry Nodes and the compositor.Hair dynamics represents a major milestone: Geometry Nodes is set to reach feature parity with the legacy particle hair system. This will be the first step towards replacing the existing high-level simulation systems.Node-based image/texture Data-blocks will introduce procedural texture generation (think texture nodes 2.0), possible thanks to the GPU compositor development.Make productions more accessible for small and medium-sized studios.Project Setup, meaning project-wide variables and environments, will provide a unified way to share settings and properties across multiple .blend files within a single production. This will make asset management and shot creation more efficient and ensure consistency throughout the pipeline.Online Remote Assets will allow artists to access resources directly from online libraries such as third-party, community-curated content and various stores. This feature will also help remote productions that need their own asset libraries. This is the next step for the Extension Platform.Overrides will be simplified and re-iterated upon to provide an intuitive way to define properties dynamically for specific contexts, such as files, scenes, or collections. These improvements will reduce the need for external tools to handle override conflicts, making production pipelines smoother and more reliable.PerformanceBring more responsiveness into asset creation.While improving performance is an on-going effort, there are two areas in particular that currently are blocking for some productions requirements.EEVEE material shader compilation is currently a blocking operation for certain production requirements, especially during look development with heavy assets. The focus will be on enabling parallel compilation, investigating issues with the shader cache, and optimizing material compilation in complex production scenes.Shape Keys are another area requiring attention, particularly for character pipelines that rely on multiple shape keys for finer details and adjustment layers. The current storage system significantly impacts scalability. The plan is to modernize their storage, transitioning it to a more generic attribute systemsimilar to the approach used for UVsand implement sparse storage, ensuring that only the parts of a shape key that differ are stored.SculptingNon-destructive sculpting with layers, and better keyboard-less workflow.Multires propagation spikes remain a critical issue. These occur when changes to lower subdivision levels are not properly reflected in higher levels, leading to infamous artifacts. Fixing this problem is a priority to ensure the multires modifier works reliably in production.Sculpting Layers are a natural next step now that sculpting mode can handle more data, thanks to last years performance improvements. Adding support for mixing multiple layers will enable higher levels of detail and deforming layers essential for animation workflows, giving artists greater control and flexibility.Tablet pen support is important for workflows like sculpting, painting, and 2D animation. While the mouse can often be replaced by a pen, Blenders heavy reliance on keyboard input makes it cumbersome to use. Even more so for display tablets and, in the future, portable devices. The initial focus will be on supporting touch inputs, with basic gestures for navigation, undo, and redo.Storyboarding and basic camera editing from the VSE (video sequence editor).Sequence data-block.Quick access to Grease Pencil drawing for the active scene strip.Edit/animate scene strip camera from VSE.Storyboarding tools (e.g., easy of use to create new scene strips).Editorial and Storyboarding are key to film production. Inspired by the Storypencil add-on, and with Grease Pencil 3.0 complete, some of the team is now shifting the focus to editorial tools. The goal is to create a seamless workflow for storyboarding, combining sketching, timing, and editing to help artists bring their stories to life efficiently.On-going ProjectsThere is on-going maintenance and development in the modules. Here are a few of the areas being worked on.Rendering (Cycles, NPR, ).Vulkan (including a presentation at Vulkanised 2025).UV syncing and other improvements.HDR support in all the editors.Layered Animation.USD and game interoperability via glTF.Blender 5.0 backward incompatible changes.Other module work.ReleasesWhile projects dont target specific releases, Blender Foundation follows the cadence of 3 releases a year. The planned releases for 2025 and their initial dates are:Blender 4.4 (March) will be focused on stability and polishing.Blender 4.5 LTS (July) to wrap up the Blender 4 series.Blender 5.0 (November), to kickstart a new development cycle.On top of this, LTS release updates are expected throughout the year:Blender 3.6 LTS until June 2025.Blender 4.2 LTS until July 2026.Blender 4.5 LTS until July 2027.In 2024 there were 24 LTS releases among Blender 3.3 LTS, 3.6 LTS and 4.2 LTS.Blender ConferenceIn other news, the date for the traditional Blender Conference in Amsterdam moved to September this year. Learn more.Make this PossibleAll of this progress is made possible thanks to the donations and ongoing community involvement and contributions.The ambitious plans for 2025 reflect the growing scope of Blender, but they are also limited by the current resources available. While Blender is a community-driven project, much of the work is carried out by developers employed by Blender Institute or working with development grants.Further, some of the targets outlined here may need to be delayed or put on hold if the development team gets too busy managing ongoing maintenance or dealing with unforeseen delays.The same applies to certain development goals that have been proposed over the years, such as Blender Apps and Layered Textures, which are not feasible with the current team size. Support the Future of BlenderDonate to Blender by joining the Development Fund to support the Blender Foundations work on core development, maintenance, and new releases. Donate to BlenderTo follow new developments keep an eye on theBlender Developers Blog.On behalf of everyone, I hope we have a great 2025, and happy Blending!Dalai FelintoHead of Product, Blender
    0 Comments ·0 Shares ·108 Views
  • Layered Animation Workshop 2024
    code.blender.org
    Layered Animation Workshop 2024January 3rd, 2025Animation/Rigging, General Developmentdr. Sybren html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"Just before Blender Conference 2025, the Animation & Rigging module held a day-long workshop to discuss layered actions should work in Blender. In this post, well share the outcomes of that workshop.For more context on this topic, please visit Animation 2025: Progress & Planning.Joining in the workshop were Brad Clark, Christoph Lendenfeld, Dorothee Ditrich, Falk David, Lukas Tnne, Marion Stalke, Nate Rupsis, Nathan Vegdahl, Nika Kutsniashvili, Pierrick Picaut, Raymond Luc, Rik Schutte, and Sybren Stvel.Workshop FocusA single day isnt long enough to come up with a full design, so we tried to focus on topics that we could make real progress on within a day, and which would help orient the project. With that in mind, we structured the workshop into two parts:Part 1: decide which use cases and supporting workflows we should target in the initial minimal version of layered actions, and also what features we need to support in service of that. The focus here was on determining a minimal set of features that we can feasibly develop in a reasonable time frame, while still being a useful initial version.Part 2: discuss some of the trickier UI/UX questions raised by the features we decided on, and how they should work in practice.So, without further delay, here is what we discussed at the workshop.Use Cases and WorkflowsWe identified four broad categories of use cases/workflows for animation layers:Creating new animations from scratch via layers. For example, animating a base layer of a character walking and then an additional layer for finer details in the motion, like shivering.Adjusting existing animations. For example, adjusting mocap data non-destructively, or fixing an intersecting hand in someone elses (or your own!) messy animation.Organizing animation data. For example, putting a characters facial animation on one layer and their body animation on another, or storing backups of previous animation stages (blocking, splining, etc.) in disabled layers for reference.Incorporating non-keyframe data. This might be things like simulation layers, layers that bring in motion from cache files, layers that define animation-level constraints, etc.Of these categories, we decided to leave #4 out of the initial version of layered actions. There are a lot of unknowns and potentially hard problems to solve with many of the use cases in that category, and just generally its not the primary reason people want animation layers.We decided that the remaining three categories are all reasonable to accomodate in an initial minimal viable product (MVP) as long as we stick to the basics rather than trying to get fancy.Intitial Feature SetFrom the above use cases, we narrowed down what we thought a reasonable minimal feature set would be. Additional features can always be added later, so the focus of this was on the minimum features needed for it to be useful. We of course want additional features down the line.Here is a list of what we thought we couldnt be without:Layers can be named.Layers can be given a color.Layers can be selected, and there is an active layer.Layers can be reordered.Layers can be added, deleted, and duplicated.Layers can be locked.Layers can be muted/disabled.Layers can be soloed (multiple layers can be soloed simultaneously).Each Layer has a blend mode. For initial release, these will be replace (similar to alpha-over in compositing software) and combine (conceptually an add mode, except data-type aware so that rotations rotate, scales scale, etc.).Layers have animatable influence / weight.Layers can be baked down together with the layers below them, as a way of merging layers togther. For the initial version this will just be a dumb per-frame bake.Layers are contained within, and owned by, an Action. Each Action has its own set of layers.These features may seem quite basic. Thats because they are quite basic, and thats the point. Its a small, basic set of features that are manageable to tackle in an initial Minimal Viable Product (MVP). Additional features (like layer groups, smart baking, time warping, etc.) can wait for after the MVP is completed and in peoples hands.We dont want people to have to wait for all of the fancy features to be done before they can use the system at all. And when we get feedback, we want a simple system we can easily adjust.Where/How Do You Manage Layers?There will be a separate editor for managing layers, and for selecting the active layer within an Action. Maybe this will even start out as a panel in the Action editor for the simplest of implementations.At first, the other animation editors are only going to show data from the active layer.This is just a start to get something simple in the hands of animators as soon as possible. With a more tangible layered workflow in Blender, it will be easier to design the necessary improvements to the UI/UX.Where Do Keys Go?When working with multiple layers, it is not immediately obvious where keys should go when you press the I button to key something. Below is the flow diagram we came up with.Lets talk through the above flow diagram:If there are no layers yet, create one and use that to store the keys.If there is only one layer, use that to store the keys.With multiple layers, there is a choice depending on whether the Available (name to be improved) checkbox is checked.Unchecked: keys should always go to the active layer. Blender ensures that there is always a layer active (if there are no layers see above).Checked: keys should go to the layer that already animates whatever youre keying now. See below.How many layers are already animating this property?none use the active layer (*)one layer use thatmore than one layer: is one of those the active layer? If so, use it, otherwise use the topmost, unlocked layer.(*): The flow diagram also goes into a choice for auto-keying vs. explicit keying. We hope that with this text the rest of the diagram is also clear.That Available checkbox will likely be a user preference, as it is expected that itll be a personal choice and reflect more how you animate than what file youre working in.How Does Blending Work?Blending the animation from different layers together is a fundamental aspect of layered animation, but is also surprisingly tricky to get right. It also impacts how certain other features should work.So how does blending work? was an important question to answer. Below are our answers to that, as well as to the further questions that it raises.What blend modes are there, and how do they work?The initial Minimal Viable Product (MVP) will have just two blend modes: replace and combine. Other blend modes may be added in the future if there are real use cases for them, but for the MVP we will just have these two:Replace is like alpha over, overriding the animated values of the layers below. Changing the layers influence between 0-100% blends between the values of the layers below and the values of the current layer.Combine is conceptually like add, accumulating on top of the animated values of the layers below. For most properties this is a literal mathematical add, but for some properties (such as scale and quaternion rotation) that either isnt really what you want or isnt even sensical. In those latter cases the most appropriate accumulation operation is used instead (e.g. multiply for scale and quaternion multiplication for quaternion rotations). Changing the layers influence between 0-100% blends between the values of the layers below and the accumulated result of those values with the current layer.For both blend modes, layers only affect properties that they animate: if a property is not animated on a layer then its value is simply passed through untouched.What happens when there is no value on the layers below?For replace layers with less-than-100% influence and combine layers with any influence, there has to be something below for the layer to blend with. But what if the layer is the bottom layer? Or what if it animates a property that isnt animated on any of the layers below it? What does it blend with?We considered two alternatives:Not blending: if there is nothing to blend with, dont blend at all and just replace at 100% regardless of the layers actual blend mode and influence.Blend to default: use the propertys default value as the value below to blend with. This means blending to zero for location, one for scale, etc. Effectively, this means bones blend to their rest pose, and objects blend to their delta transform (which is often also zero, so then they blend to the origin, parent, etc.).Neither solution is perfect, each having less-than-ideal behavior in at least some situations.Not blending means that the effective influence of a layer can be 100% even when actually set to 0% or an extremely small percentage. Moreover, that effective influence can be different for different animated properties depending on what is and isnt animated on the layers below, which could be confusing. It could also frustrate certain workflows, such as temporarily muting other layers to tweak the current layers animation in isolation: if the current layers influence is small, then muting the layers below it would effectively jump its influence to 100%, exaggerating its actual effect on the animation.On the other hand, blend to default also has issues. The default values for properties often arent useful/meaningful, so blending with them is likely to be pretty useless in many cases. For example, unparented objects would typically blend to the world origin.In the end we settled on blend to default. Its behavior is more predictable and less disruptive, and the user can work around useless default values if needed by keying useful values on a base layer.What happens when you mute a layer?Muting a layer will affect blending as if you removed the layer entirely. Note that for animated properties that are not on any layers below, this is specifically different from setting the layers influence to zero; that would blend to default, while muting the layer stops animating the property altogether.Terminology note: we may want to call this disable rather than mute. To be decided.Inserting and editing keys on middle layersWhen you have multiple layers, you will often want to insert keys on one of the middle layers. When this happens, the value of that key must be determined.We decided that the inserted value should be whatever value makes the final mix of all layers together produce the current pose. In practice this is almost always what is wanted: any other behavior would mean that inserting a key with the current pose may actually change the pose itself, which would be quite surprising! Accomplishing this means that the keyframing code needs to account for and reverse the effects of the other layers when determining the value to key. This is a bit like crazy space in mesh edit mode, which allows you to directly adjust the deformed positions of vertices.However, just like crazy space, this isnt always the behavior you want. Occasionally you want to specify the exact value to key, regardless of the effects of other layers. For the initial MVP you will be able to more-or-less accomplish this by soloing the layer before posing and keying, but in the future we want to explore approaches to accomplish this more directly.There are also operations other than key insertion that may be useful to do with this crazy space behavior. For example, perhaps you want to add a layer and use it to smooth out the final mixed animation. If the smooth operator in the graph editor only sees the f-curves of a single layer in isolation, this wont work. Instead, it will need to (optionally) perform the smoothing on the final mixed values and then back-propagate those smoothed values, accounting for the effects of the other layers. For the MVP we likely wont be implementing this; there are some subtle and non-obvious details that may be challenging to get right. But it is something we want to support in the future.Finally, there are of course cases where the crazy space keying behavior is impossible. For example, if there is a replace layer with 100% influence above the layer youre keying on: no matter what value you insert a key with, it cannot affect the final mixed pose. We discussed a few alternatives for what should happen in such cases, but ultimately decided that for the MVP we should keep it simple: Blender will simply reject keying and issue an error. After this system is built, we can experiment with other approaches and see what actually works best in practice.Wrapping UpWere extremely happy with how the workshop went, and we believe this is a solid direction for layered actions. Nevertheless, this is not the end of the design process. There is still a lot that needs to be figured out. Moreover, we could only accommodate a limited number of people at the workshop, and we want feedback and ideas from wider community as well. The best way to get involved is to join our weekly module meeting, and we look forward to seeing you there!
    0 Comments ·0 Shares ·265 Views
  • The Future of Overrides
    code.blender.org
    The Future of OverridesDecember 13th, 2024Code Design, General DevelopmentDalai Felinto html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"In December 2024, a workshop was held at the Blender HQ in Amsterdam to discuss the use of overrides in production environments.The workshop was attended by Andy Goralczyk and Simon Thommes from Blender Studio, while Bastien Montagne, Sergey Sharybin, and Dalai Felinto attended on behalf of the development team.Left to right: Simon, Sergey, Bastien, Andy, Dalai (photo) at the Blender HQ in Amsterdam.The main topics discussed were the pain points of the existing (library) overrides system, its limitations, and potential improvements for future productions.Overrides in productionsThe existing Library Overrides system is very powerful. However, with great power comes great responsibility complexity.The system was designed to replace the old proxy system and support multiple instances of the same character within a scene. Its most extensive use case was the Sprite Fright project, which involved animating numerous Sprite characters, all overridden from the same blendfile.Sprite Fright CC-BY Blender Studio.Although the initial plan appeared solid, the systems design introduced the need for active maintenance. Files would frequently go out of sync, requiring Blender to resync linked librariestaking minutes each time a file containing modified linked rig was opened.This led to name collisions in production files and the need for a custom script to reopen and resave all interlinked files daily, to keep relationships in sync.Meanwhile, Blender Studio developed an add-on to handle shot-based non-character overrides (e.g., light tweaks). This simpler approach was very functional and could handle a wide range of use cases more efficiently compared to Library Overrides.After completing enough projects using this pipeline (Sprite Fright, Charge, Wing It!, Gold, and smaller productions), it is time to improve Blenders approach to overrides.Leave the complexity out for 99% casesThe main feedback was that, in most scenarios where overrides are needed, a simple solution should suffice. To put it differently:I want to link a character and animate it [but]in 99% of cases we dont need the complexity of overrides.For the rare instances where artists require full control over a hierarchy, the existing Library Overrides system will still be available. In that sense, Library Overrides are here to stay. However, both rigged character animations and individual properties (e.g., Light power) should be overridable in a more streamlined way.(Dynamic) OverridesThe proposed solution introduces a new type of override (codename: Dynamic Overrides), which can operate on linked or local data. When working with linked data, a Library Override can still be created when necessary, but now it can be done without overriding the entire hierarchy.Key-points:Flexible Storage: Dynamic Overrides can be stored in various places, such as scenes or collections, giving users full control over their location.Linkable: Depending on where they are stored, Dynamic Overrides can also be linked.Granular Control:Overrides can apply to specific properties rather than entire hierarchies.The system allows for individual adjustments (i.e., a single property).ID Pointers Support: Can replace/override ID pointers.Remappable: They can be swapped when broken paths are found.Enhanced Usability:Dynamic Overrides take over most of the current Library Overrides interface, providing a streamlined experience.Library Overrides will still be necessary for specific features like modifiers and viewport interactions for now.Co-Existence with Library Overrides:Linked rigged characters will first get a Library Override for the rig, without any hierarchy.Followed by a Dynamic Override to remap usages of the linked armature to the local library overridden rig.This re-creates the proxy system experience with a more robust implementation.Library Overrides Hierarchy still available:Library Overrides hierarchies remain available for the rare (1%) complex use cases.Dynamic Overrides can be converted into Library Overrides when a full hierarchy is required.Overrides data-blockA new data-block type, Override, would be introduced. Initially, this will be used by the Scene ID, making the overrides globally applicable within a single scene.In the future, this data-block could be applied more specifically to collections and other contexts. This would allow different versions of the same material or object to coexist, each with distinct properties based on their contexts overrides.Overrides ID Data-block data structure design.There are three types of override rules which are being considered:ID Remap: Designed for animation of linked rigged characters.RNAPath: Focused on overriding individual properties.Filter: A mechanism to apply RNAPath changes to multiple data-blocks simultaneously, rather than just one.User InterfaceBelow are mockups showcasing possible integrations for overrides in the user interface.Creating overridesAn override can be added via the context menu or by using the O shortcut.Context Menu: Add Override and Remove Override options.Where to view Overrides?Properties Editor: Overrides can be identified by their override-specific color.Overrides Panel: A dedicated panel listing all overrides will be available.Initially, this list will only appear at the scene level. In the future, it will be accessible in other locations where overrides can be stored (e.g., Collections).Advanced SetupFor more complex setups, the overrides data-block can be linked from a different file. This allows for creating a hierarchical set of override rules that can be stacked and reused across multiple contexts.Short term alternativesBefore this project can fully begin, a few steps will be taken to speed up background blend-files processing:Option to skip dependency graph building in background mode.Option to skip Library Override re-sync in background mode.Expose some blend-file libraries dependency information in the Python API.These improvements will help with the Blender Studio pipeline, which relies on daily project-wide resyncs to minimize override conflicts. A script is used to open all files that link any edited files and save them, ensuring that override resyncs do not accumulate over time.MilestonesOverride ID Data-blockAnimation support for overriden properties.Filter for overrides (wildcard RNA properties).Non-global overrides (context-based overrides).Good-to-have targets:Viewport interaction (gizmos).Modifiers, constraints, (requires design, could be targeted for 5.0).Closing thoughtsThe concept of dynamic overrides is not new, but it has now been refined to a point where the team feels it is ready for development.This maturation period was also crucial for Library Overrides to be battle-tested and for the use cases of dynamic overrides to become more clearly defined. This will enable both types of overrides to be used in combination, leveraging the strengths of each to achieve the best of both worlds.Next stepsOverrides will be one of the main targets for 2025. The exact timeline will depend on the Blender Studio project lineup and the availability of the development team.Once an initial prototype is ready for testing, a thread will be created on the Developer Forum for studios and individual artists to share their feedback.Support the Future of BlenderDonate to Blender by joining the Development Fund to support the Blender Foundations work on core development, maintenance, and new releases. Donate to Blender
    0 Comments ·0 Shares ·424 Views
  • 0 Comments ·0 Shares ·531 Views
  • 0 Comments ·0 Shares ·621 Views
  • Blender 4.3 Release
    www.blender.org
    Blender 4.3 ReleaseNovember 19th, 2024Press ReleasesPablo Vazquez html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"Join the 2% Just 2 percent of users donating can help bring in more developers to keep Blender the best 3D software out there. Free for everyone, forever! Blender Foundation and the online developers community are proud to present Blender 4.3!Blender 4.3 splash artwork by Blender StudioWhats NewBlender 4.3 builds on the feature-packed 4.2 LTS with improvements to existing tools, performance enhancements, and the foundations that will shape the years to come.Some highlights:EEVEE: Light & Shadow LinkingRendering: Metallic BSDF, and new Gabor Noise texture.Compositor: Support for EEVEE passes, new White Point Color Balance, and more.Grease Pencil: Complete rewrite to support Layer Groups, Geometry Nodes, better erase tool, gradients, and much more.Geometry Nodes: For Each Zone, Gizmos, Bakes can be packed now, new nodes and UI improvements.Sculpt: Major refactor under the hood to improve performance.UV: New Minimum Stretch (SLIM) unwrapping method.Modeling: Bevel modifier can now use custom attributes.Brush Assets: All brushes are now assets, to be shared easily between projects.USD: Support for exporting Point Clouds.glTF: Draco mesh compression for importing, better export of UDIM tiles, quaternions and matrix attributes. Plus loads of bug fixes.And so much more!Watch the video summary on Blenders YouTube channel.And many more features and fixes await youexplore the release notes for an in-depth look at whats new!Thank you!This work is made possible thanks to the outstanding contributions of the Blender community, and the support of the over 4800 individuals and 35 organizations contributing to theBlender Development Fund.Happy Blending!The Blender TeamNovember 19th, 2024Support the Future of BlenderDonate to Blender by joining the Development Fund to support the Blender Foundations work on core development, maintenance, and new releases. Donate to Blender
    0 Comments ·0 Shares ·634 Views
  • 0 Comments ·0 Shares ·634 Views
  • 0 Comments ·0 Shares ·632 Views
  • Blender Foundations 2024 Fundraiser
    www.blender.org
    Blender Foundations 2024 FundraiserNovember 18th, 2024Press ReleasesFrancesco Siddi html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"AMSTERDAM, Netherlands The Blender Foundation today announced its latest fundraising campaign. This campaign, themed Join the 2 percent, aims to substantially increase the amount of incoming donations to support the continued development and maintenance of the beloved free and open-source 3D creation software.Blender is free for everyone. However, developing and maintaining the project is not without cost. These costs are solely covered by donations from thousands of individuals and several corporations. While having a good relationship with corporations is important, individual donations from users are crucial, as they allow Blender to remain an independent community project with development focus on end-user benefits.Blender is massively popular: 20 million downloads were registered in 2023. Understandably, most people are not in the position to financially support the project, but its reasonable to estimate that around 2% of the users have benefited from Blender in one way or another. Its to these people that the Foundation wishes to reach out: join the 2% of users that donate to Blender and keep it free for everyone!About the Blender FoundationThe Blender Foundation is a public benefit organization with the mission to provide everyone access to the worlds best 3D CG technology as free/open source tools, by facilitating and supporting the projects at blender.org. Blender is being used by millions of artists, designers, filmmakers, and professionals worldwide. The foundation is committed to ensuring that Blender remains a powerful, free and open-source tool for creative expression and innovation.Contact:Ton Roosendaal, Blender Foundation[emailprotected]
    0 Comments ·0 Shares ·641 Views
  • 0 Comments ·0 Shares ·654 Views
  • 0 Comments ·0 Shares ·667 Views
  • 0 Comments ·0 Shares ·672 Views
  • 0 Comments ·0 Shares ·681 Views
  • 0 Comments ·0 Shares ·678 Views
  • 0 Comments ·0 Shares ·679 Views
  • 0 Comments ·0 Shares ·681 Views
  • 0 Comments ·0 Shares ·683 Views
  • This Summers Sculpt Mode Refactor
    code.blender.org
    This Summers Sculpt Mode RefactorNovember 7th, 2024Code Design, General DevelopmentHans Goudey html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"Over the past several months sculpt mode underwent a large rewrite. Since the project has wrapped up, this post gives an overview of what changed.Unlike most other development projects, this had no effect on the interface. Before and after the project, Blender looked exactly the same. Typically this should raise some eyebrows, because it often means developers are prioritizing work based on its effect on the code rather than its utility to users. In this case, problems with the code have made feature development significantly harder over the years, and refactoring came with plenty of potential performance improvements.Overall, for those who want to skip all the technical details, entering sculpt mode in Blender 4.3 is over 5x faster, brushes themselves are about 8x faster, and memory usage is reduced by about 30%. For actual visible changes to sculpting in 4.3, see brush assets. For a full list of the refactor work, see the task.Entering Sculpt ModeEntering sculpt mode was known to be quite slow. Based on profiles, it also looked much slower than it should be, since it was completely single threaded.A profile of Blender as it enters sculpt mode on a large mesh in 4.2, where each row is a CPU core.It turns out Blender was bottlenecked by two things: building the BVH tree that accelerates spatial searches and raycasting and uploading the mesh data to the GPU for drawing.Improving the BVH build time was a months-long iterative process of finding bottlenecks with a profiler, addressing them, and cleaning the code to make further refactoring possible. Adding trivial multi-threading to the calculation of bounds and other temporary data was the most significant improvement, at almost 5x. Beyond that, reducing memory usage improved performance by another 30%, simplifying the spatial partitioning of face indices using the C++ standard library another 30%. And finally, changing the BVH from storing triangles to storing faces (for a quad mesh there are half as many triangles as faces!) improved performance by another 2.3x.Entering sculpt mode is about 5 times faster compared to 4.2 (a change from 11 to 1.9 seconds with a 16 million face mesh with a Ryzen 7950x).Lessons for DevelopersAny array the size of a mesh is far from free. We should think hard about whether all the data in the array is really necessary.Any algorithm should clearly separate serial and parallel parts. Any loop that can be done in parallel should be inside a parallel_for.We shouldnt be reimplementing common algorithms like partitioning; that makes code so scary and weird that no one touches it for years.DrawingThere is a fundamental cost of uploading geometry data to the GPU and we will always be bottlenecked to some extent by the large amount of data we need to render. However, as a tweaked version of code from 15 years ago, sculpt mode drawing had enough overhead and complexity that significant improvements were possible.The GPU data for the whole mesh is split into chunks, with one chunk per BVH node. One main problem with the old data upload was its outer loop over nodes. That forced all the book-keeping to be duplicated for every node. Often just focusing on simplifying the code gave performance improvements indirectly. Removing two levels of function call indirection for multires data upload roughly doubled the performance, and removing function calls for every mesh edge gave another 30% improvement.The main change to the drawing code was a rewrite to avoid all duplicate work per BVH node, add multi-threading, and change the way we tag changed data. This improved memory usage by roughly 15% (we now calculate viewport wireframe data if the overlay is actually turned on), and entering sculpt mode became at least 10% faster.GPU memory usage was reduced by almost 2x using indexed drawing to avoid duplicating vertex data for every single triangle. Now vertex data is only duplicated per face corner.Previously, sculpting on a BVH node would cause every single attribute to be reuploaded to the GPU. Now we only reupload attributes that actually changed. For example, changing face sets only reuploads face sets. Tracking this state only costs a single bit per node.BVH Tree DesignPreviously, the sculpt BVH tree, often referred to as the PBVH (Paint Bounding Volume Hierarchy) was a catch-all storage for any data needed anywhere in sculpt mode. To reduce the codes spaghetti factor and clarify the design, we wanted to focus the BVH on its goal of accelerating spatial lookups and raycasting. To do that we removed references to mesh visibility, topology, positions, colors, masks, the viewport clipping planes, back pointers to the geometry, etc. from the BVH tree. All of this data was stored redundantly in the BVH tree, so whenever it changed, the BVH tree needed to change too. Nowadays the design is more focused and its much easier to understand the purpose of the BVH.Another fundamental change to the BVH was replacing each nodes references to triangles with references to faces. In a typical quad mesh there are twice as many triangles as faces, so this allowed us to halve a good portion of the BVH trees memory overhead.Brush EvaluationTo evaluate a brush, regions (BVH nodes) of the mesh are first tested roughly for inclusion within its radius. For every vertex in each of these regions, we calculate a position translation and the brushs strength. The vertex strength includes more granular filtering based on the brush radius, mask values, automasking, and other brush settings.Meshes are split into multiple BVH nodes which are used to filter unaffected geometry.Prior to this project, all these calculations were performed vertex by vertex. For each vertex, we retrieved the necessary information, calculated the deformation and the relative strength and then finally applied the brushs change. Because mesh data is stored in large contiguous arrays, it is inefficient from a memory perspective to process all attributes for a particular vertex at once, as this likely results in many cache misses and evictions.While the previous code was somewhat concise, handling all three sculpt mesh types (regular meshes, dynamic topology, multires) at once, this generic processing had some significant negative side effects:The old brush code was hard reason about because of C macros and the combination of multiple data structures in one loop.The structure had little opportunity for improved performance because of runtime switching between data structures and the lowest-common-denominator effect of handling different formats.A do everything for each vertex structure has memory access patterns that dont align with the way data is actually stored.Brush code now just processes a single action for all the vertices in a node at the same time, splitting the code into very simple hot loops which can use SIMD, use much more predictable memory access patterns, and have significantly less branching per-vertex.For further reference, here is a change that refactored the clay thumb brush. Though the new code has more lines, its more independent, flexible, and easier to change.Proxy SystemPreviously, brush deformations were accumulating into a temporary proxy storage on each BVH node. This accumulation occurred for each symmetry iteration until the end of a given brush step, at which point the data was written into the evaluated mesh positions, shape key data, and the base mesh itself.We completely removed the proxy system as part of refactoring each brush. Instead, brushes now immediately write their deformation during each each symmetry step calculation. This avoids storing temporary data and improves cache access patterns by writing to memory that is already cached. Removing the proxy storage also reduced the size of BVH nodes by around 40%, which aligns with our ongoing goal of improving performance by splitting the mesh into more nodes.Profiling revealed a significant bottleneck during brush evaluation: just storing the meshs initial state for the undo system was taking 60% of the time. When something so simple is taking so much time, there is clearly a problem.The issue turned out to be that most threads involved in brush evaluation were waiting for a lock while a single thread did a linear search through the undo data, trying to find the values for its BVH node.for (std::unique_ptr<undo::Node> &unode : step_data->nodes) { if (unode->bvh_node == bvh_node && unode->data_type == type) { return unode.get(); }}Simply changing the vector to a Map hash table gave us back that time and significantly improved the responsiveness of brushes.return step_data->undo_nodes_by_pbvh_node.lookup({node, type});Though there was plenty of refactoring required to make this possible, the nice part is how often very little time with a profiler is necessary to identify significant improvements.Undo Data Memory UsageUndo steps also became slightly more memory efficient in 4.3. The overhead of each BVH nodes undo storage for a brush stroke reduced 10x from about 4KB to about 400 bytes.In the future we would like to look into compressing stored undo step data. This could require significantly less memory.For another example of thread contention, we look to the counting of undo step memory usage. Undo data is created from multiple threads, and each thread incremented the same memory usage counter variable. Simply counting memory usage later on with a proper reduction gave a 4% brush evaluation performance improvement.Writing to the same memory from multiple threads at the same time is slow!In yet another thread contention problem, writing true to a single boolean from multiple threads turned out to be a significant issue for the calculation of the average mesh normal under the cursor. The boolean was logically redundant, so just removing it improved brush evaluation performance by 2x.Multi-Resolution ModifierMost of these performance improvements were targeted at base mesh sculpting where there was more low-hanging fruit. However, multires changes followed the same design and there were a few more specific optimizations for it too. Most significantly, moving to a struct-of-arrays format for positions, normals, and masks gave a 32% improvement to brush performance, and simplified code.The sculpt-mode multires data structure was optimized the same way meshes were optimized over the past years (see last years conference talk)Some multires workflows have remaining bottlenecks though, like subdivision evaluation or bad performance at very high subdivision levels.The End!Thanks for reading! It was a pleasure to be able to iterate on the internals of sculpt mode. Hopefully the changes can be a solid foundation for many future improvements.Support the Future of BlenderDonate to Blender by joining the Development Fund to support the Blender Foundations work on core development, maintenance, and new releases. Donate to Blender
    0 Comments ·0 Shares ·699 Views
  • Geometry Nodes Workshop: October 2024
    code.blender.org
    html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"After the Blender Conference, the Geometry Nodes team came together once again to discuss many design topics. This time our focus main focus was to improve support for physics, especially hair dynamics in Geometry Nodes. A few other topics were discussed as well though. You can also read the raw notes we took during the meetings.The following people participated in the workshop (from left to right): Lukas Tnne, Hans Goudey, Simon Thommes (afternoons) and Jacques Lucke. Additionally, Dalai Felinto helped kickoff the workshop and Falk David joined in every now and then.Previously in Geometry NodesOur last workshop was 5 months ago. This section provides a quick update on the topics we discussed there. Omitted topics dont have any news.Gizmos: They are part of the Blender 4.3 release. Next step here is to add gizmos to some built-in nodes like the Transform Geometry or Grid nodes.Baking: Bakes can be packed now. Next step is to provide higher level tooling to work with multiple bakes in a scene.Rename Sockets in Nodes: Ctrl+click to rename sockets works in a few nodes now (e.g. Bake, Simulation, Capture Attribute). There are some technical difficulties with making it work with double click and for right-aligned labels.Tools for Node Tree UX: Built-in nodes support socket separators now (used in the For-Each Zone). Support will be added to node groups at some point. The viewer node automatically changes its position now.Asset Embedding: A prototype was built to test the behavior. We agreed on how we solve the technical difficulties with it, but some UI aspects are still somewhat unclear (e.g. how this is presented to the user as a new import method besides linking and appending).Menu Socket: We improved the error handling when there are invalid links, giving more information to the user about what is wrong. This applies to menu sockets, but also other invalid links like invalid type conversions.Socket Shapes: We found a design where everyone is okay with the trade-offs it makes. A prototype was built. The work on it is still ongoing.Grease Pencil: Geometry Nodes can work with Grease Pencil data starting with Blender 4.3.For-Each Zones: There is a new For-Each Element zone in 4.3. Work on other kinds of For-Each zones is ongoing.Approaching PhysicsAs usual, there are many different perspectives that we have to take into account for when designing how we want to approach physics in Geometry Nodes:Using high level node group assets to setup e.g. a hair simulation.Building and/or customizing solvers for specialized effects.The modifier-only workflow.Higher level add-ons which abstract away the node and modifier interface.We started out by clarifying that there is a fairly fundamental difference in how to think when chaining multiple geometry operations vs. setting up a physics simulation. The difference is that when creating a simulation, one thinks about the desired behavior (forces, emitters, colliders, ) first, and not so much about the order in which the geometry is actually processed. In fact, the majority of users should only have to care about the behavior without worrying about specific geometry operations.We therefore want to provide better ways to separate describing the desired behavior from actually implementing the behavior. We call this the declarative approach. It gives users high level control over a potentially very complex evaluation system that makes all the desired behaviors work. The declarative approach can also be very useful for things beyond physics like building a brush engine or scattering system.To achieve this separation, we will introduce two new socket types: bundles and closures, which are explained in more detail below (exact names are not set in stone yet).BundlesA bundle is a container that allows packing multiple values into a a single socket. Values of different types can be put into a single bundle. A work-in-progress patch is available already.Bundles are quite useful to reduce the number of necessary links. For now, we are mostly interested in how they can be used to create a uniform interface for various kinds of simulation behaviors. Each behavior will be a bundle that contains the necessary information for the solver to understand what to do with it.ClosuresClosures sockets allow passing around arbitrary functions including entire node groups. For example, this allows passing a node group as an input into another group which will then evaluate it. This is an entirely new paradigm in Blenders node systems, and without being already familiar with the concept of passing functions around as data, its not trivial to understand. However, its incredibly powerful and allows building much more flexible and user-friendly high level node groups.In programming, the term closure refers to functions which may be passed around as data and can capture variables from where they are created. We have not found a good alternative name yet.To create closures, we use a new closure zone. Its a bit like creating a small local node group that can then be passed around. Just using existing node groups does not work, because we need the ability to pass data from the outside into the closure (like in all other zone types). Also, its good to have the ability to build the entire node tree in a single group to see everything at once.Position Based DynamicsThe declarative approach with bundles and closures is generally useful for all kinds of physics simulations. While we want to enable users to build their own solvers, we also want to integrate hair simulation specifically into Geometry Nodes directly.The hair simulation is designed around a Position-Based Dynamics (PBD/XPBD) solver. This solver has been applied to soft-body simulation, cloth, hair, granular materials and more.The PBD method is often used for real-time game physics and is relatively easy to implement. It has advantages in terms of speed and accuracy over the linearized velocity-based cloth solver currently used for hair dynamics. There are lots of learning resources and scientific papers on the topic for people to learn more. When first looking into this, we found this overview and this video tutorial series particularly useful.We will try and implement as much of this as possible using generic geometry nodes. Some parts like collision detection and constraint grouping may require new built-in nodes for performance reasons. This will be decided when we get there.ListsFor this project well likely need lists in different places, for example to manage a list of behaviors passed into the solver and to process contact points after collision detection. Lists have been a talking point in previous workshops and we dont have much new information that has not been said before. We went over the set of nodes wed need, but there were no real surprises there.Lists are also particularly important for hair, because we need to map generated hair to potentially multiple guide hair strands. Currently, there is no good way to store that mapping which makes any workflow that uses guides, especially for simulation, quite unreliable.The main blocker to get lists into Geometry Nodes is still the socket shapes discussion.Socket ShapesThe last blog post contains an explanation of the topic. Last time, we didnt come to a conclusion for how to deal with socket shapes when we get more types like fields, lists, grids and images. The tricky thing is that we cant show all information wed like to with just socket shapes, so we have to decide what we dont want to show anymore.Some design work has been done on the topic in the last couple of months and a simple prototype has been built too. Were now at a point where we are all at least okay with the solutions tradeoffs so that we can hopefully progress on the topic. Once that is resolved, volume grids and lists are much easier to get into a releasable state.For Each Geometry ZoneBlender 4.3 comes with the For Each Element zone. While thats very useful already, there are other kinds of for-each zones that can be useful. One of those is a For Each Geometry zone, that we used to call For Each Unique Instance in previous workshops.Its purpose is to iterate over each real geometry in a geometry set that may contain an instance hierarchy. Many built-in nodes do this internally already. For example, the Subdivision Surface node applies its effect to all meshes in the input, including those in instances. For various reasons, not all built-in nodes can or should do this. A new For Each Geometry zone would allow adding the same functionality to all built-in nodes and custom node groups which is impossible currently.This is quite different from the Instances mode in the For Each Element zone. If the geometry to be processed contains many instances of the same mesh, the existing zone would run for each mesh separately, while this new zone would only run once, because there is only a single mesh.There is already some previous design work available in #123021.We reconfirmed the overall design for modal node tools from a year ago. Since then, we also noticed that there are two kinds of modal operators in Blender currently:Operators based on the initial state (like bevel). These have redo panels.History dependent operators using the previous state at every modal step (like brushes). These dont have redo panels.Both kinds of operators could be created with nodes. However, when we talked about modal node tools so far, we were mainly concerned with the second type. Many use cases of the first kind can probably be solved with gizmos or a gizmo like system. Thats because the interactive part of these operators is mostly just used to control some input values for a non-modal operator.We also noticed that there are problems caused by fact that all node tools are just a single operator in the end (geometry.execute_node_group), but none of these seem impossible to solve. For example, we want modal node tools to come with their own keymap, but users should be able to override this keymap like any other keymap in Blender. Typically, there is a mapping from modal operator to keymap, but that does not work well here yet for the mentioned reason. Alternatively, it may be a nice solution to attach keymaps to specific assets in the user preferences instead of just to operators.It can also be possible to register a separate operator for each node tool, but that comes with its own problems. For example, that would introduce yet another way to reference specific asset data-blocks by their operator name and can easily cause operator name conflicts too.Field Context ZoneWe started discussing a new Field Context Zone. The overall design is very incomplete and we dont have concrete answers to many questions surrounding it yet. The general idea is to give access to the field evaluation context more explicitly.For example, for a field thats evaluated on a geometry, the new zone would have the context geometry as input, and would output a field that depends on that geometry. This opens up new opportunities for building fields that would be much more annoying to build before.The zone would also reduce redundancy in the design of nodes. We have pairs of nodes like Sample Index and Evaluate at Index which are the same except that one has geometry as an input and the other does not. A goal of the zone is that the Evaluate at Index node could be built out of the Sample Index node.A limitation of geometry nodes is that it can only output a geometry that is then passed to the next modifier. Sometimes it would be very useful to output other data like another geometry or single values. Those values could become part of the evaluated state of an object so that it can be referenced by other objects using nodes or drivers.This would allow outputting a bunch of vectors from Geometry Nodes which are then used to drive an armature. Additionally, we could allow outputting a bundle of values that is then passed into the next modifier. This way it becomes possible to build more rich modifier stacks without the limitation of having to encode all information in the geometry passed between modifiers.We could even allow outputting fields and closures from objects (probably with some limitations due to the lifetime of some data). This would allow building all kinds of effector objects that encode some behavior that can be understood by other Geometry Nodes setups. This can also be thought of as a generalization of the existing force field object type.Internal Data SocketsIn some cases, we want to add functionality that requires passing around data of that we dont want to expose fully. A good example would be KD trees and BVH trees which allow speeding up algorithms that require finding nearest points or doing ray casts. These data-structures have well defined APIs that we could expose, but exposing their implementation details could make future optimization much more difficult, because optimizations could require breaking files.It does not seem benefitial to add a new socket type for each kind of internal data. So far we think that it is good enough to only add a single type (with a single color) that is used to pass around all kinds of internal data.Another use-case that came up in the past is a Bake Reference socket that passes data from a Bake to an Import Bake node (once we have that). The tricky thing with an Import Bake node is that it has to be able to read bakes from disk as well as packed bakes. So just giving it a file path input does not work. Reading from files should still be possible of course, but we also need a solution for packed bakes.Group Input DefaultsEvery input of a node group has a default value. For some types, the default is currently hardcoded (e.g. an empty geometry). Others can be choosen manually in the sidebar where some socket types support more complex inputs. For example, vector sockets can be the position field by default. However, the set of possible defaults is currently hardcoded. The goal of this topic is to generalize the system for defaults to remove limitations.The overall idea is to have a new Group Defaults node that has an input socket for every input of the node group. The default of any input is specified by just connecting the value to the node like in the mockup below.We could also make it possible for some default values to depend other input values, but its not clear yet how much complexity this adds, so that may only be done later.A tricky aspect is that adding a default to a socket that did not have one yet may override its value in all group nodes that use this group. Thats kind of the inverse of a problem we have already: changing group input defaults are not propagated to group nodes at all. The problem is that we dont really know if a value has already been modified or not, which becomes even trickier when the node group is linked from another file.Context InputsThe goal of this topic is to solve the following problems:We want to remove the need for control node groups as a way to get global input values (example). While useful in some setups, this approach does not work all that well when building reusable node systems.We have no good way to pass the hair systems surface geometry to the relevant hair nodes in a good way.We have no way to override existing contextual input nodes like Mouse Position, Active Camera and Scene Time.We need a more flexible replacement for the Is Viewport node, which is used to control a performance vs. quality trade-off. Just making this decision based on whether were rendering or not is not good enough. Sometimes the fast mode of a node group should be used when in edit mode, and otherwise the high quality mode.What all these issues have in common is that we want to pass information into nested node groups without having to set up all the intermediate links which would cause a lot of annoying boilerplate. Nevertheless, we want to be able to override all these inputs at any intermediate level.The proposed solution is to generalize the concept of Context Inputs. There are many existing context input nodes (like Scene Time and Mouse Position) already. We also want to add a Context Input node for custom inputs. Whenever a context node is used in a (nested) node group, that will automatically create an input for the node group. Group nodes at a higher level can then decide to either pass in a specific value for that input or to not connect it. If its not connected, the context input will be propagated further up.If the context value has not been provided by any node, its propagated up to the Geometry Nodes modifier where again users can choose to specify it. If not, we could support reading the value from a custom property of the object or scene.There is a work-in-progress pull request for this feature.Modifier InputsWe want to add more features to group inputs in the modifier:For context inputs, we need the ability to decide whether a specific input should be provided or not.For geometry inputs we want to choose whether an object or collection input should be used and if the original or relative space is used (like in the Object Info node).Putting all these choices in the modifier and having them always visible is problematic from a UI perspective. Even now, the button to switch between single value and attribute input adds clutter that is not needed in many cases.We explored options for how this could work like putting the options in the right click menu, in the manage panel or having edit button in the modifier that allows temporarily showing all additional settings. For now, the approach with the right click menu seems best even if it is a little less discoverable at first.Bundles for Dynamic Socket CountsWhen we explored bundles further, we noticed that they may also provide a good solution for another long standing limitation which we discussed back in 2022: dynamic socket counts. Since then, quite some effort went into improved support for dynamic socket counts and nowadays we have them in multiple built-in nodes like all the zones, Capture Attribute and Bake. Whats missing is support for building node groups that have a dynamic number of inputs and outputs.We could allow tagging a bundle input of a node group as an extensible socket. Then from the outside, one could pass multiple values which will become a bundle inside the group. When outputting that bundle from the group, all the values are separated again.Inside of the group, the nodes would have to process all elements in the bundle. Built-in nodes could do that automatically. For example, when the Capture Attribute node has a bundle input, it could recursively capture each contained field and replace it with the captured anonymous attribute field. Something similar can be done in other nodes that already have a dynamic number of sockets.Support the Future of BlenderDonate to Blender by joining the Development Fund to support the Blender Foundations work on core development, maintenance, and new releases. Donate to Blender
    0 Comments ·0 Shares ·701 Views
  • New Brush Thumbnails
    code.blender.org
    html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"Since the start of 2023 when the Brush Asset project went into full force, the goal was also to overhaul the brush thumbnails. A lot of thought went into the new design to make it future proof and fit into the current UI.This ended up as an active community effort to find a coherent and clear visual language. A big thanks to everyone who gave feedback and helped shape the thumbnails that will now be part of Blender 4.3!Style Guides & Example FilesTo make the process fully transparent and easy, a detailed style guide can be found in the developer documentation. Even though no elaborate setups are needed to create authentic looking thumbnails, it also links to the repository where the thumbnails were created.A short snippet of the style guide pageAn Open & Future Proof StyleFor about 15 years since Blender 2.5 the previous brush thumbnails have been added and were built upon. Unfortunately each new addition and iteration created more inconsistencies.A collage of previous brush thumbnails from Blender 2.5 4.2A primary goal was to create a recognizable and consistent design language for all Blender brushes. For all modes and object types. The thumbnails had to seamlessly fit into the themes of the UI and reuse similar accent colors.With the addition of Brush Assets its easier to create huge brush libraries than ever. This exposed a big issue.Previously it was quite difficult to expand the set of brush thumbnails and icons. The files were not accessible to recreate the original thumbnails or create new ones and the process was opaque. Because of this many brushes that were added over the years were lacking a thumbnail or were reused existing ones. Even the process of creating new toolbar icons had a limit to how much variation is possible.Thats why the the creation of Blender 4.3s new thumbnails had to be easy to reproduce and that they seamlessly fit in with all other brushes. The built-in set of Essentials brushes was expanded quite a bit with useful presets, all with new recognizable thumbnails. Users and asset authors should find it just as easy to expand it further.Various early concepts and ideasWe also explored the idea of automatically generated brush previews during the development of Blender 2.8. But covering all possible 2D and 3D brush types and stroke effects is too complex for a procedural system. Instead the creation should be in the hands of the user and as straight forward as possible.Node asset thumbnails for the new hair curves were also created at the same time and the look was directly affected by this. Ideally all official Essentials assets should fit into a similarly coherent look.Iteration Towards Ease of CreationOver the past two years the style of the thumbnails kept being shifted and refined. Many aspects were simplified or dropped in favor for making the creation and visuals simpler.In the original design the thumbnails were supposed to make use of a set of unique icons in the corner to communicate an otherwise obscure meaning or behavior or the brush types. This idea slowly evolved into the flat colored arrows and lines on most of the thumbnails, which are much easier to create and be creative with.Colors also stayed a very secondary element for identifying brushes to keep the thumbnails color-blind friendly.All thumbnails were also supposed to utilize colors, but to keep them clear and focused eventually any regular draw brushes were left without unnecessary colors or strokes.An example of iteration over the Draw and Snake Hook brushes from start to final result.There was also testing of different shaders and lighting effects but the final look always came back to the idea that anybody should be able to create a perfect brush thumbnail on the fly. Some thumbnails are a bit more specific and involved but the key look of Blender thumbnails should be accessible. Simple use of Matcap/flat shading is all you need.To put a direct comparison to the old thumbnails above, here is the collage of the final thumbnail selection that was used as a base reference to create all remaining thumbnails. Many more new brushes and existing brushes with missing thumbnails were added since then.A focused selection of key brushes from every mode and object typeTry it Out!More features can be added for future releases to make the creation of custom thumbnails much faster. For example by making screenshots directly within Blender to assign asset thumbnails. And by adding the exact same Matcap as part of the default selection.We look forward to how the community will be able to expand the brush selection far more than ever before and share distinct looking brushes. Download the Blender 4.3 Beta now to test it out.For feedback and contributing to the Essentials brushes, visit the Call for Content: Default Brushes.Support the Future of BlenderDonate to Blender by joining the Development Fund to support the Blender Foundations work on core development, maintenance, and new releases. Donate to Blender
    0 Comments ·0 Shares ·706 Views
  • Blender Conference 2024 Recap
    www.blender.org
    Blender Conference 2024 RecapNovember 1st, 2024Press ReleasesFrancesco Siddi html PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN" "http://www.w3.org/TR/REC-html40/loose.dtd"Blender Conference 2024 wrapped one week ago, hopefully we all made it past the post-bcon blues!As usual, you can enjoy all the recorded presentations on BlendersYouTube channel, and on PeerTube.Dont forget to check out the Photo Gallery!FeedbackOverall, feedback was positive. Compared to previous years, food and venue rating went up, while overall satisfaction with the event remains very positive. When it comes to the program, satisfaction moved from extremely high to high, due to the average quality of a few sessions. This is something we will definitely focus on improving for next year!We will also explore additional ways to encourage attendees to engage with one another, and we aim to make the venue even more welcoming and comfortable.Thank you!The event was made possible thanks to the contribution of many people and made memorable thanks to all attendees and speakers. Special thanks to Amerpodia and the Felix Meritis staff, to Faber audiovisuals and especially to the Blender HQ and remote teams for making this an amazing experience.See you next year!Francesco
    0 Comments ·0 Shares ·720 Views
  • 0 Comments ·0 Shares ·735 Views
  • 0 Comments ·0 Shares ·759 Views
  • 0 Comments ·0 Shares ·758 Views
  • 0 Comments ·0 Shares ·800 Views
  • 0 Comments ·0 Shares ·786 Views
  • 0 Comments ·0 Shares ·770 Views
  • 0 Comments ·0 Shares ·775 Views
  • 0 Comments ·0 Shares ·773 Views
More Stories