| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							|  |  |  |  * of the License, or (at your option) any later version. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-02-18 08:08:12 +11:00
										 |  |  | /** \file
 | 
					
						
							|  |  |  |  * \ingroup blenloader | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* allow readfile to use deprecated functionality */ | 
					
						
							|  |  |  | #define DNA_DEPRECATED_ALLOW
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-20 16:12:36 +02:00
										 |  |  | #include <float.h>
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include <string.h>
 | 
					
						
							| 
									
										
										
										
											2017-06-20 14:33:13 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2017-11-14 17:00:10 +11:00
										 |  |  | #include "BLI_listbase.h"
 | 
					
						
							| 
									
										
										
										
											2018-05-04 17:25:49 +02:00
										 |  |  | #include "BLI_math.h"
 | 
					
						
							| 
									
										
										
										
											2017-11-14 17:00:10 +11:00
										 |  |  | #include "BLI_mempool.h"
 | 
					
						
							|  |  |  | #include "BLI_string.h"
 | 
					
						
							|  |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												VR: Initial Virtual Reality support - Milestone 1, Scene Inspection
NOTE: While most of the milestone 1 goals are there, a few smaller features and
improvements are still to be done.
Big picture of this milestone: Initial, OpenXR-based virtual reality support
for users and foundation for advanced use cases.
Maniphest Task: https://developer.blender.org/T71347
The tasks contains more information about this milestone.
To be clear: This is not a feature rich VR implementation, it's focused on the
initial scene inspection use case. We intentionally focused on that, further
features like controller support are part of the next milestone.
- How to use?
Instructions on how to use this are here:
https://wiki.blender.org/wiki/User:Severin/GSoC-2019/How_to_Test
These will be updated and moved to a more official place (likely the manual) soon.
Currently Windows Mixed Reality and Oculus devices are usable. Valve/HTC
headsets don't support the OpenXR standard yet and hence, do not work with this
implementation.
---------------
This is the C-side implementation of the features added for initial VR
support as per milestone 1. A "VR Scene Inspection" Add-on will be
committed separately, to expose the VR functionality in the UI. It also
adds some further features for milestone 1, namely a landmarking system
(stored view locations in the VR space)
Main additions/features:
* Support for rendering viewports to an HMD, with good performance.
* Option to sync the VR view perspective with a fully interactive,
  regular 3D View (VR-Mirror).
* Option to disable positional tracking. Keeps the current position (calculated
  based on the VR eye center pose) when enabled while a VR session is running.
* Some regular viewport settings for the VR view
* RNA/Python-API to query and set VR session state information.
* WM-XR: Layer tying Ghost-XR to the Blender specific APIs/data
* wmSurface API: drawable, non-window container (manages Ghost-OpenGL and GPU
  context)
* DNA/RNA for management of VR session settings
* `--debug-xr` and `--debug-xr-time` commandline options
* Utility batch & config file for using the Oculus runtime on Windows.
* Most VR data is runtime only. The exception is user settings which are saved
  to files (`XrSessionSettings`).
* VR support can be disabled through the `WITH_XR_OPENXR` compiler flag.
For architecture and code documentation, see
https://wiki.blender.org/wiki/Source/Interface/XR.
---------------
A few thank you's:
* A huge shoutout to Ray Molenkamp for his help during the project - it would
  have not been that successful without him!
* Sebastian Koenig and Simeon Conzendorf for testing and feedback!
* The reviewers, especially Brecht Van Lommel!
* Dalai Felinto for pushing and managing me to get this done ;)
* The OpenXR working group for providing an open standard. I think we're the
  first bigger application to adopt OpenXR. Congratulations to them and
  ourselves :)
This project started as a Google Summer of Code 2019 project - "Core Support of
Virtual Reality Headsets through OpenXR" (see
https://wiki.blender.org/wiki/User:Severin/GSoC-2019/).
Some further information, including ideas for further improvements can be found
in the final GSoC report:
https://wiki.blender.org/wiki/User:Severin/GSoC-2019/Final_Report
Differential Revisions: D6193, D7098
Reviewed by: Brecht Van Lommel, Jeroen Bakker
											
										 
											2020-03-17 20:20:55 +01:00
										 |  |  | #include "DNA_defaults.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  | #include "DNA_anim_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "DNA_armature_types.h"
 | 
					
						
							| 
									
										
										
										
											2017-05-11 19:08:59 +02:00
										 |  |  | #include "DNA_camera_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-29 00:29:37 +02:00
										 |  |  | #include "DNA_cloth_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-29 15:32:50 +02:00
										 |  |  | #include "DNA_collection_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-04-16 14:07:42 +02:00
										 |  |  | #include "DNA_constraint_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "DNA_curve_types.h"
 | 
					
						
							| 
									
										
										
										
											2019-11-20 16:12:32 -05:00
										 |  |  | #include "DNA_curveprofile_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-04-23 15:10:20 +02:00
										 |  |  | #include "DNA_fluid_types.h"
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  | #include "DNA_freestyle_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "DNA_genfile.h"
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  | #include "DNA_gpencil_modifier_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "DNA_gpencil_types.h"
 | 
					
						
							|  |  |  | #include "DNA_gpu_types.h"
 | 
					
						
							|  |  |  | #include "DNA_key_types.h"
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | #include "DNA_layer_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "DNA_light_types.h"
 | 
					
						
							| 
									
										
										
										
											2017-12-02 13:01:40 +01:00
										 |  |  | #include "DNA_lightprobe_types.h"
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  | #include "DNA_linestyle_types.h"
 | 
					
						
							| 
									
										
										
										
											2017-02-07 11:20:15 +01:00
										 |  |  | #include "DNA_material_types.h"
 | 
					
						
							| 
									
										
										
										
											2017-05-30 01:29:03 +02:00
										 |  |  | #include "DNA_mesh_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-08-02 13:36:22 +02:00
										 |  |  | #include "DNA_modifier_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "DNA_object_types.h"
 | 
					
						
							| 
									
										
										
										
											2017-12-21 13:29:14 -02:00
										 |  |  | #include "DNA_particle_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-06-27 17:08:58 +02:00
										 |  |  | #include "DNA_rigidbody_types.h"
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | #include "DNA_scene_types.h"
 | 
					
						
							| 
									
										
											  
											
												Outliner: Delete all selected collections, not just active one
There were some issues with how we store outliner tree elements:
Apparently the only removable elements have been data-blocks so far.
When recreating the TreeElements, their TreeStoreElem instances were
mainly identified by their ID pointer. However non-data-blocks mostly
depend on an index. For collections, such an index isn't a reliable
measure though if we want to allow removing items. Depending on it for
identifying the TreeStoreElem instance would cause some quite noticeable
glitches (wrong highlights, two elements sharing highlight, etc).
For now I've solved that by actually removing the TreeStoreElem that
represents the removed element. A little limitation of this is that
after undoing the removal, some information might get lost, like
flags to store selection, or opened/closed state.
A better solution that would also fix this issue would be having a real
unique identifier for each non-data-block element, like an idname or even
its data-pointer. Not sure if we can get those to work reliable with
file read/write though, would have to investigate...
Also added a general Outliner tree traversal utility.
											
										 
											2017-02-28 20:37:14 +01:00
										 |  |  | #include "DNA_screen_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  | #include "DNA_shader_fx_types.h"
 | 
					
						
							| 
									
										
										
										
											2019-03-07 00:07:23 +11:00
										 |  |  | #include "DNA_text_types.h"
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  | #include "DNA_texture_types.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "DNA_view3d_types.h"
 | 
					
						
							|  |  |  | #include "DNA_workspace_types.h"
 | 
					
						
							| 
									
										
										
										
											2019-09-07 23:17:40 +10:00
										 |  |  | #include "DNA_world_types.h"
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  | #include "BKE_animsys.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  | #include "BKE_brush.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-07 15:37:31 +01:00
										 |  |  | #include "BKE_cloth.h"
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | #include "BKE_collection.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-31 10:22:19 +02:00
										 |  |  | #include "BKE_colortools.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "BKE_constraint.h"
 | 
					
						
							|  |  |  | #include "BKE_curveprofile.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-07 15:37:31 +01:00
										 |  |  | #include "BKE_customdata.h"
 | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  | #include "BKE_fcurve.h"
 | 
					
						
							| 
									
										
										
										
											2017-11-16 13:39:25 -02:00
										 |  |  | #include "BKE_freestyle.h"
 | 
					
						
							| 
									
										
										
										
											2020-02-05 16:18:17 +01:00
										 |  |  | #include "BKE_global.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  | #include "BKE_gpencil.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 11:35:17 +01:00
										 |  |  | #include "BKE_gpencil_geom.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  | #include "BKE_gpencil_modifier.h"
 | 
					
						
							| 
									
										
										
										
											2017-03-30 17:01:23 +02:00
										 |  |  | #include "BKE_idprop.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-07 15:37:31 +01:00
										 |  |  | #include "BKE_key.h"
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | #include "BKE_layer.h"
 | 
					
						
							| 
									
										
										
										
											2020-03-19 09:33:03 +01:00
										 |  |  | #include "BKE_lib_id.h"
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | #include "BKE_main.h"
 | 
					
						
							| 
									
										
										
										
											2017-05-30 01:29:03 +02:00
										 |  |  | #include "BKE_mesh.h"
 | 
					
						
							| 
									
										
										
										
											2017-06-20 14:33:13 +02:00
										 |  |  | #include "BKE_node.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-07 15:37:31 +01:00
										 |  |  | #include "BKE_paint.h"
 | 
					
						
							| 
									
										
										
										
											2018-06-27 17:08:58 +02:00
										 |  |  | #include "BKE_pointcache.h"
 | 
					
						
							| 
									
										
										
										
											2017-06-22 10:32:50 +02:00
										 |  |  | #include "BKE_report.h"
 | 
					
						
							| 
									
										
										
										
											2018-12-10 15:01:32 +01:00
										 |  |  | #include "BKE_rigidbody.h"
 | 
					
						
							| 
									
										
											  
											
												UI: New Global Top-Bar (WIP)
== Main Features/Changes for Users
* Add horizontal bar at top of all non-temp windows, consisting out of two horizontal sub-bars.
* Upper sub-bar contains global menus (File, Render, etc.), tabs for workspaces and scene selector.
* Lower sub-bar contains object mode selector, screen-layout and render-layer selector. Later operator and/or tool settings will be placed here.
* Individual sections of the topbar are individually scrollable.
* Workspace tabs can be double- or ctrl-clicked for renaming and contain 'x' icon for deleting.
* Top-bar should scale nicely with DPI.
* The lower half of the top-bar can be hided by dragging the lower top-bar edge up. Better hiding options are planned (e.g. hide in fullscreen modes).
* Info editors at the top of the window and using the full window width with be replaced by the top-bar.
* In fullscreen modes, no more info editor is added on top, the top-bar replaces it.
== Technical Features/Changes
* Adds initial support for global areas
  A global area is part of the window, not part of the regular screen-layout.
  I've added a macro iterator to iterate over both, global and screen-layout level areas. When iterating over areas, from now on developers should always consider if they have to include global areas.
* Adds a TOPBAR editor type
  The editor type is hidden in the UI editor type menu.
* Adds a variation of the ID template to display IDs as tab buttons (template_ID_tabs in BPY)
* Does various changes to RNA button creation code to improve their appearance in the horizontal top-bar.
* Adds support for dynamically sized regions. That is, regions that scale automatically to the layout bounds.
  The code for this is currently a big hack (it's based on drawing the UI multiple times). This should definitely be improved.
* Adds a template for displaying operator properties optimized for the top-bar. This will probably change a lot still and is in fact disabled in code.
Since the final top-bar design depends a lot on other 2.8 designs (mainly tool-system and workspaces), we decided to not show the operator or tool settings in the top-bar for now. That means most of the lower sub-bar is empty for the time being.
NOTE: Top-bar or global area data is not written to files or SDNA. They are simply added to the window when opening Blender or reading a file. This allows us doing changes to the top-bar without having to care for compatibility.
== ToDo's
It's a bit hard to predict all the ToDo's here are the known main ones:
* Add options for the new active-tool system and for operator redo to the topbar.
* Automatically hide the top-bar in fullscreen modes.
* General visual polish.
* Top-bar drag & drop support (WIP in temp-tab_drag_drop).
* Improve dynamic regions (should also fix some layout glitches).
* Make internal terminology consistent.
* Enable topbar file writing once design is more advanced.
* Address TODO's and XXX's in code :)
Thanks @brecht for the review! And @sergey for the complaining ;)
Differential Revision: D2758
											
										 
											2018-04-20 17:14:03 +02:00
										 |  |  | #include "BKE_screen.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-23 18:37:29 +02:00
										 |  |  | #include "BKE_sequencer.h"
 | 
					
						
							| 
									
										
										
										
											2018-06-05 08:15:30 +02:00
										 |  |  | #include "BKE_studiolight.h"
 | 
					
						
							| 
									
										
										
										
											2018-10-03 10:20:16 +02:00
										 |  |  | #include "BKE_unit.h"
 | 
					
						
							| 
									
										
										
										
											2018-11-07 15:37:31 +01:00
										 |  |  | #include "BKE_workspace.h"
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-11-06 18:06:33 +11:00
										 |  |  | /* Only for IMB_BlendMode */ | 
					
						
							|  |  |  | #include "IMB_imbuf.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-05 18:48:05 +03:00
										 |  |  | #include "DEG_depsgraph.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-27 09:20:06 +02:00
										 |  |  | #include "BLT_translation.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | #include "BLO_readfile.h"
 | 
					
						
							|  |  |  | #include "readfile.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-24 22:54:51 +11:00
										 |  |  | /* Make preferences read-only, use versioning_userdef.c. */ | 
					
						
							|  |  |  | #define U (*((const UserDef *)&U))
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 13:15:51 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Rename if the ID doesn't exist. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | static ID *rename_id_for_versioning(Main *bmain, | 
					
						
							|  |  |  |                                     const short id_type, | 
					
						
							|  |  |  |                                     const char *name_src, | 
					
						
							|  |  |  |                                     const char *name_dst) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   /* We can ignore libraries */ | 
					
						
							|  |  |  |   ListBase *lb = which_libbase(bmain, id_type); | 
					
						
							|  |  |  |   ID *id = NULL; | 
					
						
							|  |  |  |   LISTBASE_FOREACH (ID *, idtest, lb) { | 
					
						
							|  |  |  |     if (idtest->lib == NULL) { | 
					
						
							|  |  |  |       if (STREQ(idtest->name + 2, name_src)) { | 
					
						
							|  |  |  |         id = idtest; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (STREQ(idtest->name + 2, name_dst)) { | 
					
						
							|  |  |  |         return NULL; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   if (id != NULL) { | 
					
						
							|  |  |  |     BLI_strncpy(id->name + 2, name_dst, sizeof(id->name) - 2); | 
					
						
							|  |  |  |     /* We know it's unique, this just sorts. */ | 
					
						
							|  |  |  |     BLI_libblock_ensure_unique_name(bmain, id->name); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return id; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Main Workspace Integration
This commit does the main integration of workspaces, which is a design we agreed on during the 2.8 UI workshop (see https://wiki.blender.org/index.php/Dev:2.8/UI/Workshop_Writeup)
Workspaces should generally be stable, I'm not aware of any remaining bugs (or I've forgotten them :) ). If you find any, let me know!
(Exception: mode switching button might get out of sync with actual mode in some cases, would consider that a limitation/ToDo. Needs to be resolved at some point.)
== Main Changes/Features
* Introduces the new Workspaces as data-blocks.
* Allow storing a number of custom workspaces as part of the user configuration. Needs further work to allow adding and deleting individual workspaces.
* Bundle a default workspace configuration with Blender (current screen-layouts converted to workspaces).
* Pressing button to add a workspace spawns a menu to select between "Duplicate Current" and the workspaces from the user configuration. If no workspaces are stored in the user configuration, the default workspaces are listed instead.
* Store screen-layouts (`bScreen`) per workspace.
* Store an active screen-layout per workspace. Changing the workspace will enable this layout.
* Store active mode in workspace. Changing the workspace will also enter the mode of the new workspace. (Note that we still store the active mode in the object, moving this completely to workspaces is a separate project.)
* Store an active render layer per workspace.
* Moved mode switch from 3D View header to Info Editor header.
* Store active scene in window (not directly workspace related, but overlaps quite a bit).
* Removed 'Use Global Scene' User Preference option.
* Compatibility with old files - a new workspace is created for every screen-layout of old files. Old Blender versions should be able to read files saved with workspace support as well.
* Default .blend only contains one workspace ("General").
* Support appending workspaces.
Opening files without UI and commandline rendering should work fine.
Note that the UI is temporary! We plan to introduce a new global topbar
that contains the workspace options and tabs for switching workspaces.
== Technical Notes
* Workspaces are data-blocks.
* Adding and removing `bScreen`s should be done through `ED_workspace_layout` API now.
* A workspace can be active in multiple windows at the same time.
* The mode menu (which is now in the Info Editor header) doesn't display "Grease Pencil Edit" mode anymore since its availability depends on the active editor. Will be fixed by making Grease Pencil an own object type (as planned).
* The button to change the active workspace object mode may get out of sync with the mode of the active object. Will either be resolved by moving mode out of object data, or we'll disable workspace modes again (there's a `#define USE_WORKSPACE_MODE` for that).
* Screen-layouts (`bScreen`) are IDs and thus stored in a main list-base. Had to add a wrapper `WorkSpaceLayout` so we can store them in a list-base within workspaces, too. On the long run we could completely replace `bScreen` by workspace structs.
* `WorkSpace` types use some special compiler trickery to allow marking structs and struct members as private. BKE_workspace API should be used for accessing those.
* Added scene operators `SCENE_OT_`. Was previously done through screen operators.
== BPY API Changes
* Removed `Screen.scene`, added `Window.scene`
* Removed `UserPreferencesView.use_global_scene`
* Added `Context.workspace`, `Window.workspace` and `BlendData.workspaces`
* Added `bpy.types.WorkSpace` containing `screens`, `object_mode` and `render_layer`
* Added Screen.layout_name for the layout name that'll be displayed in the UI (may differ from internal name)
== What's left?
* There are a few open design questions (T50521). We should find the needed answers and implement them.
* Allow adding and removing individual workspaces from workspace configuration (needs UI design).
* Get the override system ready and support overrides per workspace.
* Support custom UI setups as part of workspaces (hidden panels, hidden buttons, customizable toolbars, etc).
* Allow enabling add-ons per workspace.
* Support custom workspace keymaps.
* Remove special exception for workspaces in linking code (so they're always appended, never linked). Depends on a few things, so best to solve later.
* Get the topbar done.
* Workspaces need a proper icon, current one is just a placeholder :)
Reviewed By: campbellbarton, mont29
Tags: #user_interface, #bf_blender_2.8
Maniphest Tasks: T50521
Differential Revision: https://developer.blender.org/D2451
											
										 
											2017-06-01 19:56:58 +02:00
										 |  |  | static bScreen *screen_parent_find(const bScreen *screen) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-22 01:10:29 +10:00
										 |  |  |   /* Can avoid lookup if screen state isn't maximized/full
 | 
					
						
							|  |  |  |    * (parent and child store the same state). */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (ELEM(screen->state, SCREENMAXIMIZED, SCREENFULL)) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |     LISTBASE_FOREACH (const ScrArea *, area, &screen->areabase) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |       if (area->full && area->full != screen) { | 
					
						
							|  |  |  |         BLI_assert(area->full->state == screen->state); | 
					
						
							|  |  |  |         return area->full; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return NULL; | 
					
						
							| 
									
										
											  
											
												Main Workspace Integration
This commit does the main integration of workspaces, which is a design we agreed on during the 2.8 UI workshop (see https://wiki.blender.org/index.php/Dev:2.8/UI/Workshop_Writeup)
Workspaces should generally be stable, I'm not aware of any remaining bugs (or I've forgotten them :) ). If you find any, let me know!
(Exception: mode switching button might get out of sync with actual mode in some cases, would consider that a limitation/ToDo. Needs to be resolved at some point.)
== Main Changes/Features
* Introduces the new Workspaces as data-blocks.
* Allow storing a number of custom workspaces as part of the user configuration. Needs further work to allow adding and deleting individual workspaces.
* Bundle a default workspace configuration with Blender (current screen-layouts converted to workspaces).
* Pressing button to add a workspace spawns a menu to select between "Duplicate Current" and the workspaces from the user configuration. If no workspaces are stored in the user configuration, the default workspaces are listed instead.
* Store screen-layouts (`bScreen`) per workspace.
* Store an active screen-layout per workspace. Changing the workspace will enable this layout.
* Store active mode in workspace. Changing the workspace will also enter the mode of the new workspace. (Note that we still store the active mode in the object, moving this completely to workspaces is a separate project.)
* Store an active render layer per workspace.
* Moved mode switch from 3D View header to Info Editor header.
* Store active scene in window (not directly workspace related, but overlaps quite a bit).
* Removed 'Use Global Scene' User Preference option.
* Compatibility with old files - a new workspace is created for every screen-layout of old files. Old Blender versions should be able to read files saved with workspace support as well.
* Default .blend only contains one workspace ("General").
* Support appending workspaces.
Opening files without UI and commandline rendering should work fine.
Note that the UI is temporary! We plan to introduce a new global topbar
that contains the workspace options and tabs for switching workspaces.
== Technical Notes
* Workspaces are data-blocks.
* Adding and removing `bScreen`s should be done through `ED_workspace_layout` API now.
* A workspace can be active in multiple windows at the same time.
* The mode menu (which is now in the Info Editor header) doesn't display "Grease Pencil Edit" mode anymore since its availability depends on the active editor. Will be fixed by making Grease Pencil an own object type (as planned).
* The button to change the active workspace object mode may get out of sync with the mode of the active object. Will either be resolved by moving mode out of object data, or we'll disable workspace modes again (there's a `#define USE_WORKSPACE_MODE` for that).
* Screen-layouts (`bScreen`) are IDs and thus stored in a main list-base. Had to add a wrapper `WorkSpaceLayout` so we can store them in a list-base within workspaces, too. On the long run we could completely replace `bScreen` by workspace structs.
* `WorkSpace` types use some special compiler trickery to allow marking structs and struct members as private. BKE_workspace API should be used for accessing those.
* Added scene operators `SCENE_OT_`. Was previously done through screen operators.
== BPY API Changes
* Removed `Screen.scene`, added `Window.scene`
* Removed `UserPreferencesView.use_global_scene`
* Added `Context.workspace`, `Window.workspace` and `BlendData.workspaces`
* Added `bpy.types.WorkSpace` containing `screens`, `object_mode` and `render_layer`
* Added Screen.layout_name for the layout name that'll be displayed in the UI (may differ from internal name)
== What's left?
* There are a few open design questions (T50521). We should find the needed answers and implement them.
* Allow adding and removing individual workspaces from workspace configuration (needs UI design).
* Get the override system ready and support overrides per workspace.
* Support custom UI setups as part of workspaces (hidden panels, hidden buttons, customizable toolbars, etc).
* Allow enabling add-ons per workspace.
* Support custom workspace keymaps.
* Remove special exception for workspaces in linking code (so they're always appended, never linked). Depends on a few things, so best to solve later.
* Get the topbar done.
* Workspaces need a proper icon, current one is just a placeholder :)
Reviewed By: campbellbarton, mont29
Tags: #user_interface, #bf_blender_2.8
Maniphest Tasks: T50521
Differential Revision: https://developer.blender.org/D2451
											
										 
											2017-06-01 19:56:58 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_version_workspaces_create_from_screens(Main *bmain) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							|  |  |  |     const bScreen *screen_parent = screen_parent_find(screen); | 
					
						
							|  |  |  |     WorkSpace *workspace; | 
					
						
							|  |  |  |     if (screen->temp) { | 
					
						
							|  |  |  |       continue; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (screen_parent) { | 
					
						
							| 
									
										
										
										
											2019-08-17 00:54:22 +10:00
										 |  |  |       /* Full-screen with "Back to Previous" option, don't create
 | 
					
						
							|  |  |  |        * a new workspace, add layout workspace containing parent. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       workspace = BLI_findstring( | 
					
						
							|  |  |  |           &bmain->workspaces, screen_parent->id.name + 2, offsetof(ID, name) + 2); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else { | 
					
						
							|  |  |  |       workspace = BKE_workspace_add(bmain, screen->id.name + 2); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (workspace == NULL) { | 
					
						
							|  |  |  |       continue; /* Not much we can do.. */ | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     BKE_workspace_layout_add(bmain, workspace, screen, screen->id.name + 2); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Main Workspace Integration
This commit does the main integration of workspaces, which is a design we agreed on during the 2.8 UI workshop (see https://wiki.blender.org/index.php/Dev:2.8/UI/Workshop_Writeup)
Workspaces should generally be stable, I'm not aware of any remaining bugs (or I've forgotten them :) ). If you find any, let me know!
(Exception: mode switching button might get out of sync with actual mode in some cases, would consider that a limitation/ToDo. Needs to be resolved at some point.)
== Main Changes/Features
* Introduces the new Workspaces as data-blocks.
* Allow storing a number of custom workspaces as part of the user configuration. Needs further work to allow adding and deleting individual workspaces.
* Bundle a default workspace configuration with Blender (current screen-layouts converted to workspaces).
* Pressing button to add a workspace spawns a menu to select between "Duplicate Current" and the workspaces from the user configuration. If no workspaces are stored in the user configuration, the default workspaces are listed instead.
* Store screen-layouts (`bScreen`) per workspace.
* Store an active screen-layout per workspace. Changing the workspace will enable this layout.
* Store active mode in workspace. Changing the workspace will also enter the mode of the new workspace. (Note that we still store the active mode in the object, moving this completely to workspaces is a separate project.)
* Store an active render layer per workspace.
* Moved mode switch from 3D View header to Info Editor header.
* Store active scene in window (not directly workspace related, but overlaps quite a bit).
* Removed 'Use Global Scene' User Preference option.
* Compatibility with old files - a new workspace is created for every screen-layout of old files. Old Blender versions should be able to read files saved with workspace support as well.
* Default .blend only contains one workspace ("General").
* Support appending workspaces.
Opening files without UI and commandline rendering should work fine.
Note that the UI is temporary! We plan to introduce a new global topbar
that contains the workspace options and tabs for switching workspaces.
== Technical Notes
* Workspaces are data-blocks.
* Adding and removing `bScreen`s should be done through `ED_workspace_layout` API now.
* A workspace can be active in multiple windows at the same time.
* The mode menu (which is now in the Info Editor header) doesn't display "Grease Pencil Edit" mode anymore since its availability depends on the active editor. Will be fixed by making Grease Pencil an own object type (as planned).
* The button to change the active workspace object mode may get out of sync with the mode of the active object. Will either be resolved by moving mode out of object data, or we'll disable workspace modes again (there's a `#define USE_WORKSPACE_MODE` for that).
* Screen-layouts (`bScreen`) are IDs and thus stored in a main list-base. Had to add a wrapper `WorkSpaceLayout` so we can store them in a list-base within workspaces, too. On the long run we could completely replace `bScreen` by workspace structs.
* `WorkSpace` types use some special compiler trickery to allow marking structs and struct members as private. BKE_workspace API should be used for accessing those.
* Added scene operators `SCENE_OT_`. Was previously done through screen operators.
== BPY API Changes
* Removed `Screen.scene`, added `Window.scene`
* Removed `UserPreferencesView.use_global_scene`
* Added `Context.workspace`, `Window.workspace` and `BlendData.workspaces`
* Added `bpy.types.WorkSpace` containing `screens`, `object_mode` and `render_layer`
* Added Screen.layout_name for the layout name that'll be displayed in the UI (may differ from internal name)
== What's left?
* There are a few open design questions (T50521). We should find the needed answers and implement them.
* Allow adding and removing individual workspaces from workspace configuration (needs UI design).
* Get the override system ready and support overrides per workspace.
* Support custom UI setups as part of workspaces (hidden panels, hidden buttons, customizable toolbars, etc).
* Allow enabling add-ons per workspace.
* Support custom workspace keymaps.
* Remove special exception for workspaces in linking code (so they're always appended, never linked). Depends on a few things, so best to solve later.
* Get the topbar done.
* Workspaces need a proper icon, current one is just a placeholder :)
Reviewed By: campbellbarton, mont29
Tags: #user_interface, #bf_blender_2.8
Maniphest Tasks: T50521
Differential Revision: https://developer.blender.org/D2451
											
										 
											2017-06-01 19:56:58 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-04-22 23:57:19 +02:00
										 |  |  | static void do_version_area_change_space_to_space_action(ScrArea *area, const Scene *scene) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   SpaceType *stype = BKE_spacetype_from_id(SPACE_ACTION); | 
					
						
							|  |  |  |   SpaceAction *saction = (SpaceAction *)stype->new (area, scene); | 
					
						
							|  |  |  |   ARegion *region_channels; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Properly free current regions */ | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (ARegion *, region, &area->regionbase) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     BKE_area_region_free(area->type, region); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   BLI_freelistN(&area->regionbase); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   area->type = stype; | 
					
						
							|  |  |  |   area->spacetype = stype->spaceid; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   BLI_addhead(&area->spacedata, saction); | 
					
						
							|  |  |  |   area->regionbase = saction->regionbase; | 
					
						
							|  |  |  |   BLI_listbase_clear(&saction->regionbase); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Different defaults for timeline */ | 
					
						
							|  |  |  |   region_channels = BKE_area_find_region_type(area, RGN_TYPE_CHANNELS); | 
					
						
							|  |  |  |   region_channels->flag |= RGN_FLAG_HIDDEN; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   saction->mode = SACTCONT_TIMELINE; | 
					
						
							|  |  |  |   saction->ads.flag |= ADS_FLAG_SUMMARY_COLLAPSED; | 
					
						
							|  |  |  |   saction->ads.filterflag |= ADS_FILTER_SUMMARY; | 
					
						
							| 
									
										
										
										
											2018-04-22 23:57:19 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Main Workspace Integration
This commit does the main integration of workspaces, which is a design we agreed on during the 2.8 UI workshop (see https://wiki.blender.org/index.php/Dev:2.8/UI/Workshop_Writeup)
Workspaces should generally be stable, I'm not aware of any remaining bugs (or I've forgotten them :) ). If you find any, let me know!
(Exception: mode switching button might get out of sync with actual mode in some cases, would consider that a limitation/ToDo. Needs to be resolved at some point.)
== Main Changes/Features
* Introduces the new Workspaces as data-blocks.
* Allow storing a number of custom workspaces as part of the user configuration. Needs further work to allow adding and deleting individual workspaces.
* Bundle a default workspace configuration with Blender (current screen-layouts converted to workspaces).
* Pressing button to add a workspace spawns a menu to select between "Duplicate Current" and the workspaces from the user configuration. If no workspaces are stored in the user configuration, the default workspaces are listed instead.
* Store screen-layouts (`bScreen`) per workspace.
* Store an active screen-layout per workspace. Changing the workspace will enable this layout.
* Store active mode in workspace. Changing the workspace will also enter the mode of the new workspace. (Note that we still store the active mode in the object, moving this completely to workspaces is a separate project.)
* Store an active render layer per workspace.
* Moved mode switch from 3D View header to Info Editor header.
* Store active scene in window (not directly workspace related, but overlaps quite a bit).
* Removed 'Use Global Scene' User Preference option.
* Compatibility with old files - a new workspace is created for every screen-layout of old files. Old Blender versions should be able to read files saved with workspace support as well.
* Default .blend only contains one workspace ("General").
* Support appending workspaces.
Opening files without UI and commandline rendering should work fine.
Note that the UI is temporary! We plan to introduce a new global topbar
that contains the workspace options and tabs for switching workspaces.
== Technical Notes
* Workspaces are data-blocks.
* Adding and removing `bScreen`s should be done through `ED_workspace_layout` API now.
* A workspace can be active in multiple windows at the same time.
* The mode menu (which is now in the Info Editor header) doesn't display "Grease Pencil Edit" mode anymore since its availability depends on the active editor. Will be fixed by making Grease Pencil an own object type (as planned).
* The button to change the active workspace object mode may get out of sync with the mode of the active object. Will either be resolved by moving mode out of object data, or we'll disable workspace modes again (there's a `#define USE_WORKSPACE_MODE` for that).
* Screen-layouts (`bScreen`) are IDs and thus stored in a main list-base. Had to add a wrapper `WorkSpaceLayout` so we can store them in a list-base within workspaces, too. On the long run we could completely replace `bScreen` by workspace structs.
* `WorkSpace` types use some special compiler trickery to allow marking structs and struct members as private. BKE_workspace API should be used for accessing those.
* Added scene operators `SCENE_OT_`. Was previously done through screen operators.
== BPY API Changes
* Removed `Screen.scene`, added `Window.scene`
* Removed `UserPreferencesView.use_global_scene`
* Added `Context.workspace`, `Window.workspace` and `BlendData.workspaces`
* Added `bpy.types.WorkSpace` containing `screens`, `object_mode` and `render_layer`
* Added Screen.layout_name for the layout name that'll be displayed in the UI (may differ from internal name)
== What's left?
* There are a few open design questions (T50521). We should find the needed answers and implement them.
* Allow adding and removing individual workspaces from workspace configuration (needs UI design).
* Get the override system ready and support overrides per workspace.
* Support custom UI setups as part of workspaces (hidden panels, hidden buttons, customizable toolbars, etc).
* Allow enabling add-ons per workspace.
* Support custom workspace keymaps.
* Remove special exception for workspaces in linking code (so they're always appended, never linked). Depends on a few things, so best to solve later.
* Get the topbar done.
* Workspaces need a proper icon, current one is just a placeholder :)
Reviewed By: campbellbarton, mont29
Tags: #user_interface, #bf_blender_2.8
Maniphest Tasks: T50521
Differential Revision: https://developer.blender.org/D2451
											
										 
											2017-06-01 19:56:58 +02:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * \brief After lib-link versioning for new workspace design. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2018-05-20 09:04:18 +02:00
										 |  |  |  * - Adds a workspace for (almost) each screen of the old file | 
					
						
							|  |  |  |  *   and adds the needed workspace-layout to wrap the screen. | 
					
						
							|  |  |  |  * - Active screen isn't stored directly in window anymore, but in the active workspace. | 
					
						
							|  |  |  |  * - Active scene isn't stored in screen anymore, but in window. | 
					
						
							|  |  |  |  * - Create workspace instance hook for each window. | 
					
						
							| 
									
										
											  
											
												Main Workspace Integration
This commit does the main integration of workspaces, which is a design we agreed on during the 2.8 UI workshop (see https://wiki.blender.org/index.php/Dev:2.8/UI/Workshop_Writeup)
Workspaces should generally be stable, I'm not aware of any remaining bugs (or I've forgotten them :) ). If you find any, let me know!
(Exception: mode switching button might get out of sync with actual mode in some cases, would consider that a limitation/ToDo. Needs to be resolved at some point.)
== Main Changes/Features
* Introduces the new Workspaces as data-blocks.
* Allow storing a number of custom workspaces as part of the user configuration. Needs further work to allow adding and deleting individual workspaces.
* Bundle a default workspace configuration with Blender (current screen-layouts converted to workspaces).
* Pressing button to add a workspace spawns a menu to select between "Duplicate Current" and the workspaces from the user configuration. If no workspaces are stored in the user configuration, the default workspaces are listed instead.
* Store screen-layouts (`bScreen`) per workspace.
* Store an active screen-layout per workspace. Changing the workspace will enable this layout.
* Store active mode in workspace. Changing the workspace will also enter the mode of the new workspace. (Note that we still store the active mode in the object, moving this completely to workspaces is a separate project.)
* Store an active render layer per workspace.
* Moved mode switch from 3D View header to Info Editor header.
* Store active scene in window (not directly workspace related, but overlaps quite a bit).
* Removed 'Use Global Scene' User Preference option.
* Compatibility with old files - a new workspace is created for every screen-layout of old files. Old Blender versions should be able to read files saved with workspace support as well.
* Default .blend only contains one workspace ("General").
* Support appending workspaces.
Opening files without UI and commandline rendering should work fine.
Note that the UI is temporary! We plan to introduce a new global topbar
that contains the workspace options and tabs for switching workspaces.
== Technical Notes
* Workspaces are data-blocks.
* Adding and removing `bScreen`s should be done through `ED_workspace_layout` API now.
* A workspace can be active in multiple windows at the same time.
* The mode menu (which is now in the Info Editor header) doesn't display "Grease Pencil Edit" mode anymore since its availability depends on the active editor. Will be fixed by making Grease Pencil an own object type (as planned).
* The button to change the active workspace object mode may get out of sync with the mode of the active object. Will either be resolved by moving mode out of object data, or we'll disable workspace modes again (there's a `#define USE_WORKSPACE_MODE` for that).
* Screen-layouts (`bScreen`) are IDs and thus stored in a main list-base. Had to add a wrapper `WorkSpaceLayout` so we can store them in a list-base within workspaces, too. On the long run we could completely replace `bScreen` by workspace structs.
* `WorkSpace` types use some special compiler trickery to allow marking structs and struct members as private. BKE_workspace API should be used for accessing those.
* Added scene operators `SCENE_OT_`. Was previously done through screen operators.
== BPY API Changes
* Removed `Screen.scene`, added `Window.scene`
* Removed `UserPreferencesView.use_global_scene`
* Added `Context.workspace`, `Window.workspace` and `BlendData.workspaces`
* Added `bpy.types.WorkSpace` containing `screens`, `object_mode` and `render_layer`
* Added Screen.layout_name for the layout name that'll be displayed in the UI (may differ from internal name)
== What's left?
* There are a few open design questions (T50521). We should find the needed answers and implement them.
* Allow adding and removing individual workspaces from workspace configuration (needs UI design).
* Get the override system ready and support overrides per workspace.
* Support custom UI setups as part of workspaces (hidden panels, hidden buttons, customizable toolbars, etc).
* Allow enabling add-ons per workspace.
* Support custom workspace keymaps.
* Remove special exception for workspaces in linking code (so they're always appended, never linked). Depends on a few things, so best to solve later.
* Get the topbar done.
* Workspaces need a proper icon, current one is just a placeholder :)
Reviewed By: campbellbarton, mont29
Tags: #user_interface, #bf_blender_2.8
Maniphest Tasks: T50521
Differential Revision: https://developer.blender.org/D2451
											
										 
											2017-06-01 19:56:58 +02:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2019-04-22 01:10:29 +10:00
										 |  |  |  * \note Some of the created workspaces might be deleted again | 
					
						
							|  |  |  |  * in case of reading the default `startup.blend`. | 
					
						
							| 
									
										
											  
											
												Main Workspace Integration
This commit does the main integration of workspaces, which is a design we agreed on during the 2.8 UI workshop (see https://wiki.blender.org/index.php/Dev:2.8/UI/Workshop_Writeup)
Workspaces should generally be stable, I'm not aware of any remaining bugs (or I've forgotten them :) ). If you find any, let me know!
(Exception: mode switching button might get out of sync with actual mode in some cases, would consider that a limitation/ToDo. Needs to be resolved at some point.)
== Main Changes/Features
* Introduces the new Workspaces as data-blocks.
* Allow storing a number of custom workspaces as part of the user configuration. Needs further work to allow adding and deleting individual workspaces.
* Bundle a default workspace configuration with Blender (current screen-layouts converted to workspaces).
* Pressing button to add a workspace spawns a menu to select between "Duplicate Current" and the workspaces from the user configuration. If no workspaces are stored in the user configuration, the default workspaces are listed instead.
* Store screen-layouts (`bScreen`) per workspace.
* Store an active screen-layout per workspace. Changing the workspace will enable this layout.
* Store active mode in workspace. Changing the workspace will also enter the mode of the new workspace. (Note that we still store the active mode in the object, moving this completely to workspaces is a separate project.)
* Store an active render layer per workspace.
* Moved mode switch from 3D View header to Info Editor header.
* Store active scene in window (not directly workspace related, but overlaps quite a bit).
* Removed 'Use Global Scene' User Preference option.
* Compatibility with old files - a new workspace is created for every screen-layout of old files. Old Blender versions should be able to read files saved with workspace support as well.
* Default .blend only contains one workspace ("General").
* Support appending workspaces.
Opening files without UI and commandline rendering should work fine.
Note that the UI is temporary! We plan to introduce a new global topbar
that contains the workspace options and tabs for switching workspaces.
== Technical Notes
* Workspaces are data-blocks.
* Adding and removing `bScreen`s should be done through `ED_workspace_layout` API now.
* A workspace can be active in multiple windows at the same time.
* The mode menu (which is now in the Info Editor header) doesn't display "Grease Pencil Edit" mode anymore since its availability depends on the active editor. Will be fixed by making Grease Pencil an own object type (as planned).
* The button to change the active workspace object mode may get out of sync with the mode of the active object. Will either be resolved by moving mode out of object data, or we'll disable workspace modes again (there's a `#define USE_WORKSPACE_MODE` for that).
* Screen-layouts (`bScreen`) are IDs and thus stored in a main list-base. Had to add a wrapper `WorkSpaceLayout` so we can store them in a list-base within workspaces, too. On the long run we could completely replace `bScreen` by workspace structs.
* `WorkSpace` types use some special compiler trickery to allow marking structs and struct members as private. BKE_workspace API should be used for accessing those.
* Added scene operators `SCENE_OT_`. Was previously done through screen operators.
== BPY API Changes
* Removed `Screen.scene`, added `Window.scene`
* Removed `UserPreferencesView.use_global_scene`
* Added `Context.workspace`, `Window.workspace` and `BlendData.workspaces`
* Added `bpy.types.WorkSpace` containing `screens`, `object_mode` and `render_layer`
* Added Screen.layout_name for the layout name that'll be displayed in the UI (may differ from internal name)
== What's left?
* There are a few open design questions (T50521). We should find the needed answers and implement them.
* Allow adding and removing individual workspaces from workspace configuration (needs UI design).
* Get the override system ready and support overrides per workspace.
* Support custom UI setups as part of workspaces (hidden panels, hidden buttons, customizable toolbars, etc).
* Allow enabling add-ons per workspace.
* Support custom workspace keymaps.
* Remove special exception for workspaces in linking code (so they're always appended, never linked). Depends on a few things, so best to solve later.
* Get the topbar done.
* Workspaces need a proper icon, current one is just a placeholder :)
Reviewed By: campbellbarton, mont29
Tags: #user_interface, #bf_blender_2.8
Maniphest Tasks: T50521
Differential Revision: https://developer.blender.org/D2451
											
										 
											2017-06-01 19:56:58 +02:00
										 |  |  |  */ | 
					
						
							|  |  |  | static void do_version_workspaces_after_lib_link(Main *bmain) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_assert(BLI_listbase_is_empty(&bmain->workspaces)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   do_version_workspaces_create_from_screens(bmain); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (wmWindowManager *wm = bmain->wm.first; wm; wm = wm->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |     LISTBASE_FOREACH (wmWindow *, win, &wm->windows) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       bScreen *screen_parent = screen_parent_find(win->screen); | 
					
						
							|  |  |  |       bScreen *screen = screen_parent ? screen_parent : win->screen; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (screen->temp) { | 
					
						
							| 
									
										
										
										
											2019-04-22 01:10:29 +10:00
										 |  |  |         /* We do not generate a new workspace for those screens...
 | 
					
						
							|  |  |  |          * still need to set some data in win. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         win->workspace_hook = BKE_workspace_instance_hook_create(bmain); | 
					
						
							|  |  |  |         win->scene = screen->scene; | 
					
						
							|  |  |  |         /* Deprecated from now on! */ | 
					
						
							|  |  |  |         win->screen = NULL; | 
					
						
							|  |  |  |         continue; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       WorkSpace *workspace = BLI_findstring( | 
					
						
							|  |  |  |           &bmain->workspaces, screen->id.name + 2, offsetof(ID, name) + 2); | 
					
						
							|  |  |  |       BLI_assert(workspace != NULL); | 
					
						
							|  |  |  |       WorkSpaceLayout *layout = BKE_workspace_layout_find(workspace, win->screen); | 
					
						
							|  |  |  |       BLI_assert(layout != NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       win->workspace_hook = BKE_workspace_instance_hook_create(bmain); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       BKE_workspace_active_set(win->workspace_hook, workspace); | 
					
						
							|  |  |  |       BKE_workspace_active_layout_set(win->workspace_hook, layout); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Move scene and view layer to window. */ | 
					
						
							|  |  |  |       Scene *scene = screen->scene; | 
					
						
							|  |  |  |       ViewLayer *layer = BLI_findlink(&scene->view_layers, scene->r.actlay); | 
					
						
							|  |  |  |       if (!layer) { | 
					
						
							|  |  |  |         layer = BKE_view_layer_default_view(scene); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       win->scene = scene; | 
					
						
							|  |  |  |       STRNCPY(win->view_layer_name, layer->name); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Deprecated from now on! */ | 
					
						
							|  |  |  |       win->screen = NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							|  |  |  |     /* Deprecated from now on! */ | 
					
						
							|  |  |  |     BLI_freelistN(&screen->scene->transform_spaces); | 
					
						
							|  |  |  |     screen->scene = NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Main Workspace Integration
This commit does the main integration of workspaces, which is a design we agreed on during the 2.8 UI workshop (see https://wiki.blender.org/index.php/Dev:2.8/UI/Workshop_Writeup)
Workspaces should generally be stable, I'm not aware of any remaining bugs (or I've forgotten them :) ). If you find any, let me know!
(Exception: mode switching button might get out of sync with actual mode in some cases, would consider that a limitation/ToDo. Needs to be resolved at some point.)
== Main Changes/Features
* Introduces the new Workspaces as data-blocks.
* Allow storing a number of custom workspaces as part of the user configuration. Needs further work to allow adding and deleting individual workspaces.
* Bundle a default workspace configuration with Blender (current screen-layouts converted to workspaces).
* Pressing button to add a workspace spawns a menu to select between "Duplicate Current" and the workspaces from the user configuration. If no workspaces are stored in the user configuration, the default workspaces are listed instead.
* Store screen-layouts (`bScreen`) per workspace.
* Store an active screen-layout per workspace. Changing the workspace will enable this layout.
* Store active mode in workspace. Changing the workspace will also enter the mode of the new workspace. (Note that we still store the active mode in the object, moving this completely to workspaces is a separate project.)
* Store an active render layer per workspace.
* Moved mode switch from 3D View header to Info Editor header.
* Store active scene in window (not directly workspace related, but overlaps quite a bit).
* Removed 'Use Global Scene' User Preference option.
* Compatibility with old files - a new workspace is created for every screen-layout of old files. Old Blender versions should be able to read files saved with workspace support as well.
* Default .blend only contains one workspace ("General").
* Support appending workspaces.
Opening files without UI and commandline rendering should work fine.
Note that the UI is temporary! We plan to introduce a new global topbar
that contains the workspace options and tabs for switching workspaces.
== Technical Notes
* Workspaces are data-blocks.
* Adding and removing `bScreen`s should be done through `ED_workspace_layout` API now.
* A workspace can be active in multiple windows at the same time.
* The mode menu (which is now in the Info Editor header) doesn't display "Grease Pencil Edit" mode anymore since its availability depends on the active editor. Will be fixed by making Grease Pencil an own object type (as planned).
* The button to change the active workspace object mode may get out of sync with the mode of the active object. Will either be resolved by moving mode out of object data, or we'll disable workspace modes again (there's a `#define USE_WORKSPACE_MODE` for that).
* Screen-layouts (`bScreen`) are IDs and thus stored in a main list-base. Had to add a wrapper `WorkSpaceLayout` so we can store them in a list-base within workspaces, too. On the long run we could completely replace `bScreen` by workspace structs.
* `WorkSpace` types use some special compiler trickery to allow marking structs and struct members as private. BKE_workspace API should be used for accessing those.
* Added scene operators `SCENE_OT_`. Was previously done through screen operators.
== BPY API Changes
* Removed `Screen.scene`, added `Window.scene`
* Removed `UserPreferencesView.use_global_scene`
* Added `Context.workspace`, `Window.workspace` and `BlendData.workspaces`
* Added `bpy.types.WorkSpace` containing `screens`, `object_mode` and `render_layer`
* Added Screen.layout_name for the layout name that'll be displayed in the UI (may differ from internal name)
== What's left?
* There are a few open design questions (T50521). We should find the needed answers and implement them.
* Allow adding and removing individual workspaces from workspace configuration (needs UI design).
* Get the override system ready and support overrides per workspace.
* Support custom UI setups as part of workspaces (hidden panels, hidden buttons, customizable toolbars, etc).
* Allow enabling add-ons per workspace.
* Support custom workspace keymaps.
* Remove special exception for workspaces in linking code (so they're always appended, never linked). Depends on a few things, so best to solve later.
* Get the topbar done.
* Workspaces need a proper icon, current one is just a placeholder :)
Reviewed By: campbellbarton, mont29
Tags: #user_interface, #bf_blender_2.8
Maniphest Tasks: T50521
Differential Revision: https://developer.blender.org/D2451
											
										 
											2017-06-01 19:56:58 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | #ifdef USE_COLLECTION_COMPAT_28
 | 
					
						
							|  |  |  | enum { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   COLLECTION_DEPRECATED_VISIBLE = (1 << 0), | 
					
						
							|  |  |  |   COLLECTION_DEPRECATED_VIEWPORT = (1 << 0), | 
					
						
							|  |  |  |   COLLECTION_DEPRECATED_SELECTABLE = (1 << 1), | 
					
						
							|  |  |  |   COLLECTION_DEPRECATED_DISABLED = (1 << 2), | 
					
						
							|  |  |  |   COLLECTION_DEPRECATED_RENDER = (1 << 3), | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_version_view_layer_visibility(ViewLayer *view_layer) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Convert from deprecated VISIBLE flag to DISABLED */ | 
					
						
							|  |  |  |   LayerCollection *lc; | 
					
						
							|  |  |  |   for (lc = view_layer->layer_collections.first; lc; lc = lc->next) { | 
					
						
							|  |  |  |     if (lc->flag & COLLECTION_DEPRECATED_DISABLED) { | 
					
						
							|  |  |  |       lc->flag &= ~COLLECTION_DEPRECATED_DISABLED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ((lc->flag & COLLECTION_DEPRECATED_VISIBLE) == 0) { | 
					
						
							|  |  |  |       lc->flag |= COLLECTION_DEPRECATED_DISABLED; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     lc->flag |= COLLECTION_DEPRECATED_VIEWPORT | COLLECTION_DEPRECATED_RENDER; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static void do_version_layer_collection_pre(ViewLayer *view_layer, | 
					
						
							|  |  |  |                                             ListBase *lb, | 
					
						
							|  |  |  |                                             GSet *enabled_set, | 
					
						
							|  |  |  |                                             GSet *selectable_set) | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Convert from deprecated DISABLED to new layer collection and collection flags */ | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (LayerCollection *, lc, lb) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (lc->scene_collection) { | 
					
						
							|  |  |  |       if (!(lc->flag & COLLECTION_DEPRECATED_DISABLED)) { | 
					
						
							|  |  |  |         BLI_gset_insert(enabled_set, lc->scene_collection); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (lc->flag & COLLECTION_DEPRECATED_SELECTABLE) { | 
					
						
							|  |  |  |         BLI_gset_insert(selectable_set, lc->scene_collection); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     do_version_layer_collection_pre( | 
					
						
							|  |  |  |         view_layer, &lc->layer_collections, enabled_set, selectable_set); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | static void do_version_layer_collection_post(ViewLayer *view_layer, | 
					
						
							|  |  |  |                                              ListBase *lb, | 
					
						
							|  |  |  |                                              GSet *enabled_set, | 
					
						
							|  |  |  |                                              GSet *selectable_set, | 
					
						
							|  |  |  |                                              GHash *collection_map) | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Apply layer collection exclude flags. */ | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (LayerCollection *, lc, lb) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (!(lc->collection->flag & COLLECTION_IS_MASTER)) { | 
					
						
							|  |  |  |       SceneCollection *sc = BLI_ghash_lookup(collection_map, lc->collection); | 
					
						
							|  |  |  |       const bool enabled = (sc && BLI_gset_haskey(enabled_set, sc)); | 
					
						
							|  |  |  |       const bool selectable = (sc && BLI_gset_haskey(selectable_set, sc)); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (!enabled) { | 
					
						
							|  |  |  |         lc->flag |= LAYER_COLLECTION_EXCLUDE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (enabled && !selectable) { | 
					
						
							|  |  |  |         lc->collection->flag |= COLLECTION_RESTRICT_SELECT; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     do_version_layer_collection_post( | 
					
						
							|  |  |  |         view_layer, &lc->layer_collections, enabled_set, selectable_set, collection_map); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-05-20 09:04:18 +02:00
										 |  |  | static void do_version_scene_collection_convert( | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     Main *bmain, ID *id, SceneCollection *sc, Collection *collection, GHash *collection_map) | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (collection_map) { | 
					
						
							|  |  |  |     BLI_ghash_insert(collection_map, collection, sc); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (SceneCollection *nsc = sc->scene_collections.first; nsc;) { | 
					
						
							|  |  |  |     SceneCollection *nsc_next = nsc->next; | 
					
						
							|  |  |  |     Collection *ncollection = BKE_collection_add(bmain, collection, nsc->name); | 
					
						
							|  |  |  |     ncollection->id.lib = id->lib; | 
					
						
							|  |  |  |     do_version_scene_collection_convert(bmain, id, nsc, ncollection, collection_map); | 
					
						
							|  |  |  |     nsc = nsc_next; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (LinkData *, link, &sc->objects) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     Object *ob = link->data; | 
					
						
							|  |  |  |     if (ob) { | 
					
						
							|  |  |  |       BKE_collection_object_add(bmain, collection, ob); | 
					
						
							|  |  |  |       id_us_min(&ob->id); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   BLI_freelistN(&sc->objects); | 
					
						
							|  |  |  |   MEM_freeN(sc); | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_version_group_collection_to_collection(Main *bmain, Collection *group) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Convert old 2.8 group collections to new unified collections. */ | 
					
						
							|  |  |  |   if (group->collection) { | 
					
						
							|  |  |  |     do_version_scene_collection_convert(bmain, &group->id, group->collection, group, NULL); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   group->collection = NULL; | 
					
						
							|  |  |  |   group->view_layer = NULL; | 
					
						
							|  |  |  |   id_fake_user_set(&group->id); | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_version_scene_collection_to_collection(Main *bmain, Scene *scene) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Convert old 2.8 scene collections to new unified collections. */ | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Temporarily clear view layers so we don't do any layer collection syncing
 | 
					
						
							|  |  |  |    * and destroy old flags that we want to restore. */ | 
					
						
							|  |  |  |   ListBase view_layers = scene->view_layers; | 
					
						
							|  |  |  |   BLI_listbase_clear(&scene->view_layers); | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (!scene->master_collection) { | 
					
						
							|  |  |  |     scene->master_collection = BKE_collection_master_add(); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Convert scene collections. */ | 
					
						
							|  |  |  |   GHash *collection_map = BLI_ghash_new(BLI_ghashutil_ptrhash, BLI_ghashutil_ptrcmp, __func__); | 
					
						
							|  |  |  |   if (scene->collection) { | 
					
						
							|  |  |  |     do_version_scene_collection_convert( | 
					
						
							|  |  |  |         bmain, &scene->id, scene->collection, scene->master_collection, collection_map); | 
					
						
							|  |  |  |     scene->collection = NULL; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   scene->view_layers = view_layers; | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Convert layer collections. */ | 
					
						
							|  |  |  |   ViewLayer *view_layer; | 
					
						
							|  |  |  |   for (view_layer = scene->view_layers.first; view_layer; view_layer = view_layer->next) { | 
					
						
							|  |  |  |     GSet *enabled_set = BLI_gset_new(BLI_ghashutil_ptrhash, BLI_ghashutil_ptrcmp, __func__); | 
					
						
							|  |  |  |     GSet *selectable_set = BLI_gset_new(BLI_ghashutil_ptrhash, BLI_ghashutil_ptrcmp, __func__); | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     do_version_layer_collection_pre( | 
					
						
							|  |  |  |         view_layer, &view_layer->layer_collections, enabled_set, selectable_set); | 
					
						
							| 
									
										
										
										
											2018-05-20 09:04:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     BKE_layer_collection_sync(scene, view_layer); | 
					
						
							| 
									
										
										
										
											2018-05-20 09:04:18 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     do_version_layer_collection_post( | 
					
						
							|  |  |  |         view_layer, &view_layer->layer_collections, enabled_set, selectable_set, collection_map); | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     BLI_gset_free(enabled_set, NULL); | 
					
						
							|  |  |  |     BLI_gset_free(selectable_set, NULL); | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     BKE_layer_collection_sync(scene, view_layer); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   BLI_ghash_free(collection_map, NULL, NULL); | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_version_layers_to_collections(Main *bmain, Scene *scene) | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Since we don't have access to FileData we check the (always valid) first
 | 
					
						
							|  |  |  |    * render layer instead. */ | 
					
						
							|  |  |  |   if (!scene->master_collection) { | 
					
						
							|  |  |  |     scene->master_collection = BKE_collection_master_add(); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (scene->view_layers.first) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Create collections from layers. */ | 
					
						
							| 
									
										
										
										
											2019-09-02 14:31:19 +02:00
										 |  |  |   Collection *collection_master = scene->master_collection; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   Collection *collections[20] = {NULL}; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   for (int layer = 0; layer < 20; layer++) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |     LISTBASE_FOREACH (Base *, base, &scene->base) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       if (base->lay & (1 << layer)) { | 
					
						
							|  |  |  |         /* Create collections when needed only. */ | 
					
						
							|  |  |  |         if (collections[layer] == NULL) { | 
					
						
							|  |  |  |           char name[MAX_NAME]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           BLI_snprintf( | 
					
						
							|  |  |  |               name, sizeof(collection_master->id.name), DATA_("Collection %d"), layer + 1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           Collection *collection = BKE_collection_add(bmain, collection_master, name); | 
					
						
							|  |  |  |           collection->id.lib = scene->id.lib; | 
					
						
							| 
									
										
										
										
											2019-05-10 10:09:23 +02:00
										 |  |  |           if (collection->id.lib != NULL) { | 
					
						
							|  |  |  |             collection->id.tag |= LIB_TAG_INDIRECT; | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           collections[layer] = collection; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (!(scene->lay & (1 << layer))) { | 
					
						
							| 
									
										
										
										
											2019-05-14 17:45:47 -03:00
										 |  |  |             collection->flag |= COLLECTION_RESTRICT_VIEWPORT | COLLECTION_RESTRICT_RENDER; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Note usually this would do slow collection syncing for view layers,
 | 
					
						
							|  |  |  |          * but since no view layers exists yet at this point it's fast. */ | 
					
						
							|  |  |  |         BKE_collection_object_add(bmain, collections[layer], base->object); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (base->flag & SELECT) { | 
					
						
							|  |  |  |         base->object->flag |= SELECT; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							|  |  |  |         base->object->flag &= ~SELECT; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Handle legacy render layers. */ | 
					
						
							|  |  |  |   bool have_override = false; | 
					
						
							|  |  |  |   const bool need_default_renderlayer = scene->r.layers.first == NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (SceneRenderLayer *, srl, &scene->r.layers) { | 
					
						
							| 
									
										
										
										
											2020-03-26 19:33:27 +01:00
										 |  |  |     ViewLayer *view_layer = BKE_view_layer_add(scene, srl->name, NULL, VIEWLAYER_ADD_NEW); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (srl->layflag & SCE_LAY_DISABLE) { | 
					
						
							|  |  |  |       view_layer->flag &= ~VIEW_LAYER_RENDER; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if ((srl->layflag & SCE_LAY_FRS) == 0) { | 
					
						
							|  |  |  |       view_layer->flag &= ~VIEW_LAYER_FREESTYLE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     view_layer->layflag = srl->layflag; | 
					
						
							|  |  |  |     view_layer->passflag = srl->passflag; | 
					
						
							|  |  |  |     view_layer->pass_alpha_threshold = srl->pass_alpha_threshold; | 
					
						
							|  |  |  |     view_layer->samples = srl->samples; | 
					
						
							|  |  |  |     view_layer->mat_override = srl->mat_override; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     BKE_freestyle_config_free(&view_layer->freestyle_config, true); | 
					
						
							|  |  |  |     view_layer->freestyle_config = srl->freestyleConfig; | 
					
						
							|  |  |  |     view_layer->id_properties = srl->prop; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Set exclusion and overrides. */ | 
					
						
							|  |  |  |     for (int layer = 0; layer < 20; layer++) { | 
					
						
							|  |  |  |       Collection *collection = collections[layer]; | 
					
						
							|  |  |  |       if (collection) { | 
					
						
							|  |  |  |         LayerCollection *lc = BKE_layer_collection_first_from_scene_collection(view_layer, | 
					
						
							|  |  |  |                                                                                collection); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (srl->lay_exclude & (1 << layer)) { | 
					
						
							|  |  |  |           /* Disable excluded layer. */ | 
					
						
							|  |  |  |           have_override = true; | 
					
						
							|  |  |  |           lc->flag |= LAYER_COLLECTION_EXCLUDE; | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |           LISTBASE_FOREACH (LayerCollection *, nlc, &lc->layer_collections) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             nlc->flag |= LAYER_COLLECTION_EXCLUDE; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else { | 
					
						
							|  |  |  |           if (srl->lay_zmask & (1 << layer)) { | 
					
						
							|  |  |  |             have_override = true; | 
					
						
							|  |  |  |             lc->flag |= LAYER_COLLECTION_HOLDOUT; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if ((srl->lay & (1 << layer)) == 0) { | 
					
						
							|  |  |  |             have_override = true; | 
					
						
							|  |  |  |             lc->flag |= LAYER_COLLECTION_INDIRECT_ONLY; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* for convenience set the same active object in all the layers */ | 
					
						
							|  |  |  |     if (scene->basact) { | 
					
						
							|  |  |  |       view_layer->basact = BKE_view_layer_base_find(view_layer, scene->basact->object); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |     LISTBASE_FOREACH (Base *, base, &view_layer->object_bases) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       if ((base->flag & BASE_SELECTABLE) && (base->object->flag & SELECT)) { | 
					
						
							|  |  |  |         base->flag |= BASE_SELECTED; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   BLI_freelistN(&scene->r.layers); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* If render layers included overrides, or there are no render layers,
 | 
					
						
							|  |  |  |    * we also create a vanilla viewport layer. */ | 
					
						
							|  |  |  |   if (have_override || need_default_renderlayer) { | 
					
						
							| 
									
										
										
										
											2020-03-26 19:33:27 +01:00
										 |  |  |     ViewLayer *view_layer = BKE_view_layer_add(scene, "Viewport", NULL, VIEWLAYER_ADD_NEW); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 01:10:29 +10:00
										 |  |  |     /* If we ported all the original render layers,
 | 
					
						
							|  |  |  |      * we don't need to make the viewport layer renderable. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (!BLI_listbase_is_single(&scene->view_layers)) { | 
					
						
							|  |  |  |       view_layer->flag &= ~VIEW_LAYER_RENDER; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* convert active base */ | 
					
						
							|  |  |  |     if (scene->basact) { | 
					
						
							|  |  |  |       view_layer->basact = BKE_view_layer_base_find(view_layer, scene->basact->object); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* convert selected bases */ | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |     LISTBASE_FOREACH (Base *, base, &view_layer->object_bases) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       if ((base->flag & BASE_SELECTABLE) && (base->object->flag & SELECT)) { | 
					
						
							|  |  |  |         base->flag |= BASE_SELECTED; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* keep lay around for forward compatibility (open those files in 2.79) */ | 
					
						
							|  |  |  |       base->lay = base->object->lay; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* remove bases once and for all */ | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (Base *, base, &scene->base) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     id_us_min(&base->object->id); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   BLI_freelistN(&scene->base); | 
					
						
							|  |  |  |   scene->basact = NULL; | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-24 16:34:15 +02:00
										 |  |  | static void do_version_collection_propagate_lib_to_children(Collection *collection) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (collection->id.lib != NULL) { | 
					
						
							|  |  |  |     for (CollectionChild *collection_child = collection->children.first; collection_child != NULL; | 
					
						
							|  |  |  |          collection_child = collection_child->next) { | 
					
						
							|  |  |  |       if (collection_child->collection->id.lib == NULL) { | 
					
						
							|  |  |  |         collection_child->collection->id.lib = collection->id.lib; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       do_version_collection_propagate_lib_to_children(collection_child->collection); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-08-24 16:34:15 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-09 20:12:21 +02:00
										 |  |  | /** convert old annotations colors */ | 
					
						
							|  |  |  | static void do_versions_fix_annotations(bGPdata *gpd) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (const bGPDpalette *, palette, &gpd->palettes) { | 
					
						
							|  |  |  |     LISTBASE_FOREACH (bGPDpalettecolor *, palcolor, &palette->colors) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       /* fix layers */ | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |       LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         /* unlock/unhide layer */ | 
					
						
							|  |  |  |         gpl->flag &= ~GP_LAYER_LOCKED; | 
					
						
							|  |  |  |         gpl->flag &= ~GP_LAYER_HIDE; | 
					
						
							|  |  |  |         /* set opacity to 1 */ | 
					
						
							|  |  |  |         gpl->opacity = 1.0f; | 
					
						
							|  |  |  |         /* disable tint */ | 
					
						
							|  |  |  |         gpl->tintcolor[3] = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |         LISTBASE_FOREACH (bGPDframe *, gpf, &gpl->frames) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (bGPDstroke *, gps, &gpf->strokes) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if ((gps->colorname[0] != '\0') && (STREQ(gps->colorname, palcolor->info))) { | 
					
						
							|  |  |  |               /* copy color settings */ | 
					
						
							|  |  |  |               copy_v4_v4(gpl->color, palcolor->color); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-04-09 20:12:21 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  | static void do_versions_remove_region(ListBase *regionbase, ARegion *region) | 
					
						
							| 
									
										
										
										
											2019-10-10 13:19:04 +11:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |   BLI_freelinkN(regionbase, region); | 
					
						
							| 
									
										
										
										
											2019-10-10 13:19:04 +11:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_versions_remove_regions_by_type(ListBase *regionbase, int regiontype) | 
					
						
							| 
									
										
										
										
											2019-04-18 06:48:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |   ARegion *region, *region_next; | 
					
						
							|  |  |  |   for (region = regionbase->first; region; region = region_next) { | 
					
						
							|  |  |  |     region_next = region->next; | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |     if (region->regiontype == regiontype) { | 
					
						
							|  |  |  |       do_versions_remove_region(regionbase, region); | 
					
						
							| 
									
										
										
										
											2019-04-18 06:48:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  | static ARegion *do_versions_find_region_or_null(ListBase *regionbase, int regiontype) | 
					
						
							| 
									
										
										
										
											2019-04-18 06:48:34 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (ARegion *, region, regionbase) { | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |     if (region->regiontype == regiontype) { | 
					
						
							|  |  |  |       return region; | 
					
						
							| 
									
										
										
										
											2019-04-18 06:48:34 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   return NULL; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  | static ARegion *do_versions_find_region(ListBase *regionbase, int regiontype) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |   ARegion *region = do_versions_find_region_or_null(regionbase, regiontype); | 
					
						
							|  |  |  |   if (region == NULL) { | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  |     BLI_assert(!"Did not find expected region in versioning"); | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |   return region; | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 06:48:34 +02:00
										 |  |  | static ARegion *do_versions_add_region(int regiontype, const char *name) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |   ARegion *region = MEM_callocN(sizeof(ARegion), name); | 
					
						
							|  |  |  |   region->regiontype = regiontype; | 
					
						
							|  |  |  |   return region; | 
					
						
							| 
									
										
										
										
											2019-04-18 06:48:34 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-22 14:54:44 +01:00
										 |  |  | static void do_versions_area_ensure_tool_region(Main *bmain, | 
					
						
							|  |  |  |                                                 const short space_type, | 
					
						
							|  |  |  |                                                 const short region_flag) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |     LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2020-01-22 14:54:44 +01:00
										 |  |  |         if (sl->spacetype == space_type) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |           ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                  &sl->regionbase; | 
					
						
							|  |  |  |           ARegion *region = BKE_area_find_region_type(area, RGN_TYPE_TOOLS); | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |           if (!region) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ARegion *header = BKE_area_find_region_type(area, RGN_TYPE_HEADER); | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             region = do_versions_add_region(RGN_TYPE_TOOLS, "tools region"); | 
					
						
							|  |  |  |             BLI_insertlinkafter(regionbase, header, region); | 
					
						
							|  |  |  |             region->alignment = RGN_ALIGN_LEFT; | 
					
						
							|  |  |  |             region->flag = region_flag; | 
					
						
							| 
									
										
										
										
											2020-01-22 14:54:44 +01:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  | static void do_version_bones_split_bbone_scale(ListBase *lb) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (Bone *, bone, lb) { | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  |     bone->scale_in_y = bone->scale_in_x; | 
					
						
							|  |  |  |     bone->scale_out_y = bone->scale_out_x; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     do_version_bones_split_bbone_scale(&bone->childbase); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Armature: add Inherit Scale options to remove shear or average the scale.
As an inherent property of matrix-based transformation math, non-
uniform scaling of a parent bone induces shear into the transform
matrix of any rotated child. Such matrices cannot be cleanly
decomposed into a combination of location/rotation/scale, which
causes issues for rigging and animation tools.
Blender bones have options to exclude rotation and/or scale from the
inherited transformation, but don't have any support for removing the
often undesired shear component. That goal requires replacing simple
parenting with a combination of multiple bones and constraints. The
same is true about the goal of inheriting some scale, but completely
avoiding shear.
This patch replaces the old Inherit Scale checkbox with a enum that
supports multiple options:
* Full: inherit all effects of scale, like with enabled Inherit Scale.
* Fix Shear: removes shear from the final inherited transformation.
  The cleanup math is specifically designed to preserve the main
  axis of the bone, its length and total volume, and minimally
  affect roll on average. It however will not prevent reappearance
  of shear due to local rotation of the child or its children.
* Average: inherit uniform scale that represents the parent volume.
  This is the simplest foolproof solution that will inherit some
  scale without ever causing shear.
* None: completely remove scale and shear.
* None (Legacy): old disabled Inherit Scale checkbox.
  This mode does not handle parent shear in any way, so the child
  is likely to end up having both scale and shear. It is retained
  for backward compatibility.
Since many rigging-related addons access the use_inherit_scale
property from Python, it is retained as a backward compatibility
stub that provides the old functionality.
As a side effect of reworking the code, this also fixes a matrix
multiplication order bug in the Inherit Rotation code, which caused
the parent local scale to be applied in world space. In rigger
opinion this option is useless in production rigs, so this fix
should not be a problem.
Reviewers: brecht
Differential Revision: https://developer.blender.org/D5588
											
										 
											2019-09-04 10:10:27 +03:00
										 |  |  | static void do_version_bones_inherit_scale(ListBase *lb) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (Bone *, bone, lb) { | 
					
						
							| 
									
										
											  
											
												Armature: add Inherit Scale options to remove shear or average the scale.
As an inherent property of matrix-based transformation math, non-
uniform scaling of a parent bone induces shear into the transform
matrix of any rotated child. Such matrices cannot be cleanly
decomposed into a combination of location/rotation/scale, which
causes issues for rigging and animation tools.
Blender bones have options to exclude rotation and/or scale from the
inherited transformation, but don't have any support for removing the
often undesired shear component. That goal requires replacing simple
parenting with a combination of multiple bones and constraints. The
same is true about the goal of inheriting some scale, but completely
avoiding shear.
This patch replaces the old Inherit Scale checkbox with a enum that
supports multiple options:
* Full: inherit all effects of scale, like with enabled Inherit Scale.
* Fix Shear: removes shear from the final inherited transformation.
  The cleanup math is specifically designed to preserve the main
  axis of the bone, its length and total volume, and minimally
  affect roll on average. It however will not prevent reappearance
  of shear due to local rotation of the child or its children.
* Average: inherit uniform scale that represents the parent volume.
  This is the simplest foolproof solution that will inherit some
  scale without ever causing shear.
* None: completely remove scale and shear.
* None (Legacy): old disabled Inherit Scale checkbox.
  This mode does not handle parent shear in any way, so the child
  is likely to end up having both scale and shear. It is retained
  for backward compatibility.
Since many rigging-related addons access the use_inherit_scale
property from Python, it is retained as a backward compatibility
stub that provides the old functionality.
As a side effect of reworking the code, this also fixes a matrix
multiplication order bug in the Inherit Rotation code, which caused
the parent local scale to be applied in world space. In rigger
opinion this option is useless in production rigs, so this fix
should not be a problem.
Reviewers: brecht
Differential Revision: https://developer.blender.org/D5588
											
										 
											2019-09-04 10:10:27 +03:00
										 |  |  |     if (bone->flag & BONE_NO_SCALE) { | 
					
						
							|  |  |  |       bone->inherit_scale_mode = BONE_INHERIT_SCALE_NONE_LEGACY; | 
					
						
							|  |  |  |       bone->flag &= ~BONE_NO_SCALE; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     do_version_bones_inherit_scale(&bone->childbase); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  | static bool replace_bbone_scale_rnapath(char **p_old_path) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   char *old_path = *p_old_path; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (old_path == NULL) { | 
					
						
							|  |  |  |     return false; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (BLI_str_endswith(old_path, "bbone_scalein") || | 
					
						
							|  |  |  |       BLI_str_endswith(old_path, "bbone_scaleout")) { | 
					
						
							|  |  |  |     *p_old_path = BLI_strdupcat(old_path, "x"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     MEM_freeN(old_path); | 
					
						
							|  |  |  |     return true; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   return false; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_version_bbone_scale_fcurve_fix(ListBase *curves, FCurve *fcu) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   /* Update driver variable paths. */ | 
					
						
							|  |  |  |   if (fcu->driver) { | 
					
						
							|  |  |  |     LISTBASE_FOREACH (DriverVar *, dvar, &fcu->driver->variables) { | 
					
						
							|  |  |  |       DRIVER_TARGETS_LOOPER_BEGIN (dvar) { | 
					
						
							|  |  |  |         replace_bbone_scale_rnapath(&dtar->rna_path); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       DRIVER_TARGETS_LOOPER_END; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Update F-Curve's path. */ | 
					
						
							|  |  |  |   if (replace_bbone_scale_rnapath(&fcu->rna_path)) { | 
					
						
							|  |  |  |     /* If matched, duplicate the curve and tweak name. */ | 
					
						
							|  |  |  |     FCurve *second = copy_fcurve(fcu); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     second->rna_path[strlen(second->rna_path) - 1] = 'y'; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     BLI_insertlinkafter(curves, fcu, second); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Add to the curve group. */ | 
					
						
							|  |  |  |     second->grp = fcu->grp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (fcu->grp != NULL && fcu->grp->channels.last == fcu) { | 
					
						
							|  |  |  |       fcu->grp->channels.last = second; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static void do_version_bbone_scale_animdata_cb(ID *UNUSED(id), | 
					
						
							|  |  |  |                                                AnimData *adt, | 
					
						
							|  |  |  |                                                void *UNUSED(wrapper_data)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   LISTBASE_FOREACH_MUTABLE (FCurve *, fcu, &adt->drivers) { | 
					
						
							|  |  |  |     do_version_bbone_scale_fcurve_fix(&adt->drivers, fcu); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Maintain Volume: introduce an option switching between modes.
After a lot of thinking about this, I decided that all operation modes
that I've tried over the past couple of years, including the original
2.79 one, have their uses after all. Thus the only reasonable solution
is to add yet another option.
The modes are:
- Strict: The current 2.80 mode, which overrides the original scaling
  of the non-free axes to strictly preserve the volume. This is the most
  obvious way one would expect a 'Maintain Volume' constraint to work.
- Uniform: The original 2.79 mode, which assumes that all axes have been
  scaled the same as the free one when computing the volume. This seems
  strange, but the net effect is that when simply scaling the object
  uniformly with S, the volume is preserved; however, scaling the non-
  free axes individually allows deviating from the locked volume.
  This was obviously intended as a more or less convenient UI tool.
- Single Axis: My own variant of the intent of the Uniform scale, which
  does volume-preserving if the object is scaled just on the Free axis,
  while passing the non-free axis scaling through. I.e. instead of
  uniform S scaling, the user has to scale the object just on its
  primary axis to achieve constant volume. This can allow reducing the
  number of animation curves when only constant volume scaling is needed,
  or be an easier to control tool inside a complex rig.
											
										 
											2019-05-06 21:47:51 +03:00
										 |  |  | static void do_version_constraints_maintain_volume_mode_uniform(ListBase *lb) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (bConstraint *, con, lb) { | 
					
						
							| 
									
										
											  
											
												Maintain Volume: introduce an option switching between modes.
After a lot of thinking about this, I decided that all operation modes
that I've tried over the past couple of years, including the original
2.79 one, have their uses after all. Thus the only reasonable solution
is to add yet another option.
The modes are:
- Strict: The current 2.80 mode, which overrides the original scaling
  of the non-free axes to strictly preserve the volume. This is the most
  obvious way one would expect a 'Maintain Volume' constraint to work.
- Uniform: The original 2.79 mode, which assumes that all axes have been
  scaled the same as the free one when computing the volume. This seems
  strange, but the net effect is that when simply scaling the object
  uniformly with S, the volume is preserved; however, scaling the non-
  free axes individually allows deviating from the locked volume.
  This was obviously intended as a more or less convenient UI tool.
- Single Axis: My own variant of the intent of the Uniform scale, which
  does volume-preserving if the object is scaled just on the Free axis,
  while passing the non-free axis scaling through. I.e. instead of
  uniform S scaling, the user has to scale the object just on its
  primary axis to achieve constant volume. This can allow reducing the
  number of animation curves when only constant volume scaling is needed,
  or be an easier to control tool inside a complex rig.
											
										 
											2019-05-06 21:47:51 +03:00
										 |  |  |     if (con->type == CONSTRAINT_TYPE_SAMEVOL) { | 
					
						
							|  |  |  |       bSameVolumeConstraint *data = (bSameVolumeConstraint *)con->data; | 
					
						
							|  |  |  |       data->mode = SAMEVOL_UNIFORM; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-08 12:08:54 +03:00
										 |  |  | static void do_version_constraints_copy_scale_power(ListBase *lb) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (bConstraint *, con, lb) { | 
					
						
							| 
									
										
										
										
											2019-05-08 12:08:54 +03:00
										 |  |  |     if (con->type == CONSTRAINT_TYPE_SIZELIKE) { | 
					
						
							|  |  |  |       bSizeLikeConstraint *data = (bSizeLikeConstraint *)con->data; | 
					
						
							|  |  |  |       data->power = 1.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-04 12:06:59 +03:00
										 |  |  | static void do_version_constraints_copy_rotation_mix_mode(ListBase *lb) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |   LISTBASE_FOREACH (bConstraint *, con, lb) { | 
					
						
							| 
									
										
										
										
											2019-09-04 12:06:59 +03:00
										 |  |  |     if (con->type == CONSTRAINT_TYPE_ROTLIKE) { | 
					
						
							|  |  |  |       bRotateLikeConstraint *data = (bRotateLikeConstraint *)con->data; | 
					
						
							|  |  |  |       data->mix_mode = (data->flag & ROTLIKE_OFFSET) ? ROTLIKE_MIX_OFFSET : ROTLIKE_MIX_REPLACE; | 
					
						
							|  |  |  |       data->flag &= ~ROTLIKE_OFFSET; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-23 11:50:15 -07:00
										 |  |  | static void do_versions_seq_alloc_transform_and_crop(ListBase *seqbase) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   for (Sequence *seq = seqbase->first; seq != NULL; seq = seq->next) { | 
					
						
							| 
									
										
										
										
											2019-05-30 15:19:02 -07:00
										 |  |  |     if (ELEM(seq->type, SEQ_TYPE_SOUND_RAM, SEQ_TYPE_SOUND_HD) == 0) { | 
					
						
							|  |  |  |       if (seq->strip->transform == NULL) { | 
					
						
							|  |  |  |         seq->strip->transform = MEM_callocN(sizeof(struct StripTransform), "StripTransform"); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-05-23 11:50:15 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-30 15:19:02 -07:00
										 |  |  |       if (seq->strip->crop == NULL) { | 
					
						
							|  |  |  |         seq->strip->crop = MEM_callocN(sizeof(struct StripCrop), "StripCrop"); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-05-23 11:50:15 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-30 15:19:02 -07:00
										 |  |  |       if (seq->seqbase.first != NULL) { | 
					
						
							|  |  |  |         do_versions_seq_alloc_transform_and_crop(&seq->seqbase); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-05-23 11:50:15 -07:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-13 00:11:36 +02:00
										 |  |  | /* Return true if there is something to convert. */ | 
					
						
							| 
									
										
										
										
											2019-08-16 16:41:59 +02:00
										 |  |  | static void do_versions_material_convert_legacy_blend_mode(bNodeTree *ntree, char blend_method) | 
					
						
							| 
									
										
										
										
											2019-08-13 00:11:36 +02:00
										 |  |  | { | 
					
						
							|  |  |  |   bool need_update = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Iterate backwards from end so we don't encounter newly added links. */ | 
					
						
							|  |  |  |   bNodeLink *prevlink; | 
					
						
							|  |  |  |   for (bNodeLink *link = ntree->links.last; link; link = prevlink) { | 
					
						
							|  |  |  |     prevlink = link->prev; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Detect link to replace. */ | 
					
						
							|  |  |  |     bNode *fromnode = link->fromnode; | 
					
						
							|  |  |  |     bNodeSocket *fromsock = link->fromsock; | 
					
						
							|  |  |  |     bNode *tonode = link->tonode; | 
					
						
							|  |  |  |     bNodeSocket *tosock = link->tosock; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!(tonode->type == SH_NODE_OUTPUT_MATERIAL && STREQ(tosock->identifier, "Surface"))) { | 
					
						
							|  |  |  |       continue; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Only do outputs that are enabled for EEVEE */ | 
					
						
							|  |  |  |     if (!ELEM(tonode->custom1, SHD_OUTPUT_ALL, SHD_OUTPUT_EEVEE)) { | 
					
						
							|  |  |  |       continue; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (blend_method == 1 /* MA_BM_ADD */) { | 
					
						
							|  |  |  |       nodeRemLink(ntree, link); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       bNode *add_node = nodeAddStaticNode(NULL, ntree, SH_NODE_ADD_SHADER); | 
					
						
							|  |  |  |       add_node->locx = 0.5f * (fromnode->locx + tonode->locx); | 
					
						
							|  |  |  |       add_node->locy = 0.5f * (fromnode->locy + tonode->locy); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       bNodeSocket *shader1_socket = add_node->inputs.first; | 
					
						
							|  |  |  |       bNodeSocket *shader2_socket = add_node->inputs.last; | 
					
						
							|  |  |  |       bNodeSocket *add_socket = nodeFindSocket(add_node, SOCK_OUT, "Shader"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       bNode *transp_node = nodeAddStaticNode(NULL, ntree, SH_NODE_BSDF_TRANSPARENT); | 
					
						
							|  |  |  |       transp_node->locx = add_node->locx; | 
					
						
							|  |  |  |       transp_node->locy = add_node->locy - 110.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       bNodeSocket *transp_socket = nodeFindSocket(transp_node, SOCK_OUT, "BSDF"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Link to input and material output node. */ | 
					
						
							|  |  |  |       nodeAddLink(ntree, fromnode, fromsock, add_node, shader1_socket); | 
					
						
							|  |  |  |       nodeAddLink(ntree, transp_node, transp_socket, add_node, shader2_socket); | 
					
						
							|  |  |  |       nodeAddLink(ntree, add_node, add_socket, tonode, tosock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       need_update = true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     else if (blend_method == 2 /* MA_BM_MULTIPLY */) { | 
					
						
							|  |  |  |       nodeRemLink(ntree, link); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       bNode *transp_node = nodeAddStaticNode(NULL, ntree, SH_NODE_BSDF_TRANSPARENT); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       bNodeSocket *color_socket = nodeFindSocket(transp_node, SOCK_IN, "Color"); | 
					
						
							|  |  |  |       bNodeSocket *transp_socket = nodeFindSocket(transp_node, SOCK_OUT, "BSDF"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* If incomming link is from a closure socket, we need to convert it. */ | 
					
						
							|  |  |  |       if (fromsock->type == SOCK_SHADER) { | 
					
						
							|  |  |  |         transp_node->locx = 0.33f * fromnode->locx + 0.66f * tonode->locx; | 
					
						
							|  |  |  |         transp_node->locy = 0.33f * fromnode->locy + 0.66f * tonode->locy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         bNode *shtorgb_node = nodeAddStaticNode(NULL, ntree, SH_NODE_SHADERTORGB); | 
					
						
							|  |  |  |         shtorgb_node->locx = 0.66f * fromnode->locx + 0.33f * tonode->locx; | 
					
						
							|  |  |  |         shtorgb_node->locy = 0.66f * fromnode->locy + 0.33f * tonode->locy; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         bNodeSocket *shader_socket = nodeFindSocket(shtorgb_node, SOCK_IN, "Shader"); | 
					
						
							|  |  |  |         bNodeSocket *rgba_socket = nodeFindSocket(shtorgb_node, SOCK_OUT, "Color"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         nodeAddLink(ntree, fromnode, fromsock, shtorgb_node, shader_socket); | 
					
						
							|  |  |  |         nodeAddLink(ntree, shtorgb_node, rgba_socket, transp_node, color_socket); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							|  |  |  |         transp_node->locx = 0.5f * (fromnode->locx + tonode->locx); | 
					
						
							|  |  |  |         transp_node->locy = 0.5f * (fromnode->locy + tonode->locy); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         nodeAddLink(ntree, fromnode, fromsock, transp_node, color_socket); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Link to input and material output node. */ | 
					
						
							|  |  |  |       nodeAddLink(ntree, transp_node, transp_socket, tonode, tosock); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       need_update = true; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (need_update) { | 
					
						
							|  |  |  |     ntreeUpdateTree(NULL, ntree); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-19 14:25:29 -03:00
										 |  |  | static void do_versions_local_collection_bits_set(LayerCollection *layer_collection) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   layer_collection->local_collections_bits = ~(0); | 
					
						
							|  |  |  |   LISTBASE_FOREACH (LayerCollection *, child, &layer_collection->layer_collections) { | 
					
						
							|  |  |  |     do_versions_local_collection_bits_set(child); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  | static void do_version_curvemapping_flag_extend_extrapolate(CurveMapping *cumap) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2020-02-18 18:02:42 +01:00
										 |  |  |   if (cumap == NULL) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  | #define CUMA_EXTEND_EXTRAPOLATE_OLD 1
 | 
					
						
							|  |  |  |   for (int curve_map_index = 0; curve_map_index < 4; curve_map_index++) { | 
					
						
							|  |  |  |     CurveMap *cuma = &cumap->cm[curve_map_index]; | 
					
						
							|  |  |  |     if (cuma->flag & CUMA_EXTEND_EXTRAPOLATE_OLD) { | 
					
						
							|  |  |  |       cumap->flag |= CUMA_EXTEND_EXTRAPOLATE; | 
					
						
							|  |  |  |       return; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | #undef CUMA_EXTEND_EXTRAPOLATE_OLD
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Util version to walk over all CurveMappings in the given `bmain` */ | 
					
						
							|  |  |  | static void do_version_curvemapping_walker(Main *bmain, void (*callback)(CurveMapping *cumap)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |     callback(&scene->r.mblur_shutter_curve); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (scene->view_settings.curve_mapping) { | 
					
						
							|  |  |  |       callback(scene->view_settings.curve_mapping); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (scene->ed != NULL) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Sequence *, seq, &scene->ed->seqbase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SequenceModifierData *, smd, &seq->modifiers) { | 
					
						
							|  |  |  |           const SequenceModifierTypeInfo *smti = BKE_sequence_modifier_type_info_get(smd->type); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (smti) { | 
					
						
							|  |  |  |             if (smd->type == seqModifierType_Curves) { | 
					
						
							|  |  |  |               CurvesModifierData *cmd = (CurvesModifierData *)smd; | 
					
						
							|  |  |  |               callback(&cmd->curve_mapping); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else if (smd->type == seqModifierType_HueCorrect) { | 
					
						
							|  |  |  |               HueCorrectModifierData *hcmd = (HueCorrectModifierData *)smd; | 
					
						
							|  |  |  |               callback(&hcmd->curve_mapping); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     // toolsettings
 | 
					
						
							|  |  |  |     ToolSettings *ts = scene->toolsettings; | 
					
						
							|  |  |  |     if (ts->vpaint) { | 
					
						
							|  |  |  |       callback(ts->vpaint->paint.cavity_curve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ts->wpaint) { | 
					
						
							|  |  |  |       callback(ts->wpaint->paint.cavity_curve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ts->sculpt) { | 
					
						
							|  |  |  |       callback(ts->sculpt->paint.cavity_curve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ts->uvsculpt) { | 
					
						
							|  |  |  |       callback(ts->uvsculpt->paint.cavity_curve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ts->gp_paint) { | 
					
						
							|  |  |  |       callback(ts->gp_paint->paint.cavity_curve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ts->gp_interpolate.custom_ipo) { | 
					
						
							|  |  |  |       callback(ts->gp_interpolate.custom_ipo); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ts->gp_sculpt.cur_falloff) { | 
					
						
							|  |  |  |       callback(ts->gp_sculpt.cur_falloff); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (ts->gp_sculpt.cur_primitive) { | 
					
						
							|  |  |  |       callback(ts->gp_sculpt.cur_primitive); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     callback(ts->imapaint.paint.cavity_curve); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   FOREACH_NODETREE_BEGIN (bmain, node_tree, id) { | 
					
						
							|  |  |  |     LISTBASE_FOREACH (bNode *, node, &node_tree->nodes) { | 
					
						
							|  |  |  |       if (ELEM(node->type, | 
					
						
							|  |  |  |                SH_NODE_CURVE_VEC, | 
					
						
							|  |  |  |                SH_NODE_CURVE_RGB, | 
					
						
							|  |  |  |                CMP_NODE_CURVE_VEC, | 
					
						
							|  |  |  |                CMP_NODE_CURVE_RGB, | 
					
						
							|  |  |  |                CMP_NODE_TIME, | 
					
						
							|  |  |  |                CMP_NODE_HUECORRECT, | 
					
						
							|  |  |  |                TEX_NODE_CURVE_RGB, | 
					
						
							|  |  |  |                TEX_NODE_CURVE_TIME)) { | 
					
						
							|  |  |  |         callback((CurveMapping *)node->storage); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  |   FOREACH_NODETREE_END; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   LISTBASE_FOREACH (Light *, light, &bmain->lights) { | 
					
						
							|  |  |  |     if (light->curfalloff) { | 
					
						
							|  |  |  |       callback(light->curfalloff); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   LISTBASE_FOREACH (Brush *, brush, &bmain->brushes) { | 
					
						
							|  |  |  |     if (brush->curve) { | 
					
						
							|  |  |  |       callback(brush->curve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (brush->gpencil_settings) { | 
					
						
							|  |  |  |       if (brush->gpencil_settings->curve_sensitivity) { | 
					
						
							|  |  |  |         callback(brush->gpencil_settings->curve_sensitivity); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (brush->gpencil_settings->curve_strength) { | 
					
						
							|  |  |  |         callback(brush->gpencil_settings->curve_strength); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (brush->gpencil_settings->curve_jitter) { | 
					
						
							|  |  |  |         callback(brush->gpencil_settings->curve_jitter); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   LISTBASE_FOREACH (ParticleSettings *, part, &bmain->particles) { | 
					
						
							|  |  |  |     if (part->clumpcurve) { | 
					
						
							|  |  |  |       callback(part->clumpcurve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (part->roughcurve) { | 
					
						
							|  |  |  |       callback(part->roughcurve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (part->twistcurve) { | 
					
						
							|  |  |  |       callback(part->twistcurve); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Object */ | 
					
						
							|  |  |  |   LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |     /* Object modifiers */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							|  |  |  |       if (md->type == eModifierType_Hook) { | 
					
						
							|  |  |  |         HookModifierData *hmd = (HookModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (hmd->curfalloff) { | 
					
						
							|  |  |  |           callback(hmd->curfalloff); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (md->type == eModifierType_Warp) { | 
					
						
							|  |  |  |         WarpModifierData *tmd = (WarpModifierData *)md; | 
					
						
							|  |  |  |         if (tmd->curfalloff) { | 
					
						
							|  |  |  |           callback(tmd->curfalloff); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (md->type == eModifierType_WeightVGEdit) { | 
					
						
							|  |  |  |         WeightVGEditModifierData *wmd = (WeightVGEditModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (wmd->cmap_curve) { | 
					
						
							|  |  |  |           callback(wmd->cmap_curve); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* Grease pencil modifiers */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (ModifierData *, md, &ob->greasepencil_modifiers) { | 
					
						
							|  |  |  |       if (md->type == eGpencilModifierType_Thick) { | 
					
						
							|  |  |  |         ThickGpencilModifierData *gpmd = (ThickGpencilModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (gpmd->curve_thickness) { | 
					
						
							|  |  |  |           callback(gpmd->curve_thickness); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (md->type == eGpencilModifierType_Hook) { | 
					
						
							|  |  |  |         HookGpencilModifierData *gpmd = (HookGpencilModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (gpmd->curfalloff) { | 
					
						
							|  |  |  |           callback(gpmd->curfalloff); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |       else if (md->type == eGpencilModifierType_Noise) { | 
					
						
							|  |  |  |         NoiseGpencilModifierData *gpmd = (NoiseGpencilModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (gpmd->curve_intensity) { | 
					
						
							|  |  |  |           callback(gpmd->curve_intensity); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2020-03-13 10:28:30 +01:00
										 |  |  |       else if (md->type == eGpencilModifierType_Tint) { | 
					
						
							|  |  |  |         TintGpencilModifierData *gpmd = (TintGpencilModifierData *)md; | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |         if (gpmd->curve_intensity) { | 
					
						
							|  |  |  |           callback(gpmd->curve_intensity); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (md->type == eGpencilModifierType_Smooth) { | 
					
						
							|  |  |  |         SmoothGpencilModifierData *gpmd = (SmoothGpencilModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (gpmd->curve_intensity) { | 
					
						
							|  |  |  |           callback(gpmd->curve_intensity); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (md->type == eGpencilModifierType_Color) { | 
					
						
							|  |  |  |         ColorGpencilModifierData *gpmd = (ColorGpencilModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (gpmd->curve_intensity) { | 
					
						
							|  |  |  |           callback(gpmd->curve_intensity); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (md->type == eGpencilModifierType_Opacity) { | 
					
						
							|  |  |  |         OpacityGpencilModifierData *gpmd = (OpacityGpencilModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (gpmd->curve_intensity) { | 
					
						
							|  |  |  |           callback(gpmd->curve_intensity); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Free Style */ | 
					
						
							|  |  |  |   LISTBASE_FOREACH (struct FreestyleLineStyle *, linestyle, &bmain->linestyles) { | 
					
						
							| 
									
										
										
										
											2020-01-16 11:35:10 +01:00
										 |  |  |     LISTBASE_FOREACH (LineStyleModifier *, m, &linestyle->alpha_modifiers) { | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  |       switch (m->type) { | 
					
						
							|  |  |  |         case LS_MODIFIER_ALONG_STROKE: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_AlongStroke *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_DISTANCE_FROM_CAMERA: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_DistanceFromCamera *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_DISTANCE_FROM_OBJECT: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_DistanceFromObject *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_MATERIAL: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_Material *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_TANGENT: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_Tangent *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_NOISE: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_Noise *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_CREASE_ANGLE: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_CreaseAngle *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_CURVATURE_3D: | 
					
						
							|  |  |  |           callback(((LineStyleAlphaModifier_Curvature_3D *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LISTBASE_FOREACH (LineStyleModifier *, m, &linestyle->thickness_modifiers) { | 
					
						
							|  |  |  |       switch (m->type) { | 
					
						
							|  |  |  |         case LS_MODIFIER_ALONG_STROKE: | 
					
						
							|  |  |  |           callback(((LineStyleThicknessModifier_AlongStroke *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_DISTANCE_FROM_CAMERA: | 
					
						
							|  |  |  |           callback(((LineStyleThicknessModifier_DistanceFromCamera *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_DISTANCE_FROM_OBJECT: | 
					
						
							|  |  |  |           callback(((LineStyleThicknessModifier_DistanceFromObject *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_MATERIAL: | 
					
						
							|  |  |  |           callback(((LineStyleThicknessModifier_Material *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_TANGENT: | 
					
						
							|  |  |  |           callback(((LineStyleThicknessModifier_Tangent *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_CREASE_ANGLE: | 
					
						
							|  |  |  |           callback(((LineStyleThicknessModifier_CreaseAngle *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case LS_MODIFIER_CURVATURE_3D: | 
					
						
							|  |  |  |           callback(((LineStyleThicknessModifier_Curvature_3D *)m)->curve); | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-14 17:08:22 +01:00
										 |  |  | static void do_version_fcurve_hide_viewport_fix(struct ID *UNUSED(id), | 
					
						
							|  |  |  |                                                 struct FCurve *fcu, | 
					
						
							|  |  |  |                                                 void *UNUSED(user_data)) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   if (strcmp(fcu->rna_path, "hide")) { | 
					
						
							|  |  |  |     return; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   MEM_freeN(fcu->rna_path); | 
					
						
							|  |  |  |   fcu->rna_path = BLI_strdupn("hide_viewport", 13); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-17 00:53:18 +10:00
										 |  |  | void do_versions_after_linking_280(Main *bmain, ReportList *UNUSED(reports)) | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   bool use_collection_compat_28 = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 0)) { | 
					
						
							|  |  |  |     use_collection_compat_28 = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Convert group layer visibility flags to hidden nested collection. */ | 
					
						
							|  |  |  |     for (Collection *collection = bmain->collections.first; collection; | 
					
						
							|  |  |  |          collection = collection->id.next) { | 
					
						
							|  |  |  |       /* Add fake user for all existing groups. */ | 
					
						
							|  |  |  |       id_fake_user_set(&collection->id); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-14 17:45:47 -03:00
										 |  |  |       if (collection->flag & (COLLECTION_RESTRICT_VIEWPORT | COLLECTION_RESTRICT_RENDER)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         continue; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       Collection *hidden_collection_array[20] = {NULL}; | 
					
						
							|  |  |  |       for (CollectionObject *cob = collection->gobject.first, *cob_next = NULL; cob; | 
					
						
							|  |  |  |            cob = cob_next) { | 
					
						
							|  |  |  |         cob_next = cob->next; | 
					
						
							|  |  |  |         Object *ob = cob->ob; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (!(ob->lay & collection->layer)) { | 
					
						
							|  |  |  |           /* Find or create hidden collection matching object's first layer. */ | 
					
						
							|  |  |  |           Collection **collection_hidden = NULL; | 
					
						
							|  |  |  |           int coll_idx = 0; | 
					
						
							|  |  |  |           for (; coll_idx < 20; coll_idx++) { | 
					
						
							|  |  |  |             if (ob->lay & (1 << coll_idx)) { | 
					
						
							|  |  |  |               collection_hidden = &hidden_collection_array[coll_idx]; | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           BLI_assert(collection_hidden != NULL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (*collection_hidden == NULL) { | 
					
						
							|  |  |  |             char name[MAX_ID_NAME]; | 
					
						
							|  |  |  |             BLI_snprintf(name, sizeof(name), DATA_("Hidden %d"), coll_idx + 1); | 
					
						
							|  |  |  |             *collection_hidden = BKE_collection_add(bmain, collection, name); | 
					
						
							| 
									
										
										
										
											2019-05-14 17:45:47 -03:00
										 |  |  |             (*collection_hidden)->flag |= COLLECTION_RESTRICT_VIEWPORT | | 
					
						
							| 
									
										
											  
											
												Outliner Visibility Update
See T61578 for discussions and mockups.
Visibility Options
==================
We are adding more granular control over restriction columns in the outliner,
exposing "indirect only" and "holdout" as options, and change the way
users enable/disable collections in a viewlayer.
We also rename the object viewport restriction to hide instance.
So the options we have are:
Collection
----------
* Render Visibility
* Instance Visibility
* Selectable
(View) Layer Collection
-----------------------
* Enable
* Holdout
* Indirect Only
* Viewport
Shortcuts
=========
Isolate Collection
------------------
* Ctr + click isolates the collection.
It turns all its parents and children "visible", and all the other
collections "invisible".
If ALL the collections were already properly set, we re-set the
collections to their default value.
Set Collection Inside Collections and Objects
---------------------------------------------
* Shift + click: Set/unset inside collections and objects.
We only set objects values as well when we are in View Layer mode and
(obviously) when the objects have a matching property.
Icons
=====
Little reminder that we will need better icons for holdout, indirect only, and
probably instanced (nothing wrong with the current, but it differs from
the proposal when it is turned off).
Also, we need to decide where do we want the modifier/bones/... icons to
be (in which column) and ideally make sure their icons match the ones we
use for collections/objects.
At the moment those are using the screen icon, which is not being used
by collections.
Reviewers: brecht, billrey
Subscribers: pablovazquez
Differential Revision: https://developer.blender.org/D4823
											
										 
											2019-05-04 14:14:37 -03:00
										 |  |  |                                           COLLECTION_RESTRICT_RENDER; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           BKE_collection_object_add(bmain, *collection_hidden, ob); | 
					
						
							|  |  |  |           BKE_collection_object_remove(bmain, collection, ob, true); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  |     /* We need to assign lib pointer to generated hidden collections *after* all have been
 | 
					
						
							|  |  |  |      * created, otherwise we'll end up with several data-blocks sharing same name/library, | 
					
						
							|  |  |  |      * which is FORBIDDEN! Note: we need this to be recursive, since a child collection may be | 
					
						
							|  |  |  |      * sorted before its parent in bmain. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     for (Collection *collection = bmain->collections.first; collection != NULL; | 
					
						
							|  |  |  |          collection = collection->id.next) { | 
					
						
							|  |  |  |       do_version_collection_propagate_lib_to_children(collection); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Convert layers to collections. */ | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       do_version_layers_to_collections(bmain, scene); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 0)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							|  |  |  |       /* same render-layer as do_version_workspaces_after_lib_link will activate,
 | 
					
						
							|  |  |  |        * so same layer as BKE_view_layer_default_view would return */ | 
					
						
							|  |  |  |       ViewLayer *layer = screen->scene->view_layers.first; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, space, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (space->spacetype == SPACE_OUTLINER) { | 
					
						
							|  |  |  |             SpaceOutliner *soutliner = (SpaceOutliner *)space; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             soutliner->outlinevis = SO_VIEW_LAYER; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (BLI_listbase_count_at_most(&layer->layer_collections, 2) == 1) { | 
					
						
							|  |  |  |               if (soutliner->treestore == NULL) { | 
					
						
							|  |  |  |                 soutliner->treestore = BLI_mempool_create( | 
					
						
							|  |  |  |                     sizeof(TreeStoreElem), 1, 512, BLI_MEMPOOL_ALLOW_ITER); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               /* Create a tree store element for the collection. This is normally
 | 
					
						
							|  |  |  |                * done in check_persistent (outliner_tree.c), but we need to access | 
					
						
							|  |  |  |                * it here :/ (expand element if it's the only one) */ | 
					
						
							|  |  |  |               TreeStoreElem *tselem = BLI_mempool_calloc(soutliner->treestore); | 
					
						
							|  |  |  |               tselem->type = TSE_LAYER_COLLECTION; | 
					
						
							|  |  |  |               tselem->id = layer->layer_collections.first; | 
					
						
							|  |  |  |               tselem->nr = tselem->used = 0; | 
					
						
							|  |  |  |               tselem->flag &= ~TSE_CLOSED; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 0)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, space, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (space->spacetype == SPACE_IMAGE) { | 
					
						
							|  |  |  |             SpaceImage *sima = (SpaceImage *)space; | 
					
						
							|  |  |  |             if ((sima) && (sima->gpd)) { | 
					
						
							|  |  |  |               sima->gpd->flag |= GP_DATA_ANNOTATIONS; | 
					
						
							|  |  |  |               do_versions_fix_annotations(sima->gpd); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           if (space->spacetype == SPACE_CLIP) { | 
					
						
							|  |  |  |             SpaceClip *spclip = (SpaceClip *)space; | 
					
						
							|  |  |  |             MovieClip *clip = spclip->clip; | 
					
						
							|  |  |  |             if ((clip) && (clip->gpd)) { | 
					
						
							|  |  |  |               clip->gpd->flag |= GP_DATA_ANNOTATIONS; | 
					
						
							|  |  |  |               do_versions_fix_annotations(clip->gpd); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* New workspace design */ | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 1)) { | 
					
						
							|  |  |  |     do_version_workspaces_after_lib_link(bmain); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 2)) { | 
					
						
							|  |  |  |     /* Cleanup any remaining SceneRenderLayer data for files that were created
 | 
					
						
							|  |  |  |      * with Blender 2.8 before the SceneRenderLayer > RenderLayer refactor. */ | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (SceneRenderLayer *, srl, &scene->r.layers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         if (srl->prop) { | 
					
						
							|  |  |  |           IDP_FreeProperty(srl->prop); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         BKE_freestyle_config_free(&srl->freestyleConfig, true); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       BLI_freelistN(&scene->r.layers); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 3)) { | 
					
						
							| 
									
										
										
										
											2019-04-22 01:10:29 +10:00
										 |  |  |     /* Due to several changes to particle RNA and draw code particles from older files may
 | 
					
						
							|  |  |  |      * no longer be visible. | 
					
						
							|  |  |  |      * Here we correct this by setting a default draw size for those files. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     for (Object *object = bmain->objects.first; object; object = object->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ParticleSystem *, psys, &object->particlesystem) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         if (psys->part->draw_size == 0.0f) { | 
					
						
							|  |  |  |           psys->part->draw_size = 0.1f; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 4)) { | 
					
						
							|  |  |  |     for (Object *object = bmain->objects.first; object; object = object->id.next) { | 
					
						
							|  |  |  |       if (object->particlesystem.first) { | 
					
						
							|  |  |  |         object->duplicator_visibility_flag = OB_DUPLI_FLAG_VIEWPORT; | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ParticleSystem *, psys, &object->particlesystem) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (psys->part->draw & PART_DRAW_EMITTER) { | 
					
						
							|  |  |  |             object->duplicator_visibility_flag |= OB_DUPLI_FLAG_RENDER; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (object->transflag & OB_DUPLI) { | 
					
						
							|  |  |  |         object->duplicator_visibility_flag = OB_DUPLI_FLAG_VIEWPORT; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else { | 
					
						
							|  |  |  |         object->duplicator_visibility_flag = OB_DUPLI_FLAG_VIEWPORT | OB_DUPLI_FLAG_RENDER; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Cleanup deprecated flag from particlesettings data-blocks. */ | 
					
						
							|  |  |  |     for (ParticleSettings *part = bmain->particles.first; part; part = part->id.next) { | 
					
						
							|  |  |  |       part->draw &= ~PART_DRAW_EMITTER; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* SpaceTime & SpaceLogic removal/replacing */ | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 9)) { | 
					
						
							|  |  |  |     const wmWindowManager *wm = bmain->wm.first; | 
					
						
							|  |  |  |     const Scene *scene = bmain->scenes.first; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (wm != NULL) { | 
					
						
							|  |  |  |       /* Action editors need a scene for creation. First, update active
 | 
					
						
							|  |  |  |        * screens using the active scene of the window they're displayed in. | 
					
						
							|  |  |  |        * Next, update remaining screens using first scene in main listbase. */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (wmWindow *, win, &wm->windows) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         const bScreen *screen = BKE_workspace_active_screen_get(win->workspace_hook); | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (ELEM(area->butspacetype, SPACE_TIME, SPACE_LOGIC)) { | 
					
						
							|  |  |  |             do_version_area_change_space_to_space_action(area, win->scene); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /* Don't forget to unset! */ | 
					
						
							|  |  |  |             area->butspacetype = SPACE_EMPTY; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (scene != NULL) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (ELEM(area->butspacetype, SPACE_TIME, SPACE_LOGIC)) { | 
					
						
							|  |  |  |             /* Areas that were already handled won't be handled again */ | 
					
						
							|  |  |  |             do_version_area_change_space_to_space_action(area, scene); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /* Don't forget to unset! */ | 
					
						
							|  |  |  |             area->butspacetype = SPACE_EMPTY; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | #ifdef USE_COLLECTION_COMPAT_28
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (use_collection_compat_28 && !MAIN_VERSION_ATLEAST(bmain, 280, 14)) { | 
					
						
							|  |  |  |     for (Collection *group = bmain->collections.first; group; group = group->id.next) { | 
					
						
							|  |  |  |       do_version_group_collection_to_collection(bmain, group); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       do_version_scene_collection_to_collection(bmain, scene); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-07-31 10:22:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   /* Update Curve object Shape Key data layout to include the Radius property */ | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 23)) { | 
					
						
							|  |  |  |     for (Curve *cu = bmain->curves.first; cu; cu = cu->id.next) { | 
					
						
							| 
									
										
										
										
											2019-04-22 09:13:00 +10:00
										 |  |  |       if (!cu->key || cu->key->elemsize != sizeof(float[4])) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         continue; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:13:00 +10:00
										 |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       cu->key->elemstr[0] = 3; /*KEYELEM_ELEM_SIZE_CURVE*/ | 
					
						
							|  |  |  |       cu->key->elemsize = sizeof(float[3]); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       int new_count = BKE_keyblock_curve_element_count(&cu->nurb); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (KeyBlock *, block, &cu->key->block) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         int old_count = block->totelem; | 
					
						
							|  |  |  |         void *old_data = block->data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 09:13:00 +10:00
										 |  |  |         if (!old_data || old_count <= 0) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           continue; | 
					
						
							| 
									
										
										
										
											2019-04-22 09:13:00 +10:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         block->totelem = new_count; | 
					
						
							|  |  |  |         block->data = MEM_callocN(sizeof(float[3]) * new_count, __func__); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         float *oldptr = old_data; | 
					
						
							|  |  |  |         float(*newptr)[3] = block->data; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (Nurb *, nu, &cu->nurb) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (nu->bezt) { | 
					
						
							|  |  |  |             BezTriple *bezt = nu->bezt; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             for (int a = 0; a < nu->pntsu; a++, bezt++) { | 
					
						
							|  |  |  |               if ((old_count -= 3) < 0) { | 
					
						
							|  |  |  |                 memcpy(newptr, bezt->vec, sizeof(float[3][3])); | 
					
						
							|  |  |  |                 newptr[3][0] = bezt->tilt; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               else { | 
					
						
							|  |  |  |                 memcpy(newptr, oldptr, sizeof(float[3][4])); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               newptr[3][1] = bezt->radius; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               oldptr += 3 * 4; | 
					
						
							|  |  |  |               newptr += 4; /*KEYELEM_ELEM_LEN_BEZTRIPLE*/ | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           else if (nu->bp) { | 
					
						
							|  |  |  |             BPoint *bp = nu->bp; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             for (int a = 0; a < nu->pntsu * nu->pntsv; a++, bp++) { | 
					
						
							|  |  |  |               if (--old_count < 0) { | 
					
						
							|  |  |  |                 copy_v3_v3(newptr[0], bp->vec); | 
					
						
							|  |  |  |                 newptr[1][0] = bp->tilt; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               else { | 
					
						
							|  |  |  |                 memcpy(newptr, oldptr, sizeof(float[4])); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               newptr[1][1] = bp->radius; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               oldptr += 4; | 
					
						
							|  |  |  |               newptr += 2; /*KEYELEM_ELEM_LEN_BPOINT*/ | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         MEM_freeN(old_data); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   /* Move B-Bone custom handle settings from bPoseChannel to Bone. */ | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 25)) { | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |       bArmature *arm = ob->data; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* If it is an armature from the same file. */ | 
					
						
							|  |  |  |       if (ob->pose && arm && arm->id.lib == ob->id.lib) { | 
					
						
							|  |  |  |         bool rebuild = false; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (bPoseChannel *, pchan, &ob->pose->chanbase) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           /* If the 2.7 flag is enabled, processing is needed. */ | 
					
						
							|  |  |  |           if (pchan->bone && (pchan->bboneflag & PCHAN_BBONE_CUSTOM_HANDLES)) { | 
					
						
							|  |  |  |             /* If the settings in the Bone are not set, copy. */ | 
					
						
							|  |  |  |             if (pchan->bone->bbone_prev_type == BBONE_HANDLE_AUTO && | 
					
						
							|  |  |  |                 pchan->bone->bbone_next_type == BBONE_HANDLE_AUTO && | 
					
						
							|  |  |  |                 pchan->bone->bbone_prev == NULL && pchan->bone->bbone_next == NULL) { | 
					
						
							|  |  |  |               pchan->bone->bbone_prev_type = (pchan->bboneflag & PCHAN_BBONE_CUSTOM_START_REL) ? | 
					
						
							|  |  |  |                                                  BBONE_HANDLE_RELATIVE : | 
					
						
							|  |  |  |                                                  BBONE_HANDLE_ABSOLUTE; | 
					
						
							|  |  |  |               pchan->bone->bbone_next_type = (pchan->bboneflag & PCHAN_BBONE_CUSTOM_END_REL) ? | 
					
						
							|  |  |  |                                                  BBONE_HANDLE_RELATIVE : | 
					
						
							|  |  |  |                                                  BBONE_HANDLE_ABSOLUTE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               if (pchan->bbone_prev) { | 
					
						
							|  |  |  |                 pchan->bone->bbone_prev = pchan->bbone_prev->bone; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               if (pchan->bbone_next) { | 
					
						
							|  |  |  |                 pchan->bone->bbone_next = pchan->bbone_next->bone; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             rebuild = true; | 
					
						
							|  |  |  |             pchan->bboneflag = 0; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Tag pose rebuild for all objects that use this armature. */ | 
					
						
							|  |  |  |         if (rebuild) { | 
					
						
							|  |  |  |           for (Object *ob2 = bmain->objects.first; ob2; ob2 = ob2->id.next) { | 
					
						
							|  |  |  |             if (ob2->pose && ob2->data == arm) { | 
					
						
							|  |  |  |               ob2->pose->flag |= POSE_RECALC; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 30)) { | 
					
						
							|  |  |  |     for (Brush *brush = bmain->brushes.first; brush; brush = brush->id.next) { | 
					
						
							|  |  |  |       if (brush->gpencil_settings != NULL) { | 
					
						
							|  |  |  |         brush->gpencil_tool = brush->gpencil_settings->brush_type; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     BKE_paint_toolslots_init_from_main(bmain); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 38)) { | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  |     /* Ensure we get valid rigidbody object/constraint data in relevant collections' objects.
 | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       RigidBodyWorld *rbw = scene->rigidbody_world; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (rbw == NULL) { | 
					
						
							|  |  |  |         continue; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       BKE_rigidbody_objects_collection_validate(scene, rbw); | 
					
						
							|  |  |  |       BKE_rigidbody_constraints_collection_validate(scene, rbw); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-05-17 22:28:49 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 69)) { | 
					
						
							|  |  |  |     /* Unify DOF settings (EEVEE part only) */ | 
					
						
							|  |  |  |     const int SCE_EEVEE_DOF_ENABLED = (1 << 7); | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |       if (STREQ(scene->r.engine, RE_engine_id_BLENDER_EEVEE)) { | 
					
						
							|  |  |  |         if (scene->eevee.flag & SCE_EEVEE_DOF_ENABLED) { | 
					
						
							|  |  |  |           Object *cam_ob = scene->camera; | 
					
						
							|  |  |  |           if (cam_ob && cam_ob->type == OB_CAMERA) { | 
					
						
							|  |  |  |             Camera *cam = cam_ob->data; | 
					
						
							|  |  |  |             cam->dof.flag |= CAM_DOF_ENABLED; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Camera *, camera, &bmain->cameras) { | 
					
						
							|  |  |  |       camera->dof.focus_object = camera->dof_ob; | 
					
						
							|  |  |  |       camera->dof.focus_distance = camera->dof_distance; | 
					
						
							|  |  |  |       camera->dof.aperture_fstop = camera->gpu_dof.fstop; | 
					
						
							|  |  |  |       camera->dof.aperture_rotation = camera->gpu_dof.rotation; | 
					
						
							|  |  |  |       camera->dof.aperture_ratio = camera->gpu_dof.ratio; | 
					
						
							|  |  |  |       camera->dof.aperture_blades = camera->gpu_dof.num_blades; | 
					
						
							|  |  |  |       camera->dof_ob = NULL; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-08-13 00:11:36 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 2)) { | 
					
						
							|  |  |  |     /* Replace Multiply and Additive blend mode by Alpha Blend
 | 
					
						
							|  |  |  |      * now that we use dualsource blending. */ | 
					
						
							|  |  |  |     /* We take care of doing only nodetrees that are always part of materials
 | 
					
						
							|  |  |  |      * with old blending modes. */ | 
					
						
							|  |  |  |     for (Material *ma = bmain->materials.first; ma; ma = ma->id.next) { | 
					
						
							|  |  |  |       bNodeTree *ntree = ma->nodetree; | 
					
						
							|  |  |  |       if (ma->blend_method == 1 /* MA_BM_ADD */) { | 
					
						
							|  |  |  |         if (ma->use_nodes) { | 
					
						
							| 
									
										
										
										
											2019-08-16 16:41:59 +02:00
										 |  |  |           do_versions_material_convert_legacy_blend_mode(ntree, 1 /* MA_BM_ADD */); | 
					
						
							| 
									
										
										
										
											2019-08-13 00:11:36 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         ma->blend_method = MA_BM_BLEND; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (ma->blend_method == 2 /* MA_BM_MULTIPLY */) { | 
					
						
							|  |  |  |         if (ma->use_nodes) { | 
					
						
							| 
									
										
										
										
											2019-08-16 16:41:59 +02:00
										 |  |  |           do_versions_material_convert_legacy_blend_mode(ntree, 2 /* MA_BM_MULTIPLY */); | 
					
						
							| 
									
										
										
										
											2019-08-13 00:11:36 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |         ma->blend_method = MA_BM_BLEND; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-10-10 08:11:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-05 16:18:17 +01:00
										 |  |  |     /* Update all ruler layers to set new flag. */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |       bGPdata *gpd = scene->gpd; | 
					
						
							|  |  |  |       if (gpd == NULL) { | 
					
						
							|  |  |  |         continue; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |       LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) { | 
					
						
							| 
									
										
										
										
											2020-02-05 16:18:17 +01:00
										 |  |  |         if (STREQ(gpl->info, "RulerData3D")) { | 
					
						
							|  |  |  |           gpl->flag |= GP_LAYER_IS_RULER; | 
					
						
							|  |  |  |           break; | 
					
						
							| 
									
										
										
										
											2019-10-10 08:11:47 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-05 16:18:17 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-10 10:33:00 +11:00
										 |  |  |     /* This versioning could probably be done only on earlier versions, not sure however
 | 
					
						
							| 
									
										
										
										
											2020-02-05 16:18:17 +01:00
										 |  |  |      * which exact version fully deprecated tessfaces, so think we can keep that one here, no | 
					
						
							|  |  |  |      * harm to be expected anyway for being over-conservative. */ | 
					
						
							|  |  |  |     for (Mesh *me = bmain->meshes.first; me != NULL; me = me->id.next) { | 
					
						
							|  |  |  |       /*check if we need to convert mfaces to mpolys*/ | 
					
						
							|  |  |  |       if (me->totface && !me->totpoly) { | 
					
						
							|  |  |  |         /* temporarily switch main so that reading from
 | 
					
						
							|  |  |  |          * external CustomData works */ | 
					
						
							|  |  |  |         Main *gmain = G_MAIN; | 
					
						
							|  |  |  |         G_MAIN = bmain; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         BKE_mesh_do_versions_convert_mfaces_to_mpolys(me); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         G_MAIN = gmain; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Deprecated, only kept for conversion. */ | 
					
						
							|  |  |  |       BKE_mesh_tessface_clear(me); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Moved from do_versions because we need updated polygons for calculating normals. */ | 
					
						
							|  |  |  |       if (MAIN_VERSION_OLDER(bmain, 256, 6)) { | 
					
						
							|  |  |  |         BKE_mesh_calc_normals(me); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-08-13 00:11:36 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-01-14 17:08:22 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 282, 2)) { | 
					
						
							|  |  |  |     /* Init all Vertex/Sculpt and Weight Paint brushes. */ | 
					
						
							| 
									
										
										
										
											2020-04-18 13:15:51 +02:00
										 |  |  |     Brush *brush; | 
					
						
							| 
									
										
										
										
											2020-04-18 16:09:22 +02:00
										 |  |  |     Material *ma; | 
					
						
							| 
									
										
										
										
											2020-04-18 13:15:51 +02:00
										 |  |  |     /* Pen Soft brush. */ | 
					
						
							|  |  |  |     brush = (Brush *)rename_id_for_versioning(bmain, ID_BR, "Draw Soft", "Pencil Soft"); | 
					
						
							|  |  |  |     if (brush) { | 
					
						
							|  |  |  |       brush->gpencil_settings->icon_id = GP_BRUSH_ICON_PEN; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     rename_id_for_versioning(bmain, ID_BR, "Draw Pencil", "Pencil"); | 
					
						
							|  |  |  |     rename_id_for_versioning(bmain, ID_BR, "Draw Pen", "Pen"); | 
					
						
							|  |  |  |     rename_id_for_versioning(bmain, ID_BR, "Draw Ink", "Ink Pen"); | 
					
						
							|  |  |  |     rename_id_for_versioning(bmain, ID_BR, "Draw Noise", "Ink Pen Rough"); | 
					
						
							|  |  |  |     rename_id_for_versioning(bmain, ID_BR, "Draw Marker", "Marker Bold"); | 
					
						
							|  |  |  |     rename_id_for_versioning(bmain, ID_BR, "Draw Block", "Marker Chisel"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 16:09:22 +02:00
										 |  |  |     ma = BLI_findstring(&bmain->materials, "Black", offsetof(ID, name) + 2); | 
					
						
							|  |  |  |     if (ma && ma->gp_style) { | 
					
						
							|  |  |  |       rename_id_for_versioning(bmain, ID_MA, "Black", "Solid Stroke"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     ma = BLI_findstring(&bmain->materials, "Red", offsetof(ID, name) + 2); | 
					
						
							|  |  |  |     if (ma && ma->gp_style) { | 
					
						
							|  |  |  |       rename_id_for_versioning(bmain, ID_MA, "Red", "Squares Stroke"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     ma = BLI_findstring(&bmain->materials, "Grey", offsetof(ID, name) + 2); | 
					
						
							|  |  |  |     if (ma && ma->gp_style) { | 
					
						
							|  |  |  |       rename_id_for_versioning(bmain, ID_MA, "Grey", "Solid Fill"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     ma = BLI_findstring(&bmain->materials, "Black Dots", offsetof(ID, name) + 2); | 
					
						
							|  |  |  |     if (ma && ma->gp_style) { | 
					
						
							|  |  |  |       rename_id_for_versioning(bmain, ID_MA, "Black Dots", "Dots Stroke"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-18 13:15:51 +02:00
										 |  |  |     /* Remove useless Fill Area.001 brush. */ | 
					
						
							|  |  |  |     brush = BLI_findstring(&bmain->brushes, "Fill Area.001", offsetof(ID, name) + 2); | 
					
						
							|  |  |  |     if (brush) { | 
					
						
							|  |  |  |       BKE_id_delete(bmain, brush); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     brush = BLI_findstring(&bmain->brushes, "Pencil", offsetof(ID, name) + 2); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       ToolSettings *ts = scene->toolsettings; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       BKE_brush_gpencil_vertex_presets(bmain, ts); | 
					
						
							|  |  |  |       BKE_brush_gpencil_sculpt_presets(bmain, ts); | 
					
						
							|  |  |  |       BKE_brush_gpencil_weight_presets(bmain, ts); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Ensure new Paint modes. */ | 
					
						
							|  |  |  |       BKE_paint_ensure_from_paintmode(scene, PAINT_MODE_GPENCIL); | 
					
						
							|  |  |  |       BKE_paint_ensure_from_paintmode(scene, PAINT_MODE_VERTEX_GPENCIL); | 
					
						
							|  |  |  |       BKE_paint_ensure_from_paintmode(scene, PAINT_MODE_SCULPT_GPENCIL); | 
					
						
							|  |  |  |       BKE_paint_ensure_from_paintmode(scene, PAINT_MODE_WEIGHT_GPENCIL); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Set default Draw brush. */ | 
					
						
							|  |  |  |       if (brush != NULL) { | 
					
						
							|  |  |  |         Paint *paint = &ts->gp_paint->paint; | 
					
						
							|  |  |  |         BKE_paint_brush_set(paint, brush); | 
					
						
							|  |  |  |         /* Enable cursor by default. */ | 
					
						
							|  |  |  |         paint->flags |= PAINT_SHOW_BRUSH; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       /* Ensure Palette by default. */ | 
					
						
							|  |  |  |       BKE_gpencil_palette_ensure(bmain, scene); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-10 15:41:29 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 8)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* During development of Blender 2.80 the "Object.hide" property was
 | 
					
						
							|  |  |  |      * removed, and reintroduced in 5e968a996a53 as "Object.hide_viewport". */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |       BKE_fcurves_id_cb(&ob->id, do_version_fcurve_hide_viewport_fix, NULL); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-04-16 15:53:03 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Reset all grease pencil brushes. */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |       BKE_brush_gpencil_paint_presets(bmain, scene->toolsettings); | 
					
						
							|  |  |  |       BKE_brush_gpencil_sculpt_presets(bmain, scene->toolsettings); | 
					
						
							|  |  |  |       BKE_brush_gpencil_weight_presets(bmain, scene->toolsettings); | 
					
						
							|  |  |  |       BKE_brush_gpencil_vertex_presets(bmain, scene->toolsettings); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Ensure new Paint modes. */ | 
					
						
							|  |  |  |       BKE_paint_ensure_from_paintmode(scene, PAINT_MODE_VERTEX_GPENCIL); | 
					
						
							|  |  |  |       BKE_paint_ensure_from_paintmode(scene, PAINT_MODE_SCULPT_GPENCIL); | 
					
						
							|  |  |  |       BKE_paint_ensure_from_paintmode(scene, PAINT_MODE_WEIGHT_GPENCIL); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-10 15:41:29 +01:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-14 17:10:28 +01:00
										 |  |  |   /**
 | 
					
						
							|  |  |  |    * Versioning code until next subversion bump goes here. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * \note Be sure to check when bumping the version: | 
					
						
							| 
									
										
										
										
											2020-03-10 16:17:49 +01:00
										 |  |  |    * - #blo_do_versions_280 in this file. | 
					
						
							| 
									
										
										
										
											2020-01-14 17:10:28 +01:00
										 |  |  |    * - "versioning_userdef.c", #BLO_version_defaults_userpref_blend | 
					
						
							|  |  |  |    * - "versioning_userdef.c", #do_versions_theme | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * \note Keep this message at the bottom of the function. | 
					
						
							|  |  |  |    */ | 
					
						
							| 
									
										
										
										
											2020-01-14 17:08:22 +01:00
										 |  |  |   { | 
					
						
							| 
									
										
										
										
											2020-01-14 17:10:28 +01:00
										 |  |  |     /* Keep this block, even when empty. */ | 
					
						
							| 
									
										
										
										
											2020-01-14 17:08:22 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-12-14 11:46:49 -02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-22 01:10:29 +10:00
										 |  |  | /* NOTE: This version patch is intended for versions < 2.52.2,
 | 
					
						
							|  |  |  |  * but was initially introduced in 2.27 already. | 
					
						
							|  |  |  |  * But in 2.79 another case generating non-unique names was discovered | 
					
						
							|  |  |  |  * (see T55668, involving Meta strips). */ | 
					
						
							| 
									
										
										
										
											2018-07-23 17:52:52 +02:00
										 |  |  | static void do_versions_seq_unique_name_all_strips(Scene *sce, ListBase *seqbasep) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   for (Sequence *seq = seqbasep->first; seq != NULL; seq = seq->next) { | 
					
						
							|  |  |  |     BKE_sequence_base_unique_name_recursive(&sce->ed->seqbase, seq); | 
					
						
							|  |  |  |     if (seq->seqbase.first != NULL) { | 
					
						
							|  |  |  |       do_versions_seq_unique_name_all_strips(sce, &seq->seqbase); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2018-07-23 17:52:52 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 14:13:41 -07:00
										 |  |  | static void do_versions_seq_set_cache_defaults(Editing *ed) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  |   ed->cache_flag = SEQ_CACHE_STORE_FINAL_OUT; | 
					
						
							|  |  |  |   ed->cache_flag |= SEQ_CACHE_VIEW_FINAL_OUT; | 
					
						
							|  |  |  |   ed->cache_flag |= SEQ_CACHE_VIEW_ENABLE; | 
					
						
							|  |  |  |   ed->recycle_max_cost = 10.0f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-06-05 17:02:50 +02:00
										 |  |  | void blo_do_versions_280(FileData *fd, Library *UNUSED(lib), Main *bmain) | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   bool use_collection_compat_28 = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 0)) { | 
					
						
							|  |  |  |     use_collection_compat_28 = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       scene->r.gauss = 1.5f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 1)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Light", "float", "bleedexp")) { | 
					
						
							|  |  |  |       for (Light *la = bmain->lights.first; la; la = la->id.next) { | 
					
						
							|  |  |  |         la->bleedexp = 2.5f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "GPUDOFSettings", "float", "ratio")) { | 
					
						
							|  |  |  |       for (Camera *ca = bmain->cameras.first; ca; ca = ca->id.next) { | 
					
						
							|  |  |  |         ca->gpu_dof.ratio = 1.0f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* MTexPoly now removed. */ | 
					
						
							|  |  |  |     if (DNA_struct_find(fd->filesdna, "MTexPoly")) { | 
					
						
							|  |  |  |       for (Mesh *me = bmain->meshes.first; me; me = me->id.next) { | 
					
						
							|  |  |  |         /* If we have UV's, so this file will have MTexPoly layers too! */ | 
					
						
							|  |  |  |         if (me->mloopuv != NULL) { | 
					
						
							|  |  |  |           CustomData_update_typemap(&me->pdata); | 
					
						
							| 
									
										
										
										
											2019-07-03 15:43:05 +02:00
										 |  |  |           CustomData_free_layers(&me->pdata, CD_MTEXPOLY, me->totpoly); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           BKE_mesh_update_customdata_pointers(me, false); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 2)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Light", "float", "cascade_max_dist")) { | 
					
						
							|  |  |  |       for (Light *la = bmain->lights.first; la; la = la->id.next) { | 
					
						
							|  |  |  |         la->cascade_max_dist = 1000.0f; | 
					
						
							|  |  |  |         la->cascade_count = 4; | 
					
						
							|  |  |  |         la->cascade_exponent = 0.8f; | 
					
						
							|  |  |  |         la->cascade_fade = 0.1f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Light", "float", "contact_dist")) { | 
					
						
							|  |  |  |       for (Light *la = bmain->lights.first; la; la = la->id.next) { | 
					
						
							|  |  |  |         la->contact_dist = 0.2f; | 
					
						
							|  |  |  |         la->contact_bias = 0.03f; | 
					
						
							|  |  |  |         la->contact_spread = 0.2f; | 
					
						
							|  |  |  |         la->contact_thickness = 0.2f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "LightProbe", "float", "vis_bias")) { | 
					
						
							|  |  |  |       for (LightProbe *probe = bmain->lightprobes.first; probe; probe = probe->id.next) { | 
					
						
							|  |  |  |         probe->vis_bias = 1.0f; | 
					
						
							|  |  |  |         probe->vis_blur = 0.2f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     typedef enum eNTreeDoVersionErrors { | 
					
						
							|  |  |  |       NTREE_DOVERSION_NO_ERROR = 0, | 
					
						
							|  |  |  |       NTREE_DOVERSION_NEED_OUTPUT = (1 << 0), | 
					
						
							|  |  |  |       NTREE_DOVERSION_TRANSPARENCY_EMISSION = (1 << 1), | 
					
						
							|  |  |  |     } eNTreeDoVersionErrors; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Eevee shader nodes renamed because of the output node system.
 | 
					
						
							|  |  |  |      * Note that a new output node is not being added here, because it would be overkill | 
					
						
							|  |  |  |      * to handle this case in lib_verify_nodetree. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * Also, metallic node is now unified into the principled node. */ | 
					
						
							|  |  |  |     eNTreeDoVersionErrors error = NTREE_DOVERSION_NO_ERROR; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     FOREACH_NODETREE_BEGIN (bmain, ntree, id) { | 
					
						
							|  |  |  |       if (ntree->type == NTREE_SHADER) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (bNode *, node, &ntree->nodes) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (node->type == 194 /* SH_NODE_EEVEE_METALLIC */ && | 
					
						
							|  |  |  |               STREQ(node->idname, "ShaderNodeOutputMetallic")) { | 
					
						
							|  |  |  |             BLI_strncpy(node->idname, "ShaderNodeEeveeMetallic", sizeof(node->idname)); | 
					
						
							|  |  |  |             error |= NTREE_DOVERSION_NEED_OUTPUT; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           else if (node->type == SH_NODE_EEVEE_SPECULAR && | 
					
						
							|  |  |  |                    STREQ(node->idname, "ShaderNodeOutputSpecular")) { | 
					
						
							|  |  |  |             BLI_strncpy(node->idname, "ShaderNodeEeveeSpecular", sizeof(node->idname)); | 
					
						
							|  |  |  |             error |= NTREE_DOVERSION_NEED_OUTPUT; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           else if (node->type == 196 /* SH_NODE_OUTPUT_EEVEE_MATERIAL */ && | 
					
						
							|  |  |  |                    STREQ(node->idname, "ShaderNodeOutputEeveeMaterial")) { | 
					
						
							|  |  |  |             node->type = SH_NODE_OUTPUT_MATERIAL; | 
					
						
							|  |  |  |             BLI_strncpy(node->idname, "ShaderNodeOutputMaterial", sizeof(node->idname)); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           else if (node->type == 194 /* SH_NODE_EEVEE_METALLIC */ && | 
					
						
							|  |  |  |                    STREQ(node->idname, "ShaderNodeEeveeMetallic")) { | 
					
						
							|  |  |  |             node->type = SH_NODE_BSDF_PRINCIPLED; | 
					
						
							|  |  |  |             BLI_strncpy(node->idname, "ShaderNodeBsdfPrincipled", sizeof(node->idname)); | 
					
						
							|  |  |  |             node->custom1 = SHD_GLOSSY_MULTI_GGX; | 
					
						
							|  |  |  |             error |= NTREE_DOVERSION_TRANSPARENCY_EMISSION; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     FOREACH_NODETREE_END; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (error & NTREE_DOVERSION_NEED_OUTPUT) { | 
					
						
							|  |  |  |       BKE_report(fd->reports, RPT_ERROR, "Eevee material conversion problem. Error in console"); | 
					
						
							|  |  |  |       printf( | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  |           "You need to connect Principled and Eevee Specular shader nodes to new material " | 
					
						
							|  |  |  |           "output " | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           "nodes.\n"); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (error & NTREE_DOVERSION_TRANSPARENCY_EMISSION) { | 
					
						
							|  |  |  |       BKE_report(fd->reports, RPT_ERROR, "Eevee material conversion problem. Error in console"); | 
					
						
							|  |  |  |       printf( | 
					
						
							|  |  |  |           "You need to combine transparency and emission shaders to the converted Principled " | 
					
						
							|  |  |  |           "shader nodes.\n"); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2017-10-16 17:15:03 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | #ifdef USE_COLLECTION_COMPAT_28
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (use_collection_compat_28 && | 
					
						
							|  |  |  |         (DNA_struct_elem_find(fd->filesdna, "ViewLayer", "FreestyleConfig", "freestyle_config") == | 
					
						
							|  |  |  |          false) && | 
					
						
							|  |  |  |         DNA_struct_elem_find(fd->filesdna, "Scene", "ListBase", "view_layers")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         ViewLayer *view_layer; | 
					
						
							|  |  |  |         for (view_layer = scene->view_layers.first; view_layer; view_layer = view_layer->next) { | 
					
						
							|  |  |  |           view_layer->flag |= VIEW_LAYER_FREESTYLE; | 
					
						
							|  |  |  |           view_layer->layflag = 0x7FFF; /* solid ztra halo edge strand */ | 
					
						
							|  |  |  |           view_layer->passflag = SCE_PASS_COMBINED | SCE_PASS_Z; | 
					
						
							|  |  |  |           view_layer->pass_alpha_threshold = 0.5f; | 
					
						
							|  |  |  |           BKE_freestyle_config_init(&view_layer->freestyle_config); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2018-07-31 10:22:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     { | 
					
						
							|  |  |  |       /* Init grease pencil edit line color */ | 
					
						
							|  |  |  |       if (!DNA_struct_elem_find(fd->filesdna, "bGPdata", "float", "line_color[4]")) { | 
					
						
							|  |  |  |         for (bGPdata *gpd = bmain->gpencils.first; gpd; gpd = gpd->id.next) { | 
					
						
							|  |  |  |           ARRAY_SET_ITEMS(gpd->line_color, 0.6f, 0.6f, 0.6f, 0.5f); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Init grease pencil pixel size factor */ | 
					
						
							|  |  |  |       if (!DNA_struct_elem_find(fd->filesdna, "bGPdata", "float", "pixfactor")) { | 
					
						
							|  |  |  |         for (bGPdata *gpd = bmain->gpencils.first; gpd; gpd = gpd->id.next) { | 
					
						
							|  |  |  |           gpd->pixfactor = GP_DEFAULT_PIX_FACTOR; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Grease pencil multiframe falloff curve */ | 
					
						
							|  |  |  |       if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |               fd->filesdna, "GP_Sculpt_Settings", "CurveMapping", "cur_falloff")) { | 
					
						
							|  |  |  |         for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |           /* sculpt brushes */ | 
					
						
							|  |  |  |           GP_Sculpt_Settings *gset = &scene->toolsettings->gp_sculpt; | 
					
						
							|  |  |  |           if ((gset) && (gset->cur_falloff == NULL)) { | 
					
						
							| 
									
										
										
										
											2019-08-07 03:21:55 +10:00
										 |  |  |             gset->cur_falloff = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |             BKE_curvemapping_initialize(gset->cur_falloff); | 
					
						
							|  |  |  |             BKE_curvemap_reset(gset->cur_falloff->cm, | 
					
						
							|  |  |  |                                &gset->cur_falloff->clipr, | 
					
						
							|  |  |  |                                CURVE_PRESET_GAUSS, | 
					
						
							|  |  |  |                                CURVEMAP_SLOPE_POSITIVE); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
											  
											
												Maintain Volume: introduce an option switching between modes.
After a lot of thinking about this, I decided that all operation modes
that I've tried over the past couple of years, including the original
2.79 one, have their uses after all. Thus the only reasonable solution
is to add yet another option.
The modes are:
- Strict: The current 2.80 mode, which overrides the original scaling
  of the non-free axes to strictly preserve the volume. This is the most
  obvious way one would expect a 'Maintain Volume' constraint to work.
- Uniform: The original 2.79 mode, which assumes that all axes have been
  scaled the same as the free one when computing the volume. This seems
  strange, but the net effect is that when simply scaling the object
  uniformly with S, the volume is preserved; however, scaling the non-
  free axes individually allows deviating from the locked volume.
  This was obviously intended as a more or less convenient UI tool.
- Single Axis: My own variant of the intent of the Uniform scale, which
  does volume-preserving if the object is scaled just on the Free axis,
  while passing the non-free axis scaling through. I.e. instead of
  uniform S scaling, the user has to scale the object just on its
  primary axis to achieve constant volume. This can allow reducing the
  number of animation curves when only constant volume scaling is needed,
  or be an easier to control tool inside a complex rig.
											
										 
											2019-05-06 21:47:51 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* 2.79 style Maintain Volume mode. */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |       do_version_constraints_maintain_volume_mode_uniform(&ob->constraints); | 
					
						
							|  |  |  |       if (ob->pose) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (bPoseChannel *, pchan, &ob->pose->chanbase) { | 
					
						
							|  |  |  |           do_version_constraints_maintain_volume_mode_uniform(&pchan->constraints); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2017-12-14 11:46:49 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | #ifdef USE_COLLECTION_COMPAT_28
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (use_collection_compat_28 && !MAIN_VERSION_ATLEAST(bmain, 280, 3)) { | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       ViewLayer *view_layer; | 
					
						
							|  |  |  |       for (view_layer = scene->view_layers.first; view_layer; view_layer = view_layer->next) { | 
					
						
							|  |  |  |         do_version_view_layer_visibility(view_layer); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Collection *group = bmain->collections.first; group; group = group->id.next) { | 
					
						
							|  |  |  |       if (group->view_layer != NULL) { | 
					
						
							|  |  |  |         do_version_view_layer_visibility(group->view_layer); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
											  
											
												Collections and groups unification
OVERVIEW
* In 2.7 terminology, all layers and groups are now collection datablocks.
* These collections are nestable, linkable, instanceable, overrideable, ..
  which opens up new ways to set up scenes and link + override data.
* Viewport/render visibility and selectability are now a part of the collection
  and shared across all view layers and linkable.
* View layers define which subset of the scene collection hierarchy is excluded
  for each. For many workflows one view layer can be used, these are more of an
  advanced feature now.
OUTLINER
* The outliner now has a "View Layer" display mode instead of "Collections",
  which can display the collections and/or objects in the view layer.
* In this display mode, collections can be excluded with the right click menu.
  These will then be greyed out and their objects will be excluded.
* To view collections not linked to any scene, the "Blender File" display mode
  can be used, with the new filtering option to just see Colleciton datablocks.
* The outliner right click menus for collections and objects were reorganized.
* Drag and drop still needs to be improved. Like before, dragging the icon or
  text gives different results, we'll unify this later.
LINKING AND OVERRIDES
* Collections can now be linked into the scene without creating an instance,
  with the link/append operator or from the collections view in the outliner.
* Collections can get static overrides with the right click menu in the outliner,
  but this is rather unreliable and not clearly communicated at the moment.
* We still need to improve the make override operator to turn collection instances
  into collections with overrides directly in the scene.
PERFORMANCE
* We tried to make performance not worse than before and improve it in some
  cases. The main thing that's still a bit slower is multiple scenes, we have to
  change the layer syncing to only updated affected scenes.
* Collections keep a list of their parent collections for faster incremental
  updates in syncing and caching.
* View layer bases are now in a object -> base hash to avoid quadratic time
  lookups internally and in API functions like visible_get().
VERSIONING
* Compatibility with 2.7 files should be improved due to the new visibility
  controls. Of course users may not want to set up their scenes differently
  now to avoid having separate layers and groups.
* Compatibility with 2.8 is mostly there, and was tested on Eevee demo and Hero
  files. There's a few things which are know to be not quite compatible, like
  nested layer collections inside groups.
* The versioning code for 2.8 files is quite complicated, and isolated behind
  #ifdef so it can be removed at the end of the release cycle.
KNOWN ISSUES
* The G-key group operators in the 3D viewport were left mostly as is, they
  need to be modified still to fit better.
* Same for the groups panel in the object properties. This needs to be updated
  still, or perhaps replaced by something better.
* Collections must all have a unique name. Less restrictive namespacing is to
  be done later, we'll have to see how important this is as all objects within
  the collections must also have a unique name anyway.
* Full scene copy and delete scene are exactly doing the right thing yet.
Differential Revision: https://developer.blender.org/D3383
https://code.blender.org/2018/05/collections-and-groups/
											
										 
											2018-04-30 15:57:22 +02:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
											  
											
												Outliner Filtering System + Cleanup
User notes:
The outliner so far was a great system to handle the object oriented workflow
we had in Blender prior to 2.8. However with the introduction of collections
the bloated ammount of data we were exposed at a given time was eventually
getting on the way of fully utilizing the outliner to manage collections and
their objects.
We hope that with this filtering system the user can put together the outliner
with whichever options he or she seem fit for a given task.
Features:
* Collection filter: In case users are only focused on objects.
* Object filter: Allow users to focus on collections only.
* (Object) content filter: Modifiers, mesh, contrainst, materials, ...
* (Object) children filter: Hide object children [1].
* Object State (visible, active, selected).
* Compact header: hide search options under a search toggle.
* Preserve scrolling position before/after filtering [2].
[1] - Note we still need to be able to tell if a children of an object is in a
      collection, or if the parent object is the only one in the collection.
      This in fact was one of the first motivations for this patch. But it is to
      be addressed separately now that we can at least hide children away.
[2] - We look at the top-most collection in the outliner, and try to find it again
      after the filtering and make sure it is in the same position as before.
      This works nice now. But to work REALLY, REALLY nice we need to also store
      the previous filter options to be sure the element we try to keep on top
      was valid for both old and new filters. I would rather do this later though
      since this smell a lot like feature creeping ;)
Remove no longer needed display options:
 * Current Scene (replaced by View Layer/Collections)
 * Visible (replaced by filter)
 * Selected (same)
 * Active (same)
 * Same Type (same-ish)
How about All Scenes? I have a patch that will come next to replace the current
behaviour and focus only on compositing. So basically stop showing the objects
and show only view layers, their passes and collections, besides freestyle.
Also, while at this I'm also reorganizing the menu to keep View Layer and
Collections on top.
Developer notes:
* Unlike the per-object filtering, for collections we need to filter at tree
creation time, to prevent duplication of objects in the outliner.
Acknowledgements:
Thanks Pablo Vazquez for helping testing, thinking some design questions
together and pushing this to its final polished state as you see here.
Thanks Sergey Sharybin and Julian Eisel for code review. Julian couldn't do a
final review pass after I addressed his concerns. So blame is on me for any
issue I may be introducing here. Sergey was the author of the "preserve
scrolling position" idea. I'm happy with how it is working, thank you.
Reviewers: sergey, Severin, venomgfx
Subscribers: lichtwerk, duarteframos
Differential Revision: https://developer.blender.org/D2992
											
										 
											2018-01-19 11:39:54 -02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 3)) { | 
					
						
							|  |  |  |     /* init grease pencil grids and paper */ | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DOverlay", "float", "gpencil_paper_color[3]")) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.gpencil_paper_opacity = 0.5f; | 
					
						
							|  |  |  |               v3d->overlay.gpencil_grid_opacity = 0.9f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 6)) { | 
					
						
							|  |  |  |     if (DNA_struct_elem_find(fd->filesdna, "SpaceOutliner", "int", "filter") == false) { | 
					
						
							| 
									
										
										
										
											2020-04-03 14:23:21 +02:00
										 |  |  |       bScreen *screen; | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |       ScrArea *area; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       SpaceLink *sl; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Update files using invalid (outdated) outlinevis Outliner values. */ | 
					
						
							| 
									
										
										
										
											2020-04-03 14:23:21 +02:00
										 |  |  |       for (screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							|  |  |  |         for (area = screen->areabase.first; area; area = area->next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |           for (sl = area->spacedata.first; sl; sl = sl->next) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_OUTLINER) { | 
					
						
							|  |  |  |               SpaceOutliner *so = (SpaceOutliner *)sl; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               if (!ELEM(so->outlinevis, | 
					
						
							|  |  |  |                         SO_SCENES, | 
					
						
							|  |  |  |                         SO_LIBRARIES, | 
					
						
							|  |  |  |                         SO_SEQUENCE, | 
					
						
							|  |  |  |                         SO_DATA_API, | 
					
						
							|  |  |  |                         SO_ID_ORPHANS)) { | 
					
						
							|  |  |  |                 so->outlinevis = SO_VIEW_LAYER; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "LightProbe", "float", "intensity")) { | 
					
						
							|  |  |  |       for (LightProbe *probe = bmain->lightprobes.first; probe; probe = probe->id.next) { | 
					
						
							|  |  |  |         probe->intensity = 1.0f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |       bConstraint *con, *con_next; | 
					
						
							|  |  |  |       con = ob->constraints.first; | 
					
						
							|  |  |  |       while (con) { | 
					
						
							|  |  |  |         con_next = con->next; | 
					
						
							|  |  |  |         if (con->type == 17) { /* CONSTRAINT_TYPE_RIGIDBODYJOINT */ | 
					
						
							|  |  |  |           BLI_remlink(&ob->constraints, con); | 
					
						
							|  |  |  |           BKE_constraint_free_data(con); | 
					
						
							|  |  |  |           MEM_freeN(con); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         con = con_next; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 14:23:21 +02:00
										 |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             v3d->shading.light = V3D_LIGHTING_STUDIO; | 
					
						
							|  |  |  |             v3d->shading.flag |= V3D_SHADING_OBJECT_OUTLINE; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /* Assume (demo) files written with 2.8 want to show
 | 
					
						
							|  |  |  |              * Eevee renders in the viewport. */ | 
					
						
							|  |  |  |             if (MAIN_VERSION_ATLEAST(bmain, 280, 0)) { | 
					
						
							|  |  |  |               v3d->drawtype = OB_MATERIAL; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 7)) { | 
					
						
							|  |  |  |     /* Render engine storage moved elsewhere and back during 2.8
 | 
					
						
							|  |  |  |      * development, we assume any files saved in 2.8 had Eevee set | 
					
						
							|  |  |  |      * as scene render engine. */ | 
					
						
							|  |  |  |     if (MAIN_VERSION_ATLEAST(bmain, 280, 0)) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         BLI_strncpy(scene->r.engine, RE_engine_id_BLENDER_EEVEE, sizeof(scene->r.engine)); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 8)) { | 
					
						
							|  |  |  |     /* Blender Internal removal */ | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       if (STREQ(scene->r.engine, "BLENDER_RENDER") || STREQ(scene->r.engine, "BLENDER_GAME")) { | 
					
						
							|  |  |  |         BLI_strncpy(scene->r.engine, RE_engine_id_BLENDER_EEVEE, sizeof(scene->r.engine)); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       scene->r.bake_mode = 0; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Tex *tex = bmain->textures.first; tex; tex = tex->id.next) { | 
					
						
							|  |  |  |       /* Removed envmap, pointdensity, voxeldata, ocean textures. */ | 
					
						
							|  |  |  |       if (ELEM(tex->type, 10, 14, 15, 16)) { | 
					
						
							|  |  |  |         tex->type = 0; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 11)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Remove info editor, but only if at the top of the window. */ | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							|  |  |  |       /* Calculate window width/height from screen vertices */ | 
					
						
							|  |  |  |       int win_width = 0, win_height = 0; | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrVert *, vert, &screen->vertbase) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         win_width = MAX2(win_width, vert->vec.x); | 
					
						
							|  |  |  |         win_height = MAX2(win_height, vert->vec.y); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (ScrArea *area = screen->areabase.first, *area_next; area; area = area_next) { | 
					
						
							|  |  |  |         area_next = area->next; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (area->spacetype == SPACE_INFO) { | 
					
						
							|  |  |  |           if ((area->v2->vec.y == win_height) && (area->v1->vec.x == 0) && | 
					
						
							|  |  |  |               (area->v4->vec.x == win_width)) { | 
					
						
							|  |  |  |             BKE_screen_area_free(area); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             BLI_remlink(&screen->areabase, area); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             BKE_screen_remove_double_scredges(screen); | 
					
						
							|  |  |  |             BKE_screen_remove_unused_scredges(screen); | 
					
						
							|  |  |  |             BKE_screen_remove_unused_scrverts(screen); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             MEM_freeN(area); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* AREA_TEMP_INFO is deprecated from now on, it should only be set for info areas
 | 
					
						
							|  |  |  |          * which are deleted above, so don't need to unset it. Its slot/bit can be reused */ | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 11)) { | 
					
						
							|  |  |  |     for (Light *la = bmain->lights.first; la; la = la->id.next) { | 
					
						
							|  |  |  |       if (la->mode & (1 << 13)) { /* LA_SHAD_RAY */ | 
					
						
							|  |  |  |         la->mode |= LA_SHADOW; | 
					
						
							|  |  |  |         la->mode &= ~(1 << 13); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 12)) { | 
					
						
							|  |  |  |     /* Remove tool property regions. */ | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (ELEM(sl->spacetype, SPACE_VIEW3D, SPACE_CLIP)) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             for (ARegion *region = regionbase->first, *region_next; region; region = region_next) { | 
					
						
							|  |  |  |               region_next = region->next; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               if (region->regiontype == RGN_TYPE_TOOL_PROPS) { | 
					
						
							|  |  |  |                 BKE_area_region_free(NULL, region); | 
					
						
							|  |  |  |                 BLI_freelinkN(regionbase, region); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 13)) { | 
					
						
							|  |  |  |     /* Initialize specular factor. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Light", "float", "spec_fac")) { | 
					
						
							|  |  |  |       for (Light *la = bmain->lights.first; la; la = la->id.next) { | 
					
						
							|  |  |  |         la->spec_fac = 1.0f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Initialize new view3D options. */ | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             v3d->shading.light = V3D_LIGHTING_STUDIO; | 
					
						
							|  |  |  |             v3d->shading.color_type = V3D_SHADING_MATERIAL_COLOR; | 
					
						
							|  |  |  |             copy_v3_fl(v3d->shading.single_color, 0.8f); | 
					
						
							|  |  |  |             v3d->shading.shadow_intensity = 0.5; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             v3d->overlay.backwire_opacity = 0.5f; | 
					
						
							|  |  |  |             v3d->overlay.normals_length = 0.1f; | 
					
						
							|  |  |  |             v3d->overlay.flag = 0; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 14)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Scene", "SceneDisplay", "display")) { | 
					
						
							|  |  |  |       /* Initialize new scene.SceneDisplay */ | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         copy_v3_v3(scene->display.light_direction, (float[3]){-M_SQRT1_3, -M_SQRT1_3, M_SQRT1_3}); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneDisplay", "float", "shadow_shift")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->display.shadow_shift = 0.1; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "ToolSettings", "char", "transform_pivot_point")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->toolsettings->transform_pivot_point = V3D_AROUND_CENTER_MEDIAN; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_find(fd->filesdna, "SceneEEVEE")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         /* First set the default for all the properties. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.gi_diffuse_bounces = 3; | 
					
						
							|  |  |  |         scene->eevee.gi_cubemap_resolution = 512; | 
					
						
							|  |  |  |         scene->eevee.gi_visibility_resolution = 32; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.taa_samples = 16; | 
					
						
							|  |  |  |         scene->eevee.taa_render_samples = 64; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.sss_samples = 7; | 
					
						
							|  |  |  |         scene->eevee.sss_jitter_threshold = 0.3f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.ssr_quality = 0.25f; | 
					
						
							|  |  |  |         scene->eevee.ssr_max_roughness = 0.5f; | 
					
						
							|  |  |  |         scene->eevee.ssr_thickness = 0.2f; | 
					
						
							|  |  |  |         scene->eevee.ssr_border_fade = 0.075f; | 
					
						
							|  |  |  |         scene->eevee.ssr_firefly_fac = 10.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.volumetric_start = 0.1f; | 
					
						
							|  |  |  |         scene->eevee.volumetric_end = 100.0f; | 
					
						
							|  |  |  |         scene->eevee.volumetric_tile_size = 8; | 
					
						
							|  |  |  |         scene->eevee.volumetric_samples = 64; | 
					
						
							|  |  |  |         scene->eevee.volumetric_sample_distribution = 0.8f; | 
					
						
							|  |  |  |         scene->eevee.volumetric_light_clamp = 0.0f; | 
					
						
							|  |  |  |         scene->eevee.volumetric_shadow_samples = 16; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.gtao_distance = 0.2f; | 
					
						
							|  |  |  |         scene->eevee.gtao_factor = 1.0f; | 
					
						
							|  |  |  |         scene->eevee.gtao_quality = 0.25f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.bokeh_max_size = 100.0f; | 
					
						
							|  |  |  |         scene->eevee.bokeh_threshold = 1.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         copy_v3_fl(scene->eevee.bloom_color, 1.0f); | 
					
						
							|  |  |  |         scene->eevee.bloom_threshold = 0.8f; | 
					
						
							|  |  |  |         scene->eevee.bloom_knee = 0.5f; | 
					
						
							|  |  |  |         scene->eevee.bloom_intensity = 0.05f; | 
					
						
							|  |  |  |         scene->eevee.bloom_radius = 6.5f; | 
					
						
							|  |  |  |         scene->eevee.bloom_clamp = 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.motion_blur_samples = 8; | 
					
						
							|  |  |  |         scene->eevee.motion_blur_shutter = 0.5f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.shadow_method = SHADOW_ESM; | 
					
						
							|  |  |  |         scene->eevee.shadow_cube_size = 512; | 
					
						
							|  |  |  |         scene->eevee.shadow_cascade_size = 1024; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         scene->eevee.flag = SCE_EEVEE_VOLUMETRIC_LIGHTS | SCE_EEVEE_GTAO_BENT_NORMALS | | 
					
						
							|  |  |  |                             SCE_EEVEE_GTAO_BOUNCE | SCE_EEVEE_TAA_REPROJECTION | | 
					
						
							|  |  |  |                             SCE_EEVEE_SSR_HALF_RESOLUTION; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* If the file is pre-2.80 move on. */ | 
					
						
							|  |  |  |         if (scene->layer_properties == NULL) { | 
					
						
							|  |  |  |           continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Now we handle eventual properties that may be set in the file. */ | 
					
						
							| 
									
										
										
										
											2018-05-16 19:34:24 +02:00
										 |  |  | #define EEVEE_GET_BOOL(_props, _name, _flag) \
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   { \ | 
					
						
							|  |  |  |     IDProperty *_idprop = IDP_GetPropertyFromGroup(_props, #_name); \ | 
					
						
							|  |  |  |     if (_idprop != NULL) { \ | 
					
						
							|  |  |  |       const int _value = IDP_Int(_idprop); \ | 
					
						
							|  |  |  |       if (_value) { \ | 
					
						
							|  |  |  |         scene->eevee.flag |= _flag; \ | 
					
						
							|  |  |  |       } \ | 
					
						
							|  |  |  |       else { \ | 
					
						
							|  |  |  |         scene->eevee.flag &= ~_flag; \ | 
					
						
							|  |  |  |       } \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |   } \ | 
					
						
							|  |  |  |   ((void)0) | 
					
						
							| 
									
										
										
										
											2018-05-16 19:34:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define EEVEE_GET_INT(_props, _name) \
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   { \ | 
					
						
							|  |  |  |     IDProperty *_idprop = IDP_GetPropertyFromGroup(_props, #_name); \ | 
					
						
							|  |  |  |     if (_idprop != NULL) { \ | 
					
						
							|  |  |  |       scene->eevee._name = IDP_Int(_idprop); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |   } \ | 
					
						
							|  |  |  |   ((void)0) | 
					
						
							| 
									
										
										
										
											2018-05-16 19:34:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define EEVEE_GET_FLOAT(_props, _name) \
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   { \ | 
					
						
							|  |  |  |     IDProperty *_idprop = IDP_GetPropertyFromGroup(_props, #_name); \ | 
					
						
							|  |  |  |     if (_idprop != NULL) { \ | 
					
						
							|  |  |  |       scene->eevee._name = IDP_Float(_idprop); \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |   } \ | 
					
						
							|  |  |  |   ((void)0) | 
					
						
							| 
									
										
										
										
											2018-05-16 19:34:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define EEVEE_GET_FLOAT_ARRAY(_props, _name, _length) \
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   { \ | 
					
						
							|  |  |  |     IDProperty *_idprop = IDP_GetPropertyFromGroup(_props, #_name); \ | 
					
						
							|  |  |  |     if (_idprop != NULL) { \ | 
					
						
							|  |  |  |       const float *_values = IDP_Array(_idprop); \ | 
					
						
							|  |  |  |       for (int _i = 0; _i < _length; _i++) { \ | 
					
						
							|  |  |  |         scene->eevee._name[_i] = _values[_i]; \ | 
					
						
							|  |  |  |       } \ | 
					
						
							|  |  |  |     } \ | 
					
						
							|  |  |  |   } \ | 
					
						
							|  |  |  |   ((void)0) | 
					
						
							| 
									
										
										
										
											2019-05-17 16:57:31 +02:00
										 |  |  |         const int SCE_EEVEE_DOF_ENABLED = (1 << 7); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         IDProperty *props = IDP_GetPropertyFromGroup(scene->layer_properties, | 
					
						
							|  |  |  |                                                      RE_engine_id_BLENDER_EEVEE); | 
					
						
							| 
									
										
										
										
											2019-05-16 21:41:22 +02:00
										 |  |  |         // EEVEE_GET_BOOL(props, volumetric_enable, SCE_EEVEE_VOLUMETRIC_ENABLED);
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         EEVEE_GET_BOOL(props, volumetric_lights, SCE_EEVEE_VOLUMETRIC_LIGHTS); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, volumetric_shadows, SCE_EEVEE_VOLUMETRIC_SHADOWS); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, gtao_enable, SCE_EEVEE_GTAO_ENABLED); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, gtao_use_bent_normals, SCE_EEVEE_GTAO_BENT_NORMALS); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, gtao_bounce, SCE_EEVEE_GTAO_BOUNCE); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, dof_enable, SCE_EEVEE_DOF_ENABLED); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, bloom_enable, SCE_EEVEE_BLOOM_ENABLED); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, motion_blur_enable, SCE_EEVEE_MOTION_BLUR_ENABLED); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, shadow_high_bitdepth, SCE_EEVEE_SHADOW_HIGH_BITDEPTH); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, taa_reprojection, SCE_EEVEE_TAA_REPROJECTION); | 
					
						
							| 
									
										
										
										
											2019-05-16 16:43:41 +02:00
										 |  |  |         // EEVEE_GET_BOOL(props, sss_enable, SCE_EEVEE_SSS_ENABLED);
 | 
					
						
							| 
									
										
										
										
											2019-08-22 16:04:25 +02:00
										 |  |  |         // EEVEE_GET_BOOL(props, sss_separate_albedo, SCE_EEVEE_SSS_SEPARATE_ALBEDO);
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         EEVEE_GET_BOOL(props, ssr_enable, SCE_EEVEE_SSR_ENABLED); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, ssr_refraction, SCE_EEVEE_SSR_REFRACTION); | 
					
						
							|  |  |  |         EEVEE_GET_BOOL(props, ssr_halfres, SCE_EEVEE_SSR_HALF_RESOLUTION); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, gi_diffuse_bounces); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, gi_diffuse_bounces); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, gi_cubemap_resolution); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, gi_visibility_resolution); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, taa_samples); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, taa_render_samples); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, sss_samples); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, sss_jitter_threshold); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, ssr_quality); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, ssr_max_roughness); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, ssr_thickness); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, ssr_border_fade); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, ssr_firefly_fac); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, volumetric_start); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, volumetric_end); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, volumetric_tile_size); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, volumetric_samples); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, volumetric_sample_distribution); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, volumetric_light_clamp); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, volumetric_shadow_samples); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, gtao_distance); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, gtao_factor); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, gtao_quality); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, bokeh_max_size); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, bokeh_threshold); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT_ARRAY(props, bloom_color, 3); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, bloom_threshold); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, bloom_knee); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, bloom_intensity); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, bloom_radius); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, bloom_clamp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, motion_blur_samples); | 
					
						
							|  |  |  |         EEVEE_GET_FLOAT(props, motion_blur_shutter); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, shadow_method); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, shadow_cube_size); | 
					
						
							|  |  |  |         EEVEE_GET_INT(props, shadow_cascade_size); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Cleanup. */ | 
					
						
							|  |  |  |         IDP_FreeProperty(scene->layer_properties); | 
					
						
							|  |  |  |         scene->layer_properties = NULL; | 
					
						
							| 
									
										
										
										
											2018-05-16 19:34:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | #undef EEVEE_GET_FLOAT_ARRAY
 | 
					
						
							|  |  |  | #undef EEVEE_GET_FLOAT
 | 
					
						
							|  |  |  | #undef EEVEE_GET_INT
 | 
					
						
							|  |  |  | #undef EEVEE_GET_BOOL
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!MAIN_VERSION_ATLEAST(bmain, 280, 15)) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->display.matcap_ssao_distance = 0.2f; | 
					
						
							|  |  |  |         scene->display.matcap_ssao_attenuation = 1.0f; | 
					
						
							|  |  |  |         scene->display.matcap_ssao_samples = 16; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_OUTLINER) { | 
					
						
							|  |  |  |               SpaceOutliner *soops = (SpaceOutliner *)sl; | 
					
						
							|  |  |  |               soops->filter_id_type = ID_GR; | 
					
						
							|  |  |  |               soops->outlinevis = SO_VIEW_LAYER; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         switch (scene->toolsettings->snap_mode) { | 
					
						
							|  |  |  |           case 0: | 
					
						
							|  |  |  |             scene->toolsettings->snap_mode = SCE_SNAP_MODE_INCREMENT; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 1: | 
					
						
							|  |  |  |             scene->toolsettings->snap_mode = SCE_SNAP_MODE_VERTEX; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 2: | 
					
						
							|  |  |  |             scene->toolsettings->snap_mode = SCE_SNAP_MODE_EDGE; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 3: | 
					
						
							|  |  |  |             scene->toolsettings->snap_mode = SCE_SNAP_MODE_FACE; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 4: | 
					
						
							|  |  |  |             scene->toolsettings->snap_mode = SCE_SNAP_MODE_VOLUME; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         switch (scene->toolsettings->snap_node_mode) { | 
					
						
							|  |  |  |           case 5: | 
					
						
							|  |  |  |             scene->toolsettings->snap_node_mode = SCE_SNAP_MODE_NODE_X; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 6: | 
					
						
							|  |  |  |             scene->toolsettings->snap_node_mode = SCE_SNAP_MODE_NODE_Y; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 7: | 
					
						
							|  |  |  |             scene->toolsettings->snap_node_mode = SCE_SNAP_MODE_NODE_X | SCE_SNAP_MODE_NODE_Y; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 8: | 
					
						
							|  |  |  |             scene->toolsettings->snap_node_mode = SCE_SNAP_MODE_GRID; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         switch (scene->toolsettings->snap_uv_mode) { | 
					
						
							|  |  |  |           case 0: | 
					
						
							|  |  |  |             scene->toolsettings->snap_uv_mode = SCE_SNAP_MODE_INCREMENT; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case 1: | 
					
						
							|  |  |  |             scene->toolsettings->snap_uv_mode = SCE_SNAP_MODE_VERTEX; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       ParticleSettings *part; | 
					
						
							|  |  |  |       for (part = bmain->particles.first; part; part = part->id.next) { | 
					
						
							|  |  |  |         part->shape_flag = PART_SHAPE_CLOSE_TIP; | 
					
						
							|  |  |  |         part->shape = 0.0f; | 
					
						
							|  |  |  |         part->rad_root = 1.0f; | 
					
						
							|  |  |  |         part->rad_tip = 0.0f; | 
					
						
							|  |  |  |         part->rad_scale = 0.01f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 18)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Material", "float", "roughness")) { | 
					
						
							|  |  |  |       for (Material *mat = bmain->materials.first; mat; mat = mat->id.next) { | 
					
						
							|  |  |  |         if (mat->use_nodes) { | 
					
						
							|  |  |  |           if (MAIN_VERSION_ATLEAST(bmain, 280, 0)) { | 
					
						
							|  |  |  |             mat->roughness = mat->gloss_mir; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           else { | 
					
						
							|  |  |  |             mat->roughness = 0.25f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else { | 
					
						
							|  |  |  |           mat->roughness = 1.0f - mat->gloss_mir; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         mat->metallic = mat->ray_mirror; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.flag |= V3D_SHADING_SPECULAR_HIGHLIGHT; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "float", "xray_alpha")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.xray_alpha = 0.5f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "char", "matcap[256]")) { | 
					
						
							|  |  |  |       StudioLight *default_matcap = BKE_studiolight_find_default(STUDIOLIGHT_TYPE_MATCAP); | 
					
						
							|  |  |  |       /* when loading the internal file is loaded before the matcaps */ | 
					
						
							|  |  |  |       if (default_matcap) { | 
					
						
							|  |  |  |         for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |           LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |             LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |               if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |                 View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |                 BLI_strncpy(v3d->shading.matcap, default_matcap->name, FILE_MAXFILE); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DOverlay", "float", "wireframe_threshold")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.wireframe_threshold = 0.5f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "float", "cavity_valley_factor")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.cavity_valley_factor = 1.0f; | 
					
						
							|  |  |  |               v3d->shading.cavity_ridge_factor = 1.0f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DOverlay", "float", "xray_alpha_bone")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.xray_alpha_bone = 0.5f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 19)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Image", "ListBase", "renderslot")) { | 
					
						
							|  |  |  |       for (Image *ima = bmain->images.first; ima; ima = ima->id.next) { | 
					
						
							|  |  |  |         if (ima->type == IMA_TYPE_R_RESULT) { | 
					
						
							|  |  |  |           for (int i = 0; i < 8; i++) { | 
					
						
							|  |  |  |             RenderSlot *slot = MEM_callocN(sizeof(RenderSlot), "Image Render Slot Init"); | 
					
						
							|  |  |  |             BLI_snprintf(slot->name, sizeof(slot->name), "Slot %d", i + 1); | 
					
						
							|  |  |  |             BLI_addtail(&ima->renderslots, slot); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SpaceAction", "char", "mode_prev")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_ACTION) { | 
					
						
							|  |  |  |               SpaceAction *saction = (SpaceAction *)sl; | 
					
						
							| 
									
										
										
										
											2019-04-22 01:10:29 +10:00
										 |  |  |               /* "Dopesheet" should be default here,
 | 
					
						
							|  |  |  |                * unless it looks like the Action Editor was active instead. */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |               if ((saction->mode_prev == 0) && (saction->action == NULL)) { | 
					
						
							|  |  |  |                 saction->mode_prev = SACTCONT_DOPESHEET; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             if (v3d->drawtype == OB_TEXTURE) { | 
					
						
							|  |  |  |               v3d->drawtype = OB_SOLID; | 
					
						
							|  |  |  |               v3d->shading.light = V3D_LIGHTING_STUDIO; | 
					
						
							|  |  |  |               v3d->shading.color_type = V3D_SHADING_TEXTURE_COLOR; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 21)) { | 
					
						
							|  |  |  |     for (Scene *sce = bmain->scenes.first; sce != NULL; sce = sce->id.next) { | 
					
						
							|  |  |  |       if (sce->ed != NULL && sce->ed->seqbase.first != NULL) { | 
					
						
							|  |  |  |         do_versions_seq_unique_name_all_strips(sce, &sce->ed->seqbase); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "View3DOverlay", "float", "texture_paint_mode_opacity")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               enum { | 
					
						
							|  |  |  |                 V3D_SHOW_MODE_SHADE_OVERRIDE = (1 << 15), | 
					
						
							|  |  |  |               }; | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							| 
									
										
										
										
											2020-03-15 21:53:57 +11:00
										 |  |  |               float alpha = (v3d->flag2 & V3D_SHOW_MODE_SHADE_OVERRIDE) ? 0.0f : 1.0f; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |               v3d->overlay.texture_paint_mode_opacity = alpha; | 
					
						
							|  |  |  |               v3d->overlay.vertex_paint_mode_opacity = alpha; | 
					
						
							|  |  |  |               v3d->overlay.weight_paint_mode_opacity = alpha; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "char", "background_type")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               copy_v3_fl(v3d->shading.background_color, 0.05f); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneEEVEE", "float", "gi_cubemap_draw_size")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->eevee.gi_irradiance_draw_size = 0.1f; | 
					
						
							|  |  |  |         scene->eevee.gi_cubemap_draw_size = 0.3f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "RigidBodyWorld", "RigidBodyWorld_Shared", "*shared")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         RigidBodyWorld *rbw = scene->rigidbody_world; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (rbw == NULL) { | 
					
						
							|  |  |  |           continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (rbw->shared == NULL) { | 
					
						
							|  |  |  |           rbw->shared = MEM_callocN(sizeof(*rbw->shared), "RigidBodyWorld_Shared"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Move shared pointers from deprecated location to current location */ | 
					
						
							|  |  |  |         rbw->shared->pointcache = rbw->pointcache; | 
					
						
							|  |  |  |         rbw->shared->ptcaches = rbw->ptcaches; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         rbw->pointcache = NULL; | 
					
						
							|  |  |  |         BLI_listbase_clear(&rbw->ptcaches); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (rbw->shared->pointcache == NULL) { | 
					
						
							|  |  |  |           rbw->shared->pointcache = BKE_ptcache_add(&(rbw->shared->ptcaches)); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SoftBody", "SoftBody_Shared", "*shared")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |         SoftBody *sb = ob->soft; | 
					
						
							|  |  |  |         if (sb == NULL) { | 
					
						
							|  |  |  |           continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (sb->shared == NULL) { | 
					
						
							|  |  |  |           sb->shared = MEM_callocN(sizeof(*sb->shared), "SoftBody_Shared"); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Move shared pointers from deprecated location to current location */ | 
					
						
							|  |  |  |         sb->shared->pointcache = sb->pointcache; | 
					
						
							|  |  |  |         sb->shared->ptcaches = sb->ptcaches; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         sb->pointcache = NULL; | 
					
						
							|  |  |  |         BLI_listbase_clear(&sb->ptcaches); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "short", "type")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               if (v3d->drawtype == OB_RENDER) { | 
					
						
							|  |  |  |                 v3d->drawtype = OB_SOLID; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               v3d->shading.type = v3d->drawtype; | 
					
						
							|  |  |  |               v3d->shading.prev_type = OB_SOLID; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneDisplay", "View3DShading", "shading")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         BKE_screen_view3d_shading_init(&scene->display.shading); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* initialize grease pencil view data */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SpaceView3D", "float", "vertex_opacity")) { | 
					
						
							| 
									
										
										
										
											2020-04-03 14:23:21 +02:00
										 |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->vertex_opacity = 1.0f; | 
					
						
							|  |  |  |               v3d->gp_flag |= V3D_GP_SHOW_EDIT_LINES; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 22)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "ToolSettings", "char", "annotate_v3d_align")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->toolsettings->annotate_v3d_align = GP_PROJECT_VIEWSPACE | GP_PROJECT_CURSOR; | 
					
						
							|  |  |  |         scene->toolsettings->annotate_thickness = 3; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "bGPDlayer", "short", "line_change")) { | 
					
						
							|  |  |  |       for (bGPdata *gpd = bmain->gpencils.first; gpd; gpd = gpd->id.next) { | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |         LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           gpl->line_change = gpl->thickness; | 
					
						
							|  |  |  |           if ((gpl->thickness < 1) || (gpl->thickness > 10)) { | 
					
						
							|  |  |  |             gpl->thickness = 3; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DOverlay", "float", "gpencil_paper_opacity")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.gpencil_paper_opacity = 0.5f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DOverlay", "float", "gpencil_grid_opacity")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.gpencil_grid_opacity = 0.5f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* default loc axis */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "GP_Sculpt_Settings", "int", "lock_axis")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         /* lock axis */ | 
					
						
							|  |  |  |         GP_Sculpt_Settings *gset = &scene->toolsettings->gp_sculpt; | 
					
						
							|  |  |  |         if (gset) { | 
					
						
							|  |  |  |           gset->lock_axis = GP_LOCKAXIS_Y; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Versioning code for Subsurf modifier. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SubsurfModifier", "short", "uv_smooth")) { | 
					
						
							|  |  |  |       for (Object *object = bmain->objects.first; object != NULL; object = object->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &object->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (md->type == eModifierType_Subsurf) { | 
					
						
							|  |  |  |             SubsurfModifierData *smd = (SubsurfModifierData *)md; | 
					
						
							|  |  |  |             if (smd->flags & eSubsurfModifierFlag_SubsurfUv_DEPRECATED) { | 
					
						
							|  |  |  |               smd->uv_smooth = SUBSURF_UV_SMOOTH_PRESERVE_CORNERS; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else { | 
					
						
							|  |  |  |               smd->uv_smooth = SUBSURF_UV_SMOOTH_NONE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SubsurfModifier", "short", "quality")) { | 
					
						
							|  |  |  |       for (Object *object = bmain->objects.first; object != NULL; object = object->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &object->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (md->type == eModifierType_Subsurf) { | 
					
						
							|  |  |  |             SubsurfModifierData *smd = (SubsurfModifierData *)md; | 
					
						
							|  |  |  |             smd->quality = min_ii(smd->renderLevels, 3); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     /* Versioning code for Multires modifier. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "MultiresModifier", "short", "quality")) { | 
					
						
							|  |  |  |       for (Object *object = bmain->objects.first; object != NULL; object = object->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &object->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (md->type == eModifierType_Multires) { | 
					
						
							|  |  |  |             MultiresModifierData *mmd = (MultiresModifierData *)md; | 
					
						
							|  |  |  |             mmd->quality = 3; | 
					
						
							|  |  |  |             if (mmd->flags & eMultiresModifierFlag_PlainUv_DEPRECATED) { | 
					
						
							|  |  |  |               mmd->uv_smooth = SUBSURF_UV_SMOOTH_NONE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else { | 
					
						
							|  |  |  |               mmd->uv_smooth = SUBSURF_UV_SMOOTH_PRESERVE_CORNERS; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "ClothSimSettings", "short", "bending_model")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           ClothModifierData *clmd = NULL; | 
					
						
							|  |  |  |           if (md->type == eModifierType_Cloth) { | 
					
						
							|  |  |  |             clmd = (ClothModifierData *)md; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           else if (md->type == eModifierType_ParticleSystem) { | 
					
						
							|  |  |  |             ParticleSystemModifierData *psmd = (ParticleSystemModifierData *)md; | 
					
						
							|  |  |  |             ParticleSystem *psys = psmd->psys; | 
					
						
							|  |  |  |             clmd = psys->clmd; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           if (clmd != NULL) { | 
					
						
							|  |  |  |             clmd->sim_parms->bending_model = CLOTH_BENDING_LINEAR; | 
					
						
							|  |  |  |             clmd->sim_parms->tension = clmd->sim_parms->structural; | 
					
						
							|  |  |  |             clmd->sim_parms->compression = clmd->sim_parms->structural; | 
					
						
							|  |  |  |             clmd->sim_parms->shear = clmd->sim_parms->structural; | 
					
						
							|  |  |  |             clmd->sim_parms->max_tension = clmd->sim_parms->max_struct; | 
					
						
							|  |  |  |             clmd->sim_parms->max_compression = clmd->sim_parms->max_struct; | 
					
						
							|  |  |  |             clmd->sim_parms->max_shear = clmd->sim_parms->max_struct; | 
					
						
							|  |  |  |             clmd->sim_parms->vgroup_shear = clmd->sim_parms->vgroup_struct; | 
					
						
							|  |  |  |             clmd->sim_parms->tension_damp = clmd->sim_parms->Cdis; | 
					
						
							|  |  |  |             clmd->sim_parms->compression_damp = clmd->sim_parms->Cdis; | 
					
						
							|  |  |  |             clmd->sim_parms->shear_damp = clmd->sim_parms->Cdis; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "BrushGpencilSettings", "float", "era_strength_f")) { | 
					
						
							|  |  |  |       for (Brush *brush = bmain->brushes.first; brush; brush = brush->id.next) { | 
					
						
							|  |  |  |         if (brush->gpencil_settings != NULL) { | 
					
						
							|  |  |  |           BrushGpencilSettings *gp = brush->gpencil_settings; | 
					
						
							|  |  |  |           if (gp->brush_type == GPAINT_TOOL_ERASE) { | 
					
						
							|  |  |  |             gp->era_strength_f = 100.0f; | 
					
						
							|  |  |  |             gp->era_thickness_f = 10.0f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         if (md->type == eModifierType_Cloth) { | 
					
						
							|  |  |  |           ClothModifierData *clmd = (ClothModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (!(clmd->sim_parms->flags & CLOTH_SIMSETTINGS_FLAG_GOAL)) { | 
					
						
							|  |  |  |             clmd->sim_parms->vgroup_mass = 0; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (!(clmd->sim_parms->flags & CLOTH_SIMSETTINGS_FLAG_SCALING)) { | 
					
						
							|  |  |  |             clmd->sim_parms->vgroup_struct = 0; | 
					
						
							|  |  |  |             clmd->sim_parms->vgroup_shear = 0; | 
					
						
							|  |  |  |             clmd->sim_parms->vgroup_bend = 0; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (!(clmd->sim_parms->flags & CLOTH_SIMSETTINGS_FLAG_SEW)) { | 
					
						
							|  |  |  |             clmd->sim_parms->shrink_min = 0.0f; | 
					
						
							|  |  |  |             clmd->sim_parms->vgroup_shrink = 0; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (!(clmd->coll_parms->flags & CLOTH_COLLSETTINGS_FLAG_ENABLED)) { | 
					
						
							|  |  |  |             clmd->coll_parms->flags &= ~CLOTH_COLLSETTINGS_FLAG_SELF; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 24)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             v3d->overlay.edit_flag |= V3D_OVERLAY_EDIT_FACES | V3D_OVERLAY_EDIT_SEAMS | | 
					
						
							|  |  |  |                                       V3D_OVERLAY_EDIT_SHARP | V3D_OVERLAY_EDIT_FREESTYLE_EDGE | | 
					
						
							|  |  |  |                                       V3D_OVERLAY_EDIT_FREESTYLE_FACE | V3D_OVERLAY_EDIT_EDGES | | 
					
						
							|  |  |  |                                       V3D_OVERLAY_EDIT_CREASES | V3D_OVERLAY_EDIT_BWEIGHTS | | 
					
						
							|  |  |  |                                       V3D_OVERLAY_EDIT_CU_HANDLES | V3D_OVERLAY_EDIT_CU_NORMALS; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "ShrinkwrapModifierData", "char", "shrinkMode")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (md->type == eModifierType_Shrinkwrap) { | 
					
						
							|  |  |  |             ShrinkwrapModifierData *smd = (ShrinkwrapModifierData *)md; | 
					
						
							|  |  |  |             if (smd->shrinkOpts & MOD_SHRINKWRAP_KEEP_ABOVE_SURFACE) { | 
					
						
							|  |  |  |               smd->shrinkMode = MOD_SHRINKWRAP_ABOVE_SURFACE; | 
					
						
							|  |  |  |               smd->shrinkOpts &= ~MOD_SHRINKWRAP_KEEP_ABOVE_SURFACE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "PartDeflect", "float", "pdef_cfrict")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |         if (ob->pd) { | 
					
						
							|  |  |  |           ob->pd->pdef_cfrict = 5.0f; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (md->type == eModifierType_Cloth) { | 
					
						
							|  |  |  |             ClothModifierData *clmd = (ClothModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             clmd->coll_parms->selfepsilon = 0.015f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "float", "xray_alpha_wire")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							| 
									
										
										
										
											2019-06-13 17:33:51 +10:00
										 |  |  |               v3d->shading.flag |= V3D_SHADING_XRAY_WIREFRAME; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 25)) { | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       UnitSettings *unit = &scene->unit; | 
					
						
							|  |  |  |       if (unit->system != USER_UNIT_NONE) { | 
					
						
							|  |  |  |         unit->length_unit = bUnit_GetBaseUnitOfType(scene->unit.system, B_UNIT_LENGTH); | 
					
						
							|  |  |  |         unit->mass_unit = bUnit_GetBaseUnitOfType(scene->unit.system, B_UNIT_MASS); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       unit->time_unit = bUnit_GetBaseUnitOfType(USER_UNIT_NONE, B_UNIT_TIME); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* gpencil grid settings */ | 
					
						
							|  |  |  |     for (bGPdata *gpd = bmain->gpencils.first; gpd; gpd = gpd->id.next) { | 
					
						
							|  |  |  |       ARRAY_SET_ITEMS(gpd->grid.color, 0.5f, 0.5f, 0.5f);  // Color
 | 
					
						
							|  |  |  |       ARRAY_SET_ITEMS(gpd->grid.scale, 1.0f, 1.0f);        // Scale
 | 
					
						
							|  |  |  |       gpd->grid.lines = GP_DEFAULT_GRID_LINES;             // Number of lines
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 28)) { | 
					
						
							|  |  |  |     for (Mesh *mesh = bmain->meshes.first; mesh; mesh = mesh->id.next) { | 
					
						
							|  |  |  |       BKE_mesh_calc_edges_loose(mesh); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 29)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             enum { V3D_OCCLUDE_WIRE = (1 << 14) }; | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             if (v3d->flag2 & V3D_OCCLUDE_WIRE) { | 
					
						
							|  |  |  |               v3d->overlay.edit_flag |= V3D_OVERLAY_EDIT_OCCLUDE_WIRE; | 
					
						
							|  |  |  |               v3d->flag2 &= ~V3D_OCCLUDE_WIRE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-16 17:24:28 +01:00
										 |  |  |     /* Files stored pre 2.5 (possibly re-saved with newer versions) may have non-visible
 | 
					
						
							|  |  |  |      * spaces without a header (visible/active ones are properly versioned). | 
					
						
							|  |  |  |      * Multiple version patches below assume there's always a header though. So inserting this | 
					
						
							|  |  |  |      * patch in-between older ones to add a header when needed. | 
					
						
							|  |  |  |      * | 
					
						
							|  |  |  |      * From here on it should be fine to assume there always is a header. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     if (!MAIN_VERSION_ATLEAST(bmain, 283, 1)) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             ARegion *region_header = do_versions_find_region_or_null(regionbase, RGN_TYPE_HEADER); | 
					
						
							| 
									
										
										
										
											2020-01-16 17:24:28 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             if (!region_header) { | 
					
						
							| 
									
										
										
										
											2020-01-16 17:24:28 +01:00
										 |  |  |               /* Headers should always be first in the region list, except if there's also a
 | 
					
						
							|  |  |  |                * tool-header. These were only introduced in later versions though, so should be | 
					
						
							|  |  |  |                * fine to always insert headers first. */ | 
					
						
							|  |  |  |               BLI_assert(!do_versions_find_region_or_null(regionbase, RGN_TYPE_TOOL_HEADER)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |               ARegion *region = do_versions_add_region(RGN_TYPE_HEADER, | 
					
						
							|  |  |  |                                                        "header 2.83.1 versioning"); | 
					
						
							|  |  |  |               region->alignment = (U.uiflag & USER_HEADER_BOTTOM) ? RGN_ALIGN_BOTTOM : | 
					
						
							|  |  |  |                                                                     RGN_ALIGN_TOP; | 
					
						
							|  |  |  |               BLI_addhead(regionbase, region); | 
					
						
							| 
									
										
										
										
											2020-01-16 17:24:28 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_PROPERTIES) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             ARegion *region = MEM_callocN(sizeof(ARegion), "navigation bar for properties"); | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             ARegion *region_header = NULL; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             for (region_header = regionbase->first; region_header; | 
					
						
							|  |  |  |                  region_header = region_header->next) { | 
					
						
							|  |  |  |               if (region_header->regiontype == RGN_TYPE_HEADER) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |                 break; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             BLI_assert(region_header); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             BLI_insertlinkafter(regionbase, region_header, region); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             region->regiontype = RGN_TYPE_NAV_BAR; | 
					
						
							|  |  |  |             region->alignment = RGN_ALIGN_LEFT; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* grease pencil fade layer opacity */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DOverlay", "float", "gpencil_fade_layer")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.gpencil_fade_layer = 0.5f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 30)) { | 
					
						
							|  |  |  |     /* grease pencil main material show switches */ | 
					
						
							|  |  |  |     for (Material *mat = bmain->materials.first; mat; mat = mat->id.next) { | 
					
						
							|  |  |  |       if (mat->gp_style) { | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |         mat->gp_style->flag |= GP_MATERIAL_STROKE_SHOW; | 
					
						
							|  |  |  |         mat->gp_style->flag |= GP_MATERIAL_FILL_SHOW; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 33)) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneEEVEE", "float", "overscan")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->eevee.overscan = 3.0f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Light *la = bmain->lights.first; la; la = la->id.next) { | 
					
						
							|  |  |  |       /* Removed Hemi lights. */ | 
					
						
							|  |  |  |       if (!ELEM(la->type, LA_LOCAL, LA_SUN, LA_SPOT, LA_AREA)) { | 
					
						
							|  |  |  |         la->type = LA_SUN; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneEEVEE", "float", "light_threshold")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->eevee.light_threshold = 0.01f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneEEVEE", "float", "gi_irradiance_smoothing")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->eevee.gi_irradiance_smoothing = 0.1f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneEEVEE", "float", "gi_filter_quality")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->eevee.gi_filter_quality = 1.0f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Light", "float", "att_dist")) { | 
					
						
							|  |  |  |       for (Light *la = bmain->lights.first; la; la = la->id.next) { | 
					
						
							|  |  |  |         la->att_dist = la->clipend; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Brush", "char", "weightpaint_tool")) { | 
					
						
							|  |  |  |       /* Magic defines from old files (2.7x) */ | 
					
						
							| 
									
										
										
										
											2018-11-06 18:06:33 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | #define PAINT_BLEND_MIX 0
 | 
					
						
							|  |  |  | #define PAINT_BLEND_ADD 1
 | 
					
						
							|  |  |  | #define PAINT_BLEND_SUB 2
 | 
					
						
							|  |  |  | #define PAINT_BLEND_MUL 3
 | 
					
						
							|  |  |  | #define PAINT_BLEND_BLUR 4
 | 
					
						
							|  |  |  | #define PAINT_BLEND_LIGHTEN 5
 | 
					
						
							|  |  |  | #define PAINT_BLEND_DARKEN 6
 | 
					
						
							|  |  |  | #define PAINT_BLEND_AVERAGE 7
 | 
					
						
							|  |  |  | #define PAINT_BLEND_SMEAR 8
 | 
					
						
							|  |  |  | #define PAINT_BLEND_COLORDODGE 9
 | 
					
						
							|  |  |  | #define PAINT_BLEND_DIFFERENCE 10
 | 
					
						
							|  |  |  | #define PAINT_BLEND_SCREEN 11
 | 
					
						
							|  |  |  | #define PAINT_BLEND_HARDLIGHT 12
 | 
					
						
							|  |  |  | #define PAINT_BLEND_OVERLAY 13
 | 
					
						
							|  |  |  | #define PAINT_BLEND_SOFTLIGHT 14
 | 
					
						
							|  |  |  | #define PAINT_BLEND_EXCLUSION 15
 | 
					
						
							|  |  |  | #define PAINT_BLEND_LUMINOSITY 16
 | 
					
						
							|  |  |  | #define PAINT_BLEND_SATURATION 17
 | 
					
						
							|  |  |  | #define PAINT_BLEND_HUE 18
 | 
					
						
							|  |  |  | #define PAINT_BLEND_ALPHA_SUB 19
 | 
					
						
							|  |  |  | #define PAINT_BLEND_ALPHA_ADD 20
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       for (Brush *brush = bmain->brushes.first; brush; brush = brush->id.next) { | 
					
						
							|  |  |  |         if (brush->ob_mode & (OB_MODE_VERTEX_PAINT | OB_MODE_WEIGHT_PAINT)) { | 
					
						
							|  |  |  |           const char tool_init = brush->vertexpaint_tool; | 
					
						
							|  |  |  |           bool is_blend = false; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           { | 
					
						
							|  |  |  |             char tool = tool_init; | 
					
						
							|  |  |  |             switch (tool_init) { | 
					
						
							|  |  |  |               case PAINT_BLEND_MIX: | 
					
						
							|  |  |  |                 tool = VPAINT_TOOL_DRAW; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_BLUR: | 
					
						
							|  |  |  |                 tool = VPAINT_TOOL_BLUR; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_AVERAGE: | 
					
						
							|  |  |  |                 tool = VPAINT_TOOL_AVERAGE; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_SMEAR: | 
					
						
							|  |  |  |                 tool = VPAINT_TOOL_SMEAR; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               default: | 
					
						
							|  |  |  |                 tool = VPAINT_TOOL_DRAW; | 
					
						
							|  |  |  |                 is_blend = true; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             brush->vertexpaint_tool = tool; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           if (is_blend == false) { | 
					
						
							|  |  |  |             brush->blend = IMB_BLEND_MIX; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           else { | 
					
						
							|  |  |  |             short blend = IMB_BLEND_MIX; | 
					
						
							|  |  |  |             switch (tool_init) { | 
					
						
							|  |  |  |               case PAINT_BLEND_ADD: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_ADD; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_SUB: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_SUB; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_MUL: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_MUL; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_LIGHTEN: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_LIGHTEN; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_DARKEN: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_DARKEN; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_COLORDODGE: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_COLORDODGE; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_DIFFERENCE: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_DIFFERENCE; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_SCREEN: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_SCREEN; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_HARDLIGHT: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_HARDLIGHT; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_OVERLAY: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_OVERLAY; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_SOFTLIGHT: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_SOFTLIGHT; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_EXCLUSION: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_EXCLUSION; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_LUMINOSITY: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_LUMINOSITY; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_SATURATION: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_SATURATION; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_HUE: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_HUE; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_ALPHA_SUB: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_ERASE_ALPHA; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |               case PAINT_BLEND_ALPHA_ADD: | 
					
						
							|  |  |  |                 blend = IMB_BLEND_ADD_ALPHA; | 
					
						
							|  |  |  |                 break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             brush->blend = blend; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* For now these match, in the future new items may not. */ | 
					
						
							|  |  |  |         brush->weightpaint_tool = brush->vertexpaint_tool; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2018-11-06 18:06:33 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_MIX
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_ADD
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_SUB
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_MUL
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_BLUR
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_LIGHTEN
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_DARKEN
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_AVERAGE
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_SMEAR
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_COLORDODGE
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_DIFFERENCE
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_SCREEN
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_HARDLIGHT
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_OVERLAY
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_SOFTLIGHT
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_EXCLUSION
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_LUMINOSITY
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_SATURATION
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_HUE
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_ALPHA_SUB
 | 
					
						
							|  |  |  | #undef PAINT_BLEND_ALPHA_ADD
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 34)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, slink, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (slink->spacetype == SPACE_USERPREF) { | 
					
						
							|  |  |  |             ARegion *navigation_region = BKE_spacedata_find_region_type( | 
					
						
							|  |  |  |                 slink, area, RGN_TYPE_NAV_BAR); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (!navigation_region) { | 
					
						
							|  |  |  |               ARegion *main_region = BKE_spacedata_find_region_type(slink, area, RGN_TYPE_WINDOW); | 
					
						
							|  |  |  |               ListBase *regionbase = (slink == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                         &slink->regionbase; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               navigation_region = MEM_callocN(sizeof(ARegion), | 
					
						
							|  |  |  |                                               "userpref navigation-region do_versions"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-14 23:29:46 +10:00
										 |  |  |               /* Order matters, addhead not addtail! */ | 
					
						
							|  |  |  |               BLI_insertlinkbefore(regionbase, main_region, navigation_region); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |               navigation_region->regiontype = RGN_TYPE_NAV_BAR; | 
					
						
							|  |  |  |               navigation_region->alignment = RGN_ALIGN_LEFT; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 36)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "float", "curvature_ridge_factor")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.curvature_ridge_factor = 1.0f; | 
					
						
							|  |  |  |               v3d->shading.curvature_valley_factor = 1.0f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Rename OpenGL to Workbench. */ | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       if (STREQ(scene->r.engine, "BLENDER_OPENGL")) { | 
					
						
							|  |  |  |         STRNCPY(scene->r.engine, RE_engine_id_BLENDER_WORKBENCH); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* init Annotations onion skin */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "bGPDlayer", "int", "gstep")) { | 
					
						
							|  |  |  |       for (bGPdata *gpd = bmain->gpencils.first; gpd; gpd = gpd->id.next) { | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |         LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           ARRAY_SET_ITEMS(gpl->gcolor_prev, 0.302f, 0.851f, 0.302f); | 
					
						
							|  |  |  |           ARRAY_SET_ITEMS(gpl->gcolor_next, 0.250f, 0.1f, 1.0f); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Move studio_light selection to lookdev_light. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "char", "lookdev_light[256]")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               memcpy(v3d->shading.lookdev_light, v3d->shading.studio_light, sizeof(char) * 256); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Change Solid mode shadow orientation. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneDisplay", "float", "shadow_focus")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         float *dir = scene->display.light_direction; | 
					
						
							|  |  |  |         SWAP(float, dir[2], dir[1]); | 
					
						
							|  |  |  |         dir[2] = -dir[2]; | 
					
						
							|  |  |  |         dir[0] = -dir[0]; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 37)) { | 
					
						
							|  |  |  |     for (Camera *ca = bmain->cameras.first; ca; ca = ca->id.next) { | 
					
						
							|  |  |  |       ca->drawsize *= 2.0f; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Grease pencil primitive curve */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "GP_Sculpt_Settings", "CurveMapping", "cur_primitive")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         GP_Sculpt_Settings *gset = &scene->toolsettings->gp_sculpt; | 
					
						
							|  |  |  |         if ((gset) && (gset->cur_primitive == NULL)) { | 
					
						
							| 
									
										
										
										
											2019-08-07 03:21:55 +10:00
										 |  |  |           gset->cur_primitive = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |           BKE_curvemapping_initialize(gset->cur_primitive); | 
					
						
							|  |  |  |           BKE_curvemap_reset(gset->cur_primitive->cm, | 
					
						
							|  |  |  |                              &gset->cur_primitive->clipr, | 
					
						
							|  |  |  |                              CURVE_PRESET_BELL, | 
					
						
							|  |  |  |                              CURVEMAP_SLOPE_POSITIVE); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 38)) { | 
					
						
							|  |  |  |     if (DNA_struct_elem_find(fd->filesdna, "Object", "char", "empty_image_visibility_flag")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |         ob->empty_image_visibility_flag ^= (OB_EMPTY_IMAGE_HIDE_PERSPECTIVE | | 
					
						
							|  |  |  |                                             OB_EMPTY_IMAGE_HIDE_ORTHOGRAPHIC | | 
					
						
							|  |  |  |                                             OB_EMPTY_IMAGE_HIDE_BACK); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           switch (sl->spacetype) { | 
					
						
							|  |  |  |             case SPACE_IMAGE: { | 
					
						
							|  |  |  |               SpaceImage *sima = (SpaceImage *)sl; | 
					
						
							|  |  |  |               sima->flag &= ~(SI_FLAG_UNUSED_0 | SI_FLAG_UNUSED_1 | SI_FLAG_UNUSED_3 | | 
					
						
							|  |  |  |                               SI_FLAG_UNUSED_6 | SI_FLAG_UNUSED_7 | SI_FLAG_UNUSED_8 | | 
					
						
							|  |  |  |                               SI_FLAG_UNUSED_17 | SI_FLAG_UNUSED_18 | SI_FLAG_UNUSED_23 | | 
					
						
							|  |  |  |                               SI_FLAG_UNUSED_24); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_VIEW3D: { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							| 
									
										
										
										
											2019-08-19 14:25:29 -03:00
										 |  |  |               v3d->flag &= ~(V3D_LOCAL_COLLECTIONS | V3D_FLAG_UNUSED_1 | V3D_FLAG_UNUSED_10 | | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |                              V3D_FLAG_UNUSED_12); | 
					
						
							|  |  |  |               v3d->flag2 &= ~(V3D_FLAG2_UNUSED_3 | V3D_FLAG2_UNUSED_6 | V3D_FLAG2_UNUSED_12 | | 
					
						
							|  |  |  |                               V3D_FLAG2_UNUSED_13 | V3D_FLAG2_UNUSED_14 | V3D_FLAG2_UNUSED_15); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_OUTLINER: { | 
					
						
							|  |  |  |               SpaceOutliner *so = (SpaceOutliner *)sl; | 
					
						
							|  |  |  |               so->filter &= ~(SO_FILTER_UNUSED_1 | SO_FILTER_UNUSED_5 | SO_FILTER_UNUSED_12); | 
					
						
							|  |  |  |               so->storeflag &= ~(SO_TREESTORE_UNUSED_1); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_FILE: { | 
					
						
							|  |  |  |               SpaceFile *sfile = (SpaceFile *)sl; | 
					
						
							|  |  |  |               if (sfile->params) { | 
					
						
							|  |  |  |                 sfile->params->flag &= ~(FILE_PARAMS_FLAG_UNUSED_1 | FILE_PARAMS_FLAG_UNUSED_6 | | 
					
						
							|  |  |  |                                          FILE_PARAMS_FLAG_UNUSED_9); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_NODE: { | 
					
						
							|  |  |  |               SpaceNode *snode = (SpaceNode *)sl; | 
					
						
							|  |  |  |               snode->flag &= ~(SNODE_FLAG_UNUSED_6 | SNODE_FLAG_UNUSED_10 | SNODE_FLAG_UNUSED_11); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_PROPERTIES: { | 
					
						
							|  |  |  |               SpaceProperties *sbuts = (SpaceProperties *)sl; | 
					
						
							|  |  |  |               sbuts->flag &= ~(SB_FLAG_UNUSED_2 | SB_FLAG_UNUSED_3); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_NLA: { | 
					
						
							|  |  |  |               SpaceNla *snla = (SpaceNla *)sl; | 
					
						
							|  |  |  |               snla->flag &= ~(SNLA_FLAG_UNUSED_0 | SNLA_FLAG_UNUSED_1 | SNLA_FLAG_UNUSED_3); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       scene->r.mode &= ~(R_MODE_UNUSED_1 | R_MODE_UNUSED_2 | R_MODE_UNUSED_3 | R_MODE_UNUSED_4 | | 
					
						
							|  |  |  |                          R_MODE_UNUSED_5 | R_MODE_UNUSED_6 | R_MODE_UNUSED_7 | R_MODE_UNUSED_8 | | 
					
						
							|  |  |  |                          R_MODE_UNUSED_10 | R_MODE_UNUSED_13 | R_MODE_UNUSED_16 | | 
					
						
							|  |  |  |                          R_MODE_UNUSED_17 | R_MODE_UNUSED_18 | R_MODE_UNUSED_19 | | 
					
						
							|  |  |  |                          R_MODE_UNUSED_20 | R_MODE_UNUSED_21 | R_MODE_UNUSED_27); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       scene->r.scemode &= ~(R_SCEMODE_UNUSED_8 | R_SCEMODE_UNUSED_11 | R_SCEMODE_UNUSED_13 | | 
					
						
							|  |  |  |                             R_SCEMODE_UNUSED_16 | R_SCEMODE_UNUSED_17 | R_SCEMODE_UNUSED_19); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (scene->toolsettings->sculpt) { | 
					
						
							|  |  |  |         scene->toolsettings->sculpt->flags &= ~(SCULPT_FLAG_UNUSED_0 | SCULPT_FLAG_UNUSED_1 | | 
					
						
							|  |  |  |                                                 SCULPT_FLAG_UNUSED_2); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (scene->ed) { | 
					
						
							|  |  |  |         Sequence *seq; | 
					
						
							|  |  |  |         SEQ_BEGIN (scene->ed, seq) { | 
					
						
							|  |  |  |           seq->flag &= ~(SEQ_FLAG_UNUSED_6 | SEQ_FLAG_UNUSED_18 | SEQ_FLAG_UNUSED_19 | | 
					
						
							|  |  |  |                          SEQ_FLAG_UNUSED_21); | 
					
						
							|  |  |  |           if (seq->type == SEQ_TYPE_SPEED) { | 
					
						
							|  |  |  |             SpeedControlVars *s = (SpeedControlVars *)seq->effectdata; | 
					
						
							|  |  |  |             s->flags &= ~(SEQ_SPEED_UNUSED_1); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         SEQ_END; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (World *world = bmain->worlds.first; world; world = world->id.next) { | 
					
						
							|  |  |  |       world->flag &= ~(WO_MODE_UNUSED_1 | WO_MODE_UNUSED_2 | WO_MODE_UNUSED_3 | WO_MODE_UNUSED_4 | | 
					
						
							|  |  |  |                        WO_MODE_UNUSED_5 | WO_MODE_UNUSED_7); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Image *image = bmain->images.first; image; image = image->id.next) { | 
					
						
							| 
									
										
										
										
											2020-02-25 15:05:53 +01:00
										 |  |  |       image->flag &= ~(IMA_HIGH_BITDEPTH | IMA_FLAG_UNUSED_1 | IMA_FLAG_UNUSED_4 | | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |                        IMA_FLAG_UNUSED_6 | IMA_FLAG_UNUSED_8 | IMA_FLAG_UNUSED_15 | | 
					
						
							|  |  |  |                        IMA_FLAG_UNUSED_16); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |       ob->flag &= ~(OB_FLAG_UNUSED_11 | OB_FLAG_UNUSED_12); | 
					
						
							|  |  |  |       ob->transflag &= ~(OB_TRANSFLAG_UNUSED_0 | OB_TRANSFLAG_UNUSED_1); | 
					
						
							|  |  |  |       ob->shapeflag &= ~OB_SHAPE_FLAG_UNUSED_1; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Mesh *me = bmain->meshes.first; me; me = me->id.next) { | 
					
						
							|  |  |  |       me->flag &= ~(ME_FLAG_UNUSED_0 | ME_FLAG_UNUSED_1 | ME_FLAG_UNUSED_3 | ME_FLAG_UNUSED_4 | | 
					
						
							|  |  |  |                     ME_FLAG_UNUSED_6 | ME_FLAG_UNUSED_7 | ME_FLAG_UNUSED_8); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Material *mat = bmain->materials.first; mat; mat = mat->id.next) { | 
					
						
							| 
									
										
										
										
											2019-05-15 12:03:26 +02:00
										 |  |  |       mat->blend_flag &= ~(1 << 2); /* UNUSED */ | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 40)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "ToolSettings", "char", "snap_transform_mode_flag")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->toolsettings->snap_transform_mode_flag = SCE_SNAP_TRANSFORM_MODE_TRANSLATE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           switch (sl->spacetype) { | 
					
						
							|  |  |  |             case SPACE_VIEW3D: { | 
					
						
							|  |  |  |               enum { V3D_BACKFACE_CULLING = (1 << 10) }; | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               if (v3d->flag2 & V3D_BACKFACE_CULLING) { | 
					
						
							|  |  |  |                 v3d->flag2 &= ~V3D_BACKFACE_CULLING; | 
					
						
							|  |  |  |                 v3d->shading.flag |= V3D_SHADING_BACKFACE_CULLING; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_find(fd->filesdna, "TransformOrientationSlot")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         for (int i = 0; i < ARRAY_SIZE(scene->orientation_slots); i++) { | 
					
						
							|  |  |  |           scene->orientation_slots[i].index_custom = -1; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Grease pencil cutter/select segment intersection threshold  */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "GP_Sculpt_Settings", "float", "isect_threshold")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         GP_Sculpt_Settings *gset = &scene->toolsettings->gp_sculpt; | 
					
						
							|  |  |  |         if (gset) { | 
					
						
							|  |  |  |           gset->isect_threshold = 0.1f; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Fix anamorphic bokeh eevee rna limits.*/ | 
					
						
							|  |  |  |     for (Camera *ca = bmain->cameras.first; ca; ca = ca->id.next) { | 
					
						
							|  |  |  |       if (ca->gpu_dof.ratio < 0.01f) { | 
					
						
							|  |  |  |         ca->gpu_dof.ratio = 0.01f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_USERPREF) { | 
					
						
							|  |  |  |             ARegion *execute_region = BKE_spacedata_find_region_type(sl, area, RGN_TYPE_EXECUTE); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (!execute_region) { | 
					
						
							|  |  |  |               ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                      &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |               ARegion *region_navbar = BKE_spacedata_find_region_type(sl, area, RGN_TYPE_NAV_BAR); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |               execute_region = MEM_callocN(sizeof(ARegion), "execute region for properties"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |               BLI_assert(region_navbar); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |               BLI_insertlinkafter(regionbase, region_navbar, execute_region); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |               execute_region->regiontype = RGN_TYPE_EXECUTE; | 
					
						
							|  |  |  |               execute_region->alignment = RGN_ALIGN_BOTTOM | RGN_SPLIT_PREV; | 
					
						
							|  |  |  |               execute_region->flag |= RGN_FLAG_DYNAMIC_SIZE; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 43)) { | 
					
						
							|  |  |  |     ListBase *lb = which_libbase(bmain, ID_BR); | 
					
						
							|  |  |  |     BKE_main_id_repair_duplicate_names_listbase(lb); | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 44)) { | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Material", "float", "a")) { | 
					
						
							|  |  |  |       for (Material *mat = bmain->materials.first; mat; mat = mat->id.next) { | 
					
						
							|  |  |  |         mat->a = 1.0f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       enum { | 
					
						
							|  |  |  |         R_ALPHAKEY = 2, | 
					
						
							|  |  |  |       }; | 
					
						
							|  |  |  |       scene->r.seq_flag &= ~(R_SEQ_UNUSED_0 | R_SEQ_UNUSED_1 | R_SEQ_UNUSED_2); | 
					
						
							|  |  |  |       scene->r.color_mgt_flag &= ~R_COLOR_MANAGEMENT_UNUSED_1; | 
					
						
							|  |  |  |       if (scene->r.alphamode == R_ALPHAKEY) { | 
					
						
							|  |  |  |         scene->r.alphamode = R_ADDSKY; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       ToolSettings *ts = scene->toolsettings; | 
					
						
							|  |  |  |       ts->particle.flag &= ~PE_UNUSED_6; | 
					
						
							|  |  |  |       if (ts->sculpt != NULL) { | 
					
						
							|  |  |  |         ts->sculpt->flags &= ~SCULPT_FLAG_UNUSED_6; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 46)) { | 
					
						
							|  |  |  |     /* Add wireframe color. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "char", "wire_color_type")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.wire_color_type = V3D_SHADING_SINGLE_COLOR; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DCursor", "short", "rotation_mode")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         if (is_zero_v3(scene->cursor.rotation_axis)) { | 
					
						
							|  |  |  |           scene->cursor.rotation_mode = ROT_MODE_XYZ; | 
					
						
							|  |  |  |           scene->cursor.rotation_quaternion[0] = 1.0f; | 
					
						
							|  |  |  |           scene->cursor.rotation_axis[1] = 1.0f; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 47)) { | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |       ParticleEditSettings *pset = &scene->toolsettings->particle; | 
					
						
							|  |  |  |       if (pset->brushtype < 0) { | 
					
						
							|  |  |  |         pset->brushtype = PE_BRUSH_COMB; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         enum { PARCURVE = 1, PARKEY = 2, PAR_DEPRECATED = 16 }; | 
					
						
							|  |  |  |         if (ELEM(ob->partype, PARCURVE, PARKEY, PAR_DEPRECATED)) { | 
					
						
							|  |  |  |           ob->partype = PAROBJECT; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         enum { OB_WAVE = 21, OB_LIFE = 23, OB_SECTOR = 24 }; | 
					
						
							|  |  |  |         if (ELEM(ob->type, OB_WAVE, OB_LIFE, OB_SECTOR)) { | 
					
						
							|  |  |  |           ob->type = OB_EMPTY; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       ob->transflag &= ~(OB_TRANSFLAG_UNUSED_0 | OB_TRANSFLAG_UNUSED_1 | OB_TRANSFLAG_UNUSED_3 | | 
					
						
							|  |  |  |                          OB_TRANSFLAG_UNUSED_6 | OB_TRANSFLAG_UNUSED_12); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       ob->nlaflag &= ~(OB_ADS_UNUSED_1 | OB_ADS_UNUSED_2); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LISTBASE_FOREACH (bArmature *, arm, &bmain->armatures) { | 
					
						
							| 
									
										
										
										
											2019-06-07 10:44:18 +02:00
										 |  |  |       arm->flag &= ~(ARM_FLAG_UNUSED_1 | ARM_FLAG_UNUSED_5 | ARM_FLAG_UNUSED_6 | | 
					
						
							|  |  |  |                      ARM_FLAG_UNUSED_7 | ARM_FLAG_UNUSED_12); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Text *, text, &bmain->texts) { | 
					
						
							|  |  |  |       text->flags &= ~(TXT_FLAG_UNUSED_8 | TXT_FLAG_UNUSED_9); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 48)) { | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       /* Those are not currently used, but are accessible through RNA API and were not
 | 
					
						
							|  |  |  |        * properly initialized previously. This is mere copy of BKE_init_scene() code. */ | 
					
						
							|  |  |  |       if (scene->r.im_format.view_settings.look[0] == '\0') { | 
					
						
							|  |  |  |         BKE_color_managed_display_settings_init(&scene->r.im_format.display_settings); | 
					
						
							|  |  |  |         BKE_color_managed_view_settings_init_render( | 
					
						
							|  |  |  |             &scene->r.im_format.view_settings, &scene->r.im_format.display_settings, "Filmic"); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (scene->r.bake.im_format.view_settings.look[0] == '\0') { | 
					
						
							|  |  |  |         BKE_color_managed_display_settings_init(&scene->r.bake.im_format.display_settings); | 
					
						
							|  |  |  |         BKE_color_managed_view_settings_init_render(&scene->r.bake.im_format.view_settings, | 
					
						
							|  |  |  |                                                     &scene->r.bake.im_format.display_settings, | 
					
						
							|  |  |  |                                                     "Filmic"); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 49)) { | 
					
						
							|  |  |  |     /* All tool names changed, reset to defaults. */ | 
					
						
							|  |  |  |     for (WorkSpace *workspace = bmain->workspaces.first; workspace; | 
					
						
							|  |  |  |          workspace = workspace->id.next) { | 
					
						
							|  |  |  |       while (!BLI_listbase_is_empty(&workspace->tools)) { | 
					
						
							|  |  |  |         BKE_workspace_tool_remove(workspace, workspace->tools.first); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 52)) { | 
					
						
							|  |  |  |     LISTBASE_FOREACH (ParticleSettings *, part, &bmain->particles) { | 
					
						
							|  |  |  |       /* Replace deprecated PART_DRAW_BB by PART_DRAW_NOT */ | 
					
						
							|  |  |  |       if (part->ren_as == PART_DRAW_BB) { | 
					
						
							|  |  |  |         part->ren_as = PART_DRAW_NOT; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       if (part->draw_as == PART_DRAW_BB) { | 
					
						
							|  |  |  |         part->draw_as = PART_DRAW_NOT; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "TriangulateModifierData", "int", "min_vertices")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (md->type == eModifierType_Triangulate) { | 
					
						
							|  |  |  |             TriangulateModifierData *smd = (TriangulateModifierData *)md; | 
					
						
							|  |  |  |             smd->min_vertices = 4; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     FOREACH_NODETREE_BEGIN (bmain, ntree, id) { | 
					
						
							|  |  |  |       if (ntree->type == NTREE_SHADER) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (bNode *, node, &ntree->nodes) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           /* Fix missing version patching from earlier changes. */ | 
					
						
							|  |  |  |           if (STREQ(node->idname, "ShaderNodeOutputLamp")) { | 
					
						
							|  |  |  |             STRNCPY(node->idname, "ShaderNodeOutputLight"); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           if (node->type == SH_NODE_BSDF_PRINCIPLED && node->custom2 == 0) { | 
					
						
							|  |  |  |             node->custom2 = SHD_SUBSURFACE_BURLEY; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     FOREACH_NODETREE_END; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 53)) { | 
					
						
							|  |  |  |     for (Material *mat = bmain->materials.first; mat; mat = mat->id.next) { | 
					
						
							|  |  |  |       /* Eevee: Keep material appearance consistent with previous behavior. */ | 
					
						
							|  |  |  |       if (!mat->use_nodes || !mat->nodetree || mat->blend_method == MA_BM_SOLID) { | 
					
						
							|  |  |  |         mat->blend_shadow = MA_BS_SOLID; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* grease pencil default animation channel color */ | 
					
						
							|  |  |  |     { | 
					
						
							|  |  |  |       for (bGPdata *gpd = bmain->gpencils.first; gpd; gpd = gpd->id.next) { | 
					
						
							|  |  |  |         if (gpd->flag & GP_DATA_ANNOTATIONS) { | 
					
						
							|  |  |  |           continue; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |         LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           /* default channel color */ | 
					
						
							|  |  |  |           ARRAY_SET_ITEMS(gpl->color, 0.2f, 0.2f, 0.2f); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 54)) { | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |       bool is_first_subdiv = true; | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         if (md->type == eModifierType_Subsurf) { | 
					
						
							|  |  |  |           SubsurfModifierData *smd = (SubsurfModifierData *)md; | 
					
						
							|  |  |  |           if (is_first_subdiv) { | 
					
						
							|  |  |  |             smd->flags |= eSubsurfModifierFlag_UseCrease; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           else { | 
					
						
							|  |  |  |             smd->flags &= ~eSubsurfModifierFlag_UseCrease; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           is_first_subdiv = false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         else if (md->type == eModifierType_Multires) { | 
					
						
							|  |  |  |           MultiresModifierData *mmd = (MultiresModifierData *)md; | 
					
						
							|  |  |  |           if (is_first_subdiv) { | 
					
						
							|  |  |  |             mmd->flags |= eMultiresModifierFlag_UseCrease; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           else { | 
					
						
							|  |  |  |             mmd->flags &= ~eMultiresModifierFlag_UseCrease; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           is_first_subdiv = false; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 55)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_TEXT) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /* Remove multiple footers that were added by mistake. */ | 
					
						
							| 
									
										
										
										
											2019-10-10 13:19:04 +11:00
										 |  |  |             do_versions_remove_regions_by_type(regionbase, RGN_TYPE_FOOTER); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /* Add footer. */ | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             ARegion *region = do_versions_add_region(RGN_TYPE_FOOTER, "footer for text"); | 
					
						
							|  |  |  |             region->alignment = (U.uiflag & USER_HEADER_BOTTOM) ? RGN_ALIGN_TOP : RGN_ALIGN_BOTTOM; | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             ARegion *region_header = do_versions_find_region(regionbase, RGN_TYPE_HEADER); | 
					
						
							|  |  |  |             BLI_insertlinkafter(regionbase, region_header, region); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 56)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             v3d->gizmo_show_armature = V3D_GIZMO_SHOW_ARMATURE_BBONE | | 
					
						
							|  |  |  |                                        V3D_GIZMO_SHOW_ARMATURE_ROLL; | 
					
						
							|  |  |  |             v3d->gizmo_show_empty = V3D_GIZMO_SHOW_EMPTY_IMAGE | V3D_GIZMO_SHOW_EMPTY_FORCE_FIELD; | 
					
						
							|  |  |  |             v3d->gizmo_show_light = V3D_GIZMO_SHOW_LIGHT_SIZE | V3D_GIZMO_SHOW_LIGHT_LOOK_AT; | 
					
						
							|  |  |  |             v3d->gizmo_show_camera = V3D_GIZMO_SHOW_CAMERA_LENS | V3D_GIZMO_SHOW_CAMERA_DOF_DIST; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 57)) { | 
					
						
							|  |  |  |     /* Enable Show Interpolation in dopesheet by default. */ | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |           if (sl->spacetype == SPACE_ACTION) { | 
					
						
							|  |  |  |             SpaceAction *saction = (SpaceAction *)sl; | 
					
						
							|  |  |  |             if ((saction->flag & SACTION_SHOW_EXTREMES) == 0) { | 
					
						
							|  |  |  |               saction->flag |= SACTION_SHOW_INTERPOLATION; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* init grease pencil brush gradients */ | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "BrushGpencilSettings", "float", "hardeness")) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       for (Brush *brush = bmain->brushes.first; brush; brush = brush->id.next) { | 
					
						
							|  |  |  |         if (brush->gpencil_settings != NULL) { | 
					
						
							|  |  |  |           BrushGpencilSettings *gp = brush->gpencil_settings; | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |           gp->hardeness = 1.0f; | 
					
						
							|  |  |  |           copy_v2_fl(gp->aspect_ratio, 1.0f); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* init grease pencil stroke gradients */ | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "bGPDstroke", "float", "hardeness")) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |       for (bGPdata *gpd = bmain->gpencils.first; gpd; gpd = gpd->id.next) { | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |         LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (bGPDframe *, gpf, &gpl->frames) { | 
					
						
							|  |  |  |             LISTBASE_FOREACH (bGPDstroke *, gps, &gpf->strokes) { | 
					
						
							|  |  |  |               gps->hardeness = 1.0f; | 
					
						
							|  |  |  |               copy_v2_fl(gps->aspect_ratio, 1.0f); | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 11:35:20 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* enable the axis aligned ortho grid by default */ | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-17 11:35:20 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             v3d->gridflag |= V3D_SHOW_ORTHO_GRID; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  |   /* Keep un-versioned until we're finished adding space types. */ | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |           ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                  &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  |           /* All spaces that use tools must be eventually added. */ | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |           ARegion *region = NULL; | 
					
						
							| 
									
										
										
										
											2020-01-22 14:54:44 +01:00
										 |  |  |           if (ELEM(sl->spacetype, SPACE_VIEW3D, SPACE_IMAGE, SPACE_SEQ) && | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |               ((region = do_versions_find_region_or_null(regionbase, RGN_TYPE_TOOL_HEADER)) == | 
					
						
							|  |  |  |                NULL)) { | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  |             /* Add tool header. */ | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             region = do_versions_add_region(RGN_TYPE_TOOL_HEADER, "tool header"); | 
					
						
							|  |  |  |             region->alignment = (U.uiflag & USER_HEADER_BOTTOM) ? RGN_ALIGN_BOTTOM : RGN_ALIGN_TOP; | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             ARegion *region_header = do_versions_find_region(regionbase, RGN_TYPE_HEADER); | 
					
						
							|  |  |  |             BLI_insertlinkbefore(regionbase, region_header, region); | 
					
						
							| 
									
										
										
										
											2019-04-29 22:50:14 +10:00
										 |  |  |             /* Hide by default, enable for painting workspaces (startup only). */ | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             region->flag |= RGN_FLAG_HIDDEN | RGN_FLAG_HIDDEN_BY_USER; | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |           if (region != NULL) { | 
					
						
							|  |  |  |             SET_FLAG_FROM_TEST( | 
					
						
							|  |  |  |                 region->flag, region->flag & RGN_FLAG_HIDDEN_BY_USER, RGN_FLAG_HIDDEN); | 
					
						
							| 
									
										
										
										
											2019-04-29 17:32:39 +10:00
										 |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-04-18 21:13:22 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 14:13:41 -07:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 60)) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "bSplineIKConstraint", "short", "yScaleMode")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |         if (ob->pose) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |           LISTBASE_FOREACH (bPoseChannel *, pchan, &ob->pose->chanbase) { | 
					
						
							|  |  |  |             LISTBASE_FOREACH (bConstraint *, con, &pchan->constraints) { | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |               if (con->type == CONSTRAINT_TYPE_SPLINEIK) { | 
					
						
							|  |  |  |                 bSplineIKConstraint *data = (bSplineIKConstraint *)con->data; | 
					
						
							|  |  |  |                 if ((data->flag & CONSTRAINT_SPLINEIK_SCALE_LIMITED) == 0) { | 
					
						
							|  |  |  |                   data->yScaleMode = CONSTRAINT_SPLINEIK_YS_FIT_CURVE; | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-20 11:58:44 +02:00
										 |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "View3DOverlay", "float", "sculpt_mode_mask_opacity")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-04-20 11:58:44 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.sculpt_mode_mask_opacity = 0.75f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-05-02 15:18:53 +02:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SceneDisplay", "char", "render_aa")) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |         scene->display.render_aa = SCE_DISPLAY_AA_SAMPLES_8; | 
					
						
							|  |  |  |         scene->display.viewport_aa = SCE_DISPLAY_AA_FXAA; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-20 11:58:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-20 18:06:31 +03:00
										 |  |  |     /* Split bbone_scalein/bbone_scaleout into x and y fields. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "bPoseChannel", "float", "scale_out_y")) { | 
					
						
							|  |  |  |       /* Update armature data and pose channels. */ | 
					
						
							|  |  |  |       LISTBASE_FOREACH (bArmature *, arm, &bmain->armatures) { | 
					
						
							|  |  |  |         do_version_bones_split_bbone_scale(&arm->bonebase); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |         if (ob->pose) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (bPoseChannel *, pchan, &ob->pose->chanbase) { | 
					
						
							|  |  |  |             pchan->scale_in_y = pchan->scale_in_x; | 
					
						
							|  |  |  |             pchan->scale_out_y = pchan->scale_out_x; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Update action curves and drivers. */ | 
					
						
							|  |  |  |       LISTBASE_FOREACH (bAction *, act, &bmain->actions) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH_MUTABLE (FCurve *, fcu, &act->curves) { | 
					
						
							|  |  |  |           do_version_bbone_scale_fcurve_fix(&act->curves, fcu); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       BKE_animdata_main_cb(bmain, do_version_bbone_scale_animdata_cb, NULL); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-28 14:13:41 -07:00
										 |  |  |     for (Scene *sce = bmain->scenes.first; sce != NULL; sce = sce->id.next) { | 
					
						
							|  |  |  |       if (sce->ed != NULL) { | 
					
						
							|  |  |  |         do_versions_seq_set_cache_defaults(sce->ed); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Outliner Visibility Update
See T61578 for discussions and mockups.
Visibility Options
==================
We are adding more granular control over restriction columns in the outliner,
exposing "indirect only" and "holdout" as options, and change the way
users enable/disable collections in a viewlayer.
We also rename the object viewport restriction to hide instance.
So the options we have are:
Collection
----------
* Render Visibility
* Instance Visibility
* Selectable
(View) Layer Collection
-----------------------
* Enable
* Holdout
* Indirect Only
* Viewport
Shortcuts
=========
Isolate Collection
------------------
* Ctr + click isolates the collection.
It turns all its parents and children "visible", and all the other
collections "invisible".
If ALL the collections were already properly set, we re-set the
collections to their default value.
Set Collection Inside Collections and Objects
---------------------------------------------
* Shift + click: Set/unset inside collections and objects.
We only set objects values as well when we are in View Layer mode and
(obviously) when the objects have a matching property.
Icons
=====
Little reminder that we will need better icons for holdout, indirect only, and
probably instanced (nothing wrong with the current, but it differs from
the proposal when it is turned off).
Also, we need to decide where do we want the modifier/bones/... icons to
be (in which column) and ideally make sure their icons match the ones we
use for collections/objects.
At the moment those are using the screen icon, which is not being used
by collections.
Reviewers: brecht, billrey
Subscribers: pablovazquez
Differential Revision: https://developer.blender.org/D4823
											
										 
											2019-05-04 14:14:37 -03:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 61)) { | 
					
						
							| 
									
										
										
										
											2019-05-08 12:08:54 +03:00
										 |  |  |     /* Added a power option to Copy Scale. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "bSizeLikeConstraint", "float", "power")) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |         do_version_constraints_copy_scale_power(&ob->constraints); | 
					
						
							|  |  |  |         if (ob->pose) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (bPoseChannel *, pchan, &ob->pose->chanbase) { | 
					
						
							|  |  |  |             do_version_constraints_copy_scale_power(&pchan->constraints); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-08 15:09:02 +02:00
										 |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-05-15 17:39:07 +02:00
										 |  |  |           if (ELEM(sl->spacetype, SPACE_CLIP, SPACE_GRAPH, SPACE_SEQ)) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2019-05-08 15:09:02 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             ARegion *region = NULL; | 
					
						
							| 
									
										
										
										
											2019-05-15 17:39:07 +02:00
										 |  |  |             if (sl->spacetype == SPACE_CLIP) { | 
					
						
							| 
									
										
										
										
											2019-05-08 15:09:02 +02:00
										 |  |  |               if (((SpaceClip *)sl)->view == SC_VIEW_GRAPH) { | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |                 region = do_versions_find_region_or_null(regionbase, RGN_TYPE_PREVIEW); | 
					
						
							| 
									
										
										
										
											2019-05-08 15:09:02 +02:00
										 |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             else { | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |               region = do_versions_find_region_or_null(regionbase, RGN_TYPE_WINDOW); | 
					
						
							| 
									
										
										
										
											2019-05-08 15:09:02 +02:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             if (region != NULL) { | 
					
						
							|  |  |  |               region->v2d.scroll &= ~V2D_SCROLL_LEFT; | 
					
						
							|  |  |  |               region->v2d.scroll |= V2D_SCROLL_RIGHT; | 
					
						
							| 
									
										
										
										
											2019-05-08 15:09:02 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												Outliner Visibility Update
See T61578 for discussions and mockups.
Visibility Options
==================
We are adding more granular control over restriction columns in the outliner,
exposing "indirect only" and "holdout" as options, and change the way
users enable/disable collections in a viewlayer.
We also rename the object viewport restriction to hide instance.
So the options we have are:
Collection
----------
* Render Visibility
* Instance Visibility
* Selectable
(View) Layer Collection
-----------------------
* Enable
* Holdout
* Indirect Only
* Viewport
Shortcuts
=========
Isolate Collection
------------------
* Ctr + click isolates the collection.
It turns all its parents and children "visible", and all the other
collections "invisible".
If ALL the collections were already properly set, we re-set the
collections to their default value.
Set Collection Inside Collections and Objects
---------------------------------------------
* Shift + click: Set/unset inside collections and objects.
We only set objects values as well when we are in View Layer mode and
(obviously) when the objects have a matching property.
Icons
=====
Little reminder that we will need better icons for holdout, indirect only, and
probably instanced (nothing wrong with the current, but it differs from
the proposal when it is turned off).
Also, we need to decide where do we want the modifier/bones/... icons to
be (in which column) and ideally make sure their icons match the ones we
use for collections/objects.
At the moment those are using the screen icon, which is not being used
by collections.
Reviewers: brecht, billrey
Subscribers: pablovazquez
Differential Revision: https://developer.blender.org/D4823
											
										 
											2019-05-04 14:14:37 -03:00
										 |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
											  
											
												Outliner Visibility Update
See T61578 for discussions and mockups.
Visibility Options
==================
We are adding more granular control over restriction columns in the outliner,
exposing "indirect only" and "holdout" as options, and change the way
users enable/disable collections in a viewlayer.
We also rename the object viewport restriction to hide instance.
So the options we have are:
Collection
----------
* Render Visibility
* Instance Visibility
* Selectable
(View) Layer Collection
-----------------------
* Enable
* Holdout
* Indirect Only
* Viewport
Shortcuts
=========
Isolate Collection
------------------
* Ctr + click isolates the collection.
It turns all its parents and children "visible", and all the other
collections "invisible".
If ALL the collections were already properly set, we re-set the
collections to their default value.
Set Collection Inside Collections and Objects
---------------------------------------------
* Shift + click: Set/unset inside collections and objects.
We only set objects values as well when we are in View Layer mode and
(obviously) when the objects have a matching property.
Icons
=====
Little reminder that we will need better icons for holdout, indirect only, and
probably instanced (nothing wrong with the current, but it differs from
the proposal when it is turned off).
Also, we need to decide where do we want the modifier/bones/... icons to
be (in which column) and ideally make sure their icons match the ones we
use for collections/objects.
At the moment those are using the screen icon, which is not being used
by collections.
Reviewers: brecht, billrey
Subscribers: pablovazquez
Differential Revision: https://developer.blender.org/D4823
											
										 
											2019-05-04 14:14:37 -03:00
										 |  |  |           if (sl->spacetype != SPACE_OUTLINER) { | 
					
						
							|  |  |  |             continue; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |           SpaceOutliner *so = (SpaceOutliner *)sl; | 
					
						
							|  |  |  |           so->filter &= ~SO_FLAG_UNUSED_1; | 
					
						
							| 
									
										
										
										
											2019-05-17 10:15:27 -03:00
										 |  |  |           so->show_restrict_flags = SO_RESTRICT_ENABLE | SO_RESTRICT_HIDE; | 
					
						
							| 
									
										
											  
											
												Outliner Visibility Update
See T61578 for discussions and mockups.
Visibility Options
==================
We are adding more granular control over restriction columns in the outliner,
exposing "indirect only" and "holdout" as options, and change the way
users enable/disable collections in a viewlayer.
We also rename the object viewport restriction to hide instance.
So the options we have are:
Collection
----------
* Render Visibility
* Instance Visibility
* Selectable
(View) Layer Collection
-----------------------
* Enable
* Holdout
* Indirect Only
* Viewport
Shortcuts
=========
Isolate Collection
------------------
* Ctr + click isolates the collection.
It turns all its parents and children "visible", and all the other
collections "invisible".
If ALL the collections were already properly set, we re-set the
collections to their default value.
Set Collection Inside Collections and Objects
---------------------------------------------
* Shift + click: Set/unset inside collections and objects.
We only set objects values as well when we are in View Layer mode and
(obviously) when the objects have a matching property.
Icons
=====
Little reminder that we will need better icons for holdout, indirect only, and
probably instanced (nothing wrong with the current, but it differs from
the proposal when it is turned off).
Also, we need to decide where do we want the modifier/bones/... icons to
be (in which column) and ideally make sure their icons match the ones we
use for collections/objects.
At the moment those are using the screen icon, which is not being used
by collections.
Reviewers: brecht, billrey
Subscribers: pablovazquez
Differential Revision: https://developer.blender.org/D4823
											
										 
											2019-05-04 14:14:37 -03:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-18 12:44:44 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 69)) { | 
					
						
							| 
									
										
										
										
											2019-05-09 11:19:38 +02:00
										 |  |  |     LISTBASE_FOREACH (bArmature *, arm, &bmain->armatures) { | 
					
						
							|  |  |  |       arm->flag &= ~(ARM_FLAG_UNUSED_7 | ARM_FLAG_UNUSED_9); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-05-15 14:45:33 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Initializes sun lights with the new angular diameter property */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Light", "float", "sun_angle")) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Light *, light, &bmain->lights) { | 
					
						
							|  |  |  |         light->sun_angle = 2.0f * atanf(light->area_size); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-04-17 06:17:24 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-05-18 12:44:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-18 20:52:20 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 70)) { | 
					
						
							|  |  |  |     /* New image alpha modes. */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Image *, image, &bmain->images) { | 
					
						
							|  |  |  |       const int IMA_IGNORE_ALPHA = (1 << 12); | 
					
						
							|  |  |  |       if (image->flag & IMA_IGNORE_ALPHA) { | 
					
						
							|  |  |  |         image->alpha_mode = IMA_ALPHA_IGNORE; | 
					
						
							|  |  |  |         image->flag &= ~IMA_IGNORE_ALPHA; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-05 17:20:19 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 71)) { | 
					
						
							|  |  |  |     /* This assumes the Blender builtin config. Depending on the OCIO
 | 
					
						
							|  |  |  |      * environment variable for versioning is weak, and these deprecated view | 
					
						
							|  |  |  |      * transforms and look names don't seem to exist in other commonly used | 
					
						
							|  |  |  |      * OCIO configs so .blend files created for those would be unaffected. */ | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       ColorManagedViewSettings *view_settings; | 
					
						
							|  |  |  |       view_settings = &scene->view_settings; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (STREQ(view_settings->view_transform, "Default")) { | 
					
						
							|  |  |  |         STRNCPY(view_settings->view_transform, "Standard"); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (STREQ(view_settings->view_transform, "RRT") || | 
					
						
							|  |  |  |                STREQ(view_settings->view_transform, "Film")) { | 
					
						
							|  |  |  |         STRNCPY(view_settings->view_transform, "Filmic"); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |       else if (STREQ(view_settings->view_transform, "Log")) { | 
					
						
							|  |  |  |         STRNCPY(view_settings->view_transform, "Filmic Log"); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       if (STREQ(view_settings->look, "Filmic - Base Contrast")) { | 
					
						
							|  |  |  |         STRNCPY(view_settings->look, "None"); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-31 14:40:41 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 74)) { | 
					
						
							| 
									
										
										
										
											2019-05-23 11:50:15 -07:00
										 |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       if (scene->ed != NULL) { | 
					
						
							|  |  |  |         do_versions_seq_alloc_transform_and_crop(&scene->ed->seqbase); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-07-22 18:44:22 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 280, 75)) { | 
					
						
							| 
									
										
										
										
											2019-05-31 13:17:16 -03:00
										 |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       if (scene->master_collection != NULL) { | 
					
						
							|  |  |  |         scene->master_collection->flag &= ~(COLLECTION_RESTRICT_VIEWPORT | | 
					
						
							|  |  |  |                                             COLLECTION_RESTRICT_SELECT | | 
					
						
							|  |  |  |                                             COLLECTION_RESTRICT_RENDER); | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-07-15 22:29:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |       UnitSettings *unit = &scene->unit; | 
					
						
							|  |  |  |       if (unit->system == USER_UNIT_NONE) { | 
					
						
							|  |  |  |         unit->length_unit = (char)USER_UNIT_ADAPTIVE; | 
					
						
							|  |  |  |         unit->mass_unit = (char)USER_UNIT_ADAPTIVE; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       RenderData *render_data = &scene->r; | 
					
						
							|  |  |  |       switch (render_data->ffcodecdata.ffmpeg_preset) { | 
					
						
							|  |  |  |         case FFM_PRESET_ULTRAFAST: | 
					
						
							|  |  |  |         case FFM_PRESET_SUPERFAST: | 
					
						
							|  |  |  |           render_data->ffcodecdata.ffmpeg_preset = FFM_PRESET_REALTIME; | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case FFM_PRESET_VERYFAST: | 
					
						
							|  |  |  |         case FFM_PRESET_FASTER: | 
					
						
							|  |  |  |         case FFM_PRESET_FAST: | 
					
						
							|  |  |  |         case FFM_PRESET_MEDIUM: | 
					
						
							|  |  |  |           render_data->ffcodecdata.ffmpeg_preset = FFM_PRESET_GOOD; | 
					
						
							|  |  |  |           break; | 
					
						
							|  |  |  |         case FFM_PRESET_SLOW: | 
					
						
							|  |  |  |         case FFM_PRESET_SLOWER: | 
					
						
							|  |  |  |         case FFM_PRESET_VERYSLOW: | 
					
						
							|  |  |  |           render_data->ffcodecdata.ffmpeg_preset = FFM_PRESET_BEST; | 
					
						
							|  |  |  |       } | 
					
						
							| 
									
										
										
										
											2019-05-31 13:17:16 -03:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-06-07 10:44:18 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     LISTBASE_FOREACH (bArmature *, arm, &bmain->armatures) { | 
					
						
							|  |  |  |       arm->flag &= ~(ARM_FLAG_UNUSED_6); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-05-18 12:44:44 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-07-22 18:44:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-01 16:00:37 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 1)) { | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-08-01 16:00:37 +02:00
										 |  |  |         if (md->type == eModifierType_DataTransfer) { | 
					
						
							|  |  |  |           /* Now datatransfer's mix factor is multiplied with weights when any,
 | 
					
						
							|  |  |  |            * instead of being ignored, | 
					
						
							|  |  |  |            * we need to take care of that to keep 'old' files compatible. */ | 
					
						
							|  |  |  |           DataTransferModifierData *dtmd = (DataTransferModifierData *)md; | 
					
						
							|  |  |  |           if (dtmd->defgrp_name[0] != '\0') { | 
					
						
							|  |  |  |             dtmd->mix_factor = 1.0f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-20 14:34:39 -06:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 3)) { | 
					
						
							| 
									
										
										
										
											2019-08-04 12:51:28 +02:00
										 |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-08-04 12:51:28 +02:00
										 |  |  |           if (sl->spacetype == SPACE_TEXT) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2020-03-06 16:56:42 +01:00
										 |  |  |             ARegion *region = do_versions_find_region_or_null(regionbase, RGN_TYPE_UI); | 
					
						
							|  |  |  |             if (region) { | 
					
						
							|  |  |  |               region->alignment = RGN_ALIGN_RIGHT; | 
					
						
							| 
									
										
										
										
											2019-08-04 12:51:28 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-08-17 17:42:00 -06:00
										 |  |  |           /* Mark outliners as dirty for syncing and enable synced selection */ | 
					
						
							|  |  |  |           if (sl->spacetype == SPACE_OUTLINER) { | 
					
						
							|  |  |  |             SpaceOutliner *soutliner = (SpaceOutliner *)sl; | 
					
						
							|  |  |  |             soutliner->sync_select_dirty |= WM_OUTLINER_SYNC_SELECT_FROM_ALL; | 
					
						
							|  |  |  |             soutliner->flag |= SO_SYNC_SELECT; | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-08-04 12:51:28 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-08-14 18:37:46 +02:00
										 |  |  |     for (Mesh *mesh = bmain->meshes.first; mesh; mesh = mesh->id.next) { | 
					
						
							|  |  |  |       if (mesh->remesh_voxel_size == 0.0f) { | 
					
						
							|  |  |  |         mesh->remesh_voxel_size = 0.1f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-07-22 18:44:22 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-08-20 14:34:39 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-22 20:43:19 +03:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 4)) { | 
					
						
							|  |  |  |     ID *id; | 
					
						
							|  |  |  |     FOREACH_MAIN_ID_BEGIN (bmain, id) { | 
					
						
							|  |  |  |       bNodeTree *ntree = ntreeFromID(id); | 
					
						
							|  |  |  |       if (ntree) { | 
					
						
							| 
									
										
										
										
											2020-03-11 12:47:25 +01:00
										 |  |  |         ntree->id.flag |= LIB_EMBEDDED_DATA; | 
					
						
							| 
									
										
										
										
											2019-08-22 20:43:19 +03:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |     FOREACH_MAIN_ID_END; | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-02 12:14:51 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 5)) { | 
					
						
							| 
									
										
										
										
											2019-08-30 16:27:31 +02:00
										 |  |  |     for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |       if (br->ob_mode & OB_MODE_SCULPT && br->normal_radius_factor == 0.0f) { | 
					
						
							|  |  |  |         br->normal_radius_factor = 0.5f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-02 12:14:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							| 
									
										
										
										
											2019-09-04 00:23:58 +10:00
										 |  |  |       /* Older files do not have a master collection, which is then added through
 | 
					
						
							| 
									
										
										
										
											2019-09-02 12:14:51 +02:00
										 |  |  |        * `BKE_collection_master_add()`, so everything is fine. */ | 
					
						
							|  |  |  |       if (scene->master_collection != NULL) { | 
					
						
							| 
									
										
										
										
											2020-03-11 12:47:25 +01:00
										 |  |  |         scene->master_collection->id.flag |= LIB_EMBEDDED_DATA; | 
					
						
							| 
									
										
										
										
											2019-09-02 12:14:51 +02:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-27 15:47:30 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 6)) { | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-08-27 15:47:30 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |             v3d->shading.flag |= V3D_SHADING_SCENE_LIGHTS_RENDER | V3D_SHADING_SCENE_WORLD_RENDER; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             /* files by default don't have studio lights selected unless interacted
 | 
					
						
							| 
									
										
										
										
											2020-04-09 10:51:34 +10:00
										 |  |  |              * with the shading popover. When no studio-light could be read, we will | 
					
						
							| 
									
										
										
										
											2019-08-27 15:47:30 +02:00
										 |  |  |              * select the default world one. */ | 
					
						
							|  |  |  |             StudioLight *studio_light = BKE_studiolight_find(v3d->shading.lookdev_light, | 
					
						
							|  |  |  |                                                              STUDIOLIGHT_TYPE_WORLD); | 
					
						
							|  |  |  |             if (studio_light != NULL) { | 
					
						
							|  |  |  |               STRNCPY(v3d->shading.lookdev_light, studio_light->name); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-09 17:41:38 +02:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 9)) { | 
					
						
							| 
									
										
											  
											
												UI: File Browser Design Overhaul
This is a general redesign of the File Browser GUI and interaction
methods. For screenshots, check patch D5601.
Main changes in short:
* File Browser as floating window
* New layout of regions
* Popovers for view and filter options
* Vertical list view with interactive column header
* New and updated icons
* Keymap consistency fixes
* Many tweaks and fixes to the drawing of views
----
General:
* The file browser now opens as temporary floating window. It closes on
  Esc. The header is hidden then.
* When the file browser is opened as regular editor, the header remains
  visible.
* All file browser regions are now defined in Python (the button
  layout).
* Adjusted related operator UI names.
Keymap:
Keymap is now consistent with other list-based views in Blender, such as
the Outliner.
* Left click to select, double-click to open
* Right-click context menus
* Shift-click to fill selection
* Ctrl-click to extend selection
Operator options:
These previously overlapped with the source list, which caused numerous
issues with resizing and presenting many settings in a small panel area.
It was also generally inconsistent with Blender.
* Moved to new sidebar, which can easily be shown or hidden using a
  prominent Options toggle.
* IO operators have new layouts to match this new sidebar, using
  sub-panels. This will have to be committed separately (Add-on
  repository).
* If operators want to show the options by default, they have the option
  to do so (see `WM_FILESEL_SHOW_PROPS`, `hide_props_region`), otherwise
  they are hidden by default.
General Layout:
The layout has been changed to be simpler, more standard, and fits
better in with Blender 2.8.
* More conventional layout (file path at top, file name at the bottom,
  execute/cancel buttons in bottom right).
* Use of popovers to group controls, and allow for more descriptive
  naming.
* Search box is always live now, just like Outliner.
Views:
* Date Modified column combines both date and time, also uses user
  friendly strings for recent dates (i.e. "Yesterday", "Today").
* Details columns (file size, modification date/time) are now toggleable
  for all display types, they are not hardcoded per display type.
* File sizes now show as B, KB, MB, ... rather than B, KiB, MiB, … They
  are now also calculated using base 10 of course.
* Option to sort in inverse order.
Vertical List View:
* This view now used a much simpler single vertical list with columns
  for information.
* Users can click on the headers of these columns to order by that
  category, and click again to reverse the ordering.
Icons:
* Updated icons by Jendrzych, with better centering.
* Files and folders have new icons in Icon view.
* Both files and folders have reworked superimposed icons that show
  users the file/folder type.
* 3D file documents correctly use the 3d file icon, which was unused
  previously.
* Workspaces now show their icon on Link/Append - also when listed in
  the Outliner.
Minor Python-API breakage:
* `bpy.types.FileSelectParams.display_type`: `LIST_SHORT` and
  `LIST_LONG` are replaced by `LIST_VERTICAL` and `LIST_HORIZONTAL`.
Removes the feature where directories would automatically be created if
they are entered into the file path text button, but don't exist. We
were not sure if users use it enough to keep it. We can definitely bring
it back.
----
//Combined effort by @billreynish, @harley, @jendrzych, my university
colleague Brian Meisenheimer and myself.//
Differential Revision: https://developer.blender.org/D5601
Reviewers: Brecht, Bastien
											
										 
											2019-09-03 15:43:38 +02:00
										 |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
											  
											
												UI: File Browser Design Overhaul
This is a general redesign of the File Browser GUI and interaction
methods. For screenshots, check patch D5601.
Main changes in short:
* File Browser as floating window
* New layout of regions
* Popovers for view and filter options
* Vertical list view with interactive column header
* New and updated icons
* Keymap consistency fixes
* Many tweaks and fixes to the drawing of views
----
General:
* The file browser now opens as temporary floating window. It closes on
  Esc. The header is hidden then.
* When the file browser is opened as regular editor, the header remains
  visible.
* All file browser regions are now defined in Python (the button
  layout).
* Adjusted related operator UI names.
Keymap:
Keymap is now consistent with other list-based views in Blender, such as
the Outliner.
* Left click to select, double-click to open
* Right-click context menus
* Shift-click to fill selection
* Ctrl-click to extend selection
Operator options:
These previously overlapped with the source list, which caused numerous
issues with resizing and presenting many settings in a small panel area.
It was also generally inconsistent with Blender.
* Moved to new sidebar, which can easily be shown or hidden using a
  prominent Options toggle.
* IO operators have new layouts to match this new sidebar, using
  sub-panels. This will have to be committed separately (Add-on
  repository).
* If operators want to show the options by default, they have the option
  to do so (see `WM_FILESEL_SHOW_PROPS`, `hide_props_region`), otherwise
  they are hidden by default.
General Layout:
The layout has been changed to be simpler, more standard, and fits
better in with Blender 2.8.
* More conventional layout (file path at top, file name at the bottom,
  execute/cancel buttons in bottom right).
* Use of popovers to group controls, and allow for more descriptive
  naming.
* Search box is always live now, just like Outliner.
Views:
* Date Modified column combines both date and time, also uses user
  friendly strings for recent dates (i.e. "Yesterday", "Today").
* Details columns (file size, modification date/time) are now toggleable
  for all display types, they are not hardcoded per display type.
* File sizes now show as B, KB, MB, ... rather than B, KiB, MiB, … They
  are now also calculated using base 10 of course.
* Option to sort in inverse order.
Vertical List View:
* This view now used a much simpler single vertical list with columns
  for information.
* Users can click on the headers of these columns to order by that
  category, and click again to reverse the ordering.
Icons:
* Updated icons by Jendrzych, with better centering.
* Files and folders have new icons in Icon view.
* Both files and folders have reworked superimposed icons that show
  users the file/folder type.
* 3D file documents correctly use the 3d file icon, which was unused
  previously.
* Workspaces now show their icon on Link/Append - also when listed in
  the Outliner.
Minor Python-API breakage:
* `bpy.types.FileSelectParams.display_type`: `LIST_SHORT` and
  `LIST_LONG` are replaced by `LIST_VERTICAL` and `LIST_HORIZONTAL`.
Removes the feature where directories would automatically be created if
they are entered into the file path text button, but don't exist. We
were not sure if users use it enough to keep it. We can definitely bring
it back.
----
//Combined effort by @billreynish, @harley, @jendrzych, my university
colleague Brian Meisenheimer and myself.//
Differential Revision: https://developer.blender.org/D5601
Reviewers: Brecht, Bastien
											
										 
											2019-09-03 15:43:38 +02:00
										 |  |  |           if (sl->spacetype == SPACE_FILE) { | 
					
						
							|  |  |  |             SpaceFile *sfile = (SpaceFile *)sl; | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             ARegion *region_ui = do_versions_find_region(regionbase, RGN_TYPE_UI); | 
					
						
							|  |  |  |             ARegion *region_header = do_versions_find_region(regionbase, RGN_TYPE_HEADER); | 
					
						
							|  |  |  |             ARegion *region_toolprops = do_versions_find_region_or_null(regionbase, | 
					
						
							|  |  |  |                                                                         RGN_TYPE_TOOL_PROPS); | 
					
						
							| 
									
										
											  
											
												UI: File Browser Design Overhaul
This is a general redesign of the File Browser GUI and interaction
methods. For screenshots, check patch D5601.
Main changes in short:
* File Browser as floating window
* New layout of regions
* Popovers for view and filter options
* Vertical list view with interactive column header
* New and updated icons
* Keymap consistency fixes
* Many tweaks and fixes to the drawing of views
----
General:
* The file browser now opens as temporary floating window. It closes on
  Esc. The header is hidden then.
* When the file browser is opened as regular editor, the header remains
  visible.
* All file browser regions are now defined in Python (the button
  layout).
* Adjusted related operator UI names.
Keymap:
Keymap is now consistent with other list-based views in Blender, such as
the Outliner.
* Left click to select, double-click to open
* Right-click context menus
* Shift-click to fill selection
* Ctrl-click to extend selection
Operator options:
These previously overlapped with the source list, which caused numerous
issues with resizing and presenting many settings in a small panel area.
It was also generally inconsistent with Blender.
* Moved to new sidebar, which can easily be shown or hidden using a
  prominent Options toggle.
* IO operators have new layouts to match this new sidebar, using
  sub-panels. This will have to be committed separately (Add-on
  repository).
* If operators want to show the options by default, they have the option
  to do so (see `WM_FILESEL_SHOW_PROPS`, `hide_props_region`), otherwise
  they are hidden by default.
General Layout:
The layout has been changed to be simpler, more standard, and fits
better in with Blender 2.8.
* More conventional layout (file path at top, file name at the bottom,
  execute/cancel buttons in bottom right).
* Use of popovers to group controls, and allow for more descriptive
  naming.
* Search box is always live now, just like Outliner.
Views:
* Date Modified column combines both date and time, also uses user
  friendly strings for recent dates (i.e. "Yesterday", "Today").
* Details columns (file size, modification date/time) are now toggleable
  for all display types, they are not hardcoded per display type.
* File sizes now show as B, KB, MB, ... rather than B, KiB, MiB, … They
  are now also calculated using base 10 of course.
* Option to sort in inverse order.
Vertical List View:
* This view now used a much simpler single vertical list with columns
  for information.
* Users can click on the headers of these columns to order by that
  category, and click again to reverse the ordering.
Icons:
* Updated icons by Jendrzych, with better centering.
* Files and folders have new icons in Icon view.
* Both files and folders have reworked superimposed icons that show
  users the file/folder type.
* 3D file documents correctly use the 3d file icon, which was unused
  previously.
* Workspaces now show their icon on Link/Append - also when listed in
  the Outliner.
Minor Python-API breakage:
* `bpy.types.FileSelectParams.display_type`: `LIST_SHORT` and
  `LIST_LONG` are replaced by `LIST_VERTICAL` and `LIST_HORIZONTAL`.
Removes the feature where directories would automatically be created if
they are entered into the file path text button, but don't exist. We
were not sure if users use it enough to keep it. We can definitely bring
it back.
----
//Combined effort by @billreynish, @harley, @jendrzych, my university
colleague Brian Meisenheimer and myself.//
Differential Revision: https://developer.blender.org/D5601
Reviewers: Brecht, Bastien
											
										 
											2019-09-03 15:43:38 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             /* Reinsert UI region so that it spawns entire area width */ | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             BLI_remlink(regionbase, region_ui); | 
					
						
							|  |  |  |             BLI_insertlinkafter(regionbase, region_header, region_ui); | 
					
						
							| 
									
										
											  
											
												UI: File Browser Design Overhaul
This is a general redesign of the File Browser GUI and interaction
methods. For screenshots, check patch D5601.
Main changes in short:
* File Browser as floating window
* New layout of regions
* Popovers for view and filter options
* Vertical list view with interactive column header
* New and updated icons
* Keymap consistency fixes
* Many tweaks and fixes to the drawing of views
----
General:
* The file browser now opens as temporary floating window. It closes on
  Esc. The header is hidden then.
* When the file browser is opened as regular editor, the header remains
  visible.
* All file browser regions are now defined in Python (the button
  layout).
* Adjusted related operator UI names.
Keymap:
Keymap is now consistent with other list-based views in Blender, such as
the Outliner.
* Left click to select, double-click to open
* Right-click context menus
* Shift-click to fill selection
* Ctrl-click to extend selection
Operator options:
These previously overlapped with the source list, which caused numerous
issues with resizing and presenting many settings in a small panel area.
It was also generally inconsistent with Blender.
* Moved to new sidebar, which can easily be shown or hidden using a
  prominent Options toggle.
* IO operators have new layouts to match this new sidebar, using
  sub-panels. This will have to be committed separately (Add-on
  repository).
* If operators want to show the options by default, they have the option
  to do so (see `WM_FILESEL_SHOW_PROPS`, `hide_props_region`), otherwise
  they are hidden by default.
General Layout:
The layout has been changed to be simpler, more standard, and fits
better in with Blender 2.8.
* More conventional layout (file path at top, file name at the bottom,
  execute/cancel buttons in bottom right).
* Use of popovers to group controls, and allow for more descriptive
  naming.
* Search box is always live now, just like Outliner.
Views:
* Date Modified column combines both date and time, also uses user
  friendly strings for recent dates (i.e. "Yesterday", "Today").
* Details columns (file size, modification date/time) are now toggleable
  for all display types, they are not hardcoded per display type.
* File sizes now show as B, KB, MB, ... rather than B, KiB, MiB, … They
  are now also calculated using base 10 of course.
* Option to sort in inverse order.
Vertical List View:
* This view now used a much simpler single vertical list with columns
  for information.
* Users can click on the headers of these columns to order by that
  category, and click again to reverse the ordering.
Icons:
* Updated icons by Jendrzych, with better centering.
* Files and folders have new icons in Icon view.
* Both files and folders have reworked superimposed icons that show
  users the file/folder type.
* 3D file documents correctly use the 3d file icon, which was unused
  previously.
* Workspaces now show their icon on Link/Append - also when listed in
  the Outliner.
Minor Python-API breakage:
* `bpy.types.FileSelectParams.display_type`: `LIST_SHORT` and
  `LIST_LONG` are replaced by `LIST_VERTICAL` and `LIST_HORIZONTAL`.
Removes the feature where directories would automatically be created if
they are entered into the file path text button, but don't exist. We
were not sure if users use it enough to keep it. We can definitely bring
it back.
----
//Combined effort by @billreynish, @harley, @jendrzych, my university
colleague Brian Meisenheimer and myself.//
Differential Revision: https://developer.blender.org/D5601
Reviewers: Brecht, Bastien
											
										 
											2019-09-03 15:43:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             region_ui->flag |= RGN_FLAG_DYNAMIC_SIZE; | 
					
						
							| 
									
										
											  
											
												UI: File Browser Design Overhaul
This is a general redesign of the File Browser GUI and interaction
methods. For screenshots, check patch D5601.
Main changes in short:
* File Browser as floating window
* New layout of regions
* Popovers for view and filter options
* Vertical list view with interactive column header
* New and updated icons
* Keymap consistency fixes
* Many tweaks and fixes to the drawing of views
----
General:
* The file browser now opens as temporary floating window. It closes on
  Esc. The header is hidden then.
* When the file browser is opened as regular editor, the header remains
  visible.
* All file browser regions are now defined in Python (the button
  layout).
* Adjusted related operator UI names.
Keymap:
Keymap is now consistent with other list-based views in Blender, such as
the Outliner.
* Left click to select, double-click to open
* Right-click context menus
* Shift-click to fill selection
* Ctrl-click to extend selection
Operator options:
These previously overlapped with the source list, which caused numerous
issues with resizing and presenting many settings in a small panel area.
It was also generally inconsistent with Blender.
* Moved to new sidebar, which can easily be shown or hidden using a
  prominent Options toggle.
* IO operators have new layouts to match this new sidebar, using
  sub-panels. This will have to be committed separately (Add-on
  repository).
* If operators want to show the options by default, they have the option
  to do so (see `WM_FILESEL_SHOW_PROPS`, `hide_props_region`), otherwise
  they are hidden by default.
General Layout:
The layout has been changed to be simpler, more standard, and fits
better in with Blender 2.8.
* More conventional layout (file path at top, file name at the bottom,
  execute/cancel buttons in bottom right).
* Use of popovers to group controls, and allow for more descriptive
  naming.
* Search box is always live now, just like Outliner.
Views:
* Date Modified column combines both date and time, also uses user
  friendly strings for recent dates (i.e. "Yesterday", "Today").
* Details columns (file size, modification date/time) are now toggleable
  for all display types, they are not hardcoded per display type.
* File sizes now show as B, KB, MB, ... rather than B, KiB, MiB, … They
  are now also calculated using base 10 of course.
* Option to sort in inverse order.
Vertical List View:
* This view now used a much simpler single vertical list with columns
  for information.
* Users can click on the headers of these columns to order by that
  category, and click again to reverse the ordering.
Icons:
* Updated icons by Jendrzych, with better centering.
* Files and folders have new icons in Icon view.
* Both files and folders have reworked superimposed icons that show
  users the file/folder type.
* 3D file documents correctly use the 3d file icon, which was unused
  previously.
* Workspaces now show their icon on Link/Append - also when listed in
  the Outliner.
Minor Python-API breakage:
* `bpy.types.FileSelectParams.display_type`: `LIST_SHORT` and
  `LIST_LONG` are replaced by `LIST_VERTICAL` and `LIST_HORIZONTAL`.
Removes the feature where directories would automatically be created if
they are entered into the file path text button, but don't exist. We
were not sure if users use it enough to keep it. We can definitely bring
it back.
----
//Combined effort by @billreynish, @harley, @jendrzych, my university
colleague Brian Meisenheimer and myself.//
Differential Revision: https://developer.blender.org/D5601
Reviewers: Brecht, Bastien
											
										 
											2019-09-03 15:43:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             if (region_toolprops && | 
					
						
							|  |  |  |                 (region_toolprops->alignment == (RGN_ALIGN_BOTTOM | RGN_SPLIT_PREV))) { | 
					
						
							| 
									
										
											  
											
												UI: File Browser Design Overhaul
This is a general redesign of the File Browser GUI and interaction
methods. For screenshots, check patch D5601.
Main changes in short:
* File Browser as floating window
* New layout of regions
* Popovers for view and filter options
* Vertical list view with interactive column header
* New and updated icons
* Keymap consistency fixes
* Many tweaks and fixes to the drawing of views
----
General:
* The file browser now opens as temporary floating window. It closes on
  Esc. The header is hidden then.
* When the file browser is opened as regular editor, the header remains
  visible.
* All file browser regions are now defined in Python (the button
  layout).
* Adjusted related operator UI names.
Keymap:
Keymap is now consistent with other list-based views in Blender, such as
the Outliner.
* Left click to select, double-click to open
* Right-click context menus
* Shift-click to fill selection
* Ctrl-click to extend selection
Operator options:
These previously overlapped with the source list, which caused numerous
issues with resizing and presenting many settings in a small panel area.
It was also generally inconsistent with Blender.
* Moved to new sidebar, which can easily be shown or hidden using a
  prominent Options toggle.
* IO operators have new layouts to match this new sidebar, using
  sub-panels. This will have to be committed separately (Add-on
  repository).
* If operators want to show the options by default, they have the option
  to do so (see `WM_FILESEL_SHOW_PROPS`, `hide_props_region`), otherwise
  they are hidden by default.
General Layout:
The layout has been changed to be simpler, more standard, and fits
better in with Blender 2.8.
* More conventional layout (file path at top, file name at the bottom,
  execute/cancel buttons in bottom right).
* Use of popovers to group controls, and allow for more descriptive
  naming.
* Search box is always live now, just like Outliner.
Views:
* Date Modified column combines both date and time, also uses user
  friendly strings for recent dates (i.e. "Yesterday", "Today").
* Details columns (file size, modification date/time) are now toggleable
  for all display types, they are not hardcoded per display type.
* File sizes now show as B, KB, MB, ... rather than B, KiB, MiB, … They
  are now also calculated using base 10 of course.
* Option to sort in inverse order.
Vertical List View:
* This view now used a much simpler single vertical list with columns
  for information.
* Users can click on the headers of these columns to order by that
  category, and click again to reverse the ordering.
Icons:
* Updated icons by Jendrzych, with better centering.
* Files and folders have new icons in Icon view.
* Both files and folders have reworked superimposed icons that show
  users the file/folder type.
* 3D file documents correctly use the 3d file icon, which was unused
  previously.
* Workspaces now show their icon on Link/Append - also when listed in
  the Outliner.
Minor Python-API breakage:
* `bpy.types.FileSelectParams.display_type`: `LIST_SHORT` and
  `LIST_LONG` are replaced by `LIST_VERTICAL` and `LIST_HORIZONTAL`.
Removes the feature where directories would automatically be created if
they are entered into the file path text button, but don't exist. We
were not sure if users use it enough to keep it. We can definitely bring
it back.
----
//Combined effort by @billreynish, @harley, @jendrzych, my university
colleague Brian Meisenheimer and myself.//
Differential Revision: https://developer.blender.org/D5601
Reviewers: Brecht, Bastien
											
										 
											2019-09-03 15:43:38 +02:00
										 |  |  |               SpaceType *stype = BKE_spacetype_from_id(sl->spacetype); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               /* Remove empty region at old location. */ | 
					
						
							|  |  |  |               BLI_assert(sfile->op == NULL); | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |               BKE_area_region_free(stype, region_toolprops); | 
					
						
							|  |  |  |               BLI_freelinkN(regionbase, region_toolprops); | 
					
						
							| 
									
										
											  
											
												UI: File Browser Design Overhaul
This is a general redesign of the File Browser GUI and interaction
methods. For screenshots, check patch D5601.
Main changes in short:
* File Browser as floating window
* New layout of regions
* Popovers for view and filter options
* Vertical list view with interactive column header
* New and updated icons
* Keymap consistency fixes
* Many tweaks and fixes to the drawing of views
----
General:
* The file browser now opens as temporary floating window. It closes on
  Esc. The header is hidden then.
* When the file browser is opened as regular editor, the header remains
  visible.
* All file browser regions are now defined in Python (the button
  layout).
* Adjusted related operator UI names.
Keymap:
Keymap is now consistent with other list-based views in Blender, such as
the Outliner.
* Left click to select, double-click to open
* Right-click context menus
* Shift-click to fill selection
* Ctrl-click to extend selection
Operator options:
These previously overlapped with the source list, which caused numerous
issues with resizing and presenting many settings in a small panel area.
It was also generally inconsistent with Blender.
* Moved to new sidebar, which can easily be shown or hidden using a
  prominent Options toggle.
* IO operators have new layouts to match this new sidebar, using
  sub-panels. This will have to be committed separately (Add-on
  repository).
* If operators want to show the options by default, they have the option
  to do so (see `WM_FILESEL_SHOW_PROPS`, `hide_props_region`), otherwise
  they are hidden by default.
General Layout:
The layout has been changed to be simpler, more standard, and fits
better in with Blender 2.8.
* More conventional layout (file path at top, file name at the bottom,
  execute/cancel buttons in bottom right).
* Use of popovers to group controls, and allow for more descriptive
  naming.
* Search box is always live now, just like Outliner.
Views:
* Date Modified column combines both date and time, also uses user
  friendly strings for recent dates (i.e. "Yesterday", "Today").
* Details columns (file size, modification date/time) are now toggleable
  for all display types, they are not hardcoded per display type.
* File sizes now show as B, KB, MB, ... rather than B, KiB, MiB, … They
  are now also calculated using base 10 of course.
* Option to sort in inverse order.
Vertical List View:
* This view now used a much simpler single vertical list with columns
  for information.
* Users can click on the headers of these columns to order by that
  category, and click again to reverse the ordering.
Icons:
* Updated icons by Jendrzych, with better centering.
* Files and folders have new icons in Icon view.
* Both files and folders have reworked superimposed icons that show
  users the file/folder type.
* 3D file documents correctly use the 3d file icon, which was unused
  previously.
* Workspaces now show their icon on Link/Append - also when listed in
  the Outliner.
Minor Python-API breakage:
* `bpy.types.FileSelectParams.display_type`: `LIST_SHORT` and
  `LIST_LONG` are replaced by `LIST_VERTICAL` and `LIST_HORIZONTAL`.
Removes the feature where directories would automatically be created if
they are entered into the file path text button, but don't exist. We
were not sure if users use it enough to keep it. We can definitely bring
it back.
----
//Combined effort by @billreynish, @harley, @jendrzych, my university
colleague Brian Meisenheimer and myself.//
Differential Revision: https://developer.blender.org/D5601
Reviewers: Brecht, Bastien
											
										 
											2019-09-03 15:43:38 +02:00
										 |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             if (sfile->params) { | 
					
						
							|  |  |  |               sfile->params->details_flags |= FILE_DETAILS_SIZE | FILE_DETAILS_DATETIME; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
											  
											
												Armature: add Inherit Scale options to remove shear or average the scale.
As an inherent property of matrix-based transformation math, non-
uniform scaling of a parent bone induces shear into the transform
matrix of any rotated child. Such matrices cannot be cleanly
decomposed into a combination of location/rotation/scale, which
causes issues for rigging and animation tools.
Blender bones have options to exclude rotation and/or scale from the
inherited transformation, but don't have any support for removing the
often undesired shear component. That goal requires replacing simple
parenting with a combination of multiple bones and constraints. The
same is true about the goal of inheriting some scale, but completely
avoiding shear.
This patch replaces the old Inherit Scale checkbox with a enum that
supports multiple options:
* Full: inherit all effects of scale, like with enabled Inherit Scale.
* Fix Shear: removes shear from the final inherited transformation.
  The cleanup math is specifically designed to preserve the main
  axis of the bone, its length and total volume, and minimally
  affect roll on average. It however will not prevent reappearance
  of shear due to local rotation of the child or its children.
* Average: inherit uniform scale that represents the parent volume.
  This is the simplest foolproof solution that will inherit some
  scale without ever causing shear.
* None: completely remove scale and shear.
* None (Legacy): old disabled Inherit Scale checkbox.
  This mode does not handle parent shear in any way, so the child
  is likely to end up having both scale and shear. It is retained
  for backward compatibility.
Since many rigging-related addons access the use_inherit_scale
property from Python, it is retained as a backward compatibility
stub that provides the old functionality.
As a side effect of reworking the code, this also fixes a matrix
multiplication order bug in the Inherit Rotation code, which caused
the parent local scale to be applied in world space. In rigger
opinion this option is useless in production rigs, so this fix
should not be a problem.
Reviewers: brecht
Differential Revision: https://developer.blender.org/D5588
											
										 
											2019-09-04 10:10:27 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Convert the BONE_NO_SCALE flag to inherit_scale_mode enum. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Bone", "char", "inherit_scale_mode")) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (bArmature *, arm, &bmain->armatures) { | 
					
						
							|  |  |  |         do_version_bones_inherit_scale(&arm->bonebase); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-04 12:06:59 +03:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Convert the Offset flag to the mix mode enum. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "bRotateLikeConstraint", "char", "mix_mode")) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |         do_version_constraints_copy_rotation_mix_mode(&ob->constraints); | 
					
						
							|  |  |  |         if (ob->pose) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (bPoseChannel *, pchan, &ob->pose->chanbase) { | 
					
						
							|  |  |  |             do_version_constraints_copy_rotation_mix_mode(&pchan->constraints); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-04 16:22:47 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-09 10:51:34 +10:00
										 |  |  |     /* Added studio-light intensity. */ | 
					
						
							| 
									
										
										
										
											2019-09-04 16:22:47 +02:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "float", "studiolight_intensity")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-09-04 16:22:47 +02:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.studiolight_intensity = 1.0f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-06 23:14:57 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Elatic deform brush */ | 
					
						
							|  |  |  |     for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							| 
									
										
										
										
											2019-09-12 03:54:12 +02:00
										 |  |  |       if (br->ob_mode & OB_MODE_SCULPT && br->elastic_deform_volume_preservation == 0.0f) { | 
					
						
							|  |  |  |         br->elastic_deform_volume_preservation = 0.5f; | 
					
						
							| 
									
										
										
										
											2019-09-06 23:14:57 +02:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-08-20 14:34:39 -06:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-09-09 17:41:38 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-07 10:01:55 -03:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 281, 15)) { | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |       if (scene->toolsettings->snap_node_mode == SCE_SNAP_MODE_NODE_X) { | 
					
						
							|  |  |  |         scene->toolsettings->snap_node_mode = SCE_SNAP_MODE_GRID; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-19 14:25:29 -03:00
										 |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "LayerCollection", "short", "local_collections_bits")) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Scene *, scene, &bmain->scenes) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (ViewLayer *, view_layer, &scene->view_layers) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (LayerCollection *, layer_collection, &view_layer->layer_collections) { | 
					
						
							|  |  |  |             do_versions_local_collection_bits_set(layer_collection); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-17 13:08:37 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-09-17 13:08:37 +02:00
										 |  |  |           if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |             View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |             LISTBASE_FOREACH (ScrArea *, area_other, &screen->areabase) { | 
					
						
							|  |  |  |               LISTBASE_FOREACH (SpaceLink *, sl_other, &area_other->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-09-17 13:08:37 +02:00
										 |  |  |                 if (sl != sl_other && sl_other->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |                   View3D *v3d_other = (View3D *)sl_other; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                   if (v3d->shading.prop == v3d_other->shading.prop) { | 
					
						
							|  |  |  |                     v3d_other->shading.prop = NULL; | 
					
						
							|  |  |  |                   } | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-09-20 15:35:28 +02:00
										 |  |  |           else if (sl->spacetype == SPACE_FILE) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |             ListBase *regionbase = (sl == area->spacedata.first) ? &area->regionbase : | 
					
						
							|  |  |  |                                                                    &sl->regionbase; | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             ARegion *region_tools = do_versions_find_region_or_null(regionbase, RGN_TYPE_TOOLS); | 
					
						
							|  |  |  |             ARegion *region_header = do_versions_find_region(regionbase, RGN_TYPE_HEADER); | 
					
						
							| 
									
										
										
										
											2019-09-20 15:35:28 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |             if (region_tools) { | 
					
						
							|  |  |  |               ARegion *region_next = region_tools->next; | 
					
						
							| 
									
										
										
										
											2019-09-20 17:36:38 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |               /* We temporarily had two tools regions, get rid of the second one. */ | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |               if (region_next && region_next->regiontype == RGN_TYPE_TOOLS) { | 
					
						
							|  |  |  |                 do_versions_remove_region(regionbase, region_next); | 
					
						
							| 
									
										
										
										
											2019-09-20 17:36:38 +02:00
										 |  |  |               } | 
					
						
							| 
									
										
										
										
											2019-09-29 20:16:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |               BLI_remlink(regionbase, region_tools); | 
					
						
							|  |  |  |               BLI_insertlinkafter(regionbase, region_header, region_tools); | 
					
						
							| 
									
										
										
										
											2019-09-20 17:36:38 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |             else { | 
					
						
							| 
									
										
										
										
											2020-04-03 12:51:03 +02:00
										 |  |  |               region_tools = do_versions_add_region(RGN_TYPE_TOOLS, | 
					
						
							|  |  |  |                                                     "versioning file tools region"); | 
					
						
							|  |  |  |               BLI_insertlinkafter(regionbase, region_header, region_tools); | 
					
						
							|  |  |  |               region_tools->alignment = RGN_ALIGN_LEFT; | 
					
						
							| 
									
										
										
										
											2019-09-20 15:35:28 +02:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							| 
									
										
										
										
											2019-09-17 13:08:37 +02:00
										 |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-16 23:16:21 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |       if (br->ob_mode & OB_MODE_SCULPT && br->area_radius_factor == 0.0f) { | 
					
						
							|  |  |  |         br->area_radius_factor = 0.5f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-09-09 17:41:38 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-10-11 12:17:32 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 282, 2)) { | 
					
						
							|  |  |  |     do_version_curvemapping_walker(bmain, do_version_curvemapping_flag_extend_extrapolate); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-04 18:59:59 +01:00
										 |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							| 
									
										
										
										
											2020-04-03 13:25:03 +02:00
										 |  |  |         area->flag &= ~AREA_FLAG_UNUSED_6; | 
					
						
							| 
									
										
										
										
											2019-11-04 18:59:59 +01:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-20 16:12:32 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Add custom curve profile to toolsettings for bevel tool */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "ToolSettings", "CurveProfile", "custom_profile")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         ToolSettings *ts = scene->toolsettings; | 
					
						
							|  |  |  |         if ((ts) && (ts->custom_bevel_profile_preset == NULL)) { | 
					
						
							|  |  |  |           ts->custom_bevel_profile_preset = BKE_curveprofile_add(PROF_PRESET_LINE); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Add custom curve profile to bevel modifier */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "BevelModifier", "CurveProfile", "custom_profile")) { | 
					
						
							|  |  |  |       for (Object *object = bmain->objects.first; object != NULL; object = object->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &object->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-11-20 16:12:32 -05:00
										 |  |  |           if (md->type == eModifierType_Bevel) { | 
					
						
							|  |  |  |             BevelModifierData *bmd = (BevelModifierData *)md; | 
					
						
							|  |  |  |             if (!bmd->custom_profile) { | 
					
						
							|  |  |  |               bmd->custom_profile = BKE_curveprofile_add(PROF_PRESET_LINE); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-18 22:47:23 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Dash Ratio and Dash Samples */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Brush", "float", "dash_ratio")) { | 
					
						
							|  |  |  |       for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |         br->dash_ratio = 1.0f; | 
					
						
							|  |  |  |         br->dash_samples = 20; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-17 01:09:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Pose brush smooth iterations */ | 
					
						
							| 
									
										
										
										
											2019-11-27 16:53:43 +01:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Brush", "float", "pose_smooth_iterations")) { | 
					
						
							| 
									
										
										
										
											2019-11-17 01:09:08 +01:00
										 |  |  |       for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |         br->pose_smooth_iterations = 4; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-27 02:02:18 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-27 14:56:16 +01:00
										 |  |  |     /* Cloth pressure */ | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-11-27 14:56:16 +01:00
										 |  |  |         if (md->type == eModifierType_Cloth) { | 
					
						
							|  |  |  |           ClothModifierData *clmd = (ClothModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           clmd->sim_parms->pressure_factor = 1; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-10-11 12:17:32 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-11-30 17:03:22 +11:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 282, 3)) { | 
					
						
							| 
									
										
										
										
											2019-11-27 02:02:18 +01:00
										 |  |  |     /* Remove Unified pressure/size and pressure/alpha */ | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       ToolSettings *ts = scene->toolsettings; | 
					
						
							|  |  |  |       UnifiedPaintSettings *ups = &ts->unified_paint_settings; | 
					
						
							|  |  |  |       ups->flag &= ~(UNIFIED_PAINT_FLAG_UNUSED_0 | UNIFIED_PAINT_FLAG_UNUSED_1); | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-08 16:47:33 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Set the default render pass in the viewport to Combined. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "int", "render_pass")) { | 
					
						
							|  |  |  |       for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |         scene->display.shading.render_pass = SCE_PASS_COMBINED; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-11-08 16:47:33 +01:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.render_pass = SCE_PASS_COMBINED; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-30 17:03:22 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Make markers region visible by default. */ | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2019-11-30 17:03:22 +11:00
										 |  |  |           switch (sl->spacetype) { | 
					
						
							|  |  |  |             case SPACE_SEQ: { | 
					
						
							|  |  |  |               SpaceSeq *sseq = (SpaceSeq *)sl; | 
					
						
							|  |  |  |               sseq->flag |= SEQ_SHOW_MARKERS; | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_ACTION: { | 
					
						
							|  |  |  |               SpaceAction *saction = (SpaceAction *)sl; | 
					
						
							|  |  |  |               saction->flag |= SACTION_SHOW_MARKERS; | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_GRAPH: { | 
					
						
							|  |  |  |               SpaceGraph *sipo = (SpaceGraph *)sl; | 
					
						
							|  |  |  |               sipo->flag |= SIPO_SHOW_MARKERS; | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case SPACE_NLA: { | 
					
						
							|  |  |  |               SpaceNla *snla = (SpaceNla *)sl; | 
					
						
							|  |  |  |               snla->flag |= SNLA_SHOW_MARKERS; | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-14 12:24:14 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 3)) { | 
					
						
							| 
									
										
										
										
											2020-04-09 17:56:36 -03:00
										 |  |  |     /* Color Management Look. */ | 
					
						
							|  |  |  |     for (Scene *scene = bmain->scenes.first; scene; scene = scene->id.next) { | 
					
						
							|  |  |  |       ColorManagedViewSettings *view_settings; | 
					
						
							|  |  |  |       view_settings = &scene->view_settings; | 
					
						
							|  |  |  |       if (BLI_str_startswith(view_settings->look, "Filmic - ")) { | 
					
						
							| 
									
										
										
										
											2020-04-16 10:31:51 -03:00
										 |  |  |         char *src = view_settings->look + strlen("Filmic - "); | 
					
						
							|  |  |  |         memmove(view_settings->look, src, strlen(src) + 1); | 
					
						
							| 
									
										
										
										
											2020-04-09 17:56:36 -03:00
										 |  |  |       } | 
					
						
							|  |  |  |       else if (BLI_str_startswith(view_settings->look, "Standard - ")) { | 
					
						
							| 
									
										
										
										
											2020-04-16 10:31:51 -03:00
										 |  |  |         char *src = view_settings->look + strlen("Standard - "); | 
					
						
							|  |  |  |         memmove(view_settings->look, src, strlen(src) + 1); | 
					
						
							| 
									
										
										
										
											2020-04-09 17:56:36 -03:00
										 |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-11 13:51:29 +11:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-01-22 14:54:44 +01:00
										 |  |  |     /* Sequencer Tool region */ | 
					
						
							|  |  |  |     do_versions_area_ensure_tool_region(bmain, SPACE_SEQ, RGN_FLAG_HIDDEN); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-09 19:10:55 +01:00
										 |  |  |     /* Cloth internal springs */ | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |       LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2019-12-09 19:10:55 +01:00
										 |  |  |         if (md->type == eModifierType_Cloth) { | 
					
						
							|  |  |  |           ClothModifierData *clmd = (ClothModifierData *)md; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           clmd->sim_parms->internal_tension = 15.0f; | 
					
						
							|  |  |  |           clmd->sim_parms->max_internal_tension = 15.0f; | 
					
						
							|  |  |  |           clmd->sim_parms->internal_compression = 15.0f; | 
					
						
							|  |  |  |           clmd->sim_parms->max_internal_compression = 15.0f; | 
					
						
							|  |  |  |           clmd->sim_parms->internal_spring_max_diversion = M_PI / 4.0f; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
											  
											
												Add support for tiled images and the UDIM naming scheme
This patch contains the work that I did during my week at the Code Quest - adding support for tiled images to Blender.
With this patch, images now contain a list of tiles. By default, this just contains one tile, but if the source type is set to Tiled, the user can add additional tiles. When acquiring an ImBuf, the tile to be loaded is specified in the ImageUser.
Therefore, code that is not yet aware of tiles will just access the default tile as usual.
The filenames of the additional tiles are derived from the original filename according to the UDIM naming scheme - the filename contains an index that is calculated as (1001 + 10*<y coordinate of the tile> + <x coordinate of the tile>), where the x coordinate never goes above 9.
Internally, the various tiles are stored in a cache just like sequences. When acquired for the first time, the code will try to load the corresponding file from disk. Alternatively, a new operator can be used to initialize the tile similar to the New Image operator.
The following features are supported so far:
- Automatic detection and loading of all tiles when opening the first tile (1001)
- Saving all tiles
- Adding and removing tiles
- Filling tiles with generated images
- Drawing all tiles in the Image Editor
- Viewing a tiled grid even if no image is selected
- Rendering tiled images in Eevee
- Rendering tiled images in Cycles (in SVM mode)
- Automatically skipping loading of unused tiles in Cycles
- 2D texture painting (also across tiles)
- 3D texture painting (also across tiles, only limitation: individual faces can not cross tile borders)
- Assigning custom labels to individual tiles (drawn in the Image Editor instead of the ID)
- Different resolutions between tiles
There still are some missing features that will be added later (see T72390):
- Workbench engine support
- Packing/Unpacking support
- Baking support
- Cycles OSL support
- many other Blender features that rely on images
Thanks to Brecht for the review and to all who tested the intermediate versions!
Differential Revision: https://developer.blender.org/D3509
											
										 
											2019-12-12 16:06:08 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Add primary tile to images. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Image", "ListBase", "tiles")) { | 
					
						
							|  |  |  |       for (Image *ima = bmain->images.first; ima; ima = ima->id.next) { | 
					
						
							|  |  |  |         ImageTile *tile = MEM_callocN(sizeof(ImageTile), "Image Tile"); | 
					
						
							|  |  |  |         tile->ok = 1; | 
					
						
							|  |  |  |         tile->tile_number = 1001; | 
					
						
							|  |  |  |         BLI_addtail(&ima->tiles, tile); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* UDIM Image Editor change. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SpaceImage", "int", "tile_grid_shape[2]")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
											  
											
												Add support for tiled images and the UDIM naming scheme
This patch contains the work that I did during my week at the Code Quest - adding support for tiled images to Blender.
With this patch, images now contain a list of tiles. By default, this just contains one tile, but if the source type is set to Tiled, the user can add additional tiles. When acquiring an ImBuf, the tile to be loaded is specified in the ImageUser.
Therefore, code that is not yet aware of tiles will just access the default tile as usual.
The filenames of the additional tiles are derived from the original filename according to the UDIM naming scheme - the filename contains an index that is calculated as (1001 + 10*<y coordinate of the tile> + <x coordinate of the tile>), where the x coordinate never goes above 9.
Internally, the various tiles are stored in a cache just like sequences. When acquired for the first time, the code will try to load the corresponding file from disk. Alternatively, a new operator can be used to initialize the tile similar to the New Image operator.
The following features are supported so far:
- Automatic detection and loading of all tiles when opening the first tile (1001)
- Saving all tiles
- Adding and removing tiles
- Filling tiles with generated images
- Drawing all tiles in the Image Editor
- Viewing a tiled grid even if no image is selected
- Rendering tiled images in Eevee
- Rendering tiled images in Cycles (in SVM mode)
- Automatically skipping loading of unused tiles in Cycles
- 2D texture painting (also across tiles)
- 3D texture painting (also across tiles, only limitation: individual faces can not cross tile borders)
- Assigning custom labels to individual tiles (drawn in the Image Editor instead of the ID)
- Different resolutions between tiles
There still are some missing features that will be added later (see T72390):
- Workbench engine support
- Packing/Unpacking support
- Baking support
- Cycles OSL support
- many other Blender features that rely on images
Thanks to Brecht for the review and to all who tested the intermediate versions!
Differential Revision: https://developer.blender.org/D3509
											
										 
											2019-12-12 16:06:08 +01:00
										 |  |  |             if (sl->spacetype == SPACE_IMAGE) { | 
					
						
							|  |  |  |               SpaceImage *sima = (SpaceImage *)sl; | 
					
						
							|  |  |  |               sima->tile_grid_shape[0] = 1; | 
					
						
							|  |  |  |               sima->tile_grid_shape[1] = 1; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-12-30 16:41:20 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |       br->add_col[3] = 0.9f; | 
					
						
							|  |  |  |       br->sub_col[3] = 0.9f; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-01-07 16:46:56 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Pose brush IK segments. */ | 
					
						
							| 
									
										
										
										
											2020-01-23 21:12:20 +01:00
										 |  |  |     for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |       if (br->pose_ik_segments == 0) { | 
					
						
							| 
									
										
										
										
											2020-01-07 16:46:56 +01:00
										 |  |  |         br->pose_ik_segments = 1; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-11 19:43:36 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Pose brush keep anchor point. */ | 
					
						
							|  |  |  |     for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |       if (br->sculpt_tool == SCULPT_TOOL_POSE) { | 
					
						
							|  |  |  |         br->flag2 |= BRUSH_POSE_IK_ANCHORED; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-11 20:04:41 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Tip Roundness. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "Brush", "float", "tip_roundness")) { | 
					
						
							|  |  |  |       for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |         if (br->ob_mode & OB_MODE_SCULPT && br->sculpt_tool == SCULPT_TOOL_CLAY_STRIPS) { | 
					
						
							|  |  |  |           br->tip_roundness = 0.18f; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-14 12:17:06 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* EEVEE: Cascade shadow bias fix */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Light *, light, &bmain->lights) { | 
					
						
							|  |  |  |       if (light->type == LA_SUN) { | 
					
						
							|  |  |  |         /* Should be 0.0004 but for practical reason we make it bigger.
 | 
					
						
							|  |  |  |          * Correct factor is scene dependent. */ | 
					
						
							|  |  |  |         light->bias *= 0.002f; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-01 12:09:55 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-02-14 12:24:14 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-02-25 15:09:30 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 5)) { | 
					
						
							| 
									
										
										
										
											2020-02-14 15:21:19 +01:00
										 |  |  |     /* Alembic Transform Cache changed from world to local space. */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (bConstraint *, con, &ob->constraints) { | 
					
						
							|  |  |  |         if (con->type == CONSTRAINT_TYPE_TRANSFORM_CACHE) { | 
					
						
							|  |  |  |           con->ownspace = CONSTRAINT_SPACE_LOCAL; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-15 01:49:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Add 2D transform to UV Warp modifier. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "UVWarpModifierData", "float", "scale[2]")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2020-02-15 01:49:50 +01:00
										 |  |  |           if (md->type == eModifierType_UVWarp) { | 
					
						
							|  |  |  |             UVWarpModifierData *umd = (UVWarpModifierData *)md; | 
					
						
							|  |  |  |             copy_v2_fl(umd->scale, 1.0f); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-25 13:25:49 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Add Lookdev blur property. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "View3DShading", "float", "studiolight_blur")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2020-02-25 13:25:49 +01:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->shading.studiolight_blur = 0.5f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-14 12:24:14 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-02-25 15:09:30 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 7)) { | 
					
						
							|  |  |  |     /* Init default Grease Pencil Vertex paint mix factor for Viewport. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "View3DOverlay", "float", "gpencil_vertex_paint_opacity")) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (bScreen *, screen, &bmain->screens) { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							|  |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							|  |  |  |               v3d->overlay.gpencil_vertex_paint_opacity = 1.0f; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /* Update Grease Pencil after drawing engine and code refactor.
 | 
					
						
							|  |  |  |      * It uses the seed variable of Array modifier to avoid double patching for | 
					
						
							|  |  |  |      * files created with a development version. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "ArrayGpencilModifierData", "int", "seed")) { | 
					
						
							|  |  |  |       /* Init new Grease Pencil Paint tools. */ | 
					
						
							|  |  |  |       { | 
					
						
							|  |  |  |         LISTBASE_FOREACH (Brush *, brush, &bmain->brushes) { | 
					
						
							|  |  |  |           if (brush->gpencil_settings != NULL) { | 
					
						
							|  |  |  |             brush->gpencil_vertex_tool = brush->gpencil_settings->brush_type; | 
					
						
							|  |  |  |             brush->gpencil_sculpt_tool = brush->gpencil_settings->brush_type; | 
					
						
							|  |  |  |             brush->gpencil_weight_tool = brush->gpencil_settings->brush_type; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         BKE_paint_toolslots_init_from_main(bmain); | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Material *, mat, &bmain->materials) { | 
					
						
							|  |  |  |         MaterialGPencilStyle *gp_style = mat->gp_style; | 
					
						
							|  |  |  |         if (gp_style == NULL) { | 
					
						
							|  |  |  |           continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* Fix Grease Pencil Material colors to Linear. */ | 
					
						
							|  |  |  |         srgb_to_linearrgb_v4(gp_style->stroke_rgba, gp_style->stroke_rgba); | 
					
						
							|  |  |  |         srgb_to_linearrgb_v4(gp_style->fill_rgba, gp_style->fill_rgba); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Move old gradient variables to texture. */ | 
					
						
							|  |  |  |         if (gp_style->fill_style == GP_MATERIAL_FILL_STYLE_GRADIENT) { | 
					
						
							|  |  |  |           gp_style->texture_angle = gp_style->gradient_angle; | 
					
						
							|  |  |  |           copy_v2_v2(gp_style->texture_scale, gp_style->gradient_scale); | 
					
						
							|  |  |  |           copy_v2_v2(gp_style->texture_offset, gp_style->gradient_shift); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* Set Checker material as Solid. This fill mode has been removed and replaced
 | 
					
						
							|  |  |  |          * by textures. */ | 
					
						
							|  |  |  |         if (gp_style->fill_style == GP_MATERIAL_FILL_STYLE_CHECKER) { | 
					
						
							|  |  |  |           gp_style->fill_style = GP_MATERIAL_FILL_STYLE_SOLID; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* Update Alpha channel for texture opacity. */ | 
					
						
							|  |  |  |         if (gp_style->fill_style == GP_MATERIAL_FILL_STYLE_TEXTURE) { | 
					
						
							|  |  |  |           gp_style->fill_rgba[3] *= gp_style->texture_opacity; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* Stroke stencil mask to mix = 1. */ | 
					
						
							|  |  |  |         if (gp_style->flag & GP_MATERIAL_STROKE_PATTERN) { | 
					
						
							|  |  |  |           gp_style->mix_stroke_factor = 1.0f; | 
					
						
							|  |  |  |           gp_style->flag &= ~GP_MATERIAL_STROKE_PATTERN; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* Mix disabled, set mix factor to 0. */ | 
					
						
							|  |  |  |         else if ((gp_style->flag & GP_MATERIAL_STROKE_TEX_MIX) == 0) { | 
					
						
							|  |  |  |           gp_style->mix_stroke_factor = 0.0f; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Fix Grease Pencil VFX and modifiers. */ | 
					
						
							|  |  |  |       LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |         if (ob->type != OB_GPENCIL) { | 
					
						
							|  |  |  |           continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* VFX. */ | 
					
						
							|  |  |  |         LISTBASE_FOREACH (ShaderFxData *, fx, &ob->shader_fx) { | 
					
						
							|  |  |  |           switch (fx->type) { | 
					
						
							|  |  |  |             case eShaderFxType_Colorize: { | 
					
						
							|  |  |  |               ColorizeShaderFxData *vfx = (ColorizeShaderFxData *)fx; | 
					
						
							|  |  |  |               if (ELEM(vfx->mode, eShaderFxColorizeMode_GrayScale, eShaderFxColorizeMode_Sepia)) { | 
					
						
							|  |  |  |                 vfx->factor = 1.0f; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               srgb_to_linearrgb_v4(vfx->low_color, vfx->low_color); | 
					
						
							|  |  |  |               srgb_to_linearrgb_v4(vfx->high_color, vfx->high_color); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eShaderFxType_Pixel: { | 
					
						
							|  |  |  |               PixelShaderFxData *vfx = (PixelShaderFxData *)fx; | 
					
						
							|  |  |  |               srgb_to_linearrgb_v4(vfx->rgba, vfx->rgba); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eShaderFxType_Rim: { | 
					
						
							|  |  |  |               RimShaderFxData *vfx = (RimShaderFxData *)fx; | 
					
						
							|  |  |  |               srgb_to_linearrgb_v3_v3(vfx->rim_rgb, vfx->rim_rgb); | 
					
						
							|  |  |  |               srgb_to_linearrgb_v3_v3(vfx->mask_rgb, vfx->mask_rgb); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eShaderFxType_Shadow: { | 
					
						
							|  |  |  |               ShadowShaderFxData *vfx = (ShadowShaderFxData *)fx; | 
					
						
							|  |  |  |               srgb_to_linearrgb_v4(vfx->shadow_rgba, vfx->shadow_rgba); | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eShaderFxType_Glow: { | 
					
						
							|  |  |  |               GlowShaderFxData *vfx = (GlowShaderFxData *)fx; | 
					
						
							|  |  |  |               srgb_to_linearrgb_v3_v3(vfx->glow_color, vfx->glow_color); | 
					
						
							|  |  |  |               vfx->glow_color[3] = 1.0f; | 
					
						
							|  |  |  |               srgb_to_linearrgb_v3_v3(vfx->select_color, vfx->select_color); | 
					
						
							|  |  |  |               vfx->blur[1] = vfx->blur[0]; | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         /* Modifiers. */ | 
					
						
							|  |  |  |         LISTBASE_FOREACH (GpencilModifierData *, md, &ob->greasepencil_modifiers) { | 
					
						
							|  |  |  |           switch ((GpencilModifierType)md->type) { | 
					
						
							|  |  |  |             case eGpencilModifierType_Array: { | 
					
						
							|  |  |  |               ArrayGpencilModifierData *mmd = (ArrayGpencilModifierData *)md; | 
					
						
							|  |  |  |               mmd->seed = 1; | 
					
						
							|  |  |  |               if ((mmd->offset[0] != 0.0f) || (mmd->offset[1] != 0.0f) || | 
					
						
							|  |  |  |                   (mmd->offset[2] != 0.0f)) { | 
					
						
							|  |  |  |                 mmd->flag |= GP_ARRAY_USE_OFFSET; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               if ((mmd->shift[0] != 0.0f) || (mmd->shift[1] != 0.0f) || (mmd->shift[2] != 0.0f)) { | 
					
						
							|  |  |  |                 mmd->flag |= GP_ARRAY_USE_OFFSET; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               if (mmd->object != NULL) { | 
					
						
							|  |  |  |                 mmd->flag |= GP_ARRAY_USE_OB_OFFSET; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Noise: { | 
					
						
							|  |  |  |               NoiseGpencilModifierData *mmd = (NoiseGpencilModifierData *)md; | 
					
						
							| 
									
										
										
										
											2020-03-13 12:24:49 +01:00
										 |  |  |               float factor = mmd->factor / 25.0f; | 
					
						
							|  |  |  |               mmd->factor = (mmd->flag & GP_NOISE_MOD_LOCATION) ? factor : 0.0f; | 
					
						
							|  |  |  |               mmd->factor_thickness = (mmd->flag & GP_NOISE_MOD_STRENGTH) ? factor : 0.0f; | 
					
						
							|  |  |  |               mmd->factor_strength = (mmd->flag & GP_NOISE_MOD_THICKNESS) ? factor : 0.0f; | 
					
						
							|  |  |  |               mmd->factor_uvs = (mmd->flag & GP_NOISE_MOD_UV) ? factor : 0.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-09 16:27:24 +01:00
										 |  |  |               mmd->noise_scale = (mmd->flag & GP_NOISE_FULL_STROKE) ? 0.0f : 1.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               if (mmd->curve_intensity == NULL) { | 
					
						
							|  |  |  |                 mmd->curve_intensity = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |                 if (mmd->curve_intensity) { | 
					
						
							|  |  |  |                   BKE_curvemapping_initialize(mmd->curve_intensity); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Tint: { | 
					
						
							|  |  |  |               TintGpencilModifierData *mmd = (TintGpencilModifierData *)md; | 
					
						
							|  |  |  |               srgb_to_linearrgb_v3_v3(mmd->rgb, mmd->rgb); | 
					
						
							|  |  |  |               if (mmd->curve_intensity == NULL) { | 
					
						
							|  |  |  |                 mmd->curve_intensity = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |                 if (mmd->curve_intensity) { | 
					
						
							|  |  |  |                   BKE_curvemapping_initialize(mmd->curve_intensity); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Smooth: { | 
					
						
							|  |  |  |               SmoothGpencilModifierData *mmd = (SmoothGpencilModifierData *)md; | 
					
						
							|  |  |  |               if (mmd->curve_intensity == NULL) { | 
					
						
							|  |  |  |                 mmd->curve_intensity = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |                 if (mmd->curve_intensity) { | 
					
						
							|  |  |  |                   BKE_curvemapping_initialize(mmd->curve_intensity); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Opacity: { | 
					
						
							|  |  |  |               OpacityGpencilModifierData *mmd = (OpacityGpencilModifierData *)md; | 
					
						
							|  |  |  |               if (mmd->curve_intensity == NULL) { | 
					
						
							|  |  |  |                 mmd->curve_intensity = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |                 if (mmd->curve_intensity) { | 
					
						
							|  |  |  |                   BKE_curvemapping_initialize(mmd->curve_intensity); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Color: { | 
					
						
							|  |  |  |               ColorGpencilModifierData *mmd = (ColorGpencilModifierData *)md; | 
					
						
							|  |  |  |               if (mmd->curve_intensity == NULL) { | 
					
						
							|  |  |  |                 mmd->curve_intensity = BKE_curvemapping_add(1, 0.0f, 0.0f, 1.0f, 1.0f); | 
					
						
							|  |  |  |                 if (mmd->curve_intensity) { | 
					
						
							|  |  |  |                   BKE_curvemapping_initialize(mmd->curve_intensity); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Thick: { | 
					
						
							|  |  |  |               if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |                       fd->filesdna, "ThickGpencilModifierData", "float", "thickness_fac")) { | 
					
						
							|  |  |  |                 ThickGpencilModifierData *mmd = (ThickGpencilModifierData *)md; | 
					
						
							|  |  |  |                 mmd->thickness_fac = mmd->thickness; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Multiply: { | 
					
						
							|  |  |  |               MultiplyGpencilModifierData *mmd = (MultiplyGpencilModifierData *)md; | 
					
						
							|  |  |  |               mmd->fading_opacity = 1.0 - mmd->fading_opacity; | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             case eGpencilModifierType_Subdiv: { | 
					
						
							|  |  |  |               const short simple = (1 << 0); | 
					
						
							|  |  |  |               SubdivGpencilModifierData *mmd = (SubdivGpencilModifierData *)md; | 
					
						
							|  |  |  |               if (mmd->flag & simple) { | 
					
						
							|  |  |  |                 mmd->flag &= ~simple; | 
					
						
							|  |  |  |                 mmd->type = GP_SUBDIV_SIMPLE; | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             default: | 
					
						
							|  |  |  |               break; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |       /* Fix Layers Colors and Vertex Colors to Linear.
 | 
					
						
							|  |  |  |        * Also set lights to on for layers. */ | 
					
						
							|  |  |  |       LISTBASE_FOREACH (bGPdata *, gpd, &bmain->gpencils) { | 
					
						
							|  |  |  |         if (gpd->flag & GP_DATA_ANNOTATIONS) { | 
					
						
							|  |  |  |           continue; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         /* Onion colors. */ | 
					
						
							|  |  |  |         srgb_to_linearrgb_v3_v3(gpd->gcolor_prev, gpd->gcolor_prev); | 
					
						
							|  |  |  |         srgb_to_linearrgb_v3_v3(gpd->gcolor_next, gpd->gcolor_next); | 
					
						
							|  |  |  |         /* Z-depth Offset. */ | 
					
						
							|  |  |  |         gpd->zdepth_offset = 0.150f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         LISTBASE_FOREACH (bGPDlayer *, gpl, &gpd->layers) { | 
					
						
							|  |  |  |           gpl->flag |= GP_LAYER_USE_LIGHTS; | 
					
						
							|  |  |  |           srgb_to_linearrgb_v4(gpl->tintcolor, gpl->tintcolor); | 
					
						
							|  |  |  |           gpl->vertex_paint_opacity = 1.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |           LISTBASE_FOREACH (bGPDframe *, gpf, &gpl->frames) { | 
					
						
							|  |  |  |             LISTBASE_FOREACH (bGPDstroke *, gps, &gpf->strokes) { | 
					
						
							|  |  |  |               /* Set initial opacity for fill color. */ | 
					
						
							|  |  |  |               gps->fill_opacity_fac = 1.0f; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               /* Calc geometry data because in old versions this data was not saved. */ | 
					
						
							|  |  |  |               BKE_gpencil_stroke_geometry_update(gps); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |               srgb_to_linearrgb_v4(gps->vert_color_fill, gps->vert_color_fill); | 
					
						
							|  |  |  |               int i; | 
					
						
							|  |  |  |               bGPDspoint *pt; | 
					
						
							|  |  |  |               for (i = 0, pt = gps->points; i < gps->totpoints; i++, pt++) { | 
					
						
							|  |  |  |                 srgb_to_linearrgb_v4(pt->vert_color, pt->vert_color); | 
					
						
							|  |  |  |               } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-10 15:41:29 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 8)) { | 
					
						
							| 
									
										
										
										
											2020-03-05 14:53:23 +01:00
										 |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "View3DOverlay", "float", "sculpt_mode_face_sets_opacity")) { | 
					
						
							|  |  |  |       for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ScrArea *, area, &screen->areabase) { | 
					
						
							|  |  |  |           LISTBASE_FOREACH (SpaceLink *, sl, &area->spacedata) { | 
					
						
							| 
									
										
										
										
											2020-03-05 14:53:23 +01:00
										 |  |  |             if (sl->spacetype == SPACE_VIEW3D) { | 
					
						
							|  |  |  |               View3D *v3d = (View3D *)sl; | 
					
						
							| 
									
										
										
										
											2020-03-09 20:10:56 +01:00
										 |  |  |               v3d->overlay.sculpt_mode_face_sets_opacity = 1.0f; | 
					
						
							| 
									
										
										
										
											2020-03-05 14:53:23 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-09 18:22:49 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Alembic Transform Cache changed from local to world space. */ | 
					
						
							|  |  |  |     LISTBASE_FOREACH (Object *, ob, &bmain->objects) { | 
					
						
							|  |  |  |       LISTBASE_FOREACH (bConstraint *, con, &ob->constraints) { | 
					
						
							|  |  |  |         if (con->type == CONSTRAINT_TYPE_TRANSFORM_CACHE) { | 
					
						
							|  |  |  |           con->ownspace = CONSTRAINT_SPACE_WORLD; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-09 21:14:47 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Boundary Edges Automasking. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find( | 
					
						
							|  |  |  |             fd->filesdna, "Brush", "int", "automasking_boundary_edges_propagation_steps")) { | 
					
						
							|  |  |  |       for (Brush *br = bmain->brushes.first; br; br = br->id.next) { | 
					
						
							|  |  |  |         br->automasking_boundary_edges_propagation_steps = 1; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-10 12:47:43 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Corrective smooth modifier scale*/ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "CorrectiveSmoothModifierData", "float", "scale")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2020-03-10 12:47:43 +01:00
										 |  |  |           if (md->type == eModifierType_CorrectiveSmooth) { | 
					
						
							|  |  |  |             CorrectiveSmoothModifierData *csmd = (CorrectiveSmoothModifierData *)md; | 
					
						
							|  |  |  |             csmd->scale = 1.0f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-10 15:41:29 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Default Face Set Color. */ | 
					
						
							|  |  |  |     for (Mesh *me = bmain->meshes.first; me != NULL; me = me->id.next) { | 
					
						
							|  |  |  |       if (me->totpoly > 0) { | 
					
						
							|  |  |  |         int *face_sets = CustomData_get_layer(&me->pdata, CD_SCULPT_FACE_SETS); | 
					
						
							|  |  |  |         if (face_sets) { | 
					
						
							|  |  |  |           me->face_sets_color_default = abs(face_sets[0]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-03-10 16:17:49 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-03-23 16:43:54 +01:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 11)) { | 
					
						
							| 
									
										
										
										
											2020-03-12 13:35:22 +11:00
										 |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "OceanModifierData", "float", "fetch_jonswap")) { | 
					
						
							|  |  |  |       for (Object *object = bmain->objects.first; object != NULL; object = object->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &object->modifiers) { | 
					
						
							| 
									
										
										
										
											2020-03-12 13:35:22 +11:00
										 |  |  |           if (md->type == eModifierType_Ocean) { | 
					
						
							|  |  |  |             OceanModifierData *omd = (OceanModifierData *)md; | 
					
						
							|  |  |  |             omd->fetch_jonswap = 120.0f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
											  
											
												VR: Initial Virtual Reality support - Milestone 1, Scene Inspection
NOTE: While most of the milestone 1 goals are there, a few smaller features and
improvements are still to be done.
Big picture of this milestone: Initial, OpenXR-based virtual reality support
for users and foundation for advanced use cases.
Maniphest Task: https://developer.blender.org/T71347
The tasks contains more information about this milestone.
To be clear: This is not a feature rich VR implementation, it's focused on the
initial scene inspection use case. We intentionally focused on that, further
features like controller support are part of the next milestone.
- How to use?
Instructions on how to use this are here:
https://wiki.blender.org/wiki/User:Severin/GSoC-2019/How_to_Test
These will be updated and moved to a more official place (likely the manual) soon.
Currently Windows Mixed Reality and Oculus devices are usable. Valve/HTC
headsets don't support the OpenXR standard yet and hence, do not work with this
implementation.
---------------
This is the C-side implementation of the features added for initial VR
support as per milestone 1. A "VR Scene Inspection" Add-on will be
committed separately, to expose the VR functionality in the UI. It also
adds some further features for milestone 1, namely a landmarking system
(stored view locations in the VR space)
Main additions/features:
* Support for rendering viewports to an HMD, with good performance.
* Option to sync the VR view perspective with a fully interactive,
  regular 3D View (VR-Mirror).
* Option to disable positional tracking. Keeps the current position (calculated
  based on the VR eye center pose) when enabled while a VR session is running.
* Some regular viewport settings for the VR view
* RNA/Python-API to query and set VR session state information.
* WM-XR: Layer tying Ghost-XR to the Blender specific APIs/data
* wmSurface API: drawable, non-window container (manages Ghost-OpenGL and GPU
  context)
* DNA/RNA for management of VR session settings
* `--debug-xr` and `--debug-xr-time` commandline options
* Utility batch & config file for using the Oculus runtime on Windows.
* Most VR data is runtime only. The exception is user settings which are saved
  to files (`XrSessionSettings`).
* VR support can be disabled through the `WITH_XR_OPENXR` compiler flag.
For architecture and code documentation, see
https://wiki.blender.org/wiki/Source/Interface/XR.
---------------
A few thank you's:
* A huge shoutout to Ray Molenkamp for his help during the project - it would
  have not been that successful without him!
* Sebastian Koenig and Simeon Conzendorf for testing and feedback!
* The reviewers, especially Brecht Van Lommel!
* Dalai Felinto for pushing and managing me to get this done ;)
* The OpenXR working group for providing an open standard. I think we're the
  first bigger application to adopt OpenXR. Congratulations to them and
  ourselves :)
This project started as a Google Summer of Code 2019 project - "Core Support of
Virtual Reality Headsets through OpenXR" (see
https://wiki.blender.org/wiki/User:Severin/GSoC-2019/).
Some further information, including ideas for further improvements can be found
in the final GSoC report:
https://wiki.blender.org/wiki/User:Severin/GSoC-2019/Final_Report
Differential Revisions: D6193, D7098
Reviewed by: Brecht Van Lommel, Jeroen Bakker
											
										 
											2020-03-17 20:20:55 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |     if (!DNA_struct_find(fd->filesdna, "XrSessionSettings")) { | 
					
						
							|  |  |  |       for (wmWindowManager *wm = bmain->wm.first; wm; wm = wm->id.next) { | 
					
						
							|  |  |  |         const View3D *v3d_default = DNA_struct_default_get(View3D); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         wm->xr.session_settings.shading = v3d_default->shading; | 
					
						
							|  |  |  |         /* Don't rotate light with the viewer by default, make it fixed. */ | 
					
						
							|  |  |  |         wm->xr.session_settings.shading.flag |= V3D_SHADING_WORLD_ORIENTATION; | 
					
						
							|  |  |  |         wm->xr.session_settings.draw_flags = (V3D_OFSDRAW_SHOW_GRIDFLOOR | | 
					
						
							|  |  |  |                                               V3D_OFSDRAW_SHOW_ANNOTATION); | 
					
						
							|  |  |  |         wm->xr.session_settings.clip_start = v3d_default->clip_start; | 
					
						
							|  |  |  |         wm->xr.session_settings.clip_end = v3d_default->clip_end; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         wm->xr.session_settings.flag = XR_SESSION_USE_POSITION_TRACKING; | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-29 22:51:15 +11:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Surface deform modifier strength*/ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SurfaceDeformModifierData", "float", "strength")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2020-03-29 22:51:15 +11:00
										 |  |  |           if (md->type == eModifierType_SurfaceDeform) { | 
					
						
							|  |  |  |             SurfaceDeformModifierData *sdmd = (SurfaceDeformModifierData *)md; | 
					
						
							|  |  |  |             sdmd->strength = 1.0f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-02-25 15:09:30 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-03-23 16:43:54 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-06 20:07:05 +10:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 12)) { | 
					
						
							|  |  |  |     /* Activate f-curve drawing in the sequencer. */ | 
					
						
							|  |  |  |     for (bScreen *screen = bmain->screens.first; screen; screen = screen->id.next) { | 
					
						
							|  |  |  |       for (ScrArea *area = screen->areabase.first; area; area = area->next) { | 
					
						
							|  |  |  |         for (SpaceLink *sl = area->spacedata.first; sl; sl = sl->next) { | 
					
						
							|  |  |  |           if (sl->spacetype == SPACE_SEQ) { | 
					
						
							|  |  |  |             SpaceSeq *sseq = (SpaceSeq *)sl; | 
					
						
							|  |  |  |             sseq->flag |= SEQ_SHOW_FCURVES; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-31 17:06:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Remesh Modifier Voxel Mode. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "RemeshModifierData", "float", "voxel_size")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							| 
									
										
										
										
											2020-04-03 19:15:01 +02:00
										 |  |  |         LISTBASE_FOREACH (ModifierData *, md, &ob->modifiers) { | 
					
						
							| 
									
										
										
										
											2020-03-31 17:06:17 +02:00
										 |  |  |           if (md->type == eModifierType_Remesh) { | 
					
						
							|  |  |  |             RemeshModifierData *rmd = (RemeshModifierData *)md; | 
					
						
							|  |  |  |             rmd->voxel_size = 0.1f; | 
					
						
							|  |  |  |             rmd->adaptivity = 0.0f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-03-23 16:43:54 +01:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2020-04-06 20:07:05 +10:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 11:46:52 +10:00
										 |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 14)) { | 
					
						
							| 
									
										
										
										
											2020-04-13 17:15:16 +02:00
										 |  |  |     /* Solidify modifier merge tolerance. */ | 
					
						
							|  |  |  |     if (!DNA_struct_elem_find(fd->filesdna, "SolidifyModifierData", "float", "merge_tolerance")) { | 
					
						
							|  |  |  |       for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |         for (ModifierData *md = ob->modifiers.first; md; md = md->next) { | 
					
						
							|  |  |  |           if (md->type == eModifierType_Solidify) { | 
					
						
							|  |  |  |             SolidifyModifierData *smd = (SolidifyModifierData *)md; | 
					
						
							|  |  |  |             /* set to 0.0003 since that is what was used before, default now is 0.0001 */ | 
					
						
							|  |  |  |             smd->merge_tolerance = 0.0003f; | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-04-23 11:46:52 +10:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /* Enumerator was incorrect for a time in 2.83 development.
 | 
					
						
							|  |  |  |      * Note that this only corrects values known to be invalid. */ | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |       RigidBodyCon *rbc = ob->rigidbody_constraint; | 
					
						
							|  |  |  |       if (rbc != NULL) { | 
					
						
							|  |  |  |         enum { | 
					
						
							|  |  |  |           INVALID_RBC_TYPE_SLIDER = 2, | 
					
						
							|  |  |  |           INVALID_RBC_TYPE_6DOF_SPRING = 4, | 
					
						
							|  |  |  |           INVALID_RBC_TYPE_MOTOR = 7, | 
					
						
							|  |  |  |         }; | 
					
						
							|  |  |  |         switch (rbc->type) { | 
					
						
							|  |  |  |           case INVALID_RBC_TYPE_SLIDER: | 
					
						
							|  |  |  |             rbc->type = RBC_TYPE_SLIDER; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case INVALID_RBC_TYPE_6DOF_SPRING: | 
					
						
							|  |  |  |             rbc->type = RBC_TYPE_6DOF_SPRING; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |           case INVALID_RBC_TYPE_MOTOR: | 
					
						
							|  |  |  |             rbc->type = RBC_TYPE_MOTOR; | 
					
						
							|  |  |  |             break; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 15:10:20 +02:00
										 |  |  |   /* Match scale of fluid modifier gravity with scene gravity. */ | 
					
						
							|  |  |  |   if (!MAIN_VERSION_ATLEAST(bmain, 283, 15)) { | 
					
						
							|  |  |  |     for (Object *ob = bmain->objects.first; ob; ob = ob->id.next) { | 
					
						
							|  |  |  |       for (ModifierData *md = ob->modifiers.first; md; md = md->next) { | 
					
						
							|  |  |  |         if (md->type == eModifierType_Fluid) { | 
					
						
							|  |  |  |           FluidModifierData *fmd = (FluidModifierData *)md; | 
					
						
							|  |  |  |           if (fmd->domain != NULL) { | 
					
						
							|  |  |  |             mul_v3_fl(fmd->domain->gravity, 9.81f); | 
					
						
							|  |  |  |           } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |       } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  |   } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-04-23 11:46:52 +10:00
										 |  |  |   /**
 | 
					
						
							|  |  |  |    * Versioning code until next subversion bump goes here. | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * \note Be sure to check when bumping the version: | 
					
						
							|  |  |  |    * - #do_versions_after_linking_280 in this file. | 
					
						
							|  |  |  |    * - "versioning_userdef.c", #BLO_version_defaults_userpref_blend | 
					
						
							|  |  |  |    * - "versioning_userdef.c", #do_versions_theme | 
					
						
							|  |  |  |    * | 
					
						
							|  |  |  |    * \note Keep this message at the bottom of the function. | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   { | 
					
						
							|  |  |  |     /* Keep this block, even when empty. */ | 
					
						
							| 
									
										
										
										
											2020-04-06 20:07:05 +10:00
										 |  |  |   } | 
					
						
							| 
									
										
											  
											
												Render Layers and Collections (merge from render-layers)
Design Documents
----------------
* https://wiki.blender.org/index.php/Dev:2.8/Source/Layers
* https://wiki.blender.org/index.php/Dev:2.8/Source/DataDesignRevised
User Commit Log
---------------
* New Layer and Collection system to replace render layers and viewport layers.
* A layer is a set of collections of objects (and their drawing options) required for specific tasks.
* A collection is a set of objects, equivalent of the old layers in Blender. A collection can be shared across multiple layers.
* All Scenes have a master collection that all other collections are children of.
* New collection "context" tab (in Properties Editor)
* New temporary viewport "collections" panel to control per-collection
visibility
Missing User Features
---------------------
* Collection "Filter"
  Option to add objects based on their names
* Collection Manager operators
  The existing buttons  are placeholders
* Collection Manager drawing
  The editor main region is empty
* Collection Override
* Per-Collection engine settings
  This will come as a separate commit, as part of the clay-engine branch
Dev Commit Log
--------------
* New DNA file (DNA_layer_types.h) with the new structs
  We are replacing Base by a new extended Base while keeping it backward
  compatible with some legacy settings (i.e., lay, flag_legacy).
  Renamed all Base to BaseLegacy to make it clear the areas of code that
  still need to be converted
  Note: manual changes were required on - deg_builder_nodes.h, rna_object.c, KX_Light.cpp
* Unittesting for main syncronization requirements
  - read, write, add/copy/remove objects, copy scene, collection
  link/unlinking, context)
* New Editor: Collection Manager
  Based on patch by Julian Eisel
  This is extracted from the layer-manager branch. With the following changes:
    - Renamed references of layer manager to collections manager
    - I doesn't include the editors/space_collections/ draw and util files
    - The drawing code itself will be implemented separately by Julian
* Base / Object:
  A little note about them. Original Blender code would try to keep them
  in sync through the code, juggling flags back and forth. This will now
  be handled by Depsgraph, keeping Object and Bases more separated
  throughout the non-rendering code.
  Scene.base is being cleared in doversion, and the old viewport drawing
  code was poorly converted to use the new bases while the new viewport
  code doesn't get merged and replace the old one.
Python API Changes
------------------
```
- scene.layers
+ # no longer exists
- scene.objects
+ scene.scene_layers.active.objects
- scene.objects.active
+ scene.render_layers.active.objects.active
- bpy.context.scene.objects.link()
+ bpy.context.scene_collection.objects.link()
- bpy_extras.object_utils.object_data_add(context, obdata, operator=None, use_active_layer=True, name=None)
+ bpy_extras.object_utils.object_data_add(context, obdata, operator=None, name=None)
- bpy.context.object.select
+ bpy.context.object.select = True
+ bpy.context.object.select = False
+ bpy.context.object.select_get()
+ bpy.context.object.select_set(action='SELECT')
+ bpy.context.object.select_set(action='DESELECT')
-AddObjectHelper.layers
+ # no longer exists
```
											
										 
											2017-02-07 10:18:38 +01:00
										 |  |  | } |