diff --git a/.gitignore b/.gitignore
index 1196a9fe19..1812c0ab3d 100644
--- a/.gitignore
+++ b/.gitignore
@@ -24,6 +24,8 @@ ipch
*.vcxproj.filters
*.pdb
*.lib
+*.VC.db
+*.VC.VC.opendb
# OSX/Linux build products
*.mak
@@ -70,6 +72,7 @@ voice_ban.dt
# Momentum
*.tim
*.zon
+*.momrec
# Others
*.cache
@@ -77,4 +80,6 @@ voice_ban.dt
*.prt
*.vmx
*.lin
-*.vdf
\ No newline at end of file
+*.vdf
+*.pch.ib_tag
+*.ib_pdb_index
diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md
index 2d1b5545e1..29ef18f765 100644
--- a/CONTRIBUTING.md
+++ b/CONTRIBUTING.md
@@ -1,14 +1,19 @@
-# About contributing
-Contributing to the mod is very easy. Just fork the repo, make your desired changes
-and then send us a pull request and we'll happly revise it.
+# About Contributing
+Contributing to this project is very easy. Just fork the repo, make your desired changes
+and then send us a pull request and we'll happily revise it.
+Note: We use Hungarian Notation (Systems), spaces instead of tabs, and ClangFormat for any custom file added to the project.
-When writing the Pull Request comment, don't forget to ask to get listed in the contributors section of the web by providing a name/alias that will be displayed in the credits section of the mod. If you don't provide a name, we'll use your GitHub username
+If your work is to be used in our project, we will credit you with a Contributor role on [our credits page.](http://momentum-mod.org/about) If you wish to have a certain name in this credit, make sure to mention it in the comments of your Pull Request, otherwise, we'll just use your GitHub username.
-**Every help we can get is welcomed**
+If we like your work enough, we may invite you to be on the team!
+If you have any other concerns, feel free to [contact us!](http://momentum-mod.org/contact)
-Also, *as this is a Soruce mod*, VALVe's contributing conditions apply here as well:
+**All the help we can get is very welcome!**
+
+
+Also, *as this is a Source mod*, VALVe's contributing conditions apply here as well:
*As a condition of providing a Contribution, you agree that:*
@@ -26,4 +31,4 @@ provide your Contribution "as is" without warranties.*
creation, you may submit it to Valve separate from any Contribution,
explicitly identifying it as sourced from a third party, stating the details
of its origin, and informing Valve of any license or other restriction of
-which you are personally aware.*
+which you are personally aware.*
\ No newline at end of file
diff --git a/README.md b/README.md
index 276f338354..1184ff6fd7 100644
--- a/README.md
+++ b/README.md
@@ -1,23 +1,21 @@
# Momentum Mod
![Build Status](https://ci.appveyor.com/api/projects/status/9hpr4p9suvlge305?svg=true)
-Momentum Mod is a free stand-alone Source mod with Counter-Strike: Source physics
-dedicated to bhop and surfing while trying to improve them and simultaneously making
-it easier to access and play (offline and online) as well as being cheaper
+Momentum Mod is a free, stand-alone Source Engine mod, based on Counter-Strike: Source movement physics.
+This project is dedicated to bhop and surfing, while not only trying to replicate them, but also trying to improve them.
+Our goal is to make it easier to access and play (offline and online) as well as being cheaper (did we mention it's free?)
than any other Source game you'd have to buy to play either of these game modes.
## Contributing
You can read about how to contribute to the development of the mod
-at the [contributing](CONTRIBUTING.md) section
+at the [contributing](CONTRIBUTING.md) section.
-You can find a (code focused) TO DO at [TODO.md](TODO.md), where you can see what we
-plan to do next or what we have in mind (But, as it is a development list, we may skip some
-of the ideas for whatever reason)
+You can find a general TO-DO for the project over [at our Trello board](https://trello.com/momentum_mod). Feel free to tackle something if it tickles your fancy! Just note that if members are assigned to a feature, it is most likely already being worked on!
## Contact
-You can contact us [at our website](http://momentum-mod.org/contact)
-
-The licenses and legal notices can be found at [SDK LICENSE](LICENSE) and [THIRD PARTY LEGAL NOTICES](thirdpartylegalnotices.txt)
+You can [contact us at our website](http://momentum-mod.org/contact)!
+## License
+The licenses and legal notices can be found at [SDK LICENSE](LICENSE) and [THIRD PARTY LEGAL NOTICES](thirdpartylegalnotices.txt)
\ No newline at end of file
diff --git a/TODO.md b/TODO.md
deleted file mode 100644
index 653f4f0349..0000000000
--- a/TODO.md
+++ /dev/null
@@ -1,204 +0,0 @@
-## ALPHA
-- [x] PORT TO MP BRANCH
-
-- [ ] Gameinterface.cpp (Server)
- - [ ] Delete comment on Motd file not being able to be loaded (L:1721) once we're on MP branch
-
-- [ ] ClientScoreboardDialog.cpp (Client)
- - [ ] Get online data from the API
- - [x] Add friends leaderboard list
- - [x] Add format for online & friends leaderboard lists
- - [ ] Fill the lists with API data
- - [ ] Update rank for event runtime_posted
- - [x] Discuss update interval time
- - [ ] Consider adding a "100 tick" column
- - [x] Localize rank tokens
- - [ ] Make FindItemIDForPlayerIndex(int) return an ItemID for another person's time
- - [ ] Sort function for online times
- - [x] Fix bugs: Lines being chopped down & mapsummary not being set
- - [x] Discuss columns widths
- - [ ] De-hardcode the font used on size checking
- - [x] Find where to place friends leaderboards
- - [ ] A lot of variables are not necessary. Ensure which are and remove the rest
- - [ ] Use GetTextSize instead of calculating it per character
-
-- [ ] MapSelector.cpp (Client)
- - [ ] Localize strings (remove ServerBrowser)
- - [x] Make the panel display from menu selection (edit GameMenu.res and do "engine ToggleMapsPanel")
- - [ ] Remove references to Server Browser
- - [ ] Cleanup classes to remove useless/commented code
- - [ ] Local Maps tab
- - [x] Header columns: Completed | Map name | Game type | Difficulty | Best time
- - [x] Populate with maps already on disk (parse .mom files?)
- - [ ] Parse .mom/zon/bsp files to fill the Dialog with information
- - [x] Change filters
- - [x] Map name
- - [x] Gametype (bhop/surf/etc)
- - [x] Difficulty
- - [x] Linear/Staged
- - [ ] "Online Maps" Tab
- - [ ] Apply filters to API searches
- - [ ] Parse data from API and apply to list
- - [ ] Start the selected map
- - [ ] Download a selected map, and its .zon and .mom file (if not exist)
- - [ ] Open a MapInfoDialog to show progress on download?
- - [x] Set the correct gamemode type, tickrate, etc based on .mom file
-
-- [ ] MapInfoDialog.cpp (Client)
- - [ ] Localize (remove ServerBrowser)
- - [ ] Show information about the map
- - [ ] Local info
- - [ ] Local PBs
- - [ ] Link replays to each local time
- - [ ] Other local info/stats (how many total runs)
- - [ ] Online info
- - [ ] Top 10 times for the map
- - [ ] Link replays to each online time
- - [ ] Other online info/stats
- - [ ] Make the user able to start the map from the Dialog
- - [ ] Online maps need to be downloaded
- - [ ] Local maps simply start like normal
-
-- [ ] The "mom"-ification and refactoring
- - [ ] mom_player (Server/Client)
- - [ ] Copy valuable snippets from HL2/CS Player classes
- - [x] Clean up the EntSelectSpawnPoint() method
- - [ ] mom_gamerules (Shared)
- - [ ] Follow the hl2_gamerules.cpp file for creation
- - [ ] Improve mom_spawn_with_weapons implementation
- - [x] mom_gamemovement.cpp (Shared)
- - [x] Implement rampboost fix by TotallyMehis
- - [ ] mom_usermessages.cpp (Shared)
- - [x] Remove the usermessages that aren't necessary
- - [ ] Remove even more messages
- - [ ] mom_client.cpp (Server)
- - [ ] Precache all necessary sounds/models for the mod
- - [ ] VPC Scripts
- - [ ] Add the new mom files to the proper VPC scripts
- - [ ] Verify & remove the files we deleted from the appropriate VPC scripts
- - [ ] Remove any and all unnecessary HL2/generic code that doesn't pertain to the mod
- - [x] Remove all ifdef (SIXENSE) code segments
- - [x] Remove all ifdef (XBOX/X360 etc) & IsX360() code segments
- - [x] Remove all ifdef (TF/PORTAL/DOD) code segments
- - [x] Remove all ifdef (HL2_EPISODIC/HL2_LOSTCOAST/HL2MP) code segments
- - [x] Remove all ifdef (HL1_DLL/CSPORT_DLL) code segments
- - [x] Remove all ifdef (INVASION_DLL/NEXT_BOT/TERROR/USES_ECON_ITEMS) code segments
- - [x] Inspect and cherry pick ifdef (CSTRIKE_DLL) code segments
- - [ ] Format (CTRL + K, CTRL + D) every class to follow the tabs->spaces and other spacing style for code
- - [ ] Remove any unused files
- - [x] hud_squadstatus.cpp
- - [x] hud_posture.cpp
- - [x] hud_flashlight.cpp (the hud element)
- - [x] hud_battery.cpp
- - [ ] teamplayroundbased_gamerules.h/cpp
- - [ ] Entire hl2/ subfolder in client/server/shared
- - [x] Entire sdk/ subfolder in client/server/shared
- - [ ] Eventually undefine HL2_DLL and remove corresponding code
-
-- [x] Creation of a shared (Client/Server) utils class with useful methods/data (gamemode, tickrate etc)
- - [x] Create global enumeration for gamemodes
- - [x] Store current gamemode on a global variable
-
-- [ ] Gamemodes
- - [x] *BHOP* -> 100 tick, no stamina, autojump/no autojump (Cvar so people can manual scroll if they want)
- - [ ] *SURF* -> 66 (default)/100 , no stamina, autojump
- - [ ] *KZ* -> 100 tick, stamina, no autojump
-
-- [ ] weapon_momentum_gun.cpp (Shared) and CS:S weapon entities
- - [x] Import CS:S weapon entities over
- - [x] Import extra CS:S weapon entities (Knife and Grenades)
- - [x] Cleanup CS:S weapon entities/reduce class clutter
- - [ ] Make the main gun toggleable (the player spawns with it, presses button to use/hide it)
- - [ ] Look into removing the crosshair? Customization?
- - [ ] Consider keeping the hud_ammo.cpp HUD element for displaying how many bullets the player has in the clip
- - [ ] Change model
- - [ ] Tone down or remove view-bob
-
-- [ ] timer.cpp (Client)
- - [ ] Play effects (animations) for run states
- - [x] Move to bottom center (above speedometer)
- - [x] Utilize the .res file variables for position/color/etc
- - [x] Feed real data for the hud
- - [x] Have more info (checkpoints, current stage/total stages, etc)
- - [x] Only display relevant info
- - [ ] Act accordingly to gamemode
- - [ ] Add stamina settings for kz/scroll modes
- - [x] Implement Hud Messaging system to interact with Timer.cpp (server)
- - [x] Localization
- - [x] Discuss bufsize for strings taking intoa count localizations
-
-- [ ] hud_cp_menu.cpp (Client)
- - [x] Make creating a checkpoint stop your timer
- - [ ] Make checkpoints available for output to files
- - [ ] Consider local timer for routing
- - [ ] Consider KZ game mode basically requiring checkpoints
- - [ ] Extract underlying menu class and make hud_cp_menu create one
- - [x] Use .res files
-
-- [ ] mom_triggers.cpp (Server)
- - [ ] Tweak limit speed method
- - [x] Implement Hud Messaging system to interact with timer.cpp (client)
- - [x] Add the option to define what angles should the player have after being teleported
- - [ ] Unify every spawnflag (So each one has an unique 'id')
- - [ ] Bonus stages (either flags added to existing triggers or child entites)
-
-- [ ] Timer.cpp (Server)
- - [ ] Add hash checking
- - [x] GetCPCount seems to return wrongly
- - [x] Are command flags needed?
-
-- [x] tickset.cpp (Server) Make tick-setting crossplatform
-
-- [x] In-game mapzone editor (Server/Client) allows for creation of zone files (on older CS maps) without using Hammer
-
-- [ ] mapzones.cpp (Server)
- - [ ] Add support for the new custom triggers
-
-- [x] mapzones_edit.cpp (Server)
- - [x] Change description for mom_zone_defmethod
- - [x] Improve methods of triggers (Probbably also find a better suitting name)
- - [ ] Improve binding (Add more build binds for things like mom_zone_defzone variations)
-
-- [ ] Credits
- - [ ] Few values are set to default when the map ends, we have to set it to how the user had it before going to the credits
- - [ ] If the user disconnects before the credits ending, hud convar values will not be set back to how they were before
-
-- [ ] GUI changes
- - [ ] Add practice mode state to timer VGUI panel
-
-## BETA
-- [ ] Implement CEF
- - [ ] Create custom HTML HUD
- - [ ] Create custom HTML menu
- - [ ] Incorporate (precompiled/source?) into project
-
-- [ ] Consider importing Portal-like entities for non-euclidean geometry
-
-- [ ] Replays
- - [ ] Use ghostingmod as an example of how to make/read the files
- - [ ] Make map selection/leaderboards be able to download replays
-
-- [ ] Spectate system (like replays but streamed online)
- - [ ] Use ghostingmod (server) as an example
- - [ ] Racing system (like spectating but you can move around)
- - [ ] Synchronize start, notified ends
- - [ ] Allow disqualifications, drop outs, disconnections
- - [ ] Free play online ghosts (Similar to current bhop/surf servers. Community is important.)
-
-- [ ] Global chat
- - [ ] Simple general and map chat via IRC or something
-
-- [x] func_shootboost: (Potential entity that handles shootboosts (not needed))
-
-- [ ] weapon_momentum_gun (Client/Server)
- - [ ] "Wire-frame" models for each gun override
- - [ ] Edited gun sounds that reference original sounds?
-
-- [ ] Gamemodes (Ideas)
- - [ ] RocketJump -> 100 tick?, no stamina?, autojump?
-
-## BETA+ (Official Release)
-- [ ] Get greenlit
-
-- [ ] Timer.cpp (Server)
- - [ ] Include the extra security measures
diff --git a/mp/game/momentum/bin/game_shader_generic_eshader_2013.dll b/mp/game/momentum/bin/game_shader_generic_eshader_2013.dll
new file mode 100644
index 0000000000..4001f6caea
Binary files /dev/null and b/mp/game/momentum/bin/game_shader_generic_eshader_2013.dll differ
diff --git a/mp/game/momentum/bin/shadereditor_2013.dll b/mp/game/momentum/bin/shadereditor_2013.dll
new file mode 100644
index 0000000000..1c2a9c01b2
Binary files /dev/null and b/mp/game/momentum/bin/shadereditor_2013.dll differ
diff --git a/mp/game/momentum/cfg/config_default.cfg b/mp/game/momentum/cfg/config_default.cfg
index c84c0051cd..f92a2c3f18 100644
--- a/mp/game/momentum/cfg/config_default.cfg
+++ b/mp/game/momentum/cfg/config_default.cfg
@@ -15,8 +15,7 @@ bind "CTRL" "+duck"
bind "e" "+use"
bind "c" "impulse 50"
bind "r" "+reload"
-bind "ALT" "+walk"
-bind "SHIFT" "+speed"
+bind "SHIFT" "+walk"
bind "MOUSE1" "+attack"
bind "MOUSE2" "+attack2"
bind "f" "impulse 100"
@@ -39,7 +38,7 @@ bind "g" "phys_swap"
bind "y" "messagemode"
bind "u" "messagemode2"
bind "k" "+voicerecord"
-//Momentum releated
+//Momentum related
bind "F5" "mom_restart"
bind "F6" "mom_reset"
bind "z" "showCPmenu"
diff --git a/mp/game/momentum/cfg/valve.rc b/mp/game/momentum/cfg/valve.rc
index e3abfaa662..09a2b13946 100644
--- a/mp/game/momentum/cfg/valve.rc
+++ b/mp/game/momentum/cfg/valve.rc
@@ -13,4 +13,6 @@ exec autoexec.cfg
//
stuffcmds
sv_unlockedchapters 99 //Random background selection
-startupmenu
\ No newline at end of file
+startupmenu
+//"fix" for demo playback stutter bug. MOM_TODO: fix this for realzies
+demo_interpolateview 0
diff --git a/mp/game/momentum/maps/bhop_eazy.bsp b/mp/game/momentum/maps/bhop_eazy.bsp
new file mode 100644
index 0000000000..3f7bfeca4a
Binary files /dev/null and b/mp/game/momentum/maps/bhop_eazy.bsp differ
diff --git a/mp/game/momentum/materials/detail/detailsprites_editor.vmt b/mp/game/momentum/materials/detail/detailsprites_editor.vmt
new file mode 100644
index 0000000000..dc012d6741
--- /dev/null
+++ b/mp/game/momentum/materials/detail/detailsprites_editor.vmt
@@ -0,0 +1,6 @@
+"EDITOR_SHADER"
+{
+ "$SHADERNAME" "detail_prop_shader"
+
+ "$basetexture" "detail/grass_sprites"
+}
diff --git a/mp/game/momentum/materials/detail/grass_lawn_cut.vmt b/mp/game/momentum/materials/detail/grass_lawn_cut.vmt
new file mode 100644
index 0000000000..0231a246ef
--- /dev/null
+++ b/mp/game/momentum/materials/detail/grass_lawn_cut.vmt
@@ -0,0 +1,8 @@
+"EDITOR_SHADER"
+{
+ "$SHADERNAME" "detail_prop_shader"
+
+ "$basetexture" "detail/grass_lawn_cut"
+ //"$grass_spec_color" "[0.367906 0.44 0.1914]"
+ "$grass_spec_color" "[0.8 1.0 0.3]"
+}
diff --git a/mp/game/momentum/materials/detail/grass_lawn_cut.vtf b/mp/game/momentum/materials/detail/grass_lawn_cut.vtf
new file mode 100644
index 0000000000..8d0501d4df
Binary files /dev/null and b/mp/game/momentum/materials/detail/grass_lawn_cut.vtf differ
diff --git a/mp/game/momentum/materials/detail/grass_lawn_cut_dark.vmt b/mp/game/momentum/materials/detail/grass_lawn_cut_dark.vmt
new file mode 100644
index 0000000000..e87a874b15
--- /dev/null
+++ b/mp/game/momentum/materials/detail/grass_lawn_cut_dark.vmt
@@ -0,0 +1,7 @@
+"EDITOR_SHADER"
+{
+ "$SHADERNAME" "detail_prop_shader"
+
+ "$basetexture" "detail/grass_lawn_cut_dark"
+ "$grass_spec_color" "[0.7 0.6 0.5]"
+}
diff --git a/mp/game/momentum/materials/detail/grass_lawn_cut_dark.vtf b/mp/game/momentum/materials/detail/grass_lawn_cut_dark.vtf
new file mode 100644
index 0000000000..3c03999de5
Binary files /dev/null and b/mp/game/momentum/materials/detail/grass_lawn_cut_dark.vtf differ
diff --git a/mp/game/momentum/materials/detail/grass_lawn_cut_lite.vmt b/mp/game/momentum/materials/detail/grass_lawn_cut_lite.vmt
new file mode 100644
index 0000000000..8f7d82fc4c
--- /dev/null
+++ b/mp/game/momentum/materials/detail/grass_lawn_cut_lite.vmt
@@ -0,0 +1,7 @@
+"EDITOR_SHADER"
+{
+ "$SHADERNAME" "detail_prop_shader"
+
+ "$basetexture" "detail/grass_lawn_cut_lite"
+ "$grass_spec_color" "[0.7 0.6 0.4]"
+}
diff --git a/mp/game/momentum/materials/detail/grass_lawn_cut_lite.vtf b/mp/game/momentum/materials/detail/grass_lawn_cut_lite.vtf
new file mode 100644
index 0000000000..d3c87bb831
Binary files /dev/null and b/mp/game/momentum/materials/detail/grass_lawn_cut_lite.vtf differ
diff --git a/mp/game/momentum/materials/detail/grass_sprites.vtf b/mp/game/momentum/materials/detail/grass_sprites.vtf
new file mode 100644
index 0000000000..11f760266c
Binary files /dev/null and b/mp/game/momentum/materials/detail/grass_sprites.vtf differ
diff --git a/mp/game/momentum/materials/detail/grass_sprites_spec.vtf b/mp/game/momentum/materials/detail/grass_sprites_spec.vtf
new file mode 100644
index 0000000000..70806e8481
Binary files /dev/null and b/mp/game/momentum/materials/detail/grass_sprites_spec.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_blue_b-02.vtf b/mp/game/momentum/materials/dev_nyro/dev_blue_b-02.vtf
new file mode 100644
index 0000000000..3a7906b753
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_blue_b-02.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_blue_b-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_blue_b-04.vtf
new file mode 100644
index 0000000000..179a51be38
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_blue_b-04.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_blue_b-05.vtf b/mp/game/momentum/materials/dev_nyro/dev_blue_b-05.vtf
new file mode 100644
index 0000000000..98e9d023ac
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_blue_b-05.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-01.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-01.vtf
new file mode 100644
index 0000000000..80bc86de8a
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-01.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-03.vmt b/mp/game/momentum/materials/dev_nyro/dev_gray-03.vmt
new file mode 100644
index 0000000000..207636cb55
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_gray-03.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_gray-03"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-03.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-03.vtf
new file mode 100644
index 0000000000..3c712b75b4
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-03.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-04.vtf
new file mode 100644
index 0000000000..2d258eb363
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-04.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-05.vmt b/mp/game/momentum/materials/dev_nyro/dev_gray-05.vmt
new file mode 100644
index 0000000000..f9ed31da98
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_gray-05.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_gray-05"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-05.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-05.vtf
new file mode 100644
index 0000000000..cb85ed6a61
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-05.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-06.vmt b/mp/game/momentum/materials/dev_nyro/dev_gray-06.vmt
new file mode 100644
index 0000000000..36f161d01a
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_gray-06.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_gray-06"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-06.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-06.vtf
new file mode 100644
index 0000000000..f77678fe54
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-06.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-07.vmt b/mp/game/momentum/materials/dev_nyro/dev_gray-07.vmt
new file mode 100644
index 0000000000..a61b86ae50
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_gray-07.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_gray-07"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-07.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-07.vtf
new file mode 100644
index 0000000000..82bee7c689
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-07.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-08.vmt b/mp/game/momentum/materials/dev_nyro/dev_gray-08.vmt
new file mode 100644
index 0000000000..5666144e95
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_gray-08.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_gray-08"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-08.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-08.vtf
new file mode 100644
index 0000000000..90e739c391
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-08.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-09.vmt b/mp/game/momentum/materials/dev_nyro/dev_gray-09.vmt
new file mode 100644
index 0000000000..4a56be738e
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_gray-09.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_gray-09"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-09.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-09.vtf
new file mode 100644
index 0000000000..7d208b3798
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-09.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-10.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-10.vtf
new file mode 100644
index 0000000000..c04a9d7cf9
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-10.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-11.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-11.vtf
new file mode 100644
index 0000000000..c64ae3f5cc
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-11.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-12.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-12.vtf
new file mode 100644
index 0000000000..5bad85b896
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-12.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-13.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-13.vtf
new file mode 100644
index 0000000000..61f1149108
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-13.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-14.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-14.vtf
new file mode 100644
index 0000000000..1f808c3811
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-14.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-15.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-15.vtf
new file mode 100644
index 0000000000..d657046a76
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-15.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-16.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-16.vtf
new file mode 100644
index 0000000000..de4626c359
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-16.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-17.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-17.vtf
new file mode 100644
index 0000000000..a13265ffb2
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-17.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-18.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-18.vtf
new file mode 100644
index 0000000000..8894bb3d79
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-18.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-19.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-19.vtf
new file mode 100644
index 0000000000..4076b28419
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-19.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-20.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-20.vtf
new file mode 100644
index 0000000000..caec4ab895
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-20.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-21.vmt b/mp/game/momentum/materials/dev_nyro/dev_gray-21.vmt
new file mode 100644
index 0000000000..45b09ea3a2
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_gray-21.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_gray-21"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_gray-21.vtf b/mp/game/momentum/materials/dev_nyro/dev_gray-21.vtf
new file mode 100644
index 0000000000..6b47e257d7
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_gray-21.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_green_a-03.vtf b/mp/game/momentum/materials/dev_nyro/dev_green_a-03.vtf
new file mode 100644
index 0000000000..9244903f1c
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_green_a-03.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_green_a-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_green_a-04.vtf
new file mode 100644
index 0000000000..b6d187bcde
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_green_a-04.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_magenta_b-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_magenta_b-04.vtf
new file mode 100644
index 0000000000..354723e689
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_magenta_b-04.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_orange_b-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_orange_b-04.vtf
new file mode 100644
index 0000000000..5615a61bc3
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_orange_b-04.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_purple_a-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_purple_a-04.vtf
new file mode 100644
index 0000000000..12673f8efa
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_purple_a-04.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_red_a-01.vmt b/mp/game/momentum/materials/dev_nyro/dev_red_a-01.vmt
new file mode 100644
index 0000000000..2269f0e51d
--- /dev/null
+++ b/mp/game/momentum/materials/dev_nyro/dev_red_a-01.vmt
@@ -0,0 +1,4 @@
+"LightmappedGeneric"
+{
+"$basetexture" "dev_nyro\dev_red_a-01"
+}
diff --git a/mp/game/momentum/materials/dev_nyro/dev_red_a-01.vtf b/mp/game/momentum/materials/dev_nyro/dev_red_a-01.vtf
new file mode 100644
index 0000000000..b9e9474f81
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_red_a-01.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_red_a-02.vtf b/mp/game/momentum/materials/dev_nyro/dev_red_a-02.vtf
new file mode 100644
index 0000000000..dd86f25e39
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_red_a-02.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_red_a-03.vtf b/mp/game/momentum/materials/dev_nyro/dev_red_a-03.vtf
new file mode 100644
index 0000000000..eee656673b
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_red_a-03.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_red_a-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_red_a-04.vtf
new file mode 100644
index 0000000000..482b7326f8
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_red_a-04.vtf differ
diff --git a/mp/game/momentum/materials/dev_nyro/dev_yellow_b-04.vtf b/mp/game/momentum/materials/dev_nyro/dev_yellow_b-04.vtf
new file mode 100644
index 0000000000..a2e0b8908a
Binary files /dev/null and b/mp/game/momentum/materials/dev_nyro/dev_yellow_b-04.vtf differ
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_blue_b-02.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_blue_b-02.vmt
new file mode 100644
index 0000000000..0eca79be92
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_blue_b-02.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_blue_b-02"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_blue_b-05.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_blue_b-05.vmt
new file mode 100644
index 0000000000..5be67da4c3
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_blue_b-05.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_blue_b-05"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-03.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-03.vmt
new file mode 100644
index 0000000000..6768dfeee7
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-03.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-03"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-05.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-05.vmt
new file mode 100644
index 0000000000..4315481467
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-05.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-05"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-07.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-07.vmt
new file mode 100644
index 0000000000..f527a59d7b
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-07.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-07"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-09.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-09.vmt
new file mode 100644
index 0000000000..7afa6ecadf
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-09.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-09"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-10.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-10.vmt
new file mode 100644
index 0000000000..e50a571ca8
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-10.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-10"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-11.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-11.vmt
new file mode 100644
index 0000000000..68bff9defd
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-11.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-11"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-13.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-13.vmt
new file mode 100644
index 0000000000..92b8c1690a
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-13.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-13"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-15.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-15.vmt
new file mode 100644
index 0000000000..2f90edee15
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-15.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-15"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-17.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-17.vmt
new file mode 100644
index 0000000000..3f03855fa1
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-17.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-17"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-19.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-19.vmt
new file mode 100644
index 0000000000..784b6daf92
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-19.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-19"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-21.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-21.vmt
new file mode 100644
index 0000000000..2eace71850
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_gray-21.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-21"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_green_a-03.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_green_a-03.vmt
new file mode 100644
index 0000000000..ca6e9c31d1
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_green_a-03.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_green_a-03"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_orange_b-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_orange_b-04.vmt
new file mode 100644
index 0000000000..e5bcf8d015
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_orange_b-04.vmt
@@ -0,0 +1,5 @@
+"vertexlitgeneric"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_orange_b-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/dev_wireframe.vmt b/mp/game/momentum/materials/models/props/dev_nyro/dev_wireframe.vmt
new file mode 100644
index 0000000000..6a335a2765
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/dev_wireframe.vmt
@@ -0,0 +1,6 @@
+"wireframe"
+{
+"$model" "1"
+"$basetexture" "dev_nyro\dev_gray-21"
+"$nocull" "1"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_blue_b-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_blue_b-04.vmt
new file mode 100644
index 0000000000..2384efd1e6
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_blue_b-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_blue_b-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-01.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-01.vmt
new file mode 100644
index 0000000000..c2ef3e7d85
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-01.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-01"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-03.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-03.vmt
new file mode 100644
index 0000000000..3096ba69ed
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-03.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-03"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-04.vmt
new file mode 100644
index 0000000000..4a80983357
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-06.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-06.vmt
new file mode 100644
index 0000000000..ddba3e57ea
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-06.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-06"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-07.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-07.vmt
new file mode 100644
index 0000000000..7d6288c41e
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-07.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-07"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-09.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-09.vmt
new file mode 100644
index 0000000000..1eebf2b1bb
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-09.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-09"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-10.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-10.vmt
new file mode 100644
index 0000000000..a43d5c1c34
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-10.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-10"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-12.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-12.vmt
new file mode 100644
index 0000000000..66f027b05d
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-12.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-12"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-13.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-13.vmt
new file mode 100644
index 0000000000..ec5d774cae
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-13.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-13"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-15.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-15.vmt
new file mode 100644
index 0000000000..bca801c658
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-15.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-15"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-16.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-16.vmt
new file mode 100644
index 0000000000..200da96b82
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-16.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-16"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-18.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-18.vmt
new file mode 100644
index 0000000000..0c31b01271
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-18.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-18"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-20.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-20.vmt
new file mode 100644
index 0000000000..e6b04cf8b5
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-20.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-20"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-21.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-21.vmt
new file mode 100644
index 0000000000..97f93a430e
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_gray-21.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_gray-21"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_green_a-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_green_a-04.vmt
new file mode 100644
index 0000000000..53f42f10b5
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_green_a-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_green_a-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_magenta_b-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_magenta_b-04.vmt
new file mode 100644
index 0000000000..fd152e1cbd
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_magenta_b-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_magenta_b-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_orange_b-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_orange_b-04.vmt
new file mode 100644
index 0000000000..13ed72c843
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_orange_b-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_orange_b-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_purple_a-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_purple_a-04.vmt
new file mode 100644
index 0000000000..cb8f8cb0a5
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_purple_a-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_purple_a-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_red_a-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_red_a-04.vmt
new file mode 100644
index 0000000000..9d96174636
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_red_a-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_red_a-04"
+}
diff --git a/mp/game/momentum/materials/models/props/dev_nyro/glow_yellow_b-04.vmt b/mp/game/momentum/materials/models/props/dev_nyro/glow_yellow_b-04.vmt
new file mode 100644
index 0000000000..a463cff6c0
--- /dev/null
+++ b/mp/game/momentum/materials/models/props/dev_nyro/glow_yellow_b-04.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+"$model" "1"
+"$selfillum" "1"
+"$basetexture" "dev_nyro\dev_yellow_b-04"
+}
diff --git a/mp/game/momentum/materials/shadereditor/_rt_framebuffer_prev.vmt b/mp/game/momentum/materials/shadereditor/_rt_framebuffer_prev.vmt
new file mode 100644
index 0000000000..267b66ca93
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/_rt_framebuffer_prev.vmt
@@ -0,0 +1,5 @@
+"unlitgeneric"
+{
+ "$basetexture" "_rt_SEdit_FramebufferCopy"
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/_rt_ppe.vmt b/mp/game/momentum/materials/shadereditor/_rt_ppe.vmt
new file mode 100644
index 0000000000..e1b9cccc8c
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/_rt_ppe.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+ "$basetexture" "_rt_SEdit_pingpong_2"
+
+ "$linearwrite" 0
+}
diff --git a/mp/game/momentum/materials/shadereditor/_rtdebug_pp0.vmt b/mp/game/momentum/materials/shadereditor/_rtdebug_pp0.vmt
new file mode 100644
index 0000000000..f815be50d1
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/_rtdebug_pp0.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+ "$basetexture" "_rt_SEdit_pingpong_0"
+
+ "$linearwrite" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/ac_def.vmt b/mp/game/momentum/materials/shadereditor/ac_def.vmt
new file mode 100644
index 0000000000..d30498e835
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/ac_def.vmt
@@ -0,0 +1,9 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/ac_def"
+ $translucent 1
+ $vertexcolor 0
+ $vertexalpha 0
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/ac_def.vtf b/mp/game/momentum/materials/shadereditor/ac_def.vtf
new file mode 100644
index 0000000000..763709bfc0
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/ac_def.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/ac_func.vmt b/mp/game/momentum/materials/shadereditor/ac_func.vmt
new file mode 100644
index 0000000000..3cba2c8956
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/ac_func.vmt
@@ -0,0 +1,9 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/ac_func"
+ $translucent 1
+ $vertexcolor 0
+ $vertexalpha 0
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/ac_func.vtf b/mp/game/momentum/materials/shadereditor/ac_func.vtf
new file mode 100644
index 0000000000..59287e67d5
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/ac_func.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/ac_struct.vmt b/mp/game/momentum/materials/shadereditor/ac_struct.vmt
new file mode 100644
index 0000000000..2027277065
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/ac_struct.vmt
@@ -0,0 +1,9 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/ac_struct"
+ $translucent 1
+ $vertexcolor 0
+ $vertexalpha 0
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/ac_struct.vtf b/mp/game/momentum/materials/shadereditor/ac_struct.vtf
new file mode 100644
index 0000000000..ec1853226e
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/ac_struct.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/ac_var.vmt b/mp/game/momentum/materials/shadereditor/ac_var.vmt
new file mode 100644
index 0000000000..4f2ac0934a
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/ac_var.vmt
@@ -0,0 +1,9 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/ac_var"
+ $translucent 1
+ $vertexcolor 0
+ $vertexalpha 0
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/ac_var.vtf b/mp/game/momentum/materials/shadereditor/ac_var.vtf
new file mode 100644
index 0000000000..c27a3e3636
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/ac_var.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/arrow.vmt b/mp/game/momentum/materials/shadereditor/arrow.vmt
new file mode 100644
index 0000000000..218fa3b709
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/arrow.vmt
@@ -0,0 +1,30 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/arrow"
+ $translucent 1
+ $distancealpha 1
+
+ $softedges 0
+ $edgesoftnessstart 0.5
+ $edgesoftnessend 0.45
+ $scaleedgesoftnessbasedonscreenres 0
+
+ $glow 1
+ $glowcolor "[0 0 0]"
+ $glowalpha 2.5
+ $glowstart .0
+ $glowend 1
+
+ $outline 0
+ $outlinecolor "[0.3 0.3 0.3]"
+ $outlinealpha 0.7
+ $outlinestart0 0
+ $outlinestart1 0.02
+ $outlineend0 0.58
+ $outlineend1 0.6
+
+ $vertexcolor 1
+ $vertexalpha 1
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/arrow.vtf b/mp/game/momentum/materials/shadereditor/arrow.vtf
new file mode 100644
index 0000000000..0bb5212b6b
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/arrow.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/blank.vmt b/mp/game/momentum/materials/shadereditor/blank.vmt
new file mode 100644
index 0000000000..d7c4370005
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/blank.vmt
@@ -0,0 +1,6 @@
+"unlitgeneric"
+{
+ "$vertexalpha" 1
+ "$vertexcolor" 1
+ //"$linearwrite" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/blank.vtf b/mp/game/momentum/materials/shadereditor/blank.vtf
new file mode 100644
index 0000000000..f28b74810b
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/blank.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/busy.vmt b/mp/game/momentum/materials/shadereditor/busy.vmt
new file mode 100644
index 0000000000..a46da75766
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/busy.vmt
@@ -0,0 +1,10 @@
+"unlitgeneric"
+{
+ "$basetexture" "shadereditor/busy"
+ "$nocull" 1
+ "$nofog" 1
+ "$ignorez" 1
+ "$translucent" 1
+ "$vertexalpha" 1
+ "$vertexcolor" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/busy.vtf b/mp/game/momentum/materials/shadereditor/busy.vtf
new file mode 100644
index 0000000000..5dc62c4f5c
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/busy.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/char_arrow.vmt b/mp/game/momentum/materials/shadereditor/char_arrow.vmt
new file mode 100644
index 0000000000..b1a7bf57e2
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/char_arrow.vmt
@@ -0,0 +1,9 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/char_arrow"
+ $translucent 1
+ $vertexcolor 1
+ $vertexalpha 1
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/char_arrow.vtf b/mp/game/momentum/materials/shadereditor/char_arrow.vtf
new file mode 100644
index 0000000000..15fbbcf3b3
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/char_arrow.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/char_cr.vmt b/mp/game/momentum/materials/shadereditor/char_cr.vmt
new file mode 100644
index 0000000000..7496675935
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/char_cr.vmt
@@ -0,0 +1,9 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/char_cr"
+ $translucent 1
+ $vertexcolor 1
+ $vertexalpha 1
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/char_cr.vtf b/mp/game/momentum/materials/shadereditor/char_cr.vtf
new file mode 100644
index 0000000000..492a5eb4c1
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/char_cr.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/colorpicker.vmt b/mp/game/momentum/materials/shadereditor/colorpicker.vmt
new file mode 100644
index 0000000000..7f1d3fac89
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/colorpicker.vmt
@@ -0,0 +1,3 @@
+"COLORPICKER_BLEND"
+{
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/colorpicker_hue.vmt b/mp/game/momentum/materials/shadereditor/colorpicker_hue.vmt
new file mode 100644
index 0000000000..b3e41c5393
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/colorpicker_hue.vmt
@@ -0,0 +1,10 @@
+"Unlitgeneric"
+{
+ "$basetexture" "shadereditor/colorpicker_hue"
+
+ "$linearwrite" 1
+ "$translucent" 1
+ "$vertexcolor" 1
+ "$vertexalpha" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/colorpicker_hue.vtf b/mp/game/momentum/materials/shadereditor/colorpicker_hue.vtf
new file mode 100644
index 0000000000..e1d7bd5e00
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/colorpicker_hue.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/colorpicker_sv.vmt b/mp/game/momentum/materials/shadereditor/colorpicker_sv.vmt
new file mode 100644
index 0000000000..cadc57257d
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/colorpicker_sv.vmt
@@ -0,0 +1,10 @@
+"Unlitgeneric"
+{
+ "$basetexture" "shadereditor/colorpicker_sv"
+
+ "$linearwrite" 1
+ "$translucent" 1
+ "$vertexcolor" 1
+ "$vertexalpha" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/colorpicker_sv.vtf b/mp/game/momentum/materials/shadereditor/colorpicker_sv.vtf
new file mode 100644
index 0000000000..95ba68f516
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/colorpicker_sv.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/darken.vmt b/mp/game/momentum/materials/shadereditor/darken.vmt
new file mode 100644
index 0000000000..02532a1e2f
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/darken.vmt
@@ -0,0 +1,7 @@
+"unlitgeneric"
+{
+ "$basetexture" "shadereditor/darken"
+ "$translucent" "1"
+
+ "$vertexalpha" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/darken.vtf b/mp/game/momentum/materials/shadereditor/darken.vtf
new file mode 100644
index 0000000000..3ee878ec1c
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/darken.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/grabicon.vmt b/mp/game/momentum/materials/shadereditor/grabicon.vmt
new file mode 100644
index 0000000000..0697d64014
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/grabicon.vmt
@@ -0,0 +1,10 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/grabicon"
+ $translucent 1
+
+ $vertexcolor 1
+ $vertexalpha 1
+
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/grabicon.vtf b/mp/game/momentum/materials/shadereditor/grabicon.vtf
new file mode 100644
index 0000000000..1ec5fb5c7c
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/grabicon.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/lock.vmt b/mp/game/momentum/materials/shadereditor/lock.vmt
new file mode 100644
index 0000000000..a1088abc66
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/lock.vmt
@@ -0,0 +1,9 @@
+"UnlitGeneric"
+{
+ $basetexture "shadereditor/lock"
+ $translucent 1
+ $vertexcolor 1
+ $vertexalpha 1
+ $no_fullbright 1
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/shadereditor/lock.vtf b/mp/game/momentum/materials/shadereditor/lock.vtf
new file mode 100644
index 0000000000..a9cc501aa9
Binary files /dev/null and b/mp/game/momentum/materials/shadereditor/lock.vtf differ
diff --git a/mp/game/momentum/materials/shadereditor/vguiTexSample.vmt b/mp/game/momentum/materials/shadereditor/vguiTexSample.vmt
new file mode 100644
index 0000000000..c15c76362f
--- /dev/null
+++ b/mp/game/momentum/materials/shadereditor/vguiTexSample.vmt
@@ -0,0 +1,8 @@
+"unlitgeneric"
+{
+ "$basetexture" "shadereditor/blank"
+ //"$translucent" 1
+
+
+ $ignorez 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/texture_samples/color_0.vtf b/mp/game/momentum/materials/texture_samples/color_0.vtf
new file mode 100644
index 0000000000..53d1a760a3
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/color_0.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/cubemap_eyereflection.hdr.vtf b/mp/game/momentum/materials/texture_samples/cubemap_eyereflection.hdr.vtf
new file mode 100644
index 0000000000..70fe1f405e
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/cubemap_eyereflection.hdr.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/cubemap_eyereflection.vtf b/mp/game/momentum/materials/texture_samples/cubemap_eyereflection.vtf
new file mode 100644
index 0000000000..70fe1f405e
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/cubemap_eyereflection.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/cubemap_stormydays.hdr.vtf b/mp/game/momentum/materials/texture_samples/cubemap_stormydays.hdr.vtf
new file mode 100644
index 0000000000..ecbfa88252
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/cubemap_stormydays.hdr.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/cubemap_stormydays.vtf b/mp/game/momentum/materials/texture_samples/cubemap_stormydays.vtf
new file mode 100644
index 0000000000..d39ad0b67b
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/cubemap_stormydays.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/cubemap_uffizi.hdr.vtf b/mp/game/momentum/materials/texture_samples/cubemap_uffizi.hdr.vtf
new file mode 100644
index 0000000000..d45c2d4f2e
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/cubemap_uffizi.hdr.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/cubemap_uffizi.vtf b/mp/game/momentum/materials/texture_samples/cubemap_uffizi.vtf
new file mode 100644
index 0000000000..7550a3cb7b
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/cubemap_uffizi.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/drew/water_droplets.vtf b/mp/game/momentum/materials/texture_samples/drew/water_droplets.vtf
new file mode 100644
index 0000000000..da005c2b49
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/drew/water_droplets.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/fx_clouds_0.vtf b/mp/game/momentum/materials/texture_samples/fx_clouds_0.vtf
new file mode 100644
index 0000000000..bf36445f50
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/fx_clouds_0.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/fx_clouds_0_normal.vtf b/mp/game/momentum/materials/texture_samples/fx_clouds_0_normal.vtf
new file mode 100644
index 0000000000..b000cc57fa
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/fx_clouds_0_normal.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/fx_clouds_1.vtf b/mp/game/momentum/materials/texture_samples/fx_clouds_1.vtf
new file mode 100644
index 0000000000..0876eb0b36
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/fx_clouds_1.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/fx_clouds_2.vtf b/mp/game/momentum/materials/texture_samples/fx_clouds_2.vtf
new file mode 100644
index 0000000000..c8e5fc4cd3
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/fx_clouds_2.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/fx_clouds_3.vtf b/mp/game/momentum/materials/texture_samples/fx_clouds_3.vtf
new file mode 100644
index 0000000000..90fb1f941f
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/fx_clouds_3.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/fx_clouds_4.vtf b/mp/game/momentum/materials/texture_samples/fx_clouds_4.vtf
new file mode 100644
index 0000000000..1f09df66a9
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/fx_clouds_4.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/grass_color.vtf b/mp/game/momentum/materials/texture_samples/grass_color.vtf
new file mode 100644
index 0000000000..79c0347926
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/grass_color.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/grass_height.vtf b/mp/game/momentum/materials/texture_samples/grass_height.vtf
new file mode 100644
index 0000000000..37704d0d26
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/grass_height.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/grass_normal.vtf b/mp/game/momentum/materials/texture_samples/grass_normal.vtf
new file mode 100644
index 0000000000..fe62d0629f
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/grass_normal.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/ice_0.vtf b/mp/game/momentum/materials/texture_samples/ice_0.vtf
new file mode 100644
index 0000000000..0a5a34d790
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/ice_0.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/ice_1.vtf b/mp/game/momentum/materials/texture_samples/ice_1.vtf
new file mode 100644
index 0000000000..7a47b4d15c
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/ice_1.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/ice_2.vtf b/mp/game/momentum/materials/texture_samples/ice_2.vtf
new file mode 100644
index 0000000000..53e2c634c8
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/ice_2.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/ice_3.vtf b/mp/game/momentum/materials/texture_samples/ice_3.vtf
new file mode 100644
index 0000000000..63dde646df
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/ice_3.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/matball_01.vtf b/mp/game/momentum/materials/texture_samples/matball_01.vtf
new file mode 100644
index 0000000000..bcecf693f6
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/matball_01.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/matball_02.vtf b/mp/game/momentum/materials/texture_samples/matball_02.vtf
new file mode 100644
index 0000000000..9360ab6821
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/matball_02.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/matball_03.vtf b/mp/game/momentum/materials/texture_samples/matball_03.vtf
new file mode 100644
index 0000000000..f92111b95d
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/matball_03.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/matball_04.vtf b/mp/game/momentum/materials/texture_samples/matball_04.vtf
new file mode 100644
index 0000000000..60524c8b7a
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/matball_04.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/matball_05.vtf b/mp/game/momentum/materials/texture_samples/matball_05.vtf
new file mode 100644
index 0000000000..ae83b29b37
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/matball_05.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/matball_06.vtf b/mp/game/momentum/materials/texture_samples/matball_06.vtf
new file mode 100644
index 0000000000..566966518c
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/matball_06.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/matball_07.vtf b/mp/game/momentum/materials/texture_samples/matball_07.vtf
new file mode 100644
index 0000000000..52022e2757
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/matball_07.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/noise_2d.vtf b/mp/game/momentum/materials/texture_samples/noise_2d.vtf
new file mode 100644
index 0000000000..fe3c1a056f
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/noise_2d.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/noise_3d.vtf b/mp/game/momentum/materials/texture_samples/noise_3d.vtf
new file mode 100644
index 0000000000..2fbd54d3c1
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/noise_3d.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/normal_0.vtf b/mp/game/momentum/materials/texture_samples/normal_0.vtf
new file mode 100644
index 0000000000..74680d101f
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/normal_0.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/normal_1.vtf b/mp/game/momentum/materials/texture_samples/normal_1.vtf
new file mode 100644
index 0000000000..7a359eac3f
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/normal_1.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/normal_2.vtf b/mp/game/momentum/materials/texture_samples/normal_2.vtf
new file mode 100644
index 0000000000..347494f8c5
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/normal_2.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/rocks_color.vtf b/mp/game/momentum/materials/texture_samples/rocks_color.vtf
new file mode 100644
index 0000000000..5905680619
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/rocks_color.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/rocks_height.vtf b/mp/game/momentum/materials/texture_samples/rocks_height.vtf
new file mode 100644
index 0000000000..7608d38cdb
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/rocks_height.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/rocks_normal.vtf b/mp/game/momentum/materials/texture_samples/rocks_normal.vtf
new file mode 100644
index 0000000000..751dbbe3e8
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/rocks_normal.vtf differ
diff --git a/mp/game/momentum/materials/texture_samples/rocks_normal_2.vtf b/mp/game/momentum/materials/texture_samples/rocks_normal_2.vtf
new file mode 100644
index 0000000000..3770c28520
Binary files /dev/null and b/mp/game/momentum/materials/texture_samples/rocks_normal_2.vtf differ
diff --git a/mp/game/momentum/materials/toggle_editor_lmg.vmt b/mp/game/momentum/materials/toggle_editor_lmg.vmt
new file mode 100644
index 0000000000..9277ebf5f8
--- /dev/null
+++ b/mp/game/momentum/materials/toggle_editor_lmg.vmt
@@ -0,0 +1,4 @@
+//"LightmappedGeneric"
+"EDITOR_SHADER"
+{
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/toggle_editor_wvt.vmt b/mp/game/momentum/materials/toggle_editor_wvt.vmt
new file mode 100644
index 0000000000..fc071f0e79
--- /dev/null
+++ b/mp/game/momentum/materials/toggle_editor_wvt.vmt
@@ -0,0 +1,4 @@
+//"WorldVertexTransition"
+"EDITOR_SHADER"
+{
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/close_button.vmt b/mp/game/momentum/materials/vgui/close_button.vmt
new file mode 100644
index 0000000000..abb51e593c
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/close_button.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\close_button"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/close_button.vtf b/mp/game/momentum/materials/vgui/close_button.vtf
new file mode 100644
index 0000000000..f90b956a55
Binary files /dev/null and b/mp/game/momentum/materials/vgui/close_button.vtf differ
diff --git a/mp/game/momentum/materials/vgui/left_arrow_button.vmt b/mp/game/momentum/materials/vgui/left_arrow_button.vmt
new file mode 100644
index 0000000000..2ce04a90dc
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/left_arrow_button.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\left_arrow_button"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/left_arrow_button.vtf b/mp/game/momentum/materials/vgui/left_arrow_button.vtf
new file mode 100644
index 0000000000..d3f09fa246
Binary files /dev/null and b/mp/game/momentum/materials/vgui/left_arrow_button.vtf differ
diff --git a/mp/game/momentum/materials/vgui/left_arrow_button_grey.vmt b/mp/game/momentum/materials/vgui/left_arrow_button_grey.vmt
new file mode 100644
index 0000000000..03d0b0a2d0
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/left_arrow_button_grey.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\left_arrow_button_grey"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/left_arrow_button_grey.vtf b/mp/game/momentum/materials/vgui/left_arrow_button_grey.vtf
new file mode 100644
index 0000000000..90deecb45e
Binary files /dev/null and b/mp/game/momentum/materials/vgui/left_arrow_button_grey.vtf differ
diff --git a/mp/game/momentum/materials/vgui/loop_button.vmt b/mp/game/momentum/materials/vgui/loop_button.vmt
new file mode 100644
index 0000000000..590365225e
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/loop_button.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\loop_button"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/loop_button.vtf b/mp/game/momentum/materials/vgui/loop_button.vtf
new file mode 100644
index 0000000000..2a1d68cbb0
Binary files /dev/null and b/mp/game/momentum/materials/vgui/loop_button.vtf differ
diff --git a/mp/game/momentum/materials/vgui/loop_button_grey.vmt b/mp/game/momentum/materials/vgui/loop_button_grey.vmt
new file mode 100644
index 0000000000..3bce778942
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/loop_button_grey.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\loop_button_grey"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/loop_button_grey.vtf b/mp/game/momentum/materials/vgui/loop_button_grey.vtf
new file mode 100644
index 0000000000..d950b43fa0
Binary files /dev/null and b/mp/game/momentum/materials/vgui/loop_button_grey.vtf differ
diff --git a/mp/game/momentum/materials/vgui/replay_icon.vmt b/mp/game/momentum/materials/vgui/replay_icon.vmt
new file mode 100644
index 0000000000..2ee42f3e87
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/replay_icon.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\replay_icon"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/replay_icon.vtf b/mp/game/momentum/materials/vgui/replay_icon.vtf
new file mode 100644
index 0000000000..5d267f4863
Binary files /dev/null and b/mp/game/momentum/materials/vgui/replay_icon.vtf differ
diff --git a/mp/game/momentum/materials/vgui/replay_icon_grey.vmt b/mp/game/momentum/materials/vgui/replay_icon_grey.vmt
new file mode 100644
index 0000000000..60cb589963
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/replay_icon_grey.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\replay_icon_grey"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/replay_icon_grey.vtf b/mp/game/momentum/materials/vgui/replay_icon_grey.vtf
new file mode 100644
index 0000000000..049ba9cfc1
Binary files /dev/null and b/mp/game/momentum/materials/vgui/replay_icon_grey.vtf differ
diff --git a/mp/game/momentum/materials/vgui/right_arrow_button.vmt b/mp/game/momentum/materials/vgui/right_arrow_button.vmt
new file mode 100644
index 0000000000..e15167bcf7
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/right_arrow_button.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\right_arrow_button"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/right_arrow_button.vtf b/mp/game/momentum/materials/vgui/right_arrow_button.vtf
new file mode 100644
index 0000000000..a183211175
Binary files /dev/null and b/mp/game/momentum/materials/vgui/right_arrow_button.vtf differ
diff --git a/mp/game/momentum/materials/vgui/right_arrow_button_grey.vmt b/mp/game/momentum/materials/vgui/right_arrow_button_grey.vmt
new file mode 100644
index 0000000000..4ae55e633c
--- /dev/null
+++ b/mp/game/momentum/materials/vgui/right_arrow_button_grey.vmt
@@ -0,0 +1,6 @@
+"UnlitGeneric"
+{
+ "$basetexture" "vgui\right_arrow_button_grey"
+ "$translucent" 1
+ "$ignorez" 1
+}
\ No newline at end of file
diff --git a/mp/game/momentum/materials/vgui/right_arrow_button_grey.vtf b/mp/game/momentum/materials/vgui/right_arrow_button_grey.vtf
new file mode 100644
index 0000000000..f64763a231
Binary files /dev/null and b/mp/game/momentum/materials/vgui/right_arrow_button_grey.vtf differ
diff --git a/mp/game/momentum/models/player/player_shape_base.dx80.vtx b/mp/game/momentum/models/player/player_shape_base.dx80.vtx
new file mode 100644
index 0000000000..96941ddd63
Binary files /dev/null and b/mp/game/momentum/models/player/player_shape_base.dx80.vtx differ
diff --git a/mp/game/momentum/models/player/player_shape_base.dx90.vtx b/mp/game/momentum/models/player/player_shape_base.dx90.vtx
new file mode 100644
index 0000000000..622ca9de95
Binary files /dev/null and b/mp/game/momentum/models/player/player_shape_base.dx90.vtx differ
diff --git a/mp/game/momentum/models/player/player_shape_base.mdl b/mp/game/momentum/models/player/player_shape_base.mdl
new file mode 100644
index 0000000000..363a060dd2
Binary files /dev/null and b/mp/game/momentum/models/player/player_shape_base.mdl differ
diff --git a/mp/game/momentum/models/player/player_shape_base.sw.vtx b/mp/game/momentum/models/player/player_shape_base.sw.vtx
new file mode 100644
index 0000000000..95b83f34e8
Binary files /dev/null and b/mp/game/momentum/models/player/player_shape_base.sw.vtx differ
diff --git a/mp/game/momentum/models/player/player_shape_base.vvd b/mp/game/momentum/models/player/player_shape_base.vvd
new file mode 100644
index 0000000000..5cf3d2e570
Binary files /dev/null and b/mp/game/momentum/models/player/player_shape_base.vvd differ
diff --git a/mp/game/momentum/resource/ClientScheme.res b/mp/game/momentum/resource/ClientScheme.res
index 86bc7f6bb2..9ca380f638 100644
--- a/mp/game/momentum/resource/ClientScheme.res
+++ b/mp/game/momentum/resource/ClientScheme.res
@@ -32,6 +32,9 @@ Scheme
"MOM.Speedometer.Normal" "255 255 255 125"
"MOM.Speedometer.Increase" "30 150 210 255"
"MOM.Speedometer.Decrease" "255 75 75 255"
+ "MOM.Compare.Gain" "30 150 210 255"
+ "MOM.Compare.Loss" "255 75 75 255"
+ "MOM.Compare.Tie" "255 255 255 255"
}
///////////////////// BASE SETTINGS ////////////////////////
@@ -211,7 +214,7 @@ Scheme
ToggleButton.SelectedTextColor "White"
- Tooltip.TextColor "TransparentBlack"
+ Tooltip.TextColor "White"
Tooltip.BgColor "Red"
TreeView.BgColor "TransparentBlack"
diff --git a/mp/game/momentum/resource/SourceScheme.res b/mp/game/momentum/resource/SourceScheme.res
index 62385297f6..8a7796febd 100644
--- a/mp/game/momentum/resource/SourceScheme.res
+++ b/mp/game/momentum/resource/SourceScheme.res
@@ -182,7 +182,7 @@ Scheme
ToggleButton.SelectedTextColor "White"
- Tooltip.TextColor "Light Gray"
+ Tooltip.TextColor "White"
Tooltip.BgColor "MOM.Panel.Bg"
TreeView.BgColor "Light Gray"
diff --git a/mp/game/momentum/resource/modevents.res b/mp/game/momentum/resource/modevents.res
index cdfd53ba66..c073e83e8d 100644
--- a/mp/game/momentum/resource/modevents.res
+++ b/mp/game/momentum/resource/modevents.res
@@ -27,51 +27,35 @@
"modevents"
{
- "timer_stopped"
+ "zone_enter"//When the player/ghost enters a checkpoint/stage trigger
{
- "avg_sync" "float"
- "avg_sync2" "float"
- "avg_vel" "float"
- "max_vel" "float"
- "start_vel" "float"
- "end_vel" "float"
- "num_strafes" "short"
- "num_jumps" "short"
- }
- "new_stage"
- {
- "stage_num" "byte"
- "stage_ticks" "long" //time is in ticks
- "avg_sync" "float"
- "avg_sync2" "float"
- "avg_vel" "float"
- "max_vel" "float"
- "stage_enter_vel" "float"
- "num_strafes" "short"
- "num_jumps" "short"
}
+ "zone_exit"//When the player exits the start trigger for the stage
+ {
+ }
"run_save"
{
"run_saved" "bool"
- "run_posted" "bool"
- }
- "timer_started"
- {
- "timer_isrunning" "bool"
- }
- "player_inside_mapzone"
- {
- "inside_startzone" "bool"
- "inside_endzone" "bool"
- "map_finished" "bool"
- }
- "keypress"
- {
- "num_jumps" "short"
- "num_strafes" "short"
}
- "practice_mode"
+ "run_upload"
+ {
+ "run_posted" "bool"
+ "web_msg" "string"//MOM_TODO: fill this with more stuff?
+ }
+ "timer_state"
{
- "has_practicemode" "bool"
+ "ent" "short"
+ "is_running" "bool"
}
+ "map_init"
+ {
+ "is_linear" "bool"
+ "num_zones" "byte"
+ }
+ "spec_target_updated" // Used by the spectator GUI
+ {
+ }
+ "mapfinished_panel_closed"
+ {
+ }
}
diff --git a/mp/game/momentum/resource/momentum_english.txt b/mp/game/momentum/resource/momentum_english.txt
index 7aecba568a..8831d92285 100644
Binary files a/mp/game/momentum/resource/momentum_english.txt and b/mp/game/momentum/resource/momentum_english.txt differ
diff --git a/mp/game/momentum/resource/ui/MapFinishedDialog.res b/mp/game/momentum/resource/ui/MapFinishedDialog.res
new file mode 100644
index 0000000000..8c2e422b8b
--- /dev/null
+++ b/mp/game/momentum/resource/ui/MapFinishedDialog.res
@@ -0,0 +1,365 @@
+"resource/ui/MapFinishedDialog.res"
+{
+ "CHudMapFinishedDialog"
+ {
+ "fieldName" "CHudMapFinishedDialog"
+ "xpos" "c-110"
+ "ypos" "c-150"
+ "wide" "220"
+ "tall" "175"
+ "visible" "1"
+ "enabled" "1"
+ "TextFont" "Default"
+ }
+
+ "Prev_Zone"
+ {
+ "ControlName" "ImagePanel"
+ "fieldName" "Prev_Zone"
+ "xpos" "2"
+ "ypos" "2"
+ "wide" "8"
+ "tall" "8"
+ "scaleImage" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "image" "left_arrow_button_grey"
+ }
+
+ "Next_Zone"
+ {
+ "ControlName" "ImagePanel"
+ "fieldName" "Next_Zone"
+ "xpos" "50"//Determined by code
+ "ypos" "2"
+ "wide" "8"
+ "tall" "8"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "scaleImage" "1"
+ "image" "right_arrow_button_grey"
+ }
+
+ "Replay_Icon"
+ {
+ "ControlName" "ImagePanel"
+ "fieldName" "Replay_Icon"
+ "xpos" "180"
+ "ypos" "80"
+ "wide" "32"
+ "tall" "32"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "scaleImage" "1"
+ "image" "replay_icon_grey"
+ }
+
+ "Repeat_Button"
+ {
+ "ControlName" "ImagePanel"
+ "fieldName" "Repeat_Button"
+ "xpos" "180"
+ "ypos" "120"
+ "wide" "32"
+ "tall" "32"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "scaleImage" "1"
+ "image" "loop_button_grey"
+ }
+
+ "Close_Panel"
+ {
+ "ControlName" "ImagePanel"
+ "fieldName" "Close_Panel"
+ "xpos" "180"
+ "ypos" "2"
+ "wide" "32"
+ "tall" "32"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "scaleImage" "1"
+ "image" "close_button"
+ }
+
+ "Current_Zone"//This is the label that shows what the current zone on the map finished panel
+ {
+ "ControlName" "Label"
+ "fieldName" "Current_Zone"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "13"
+ "ypos" "2"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_OverallStats"//This changes based on page number
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Overall_Time"// or "ZoneTime"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Overall_Time"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "20"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_RunTime"//Possibly changing to #MOM_MF_Time_Zone
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Enter_Time"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Enter_Time"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "30"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Zone_Enter"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Strafes"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Strafes"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "40"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Strafes"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Jumps"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Jumps"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "50"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Jumps"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Vel_Enter"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Vel_Enter"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "60"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Velocity_Enter"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Vel_Exit"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Vel_Exit"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "70"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Velocity_Exit"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Vel_Avg"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Vel_Avg"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "80"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Velocity_Avg"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Vel_Max"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Vel_Max"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "90"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Velocity_Max"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Sync1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Sync1"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "100"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Sync1"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Zone_Sync2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Zone_Sync2"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "110"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_Sync2"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Run_Save_Status"
+ {
+ "ControlName" "Label"
+ "fieldName" "Run_Save_Status"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "130"
+ "wide" "100"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_RunNotSaved"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Run_Upload_Status"
+ {
+ "ControlName" "Label"
+ "fieldName" "Run_Upload_Status"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "20"
+ "ypos" "140"
+ "wide" "120"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_RunNotUploaded"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ "Detach_Mouse"
+ {
+ "ControlName" "Label"
+ "fieldName" "Detach_Mouse"
+ "font" "Default"//Set by "TextFont" in HudLayout.res
+ "xpos" "4"
+ "ypos" "160"
+ "wide" "150"
+ "tall" "10"//Set by font size
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" "#MOM_MF_DetachMouse"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+
+ styles
+ {
+ status
+ {
+ bgcolor="PropertySheetBG"
+ inset="8 0 0 0"
+ }
+ }
+}
diff --git a/mp/game/momentum/resource/ui/Spectator.res b/mp/game/momentum/resource/ui/Spectator.res
new file mode 100644
index 0000000000..d431037ecc
--- /dev/null
+++ b/mp/game/momentum/resource/ui/Spectator.res
@@ -0,0 +1,126 @@
+"Resource/UI/SpectatorGUI.res"
+{
+ "SpectatorGUI"
+ {
+ "ControlName" "Frame"
+ "fieldName" "SpectatorGUI"
+ "tall" "480"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ }
+ "topbar"
+ {
+ "ControlName" "Panel"
+ "fieldName" "topbar"
+ "xpos" "0"
+ "ypos" "0"
+ "tall" "52"
+ "wide" "640"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ }
+ "bottombarblank"
+ {
+ "ControlName" "Panel"
+ "fieldName" "bottombarblank"
+ "xpos" "0"
+ "ypos" "428"
+ "tall" "55" // this needs to match the size of BottomBar
+ "wide" "640"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ }
+ "playerlabel"
+ {
+ "ControlName" "Label"
+ "fieldName" "playerlabel"
+ "xpos" "r86"
+ "ypos" "20"
+ "wide" "81"
+ "tall" "15"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" ""
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+ "timelabel"
+ {
+ "ControlName" "Label"
+ "fieldName" "timelabel"
+ "xpos" "r86"
+ "ypos" "28"
+ "wide" "81"
+ "tall" "15"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" ""
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+ "replaylabel"
+ {
+ "ControlName" "Label"
+ "fieldName" "replaylabel"
+ "xpos" "c-175"
+ "ypos" "18"
+ "wide" "350"
+ "tall" "26"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textAlignment" "center"
+ }
+ "extrainfo"
+ {
+ "ControlName" "Label"
+ "fieldName" "extrainfo"
+ "xpos" "r86"
+ "ypos" "12"
+ "wide" "81"
+ "tall" "15"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "labelText" ""
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+ "titlelabel"
+ {
+ "ControlName" "Label"
+ "fieldName" "titlelabel"
+ "xpos" "16"
+ "ypos" "16"
+ "wide" "320"
+ "tall" "20"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "font" "HudNumbersSmall"
+ "labelText" ""
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ }
+}
diff --git a/mp/game/momentum/scripts/HudAnimations.txt b/mp/game/momentum/scripts/HudAnimations.txt
index e3204ec337..c5c9466de7 100644
--- a/mp/game/momentum/scripts/HudAnimations.txt
+++ b/mp/game/momentum/scripts/HudAnimations.txt
@@ -39,6 +39,37 @@ event MenuClose
Animate CHudMenuStatic ItemColor "0 0 0 0" Linear 0.0 1
}
+//Fades out the stage enter speed
+event FadeOutEnterSpeed
+{
+ //Take 5 seconds to fade the number out
+ Animate HudSpeedMeter StageAlpha "0" Accel 5.0 0.75
+}
+
+event ResetEnterSpeed
+{
+ //Stop any fadeout happening
+ StopEvent FadeOutEnterSpeed 0.0
+
+ //Reset the alpha back to normal immediately
+ Animate HudSpeedMeter StageAlpha "255" Linear 0.0 0.001
+}
+
+event FadeOutJumpSpeed
+{
+ //Fade out the last jump speed immediately, the time calculation is done in code
+ Animate HudSpeedMeter JumpAlpha "0" Accel 0.0 0.75
+}
+
+event ResetJumpSpeed
+{
+ //Stop any fadeout happening
+ StopEvent FadeOutJumpSpeed 0.0
+
+ //Reset the alpha back to normal immediately MOM_TODO: should this fade back in?
+ Animate HudSpeedMeter JumpAlpha "255" Linear 0.0 0.001
+}
+
event WeaponHighlight
{
Animate HudWeaponSelection Blur "7" Linear 0.0 0.0
diff --git a/mp/game/momentum/scripts/HudLayout.res b/mp/game/momentum/scripts/HudLayout.res
index 8d5e77da05..51b16fa086 100644
--- a/mp/game/momentum/scripts/HudLayout.res
+++ b/mp/game/momentum/scripts/HudLayout.res
@@ -1,853 +1,859 @@
"Resource/HudLayout.res"
{
//Speedometer
- HudSpeedMeter
- {
- "fieldName" "HudSpeedMeter"
- "xpos" "c-60"
- "ypos" "310"
- "wide" "120"
- "tall" "40"
- "visible" "1"
- "enabled" "1"
- "NumberFont" "HudNumbersSmallBold"
- "SmallNumberFont" "HudNumbersExtremelySmall"
- "text_ypos" "5"
- "digit_ypos" "15"
- "digit2_ypos" "30"
- "PrimaryValueColor" "MOM.Panel.Fg"
- "SecondaryValueColor" "Light Gray"
- "LabelColor" "MOM.Panel.Fg"
- "BgColor" "Blank"
- }
+ HudSpeedMeter
+ {
+ "fieldName" "HudSpeedMeter"
+ "xpos" "c-60"
+ "ypos" "310"
+ "wide" "120"
+ "tall" "80"
+ "visible" "1"
+ "enabled" "1"
+ "NumberFont" "HudNumbersSmallBold"
+ "SmallNumberFont" "HudNumbersExtremelySmall"
+ "text_ypos" "5"
+ "digit_ypos" "15"
+ "digit2_ypos" "30"
+ "PrimaryValueColor" "MOM.Panel.Fg"
+ "SecondaryValueColor" "Light Gray"
+ "LabelColor" "MOM.Panel.Fg"
+ "BgColor" "Blank"
+ "SplitAlpha" "255"//Used for fading
+ "JumpAlpha" "255"//Used for fading
+ }
//Timer
- HudTimer
- {
- "fieldName" "HudTimer"
- "xpos" "c-50"
- "ypos" "c+150"
- "wide" "100"
- "tall" "50"
- "visible" "1"
- "enabled" "1"
+ HudTimer
+ {
+ "fieldName" "HudTimer"
+ "xpos" "c-50"
+ "ypos" "c+150"
+ "wide" "100"
+ "tall" "50"
+ "visible" "1"
+ "enabled" "1"
"PaintBackgroundType" "2"
- "TimerFont" "HudNumbersSmallBold"
- "TextFont" "HudHintTextLarge"
- "SmallTextFont" "HudHintTextSmall"
- "TextColor" "MOM.Panel.Fg"
- "centerTime" "1" //If true, won't use time_xpos, centering the text instead
- "time_xpos" "50"
- "time_ypos" "3"
- "centerCps" "1" //If true, won't use cps_xpos, centering the text instead
- "cps_xpos" "50"
- "cps_ypos" "19"
- "centerStage" "1" //If true, won't use stage_xpos, centering the text instead
- "stage_xpos" "50"
- "stage_ypos" "34"
- }
- //Strafe Sync Meter
- CHudSyncMeter
- {
- "fieldName" "CHudSyncMeter"
- "xpos" "c-25"
- "ypos" "c+198"
- "wide" "50"
- "tall" "30"
- "visible" "1"
- "enabled" "1"
- "TextFont" "HudNumbersVerySmall"
- "NumberFont" "HudNumbersSmall"
- "SmallNumberFont" "HudNumbersVerySmall"
+ "TimerFont" "HudNumbersSmallBold"
+ "TextFont" "HudHintTextLarge"
+ "SmallTextFont" "HudHintTextSmall"
+ "TextColor" "MOM.Panel.Fg"
+ "centerTime" "1" //If true, won't use time_xpos, centering the text instead
+ "time_xpos" "50"
+ "time_ypos" "3"
+ "centerCps" "1" //If true, won't use cps_xpos, centering the text instead
+ "cps_xpos" "50"//Note: checkpoints only show when there's no run (and therefore splits)
+ "cps_ypos" "19"
+ "centerSplit" "1" //If true, won't use stage_xpos, centering the stage split
+ "split_xpos" "50"
+ "split_ypos" "19"
+ }
+ //Strafe Sync Meter
+ CHudSyncMeter
+ {
+ "fieldName" "CHudSyncMeter"
+ "xpos" "c-25"
+ "ypos" "c+198"
+ "wide" "50"
+ "tall" "30"
+ "visible" "1"
+ "enabled" "1"
+ "TextFont" "HudNumbersVerySmall"
+ "NumberFont" "HudNumbersSmall"
+ "SmallNumberFont" "HudNumbersVerySmall"
"PaintBackgroundType" "2"
- "text_xpos" "15"
- "text_ypos" "2"
- "digit_xpos" "12"
- "digit_ypos" "12"
- "digit2_xpos" "30"
- "digit2_ypos" "16"
- "PrimaryValueColor" "MOM.Panel.Fg"
- "SecondaryValueColor" "MOM.Panel.Fg"
- "LabelColor" "White"
- "BgColor" "Blank"
- }
+ "text_xpos" "15"
+ "text_ypos" "2"
+ "digit_xpos" "12"
+ "digit_ypos" "12"
+ "digit2_xpos" "30"
+ "digit2_ypos" "16"
+ "PrimaryValueColor" "MOM.Panel.Fg"
+ "SecondaryValueColor" "MOM.Panel.Fg"
+ "LabelColor" "White"
+ "BgColor" "Blank"
+ }
//The design for in-game menus
CHudMenuStatic
{
"fieldName" "CHudMenuStatic"
//You can override "MenuItemColor" etc here (I think)
}
- // Version warning
- CHudVersionWarn
- {
- "fieldName" "CHudVersionWarn"
- "xpos" "640"
- "ypos" "460"
- "visible" "1"
- "enabled" "1"
- "wide" "200"
- "tall" "20"
- "TextFont" "HudHintTextSmall"
- }
- CHudSyncBar
- {
- "fieldName" "CHudSyncBar"
- "xpos" "c-60"
- "ypos" "c+227"
- "wide" "120"
- "tall" "10"
- "InitialValue" "0"
- "BackgroundColor" "MOM.Panel.Bg"
- "FillColor" "255 255 255 225"
- "visible" "1"
- "enabled" "1"
- }
- CHudMapFinishedDialog
- {
- "fieldName" "CHudMapFinishedDialog"
- "xpos" "c-125"
- "ypos" "c-100"
- "wide" "250"
- "tall" "120"
- "visible" "1"
- "enabled" "1"
- "TextFont" "Default"
- "time_xpos" "20"
- "time_ypos" "5"
- "strafes_xpos" "20"
- "strafes_xpos" "25"
- "jumps_xpos" "20"
- "jumps_xpos" "45"
- "sync_xpos" "20"
- "sync_xpos" "65"
- "sync2_xpos" "20"
- "sync2_ypos" "85"
- "startvel_xpos" "120"
- "startvel_ypos" "5"
- "endvel_xpos" "120"
- "endvel_ypos" "25"
- "avgvel_xpos" "120"
- "avgvel_ypos" "45"
- "maxvel_xpos" "120"
- "maxvel_ypos" "65"
- "runsave_ypos" "95"
- "runupload_ypos""105"
- }
- CHudKeyPressDisplay
- {
- "fieldName" "CHudKeyPressDisplay"
- "xpos" "c+265"
- "ypos" "c+150"
- "wide" "150"
- "tall" "100"
- "visible" "1"
- "enabled" "1"
- "top_row_ypos" "5"
- "mid_row_ypos" "20"
- "lower_row_ypos" "35"
- "jump_row_ypos" "45"
- "duck_row_ypos" "55"
- "strafe_count_xpos" "100"
- "jump_count_xpos" "100"
- "TextFont" "MomentumIcons"
- "CounterTextFont" "HudNumbersVerySmall"
- "WordTextFont" "HudNumbersVerySmall"
- "KeyPressedColor" "MOM.Panel.Fg"
- "KeyOutlineColor" "Dark Gray"
- }
- HudHealth [$WIN32]
- {
- "fieldName" "HudHealth"
- "xpos" "16"
- "ypos" "432"
- "wide" "102"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "20"
- "digit_xpos" "50"
- "digit_ypos" "2"
- }
- HudHealth [$X360]
- {
- "fieldName" "HudHealth"
- "xpos" "48"
- "ypos" "416"
- "wide" "115"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "18"
- "digit_xpos" "60"
- "digit_ypos" "-1"
- }
-
- HudSuit [$WIN32]
- {
- "fieldName" "HudSuit"
- "xpos" "140"
- "ypos" "432"
- "wide" "108"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "20"
- "digit_xpos" "50"
- "digit_ypos" "2"
- }
- HudSuit [$X360]
- {
- "fieldName" "HudSuit"
- "xpos" "176"
- "ypos" "416"
- "wide" "117"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "18"
- "digit_xpos" "50"
- "digit_ypos" "-1"
- }
-
- HudAmmo [$WIN32]
- {
- "fieldName" "HudAmmo"
- "xpos" "r150"
- "ypos" "432"
- "wide" "136"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "20"
- "digit_xpos" "44"
- "digit_ypos" "2"
- "digit2_xpos" "98"
- "digit2_ypos" "16"
- }
- HudAmmo [$X360]
- {
- "fieldName" "HudAmmo"
- "xpos" "r208"
- "ypos" "416"
- "wide" "160"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "18"
- "digit_xpos" "60"
- "digit_ypos" "-1"
- "digit2_xpos" "120"
- "digit2_ypos" "14"
- }
-
- HudAmmoSecondary [$WIN32]
- {
- "fieldName" "HudAmmoSecondary"
- "xpos" "r76"
- "ypos" "432"
- "wide" "60"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "22"
- "digit_xpos" "36"
- "digit_ypos" "2"
- }
- HudAmmoSecondary [$X360]
- {
- "fieldName" "HudAmmoSecondary"
- "xpos" "r113"
- "ypos" "416"
- "wide" "65"
- "tall" "36"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "text_xpos" "8"
- "text_ypos" "22"
- "digit_xpos" "36"
- "digit_ypos" "-1"
- }
-
- HudSuitPower [$WIN32]
- {
- "fieldName" "HudSuitPower"
- "visible" "1"
- "enabled" "1"
- "xpos" "16"
- "ypos" "396"
- "wide" "102"
- "tall" "26"
-
- "AuxPowerLowColor" "255 0 0 220"
- "AuxPowerHighColor" "255 220 0 220"
- "AuxPowerDisabledAlpha" "70"
-
- "BarInsetX" "8"
- "BarInsetY" "15"
- "BarWidth" "92"
- "BarHeight" "4"
- "BarChunkWidth" "6"
- "BarChunkGap" "3"
-
- "text_xpos" "8"
- "text_ypos" "4"
- "text2_xpos" "8"
- "text2_ypos" "22"
- "text2_gap" "10"
-
- "PaintBackgroundType" "2"
- }
- HudSuitPower [$X360]
- {
- "fieldName" "HudSuitPower"
- "visible" "1"
- "enabled" "1"
- "xpos" "48"
- "ypos" "370"
- "wide" "102"
- "tall" "26"
-
- "AuxPowerLowColor" "255 100 0 220"
- "AuxPowerHighColor" "255 220 0 220"
- "AuxPowerDisabledAlpha" "70"
-
- "BarInsetX" "8"
- "BarInsetY" "19"
- "BarWidth" "92"
- "BarHeight" "5"
- "BarChunkWidth" "6"
- "BarChunkGap" "3"
-
- "text_xpos" "8"
- "text_ypos" "4"
- "text2_xpos" "8"
- "text2_ypos" "25"
- "text2_gap" "12"
-
- "PaintBackgroundType" "2"
- }
-
- HudPosture [$WIN32]
- {
- "fieldName" "HudPosture"
- "visible" "1"
- "PaintBackgroundType" "2"
- "xpos" "16"
- "ypos" "316"
- "tall" "36"
- "wide" "36"
- "font" "WeaponIconsSmall"
- "icon_xpos" "10"
- "icon_ypos" "0"
- }
- HudPosture [$X360]
- {
- "fieldName" "HudPosture"
- "visible" "1"
- "PaintBackgroundType" "2"
- "xpos" "48"
- "ypos" "316"
- "tall" "36"
- "wide" "36"
- "font" "WeaponIconsSmall"
- "icon_xpos" "10"
- "icon_ypos" "2"
- }
-
- HudFlashlight
- {
- "fieldName" "HudFlashlight"
- "visible" "1"
- "PaintBackgroundType" "2"
- "xpos" "270" [$WIN32]
- "ypos" "444" [$WIN32]
- "xpos_hidef" "293" [$X360] // aligned to left
- "xpos_lodef" "c-18" [$X360] // centered in screen
- "ypos" "428" [$X360]
- "tall" "24"
- "wide" "36"
- "font" "WeaponIconsSmall"
-
- "icon_xpos" "4"
- "icon_ypos" "-8"
-
- "BarInsetX" "4"
- "BarInsetY" "18"
- "BarWidth" "28"
- "BarHeight" "2"
- "BarChunkWidth" "2"
- "BarChunkGap" "1"
- }
- HudDamageIndicator
- {
- "fieldName" "HudDamageIndicator"
- "visible" "1"
- "enabled" "1"
- "DmgColorLeft" "255 0 0 0"
- "DmgColorRight" "255 0 0 0"
-
- "dmg_xpos" "30"
- "dmg_ypos" "100"
- "dmg_wide" "36"
- "dmg_tall1" "240"
- "dmg_tall2" "200"
- }
-
- HudZoom
- {
- "fieldName" "HudZoom"
- "visible" "1"
- "enabled" "1"
- "Circle1Radius" "66"
- "Circle2Radius" "74"
- "DashGap" "16"
- "DashHeight" "4" [$WIN32]
- "DashHeight" "6" [$X360]
- "BorderThickness" "88"
- }
- HudWeaponSelection
- {
- "fieldName" "HudWeaponSelection"
- "ypos" "16" [$WIN32]
- "ypos" "32" [$X360]
- "visible" "1"
- "enabled" "1"
- "SmallBoxSize" "32"
- "MediumBoxWide" "95"
- "MediumBoxWide_hidef" "78"
- "MediumBoxTall" "50"
- "MediumBoxTall_hidef" "50"
- "MediumBoxWide_lodef" "74"
- "MediumBoxTall_lodef" "50"
- "LargeBoxWide" "112"
- "LargeBoxTall" "80"
- "BoxGap" "8"
- "SelectionNumberXPos" "4"
- "SelectionNumberYPos" "4"
- "SelectionGrowTime" "0.4"
- "TextYPos" "64"
- }
-
- HudCrosshair
- {
- "fieldName" "HudCrosshair"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudDeathNotice
- {
- "fieldName" "HudDeathNotice"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudVehicle
- {
- "fieldName" "HudVehicle"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- ScorePanel
- {
- "fieldName" "ScorePanel"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudTrain
- {
- "fieldName" "HudTrain"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudMOTD
- {
- "fieldName" "HudMOTD"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudMessage
- {
- "fieldName" "HudMessage"
- "visible" "1"
- "enabled" "1"
- "wide" "f0"
- "tall" "480"
- }
-
- HudMenu
- {
- "fieldName" "HudMenu"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudCloseCaption
- {
- "fieldName" "HudCloseCaption"
- "visible" "1"
- "enabled" "1"
- "xpos" "c-250"
- "ypos" "276" [$WIN32]
- "ypos" "236" [$X360]
- "wide" "500"
- "tall" "136" [$WIN32]
- "tall" "176" [$X360]
-
- "BgAlpha" "128"
-
- "GrowTime" "0.25"
- "ItemHiddenTime" "0.2" // Nearly same as grow time so that the item doesn't start to show until growth is finished
- "ItemFadeInTime" "0.15" // Once ItemHiddenTime is finished, takes this much longer to fade in
- "ItemFadeOutTime" "0.3"
- "topoffset" "0" [$WIN32]
- "topoffset" "0" [$X360]
- }
-
- HudChat
- {
- "fieldName" "HudChat"
- "visible" "0"
- "enabled" "1"
- "xpos" "0"
- "ypos" "0"
- "wide" "4"
- "tall" "4"
- }
-
- HudHistoryResource [$WIN32]
- {
- "fieldName" "HudHistoryResource"
- "visible" "1"
- "enabled" "1"
- "xpos" "r252"
- "ypos" "40"
- "wide" "248"
- "tall" "320"
-
- "history_gap" "56" [!$OSX]
- "history_gap" "64" [$OSX]
- "icon_inset" "38"
- "text_inset" "36"
- "text_inset" "26"
- "NumberFont" "HudNumbersSmall"
- }
- HudHistoryResource [$X360]
- {
- "fieldName" "HudHistoryResource"
- "visible" "1"
- "enabled" "1"
- "xpos" "r300"
- "ypos" "40"
- "wide" "248"
- "tall" "240"
-
- "history_gap" "50"
- "icon_inset" "38"
- "text_inset" "36"
- "NumberFont" "HudNumbersSmall"
- }
-
- HudGeiger
- {
- "fieldName" "HudGeiger"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HUDQuickInfo
- {
- "fieldName" "HUDQuickInfo"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudWeapon
- {
- "fieldName" "HudWeapon"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
- HudAnimationInfo
- {
- "fieldName" "HudAnimationInfo"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudPredictionDump
- {
- "fieldName" "HudPredictionDump"
- "visible" "1"
- "enabled" "1"
- "wide" "640"
- "tall" "480"
- }
-
- HudHintDisplay
- {
- "fieldName" "HudHintDisplay"
- "visible" "0"
- "enabled" "1"
- "xpos" "c-240"
- "ypos" "c60"
- "xpos" "r148" [$X360]
- "ypos" "r338" [$X360]
- "wide" "480"
- "tall" "100"
- "HintSize" "1"
- "text_xpos" "8"
- "text_ypos" "8"
- "center_x" "0" // center text horizontally
- "center_y" "-1" // align text on the bottom
- "paintbackground" "0"
- }
-
- HudHintKeyDisplay
- {
- "fieldName" "HudHintKeyDisplay"
- "visible" "0"
- "enabled" "1"
- "xpos" "r120" [$WIN32]
- "ypos" "r340" [$WIN32]
- "xpos" "r148" [$X360]
- "ypos" "r338" [$X360]
- "wide" "100"
- "tall" "200"
- "text_xpos" "8"
- "text_ypos" "8"
- "text_xgap" "8"
- "text_ygap" "8"
- "TextColor" "255 170 0 220"
-
- "PaintBackgroundType" "2"
- }
-
-
- HudSquadStatus [$WIN32]
- {
- "fieldName" "HudSquadStatus"
- "visible" "1"
- "enabled" "1"
- "xpos" "r120"
- "ypos" "380"
- "wide" "104"
- "tall" "46"
- "text_xpos" "8"
- "text_ypos" "34"
- "SquadIconColor" "255 220 0 160"
- "IconInsetX" "8"
- "IconInsetY" "0"
- "IconGap" "24"
-
- "PaintBackgroundType" "2"
- }
- HudSquadStatus [$X360]
- {
- "fieldName" "HudSquadStatus"
- "visible" "1"
- "enabled" "1"
- "xpos" "r182"
- "ypos" "348"
- "wide" "134"
- "tall" "62"
- "text_xpos" "8"
- "text_ypos" "44"
- "SquadIconColor" "255 220 0 160"
- "IconInsetX" "8"
- "IconInsetY" "-4"
- "IconGap" "24"
- "IconFont" "SquadIcon"
-
- "PaintBackgroundType" "2"
- }
-
- HudPoisonDamageIndicator [$WIN32]
- {
- "fieldName" "HudPoisonDamageIndicator"
- "visible" "0"
- "enabled" "1"
- "xpos" "16"
- "ypos" "346"
- "wide" "136"
- "tall" "38"
- "text_xpos" "8"
- "text_ypos" "8"
- "text_ygap" "14"
- "TextColor" "255 170 0 220"
- "PaintBackgroundType" "2"
- }
- HudPoisonDamageIndicator [$X360]
- {
- "fieldName" "HudPoisonDamageIndicator"
- "visible" "0"
- "enabled" "1"
- "xpos" "48"
- "ypos" "264"
- "wide" "192"
- "tall" "46"
- "text_xpos" "8"
- "text_ypos" "6"
- "text_ygap" "16"
- "TextColor" "255 170 0 220"
- "PaintBackgroundType" "2"
- }
-
- HudCredits
- {
- "fieldName" "HudCredits"
- "TextFont" "Default"
- "visible" "1"
- "xpos" "0"
- "ypos" "0"
- "wide" "640"
- "tall" "480"
- "TextColor" "255 255 255 192"
-
- }
-
- HUDAutoAim
- {
- "fieldName" "HUDAutoAim"
- "visible" "1"
- "enabled" "1"
- "wide" "640" [$WIN32]
- "tall" "480" [$WIN32]
- "wide" "960" [$X360]
- "tall" "720" [$X360]
- }
-
- HudCommentary
- {
- "fieldName" "HudCommentary"
- "xpos" "c-190"
- "ypos" "350"
- "wide" "380"
- "tall" "40"
- "visible" "1"
- "enabled" "1"
-
- "PaintBackgroundType" "2"
-
- "bar_xpos" "50"
- "bar_ypos" "20"
- "bar_height" "8"
- "bar_width" "320"
- "speaker_xpos" "50"
- "speaker_ypos" "8"
- "count_xpos_from_right" "10" // Counts from the right side
- "count_ypos" "8"
-
- "icon_texture" "vgui/hud/icon_commentary"
- "icon_xpos" "0"
- "icon_ypos" "0"
- "icon_width" "40"
- "icon_height" "40"
- }
-
- HudHDRDemo
- {
- "fieldName" "HudHDRDemo"
- "xpos" "0"
- "ypos" "0"
- "wide" "640"
- "tall" "480"
- "visible" "1"
- "enabled" "1"
-
- "Alpha" "255"
- "PaintBackgroundType" "2"
-
- "BorderColor" "0 0 0 255"
- "BorderLeft" "16"
- "BorderRight" "16"
- "BorderTop" "16"
- "BorderBottom" "64"
- "BorderCenter" "0"
-
- "TextColor" "255 255 255 255"
- "LeftTitleY" "422"
- "RightTitleY" "422"
- }
-
- AchievementNotificationPanel
- {
- "fieldName" "AchievementNotificationPanel"
- "visible" "1"
- "enabled" "1"
- "xpos" "0"
- "ypos" "180"
- "wide" "f10" [$WIN32]
- "wide" "f60" [$X360]
- "tall" "100"
- }
-
- CHudVote
- {
- "fieldName" "CHudVote"
- "xpos" "0"
- "ypos" "0"
- "wide" "640"
- "tall" "480"
- "visible" "1"
- "enabled" "1"
- "bgcolor_override" "0 0 0 0"
- "PaintBackgroundType" "0" // rounded corners
- }
+ // Version warning
+ CHudVersionWarn
+ {
+ "fieldName" "CHudVersionWarn"
+ "xpos" "640"
+ "ypos" "460"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "200"
+ "tall" "20"
+ "TextFont" "HudHintTextSmall"
+ }
+ CHudSyncBar
+ {
+ "fieldName" "CHudSyncBar"
+ "xpos" "c-60"
+ "ypos" "c+227"
+ "wide" "120"
+ "tall" "10"
+ "InitialValue" "0"
+ "BackgroundColor" "MOM.Panel.Bg"
+ "FillColor" "255 255 255 225"
+ "visible" "1"
+ "enabled" "1"
+ }
+
+ CHudKeyPressDisplay
+ {
+ "fieldName" "CHudKeyPressDisplay"
+ "xpos" "c+265"
+ "ypos" "c+150"
+ "wide" "150"
+ "tall" "100"
+ "visible" "1"
+ "enabled" "1"
+ "top_row_ypos" "5"
+ "mid_row_ypos" "20"
+ "lower_row_ypos" "35"
+ "jump_row_ypos" "45"
+ "duck_row_ypos" "55"
+ "strafe_count_xpos" "100"
+ "jump_count_xpos" "100"
+ "TextFont" "MomentumIcons"
+ "CounterTextFont" "HudNumbersVerySmall"
+ "WordTextFont" "HudNumbersVerySmall"
+ "KeyPressedColor" "MOM.Panel.Fg"
+ "KeyOutlineColor" "Dark Gray"
+ }
+
+ CHudCompare
+ {
+ "fieldName" "CHudCompare"
+ "xpos" "50"
+ "ypos" "c+50"
+ "wide" "200"
+ "tall" "150"
+ "visible" "1"
+ "enabled" "1"
+ "PaintBackgroundType" "2"
+ "GainColor" "MOM.Compare.Gain"
+ "LossColor" "MOM.Compare.Loss"
+ "TieColor" "MOM.Compare.Tie"
+ "TextFont" "HudHintTextSmall"
+ "format_spacing" "2"//Number of pixels between each component of the comparison panel, only if mom_comparisons_format_output has value 1
+ "text_xpos" "5"
+ "text_ypos" "2"
+ }
+
+ CHudMapInfo
+ {
+ "fieldName" "CHudMapInfo"
+ "visible" "1"
+ "enabled" "1"
+ "centerStatus" "1"//If this is 1, the status will be centered above the timer, otherwise the status_xpos will be used
+ "status_xpos" "0"
+ "status_ypos" "c+135"//y-pos for the map status
+ "mapinfo_xpos" "10"//xpos for the map info (author/difficulty/etc)
+ "mapinfo_ypos" "10"//ypos for the map info
+ "StatusFont" "HudHintTextSmall"//Font for the current map area/status
+ "MapInfoFont" "HudHintTextSmall"//Font for the map information
+ }
+
+ HudHealth [$WIN32]
+ {
+ "fieldName" "HudHealth"
+ "xpos" "16"
+ "ypos" "432"
+ "wide" "102"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "20"
+ "digit_xpos" "50"
+ "digit_ypos" "2"
+ }
+ HudHealth [$X360]
+ {
+ "fieldName" "HudHealth"
+ "xpos" "48"
+ "ypos" "416"
+ "wide" "115"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "18"
+ "digit_xpos" "60"
+ "digit_ypos" "-1"
+ }
+
+ HudSuit [$WIN32]
+ {
+ "fieldName" "HudSuit"
+ "xpos" "140"
+ "ypos" "432"
+ "wide" "108"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "20"
+ "digit_xpos" "50"
+ "digit_ypos" "2"
+ }
+ HudSuit [$X360]
+ {
+ "fieldName" "HudSuit"
+ "xpos" "176"
+ "ypos" "416"
+ "wide" "117"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "18"
+ "digit_xpos" "50"
+ "digit_ypos" "-1"
+ }
+
+ HudAmmo [$WIN32]
+ {
+ "fieldName" "HudAmmo"
+ "xpos" "r150"
+ "ypos" "432"
+ "wide" "136"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "20"
+ "digit_xpos" "44"
+ "digit_ypos" "2"
+ "digit2_xpos" "98"
+ "digit2_ypos" "16"
+ }
+ HudAmmo [$X360]
+ {
+ "fieldName" "HudAmmo"
+ "xpos" "r208"
+ "ypos" "416"
+ "wide" "160"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "18"
+ "digit_xpos" "60"
+ "digit_ypos" "-1"
+ "digit2_xpos" "120"
+ "digit2_ypos" "14"
+ }
+
+ HudAmmoSecondary [$WIN32]
+ {
+ "fieldName" "HudAmmoSecondary"
+ "xpos" "r76"
+ "ypos" "432"
+ "wide" "60"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "22"
+ "digit_xpos" "36"
+ "digit_ypos" "2"
+ }
+ HudAmmoSecondary [$X360]
+ {
+ "fieldName" "HudAmmoSecondary"
+ "xpos" "r113"
+ "ypos" "416"
+ "wide" "65"
+ "tall" "36"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "text_xpos" "8"
+ "text_ypos" "22"
+ "digit_xpos" "36"
+ "digit_ypos" "-1"
+ }
+
+ HudSuitPower [$WIN32]
+ {
+ "fieldName" "HudSuitPower"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "16"
+ "ypos" "396"
+ "wide" "102"
+ "tall" "26"
+
+ "AuxPowerLowColor" "255 0 0 220"
+ "AuxPowerHighColor" "255 220 0 220"
+ "AuxPowerDisabledAlpha" "70"
+
+ "BarInsetX" "8"
+ "BarInsetY" "15"
+ "BarWidth" "92"
+ "BarHeight" "4"
+ "BarChunkWidth" "6"
+ "BarChunkGap" "3"
+
+ "text_xpos" "8"
+ "text_ypos" "4"
+ "text2_xpos" "8"
+ "text2_ypos" "22"
+ "text2_gap" "10"
+
+ "PaintBackgroundType" "2"
+ }
+ HudSuitPower [$X360]
+ {
+ "fieldName" "HudSuitPower"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "48"
+ "ypos" "370"
+ "wide" "102"
+ "tall" "26"
+
+ "AuxPowerLowColor" "255 100 0 220"
+ "AuxPowerHighColor" "255 220 0 220"
+ "AuxPowerDisabledAlpha" "70"
+
+ "BarInsetX" "8"
+ "BarInsetY" "19"
+ "BarWidth" "92"
+ "BarHeight" "5"
+ "BarChunkWidth" "6"
+ "BarChunkGap" "3"
+
+ "text_xpos" "8"
+ "text_ypos" "4"
+ "text2_xpos" "8"
+ "text2_ypos" "25"
+ "text2_gap" "12"
+
+ "PaintBackgroundType" "2"
+ }
+
+ HudPosture [$WIN32]
+ {
+ "fieldName" "HudPosture"
+ "visible" "1"
+ "PaintBackgroundType" "2"
+ "xpos" "16"
+ "ypos" "316"
+ "tall" "36"
+ "wide" "36"
+ "font" "WeaponIconsSmall"
+ "icon_xpos" "10"
+ "icon_ypos" "0"
+ }
+ HudPosture [$X360]
+ {
+ "fieldName" "HudPosture"
+ "visible" "1"
+ "PaintBackgroundType" "2"
+ "xpos" "48"
+ "ypos" "316"
+ "tall" "36"
+ "wide" "36"
+ "font" "WeaponIconsSmall"
+ "icon_xpos" "10"
+ "icon_ypos" "2"
+ }
+
+ HudFlashlight
+ {
+ "fieldName" "HudFlashlight"
+ "visible" "1"
+ "PaintBackgroundType" "2"
+ "xpos" "270" [$WIN32]
+ "ypos" "444" [$WIN32]
+ "xpos_hidef" "293" [$X360] // aligned to left
+ "xpos_lodef" "c-18" [$X360] // centered in screen
+ "ypos" "428" [$X360]
+ "tall" "24"
+ "wide" "36"
+ "font" "WeaponIconsSmall"
+
+ "icon_xpos" "4"
+ "icon_ypos" "-8"
+
+ "BarInsetX" "4"
+ "BarInsetY" "18"
+ "BarWidth" "28"
+ "BarHeight" "2"
+ "BarChunkWidth" "2"
+ "BarChunkGap" "1"
+ }
+ HudDamageIndicator
+ {
+ "fieldName" "HudDamageIndicator"
+ "visible" "1"
+ "enabled" "1"
+ "DmgColorLeft" "255 0 0 0"
+ "DmgColorRight" "255 0 0 0"
+
+ "dmg_xpos" "30"
+ "dmg_ypos" "100"
+ "dmg_wide" "36"
+ "dmg_tall1" "240"
+ "dmg_tall2" "200"
+ }
+
+ HudZoom
+ {
+ "fieldName" "HudZoom"
+ "visible" "1"
+ "enabled" "1"
+ "Circle1Radius" "66"
+ "Circle2Radius" "74"
+ "DashGap" "16"
+ "DashHeight" "4" [$WIN32]
+ "DashHeight" "6" [$X360]
+ "BorderThickness" "88"
+ }
+ HudWeaponSelection
+ {
+ "fieldName" "HudWeaponSelection"
+ "ypos" "16" [$WIN32]
+ "ypos" "32" [$X360]
+ "visible" "1"
+ "enabled" "1"
+ "SmallBoxSize" "32"
+ "MediumBoxWide" "95"
+ "MediumBoxWide_hidef" "78"
+ "MediumBoxTall" "50"
+ "MediumBoxTall_hidef" "50"
+ "MediumBoxWide_lodef" "74"
+ "MediumBoxTall_lodef" "50"
+ "LargeBoxWide" "112"
+ "LargeBoxTall" "80"
+ "BoxGap" "8"
+ "SelectionNumberXPos" "4"
+ "SelectionNumberYPos" "4"
+ "SelectionGrowTime" "0.4"
+ "TextYPos" "64"
+ }
+
+ HudCrosshair
+ {
+ "fieldName" "HudCrosshair"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudDeathNotice
+ {
+ "fieldName" "HudDeathNotice"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudVehicle
+ {
+ "fieldName" "HudVehicle"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ ScorePanel
+ {
+ "fieldName" "ScorePanel"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudTrain
+ {
+ "fieldName" "HudTrain"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudMOTD
+ {
+ "fieldName" "HudMOTD"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudMessage
+ {
+ "fieldName" "HudMessage"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "f0"
+ "tall" "480"
+ }
+
+ HudMenu
+ {
+ "fieldName" "HudMenu"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudCloseCaption
+ {
+ "fieldName" "HudCloseCaption"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "c-250"
+ "ypos" "276" [$WIN32]
+ "ypos" "236" [$X360]
+ "wide" "500"
+ "tall" "136" [$WIN32]
+ "tall" "176" [$X360]
+
+ "BgAlpha" "128"
+
+ "GrowTime" "0.25"
+ "ItemHiddenTime" "0.2" // Nearly same as grow time so that the item doesn't start to show until growth is finished
+ "ItemFadeInTime" "0.15" // Once ItemHiddenTime is finished, takes this much longer to fade in
+ "ItemFadeOutTime" "0.3"
+ "topoffset" "0" [$WIN32]
+ "topoffset" "0" [$X360]
+ }
+
+ HudChat
+ {
+ "fieldName" "HudChat"
+ "visible" "0"
+ "enabled" "1"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "4"
+ "tall" "4"
+ }
+
+ HudHistoryResource [$WIN32]
+ {
+ "fieldName" "HudHistoryResource"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "r252"
+ "ypos" "40"
+ "wide" "248"
+ "tall" "320"
+
+ "history_gap" "56" [!$OSX]
+ "history_gap" "64" [$OSX]
+ "icon_inset" "38"
+ "text_inset" "36"
+ "text_inset" "26"
+ "NumberFont" "HudNumbersSmall"
+ }
+ HudHistoryResource [$X360]
+ {
+ "fieldName" "HudHistoryResource"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "r300"
+ "ypos" "40"
+ "wide" "248"
+ "tall" "240"
+
+ "history_gap" "50"
+ "icon_inset" "38"
+ "text_inset" "36"
+ "NumberFont" "HudNumbersSmall"
+ }
+
+ HudGeiger
+ {
+ "fieldName" "HudGeiger"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HUDQuickInfo
+ {
+ "fieldName" "HUDQuickInfo"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudWeapon
+ {
+ "fieldName" "HudWeapon"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+ HudAnimationInfo
+ {
+ "fieldName" "HudAnimationInfo"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudPredictionDump
+ {
+ "fieldName" "HudPredictionDump"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640"
+ "tall" "480"
+ }
+
+ HudHintDisplay
+ {
+ "fieldName" "HudHintDisplay"
+ "visible" "0"
+ "enabled" "1"
+ "xpos" "c-240"
+ "ypos" "c60"
+ "xpos" "r148" [$X360]
+ "ypos" "r338" [$X360]
+ "wide" "480"
+ "tall" "100"
+ "HintSize" "1"
+ "text_xpos" "8"
+ "text_ypos" "8"
+ "center_x" "0" // center text horizontally
+ "center_y" "-1" // align text on the bottom
+ "paintbackground" "0"
+ }
+
+ HudHintKeyDisplay
+ {
+ "fieldName" "HudHintKeyDisplay"
+ "visible" "0"
+ "enabled" "1"
+ "xpos" "r120" [$WIN32]
+ "ypos" "r340" [$WIN32]
+ "xpos" "r148" [$X360]
+ "ypos" "r338" [$X360]
+ "wide" "100"
+ "tall" "200"
+ "text_xpos" "8"
+ "text_ypos" "8"
+ "text_xgap" "8"
+ "text_ygap" "8"
+ "TextColor" "255 170 0 220"
+
+ "PaintBackgroundType" "2"
+ }
+
+
+ HudSquadStatus [$WIN32]
+ {
+ "fieldName" "HudSquadStatus"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "r120"
+ "ypos" "380"
+ "wide" "104"
+ "tall" "46"
+ "text_xpos" "8"
+ "text_ypos" "34"
+ "SquadIconColor" "255 220 0 160"
+ "IconInsetX" "8"
+ "IconInsetY" "0"
+ "IconGap" "24"
+
+ "PaintBackgroundType" "2"
+ }
+ HudSquadStatus [$X360]
+ {
+ "fieldName" "HudSquadStatus"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "r182"
+ "ypos" "348"
+ "wide" "134"
+ "tall" "62"
+ "text_xpos" "8"
+ "text_ypos" "44"
+ "SquadIconColor" "255 220 0 160"
+ "IconInsetX" "8"
+ "IconInsetY" "-4"
+ "IconGap" "24"
+ "IconFont" "SquadIcon"
+
+ "PaintBackgroundType" "2"
+ }
+
+ HudPoisonDamageIndicator [$WIN32]
+ {
+ "fieldName" "HudPoisonDamageIndicator"
+ "visible" "0"
+ "enabled" "1"
+ "xpos" "16"
+ "ypos" "346"
+ "wide" "136"
+ "tall" "38"
+ "text_xpos" "8"
+ "text_ypos" "8"
+ "text_ygap" "14"
+ "TextColor" "255 170 0 220"
+ "PaintBackgroundType" "2"
+ }
+ HudPoisonDamageIndicator [$X360]
+ {
+ "fieldName" "HudPoisonDamageIndicator"
+ "visible" "0"
+ "enabled" "1"
+ "xpos" "48"
+ "ypos" "264"
+ "wide" "192"
+ "tall" "46"
+ "text_xpos" "8"
+ "text_ypos" "6"
+ "text_ygap" "16"
+ "TextColor" "255 170 0 220"
+ "PaintBackgroundType" "2"
+ }
+
+ HudCredits
+ {
+ "fieldName" "HudCredits"
+ "TextFont" "Default"
+ "visible" "1"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "640"
+ "tall" "480"
+ "TextColor" "255 255 255 192"
+
+ }
+
+ HUDAutoAim
+ {
+ "fieldName" "HUDAutoAim"
+ "visible" "1"
+ "enabled" "1"
+ "wide" "640" [$WIN32]
+ "tall" "480" [$WIN32]
+ "wide" "960" [$X360]
+ "tall" "720" [$X360]
+ }
+
+ HudCommentary
+ {
+ "fieldName" "HudCommentary"
+ "xpos" "c-190"
+ "ypos" "350"
+ "wide" "380"
+ "tall" "40"
+ "visible" "1"
+ "enabled" "1"
+
+ "PaintBackgroundType" "2"
+
+ "bar_xpos" "50"
+ "bar_ypos" "20"
+ "bar_height" "8"
+ "bar_width" "320"
+ "speaker_xpos" "50"
+ "speaker_ypos" "8"
+ "count_xpos_from_right" "10" // Counts from the right side
+ "count_ypos" "8"
+
+ "icon_texture" "vgui/hud/icon_commentary"
+ "icon_xpos" "0"
+ "icon_ypos" "0"
+ "icon_width" "40"
+ "icon_height" "40"
+ }
+
+ HudHDRDemo
+ {
+ "fieldName" "HudHDRDemo"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "640"
+ "tall" "480"
+ "visible" "1"
+ "enabled" "1"
+
+ "Alpha" "255"
+ "PaintBackgroundType" "2"
+
+ "BorderColor" "0 0 0 255"
+ "BorderLeft" "16"
+ "BorderRight" "16"
+ "BorderTop" "16"
+ "BorderBottom" "64"
+ "BorderCenter" "0"
+
+ "TextColor" "255 255 255 255"
+ "LeftTitleY" "422"
+ "RightTitleY" "422"
+ }
+
+ AchievementNotificationPanel
+ {
+ "fieldName" "AchievementNotificationPanel"
+ "visible" "1"
+ "enabled" "1"
+ "xpos" "0"
+ "ypos" "180"
+ "wide" "f10" [$WIN32]
+ "wide" "f60" [$X360]
+ "tall" "100"
+ }
+
+ CHudVote
+ {
+ "fieldName" "CHudVote"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "640"
+ "tall" "480"
+ "visible" "1"
+ "enabled" "1"
+ "bgcolor_override" "0 0 0 0"
+ "PaintBackgroundType" "0" // rounded corners
+ }
}
\ No newline at end of file
diff --git a/mp/game/momentum/scripts/kb_act.lst b/mp/game/momentum/scripts/kb_act.lst
index d5556206d0..9ae31fc21c 100644
--- a/mp/game/momentum/scripts/kb_act.lst
+++ b/mp/game/momentum/scripts/kb_act.lst
@@ -5,6 +5,8 @@
"+back" "#Valve_Move_Back"
"+moveleft" "#Valve_Move_Left"
"+moveright" "#Valve_Move_Right"
+"+right" "#Valve_Turn_Right"
+"+left" "#Valve_Turn_Left"
"+walk" "#Valve_Walk"
"+jump" "#Valve_Jump"
"+duck" "#Valve_Duck"
diff --git a/mp/game/momentum/scripts/propdata.txt b/mp/game/momentum/scripts/propdata.txt
index 48c7f584f1..369bdea023 100644
--- a/mp/game/momentum/scripts/propdata.txt
+++ b/mp/game/momentum/scripts/propdata.txt
@@ -54,6 +54,13 @@
"health" "10"
}
+ // Cardboard trash from props_junk still uses this.
+ "Cardboard.physics"
+ {
+ "base" "Cardboard.Base"
+ "health" "15"
+ }
+
// Cardboard / Paper blocks, less than 3 foot cubed.
// i.e. cardboard boxes. thick books
"Cardboard.Medium"
@@ -68,6 +75,31 @@
{
"base" "Cardboard.Base"
"health" "40"
+ "physicsmode" "1"
+ }
+
+ // Cardboard Boxes full of paper
+ // i.e. fileboxes, boxes of paper
+ "Cardboard.break"
+ {
+ "base" "Cardboard.Base"
+ "health" "10"
+ "physicsmode" "1"
+ }
+ // Cardboard / Paper blocks, less than 1 foot cubed.
+ // i.e. small cardboard boxes, notepads, newspapers, thin books.
+ "Cardboard.Indestructable"
+ {
+ "base" "Cardboard.Base"
+ }
+
+ // Cardboard Boxes full of paper
+ // i.e. fileboxes, boxes of paper
+ "Cardboard.breakclient"
+ {
+ "base" "Cardboard.Base"
+ "health" "10"
+ "physicsmode" "3"
}
//=================================================================================
@@ -104,9 +136,32 @@
{
"base" "Cloth.Base"
"health" "100"
+ "physicsmode" "1"
}
+ // Misc cloth objects
+ // i.e. stuffed animals, hats, etc.
+ "Cloth.Object"
+ {
+ "base" "Cloth.Base"
+ "physicsmode" "3"
+ }
+
+//=================================================================================
+// DOORS
+//=================================================================================
+ // Base damage modifiers for doors
+ // All doors have the same propdata - metal/wood/etc is handled in the door QC!
+ "Door.Standard"
+ {
+ "dmg.bullets" "1.0"
+ "dmg.club" "1.25"
+ "dmg.explosive" "1.5"
+ "health" "1000"
+ }
+
+
//=================================================================================
// WOOD
//=================================================================================
@@ -128,8 +183,10 @@
{
"base" "Wooden.Base"
"health" "6"
+ "physicsmode" "3"
"breakable_count" "0"
+
}
// Wooden blocks, less than 1 foot cubed.
@@ -138,31 +195,49 @@
{
"base" "Wooden.Base"
"health" "20"
-
+
"breakable_count" "2"
}
+ // Wooden chairs from c17 still use this entity
+ "Wooden.chair"
+ {
+ "base" "Wooden.Base"
+ "health" "25"
+
+ "breakable_count" "4"
+ }
+
// Wooden blocks, less than 3 foot cubed.
// i.e boards, small crates, pallettes, ladders, chairs.
"Wooden.Medium"
{
"base" "Wooden.Base"
"health" "30"
-
+
"breakable_count" "4"
}
+
+ // Wooden blocks, less than 3 foot cubed.
+ // Client side, No break
+ "Wooden.MediumNobreak"
+ {
+ "base" "Wooden.Base"
+ "physicsmode" "3"
+ }
+
// Large wooden blocks, less than 5 foot cubed.
// i.e Crates, benches.
"Wooden.Large"
{
"base" "Wooden.Base"
"health" "50"
-
+ "physicsmode" "1"
"breakable_count" "6"
}
-
- // Extra large wooden objects
+
+ // Extra large wooden objects
// i.e posts
"Wooden.ExtraLarge"
{
@@ -178,11 +253,54 @@
{
"base" "Wooden.Base"
"health" "130"
+ "physicsmode" "1"
"breakable_count" "10"
}
+ // small wooden objects
+ // i.e sticks
+ "Wooden.sticks"
+ {
+ "base" "Wooden.Base"
+ "physicsmode" "1"
+ "breakable_count" "0"
+
+ }
+ // Breakable Barrels
+ // i.e Wine Barrel in de_Inferno
+ "Wooden.Barrel"
+ {
+ "base" "Wooden.Base"
+ "health" "50"
+ "physicsmode" "1"
+
+ "breakable_count" "0"
+
+ }
+
+ // Wooden blocks, less than 1 foot cubed.
+ // i.e pieces of board, branches. (Server side version)
+ "Wooden.Small2"
+ {
+ "base" "Wooden.Base"
+ "health" "1"
+ "physicsmode" "1"
+ "breakable_count" "2"
+ }
+
+ // Breakable Barrels
+ // i.e Wine Barrel in de_Inferno
+ "Wooden.Barrel2"
+ {
+ "base" "Wooden.Base"
+ "health" "201"
+ "physicsmode" "1"
+
+ "breakable_count" "0"
+
+ }
//=================================================================================
@@ -203,6 +321,7 @@
{
"base" "Stone.Base"
"health" "50"
+ "physicsmode" "3"
}
// Medium stone blocks, less than 3 foot cubed
@@ -219,6 +338,7 @@
{
"base" "Stone.Base"
"health" "200"
+ "physicsmode" "1"
}
// Huge stone blocks, less than 5 foot cubed
@@ -227,6 +347,16 @@
{
"base" "Stone.Base"
"health" "400"
+ "physicsmode" "1"
+ }
+
+ // Gigantic stone blocks, more than 5 foot cubed
+ // i.e. only damaged by the bomb
+ "Stone.Gigantic"
+ {
+ "base" "Stone.Base"
+ "health" "600"
+ "physicsmode" "1"
}
//=================================================================================
@@ -247,6 +377,7 @@
{
"base" "Glass.Base"
"health" "5"
+ "physicsmode" "3"
"damage_table" "glass"
}
@@ -255,7 +386,39 @@
"base" "Glass.Base"
"dmg.explosive" "1.0" // Override base glass explosive behavior
"dmg.bullets" "0.5"
- "health" "15"
+ "health" "1"
+ "physicsmode" "1"
+ "damage_table" "glass"
+ }
+
+ "Glass.CSWindow"
+ {
+ "base" "Glass.Window"
+ "health" "1" // Shatter immediately, even from grenades.
+
+ }
+
+ "Glass.picture"
+ {
+ "base" "Glass.Base"
+ "physicsmode" "1"
+ }
+ "Glass.CSWindow2"
+ {
+ "base" "Glass.Window"
+ "health" "1" // Shatter immediately, even from grenades.
+ "physicsmode" "1"
+
+ }
+
+
+ "Glass.WindowStrong"
+ {
+ "base" "Glass.Base"
+ "dmg.explosive" "1.0" // Override base glass explosive behavior
+ "dmg.bullets" "0.5"
+ "health" "100"
+ "physicsmode" "3"
"damage_table" "glass"
}
@@ -286,6 +449,7 @@
"Metal.Medium"
{
"base" "Metal.Base"
+ "physicsmode" "1"
}
// Large metal objects.
@@ -293,6 +457,31 @@
"Metal.Large"
{
"base" "Metal.Base"
+ "physicsmode" "1"
+ }
+
+ // Breakable Medium Metal objects
+ "Metal.break"
+ {
+ "base" "Metal.Base"
+ "physicsmode" "1"
+ "health" "10"
+ }
+
+ // Breakable Medium Metal objects
+ "Metal.break2"
+ {
+ "base" "Metal.Base"
+ "physicsmode" "1"
+ "health" "100"
+ }
+
+ // Medium metal objects (Client Side).
+ // i.e. wheelbarrows, metal boxes, bicycles, barrels, ladders, filing cabinets.
+ "Metal.MediumClient"
+ {
+ "base" "Metal.Base"
+ "physicsmode" "3"
}
@@ -330,6 +519,46 @@
"Plastic.Large"
{
"base" "Plastic.Base"
+ "physicsmode" "1"
+ }
+
+
+ // Breakable medium plastic objects
+ "Plastic.break"
+ {
+ "base" "Plastic.Base"
+ "physicsmode" "1"
+ "health" "10"
+ }
+
+ // Breakable small plastic objects
+ "PlasticSmall.break"
+ {
+ "base" "Plastic.Base"
+ "physicsmode" "3"
+ "health" "10"
+ }
+
+ "PlasticSmall.NoBreak"
+ {
+ "base" "Plastic.Base"
+ "physicsmode" "3"
+ }
+
+
+ // Breakable small plastic objects
+ "Plastic.Small2"
+ {
+ "base" "Plastic.Base"
+ "physicsmode" "1"
+ }
+
+ // Plastic blocks, less than 2 foot cubed
+ // i.e. plastic cups, plastic milk crates, phones
+ "Plastic.SmallClient"
+ {
+ "base" "Plastic.Base"
+ "physicsmode" "3"
}
@@ -367,6 +596,7 @@
"Item.Large"
{
"base" "Item.Base"
+ "physicsmode" "1"
}
@@ -405,6 +635,7 @@
{
"base" "Pottery.Base"
"health" "70"
+ "physicsmode" "1"
}
// Huge pottery objects.
@@ -413,6 +644,38 @@
{
"base" "Pottery.Base"
"health" "100"
+ "physicsmode" "1"
+ }
+
+ // Breakable small pottery
+ "Pottery.break"
+ {
+ "base" "Pottery.Base"
+ "physicsmode" "3"
+ "health" "20"
+ }
+
+ // small potted plants
+ "Pottery.Plant"
+ {
+ "base" "Pottery.Base"
+ "physicsmode" "3"
+ }
+
+ // Breakable small pottery (Server Side)
+ "Pottery.break2"
+ {
+ "base" "Pottery.Base"
+ "physicsmode" "1"
+ "health" "20"
+ }
+
+ // small potted plants (Breakable)
+ "Pottery.PlantBreak"
+ {
+ "base" "Pottery.Base"
+ "physicsmode" "3"
+ "health" "20"
}
diff --git a/mp/game/momentum/shadereditorui/CRYSRG__.TTF b/mp/game/momentum/shadereditorui/CRYSRG__.TTF
new file mode 100644
index 0000000000..1d6a02ce8e
Binary files /dev/null and b/mp/game/momentum/shadereditorui/CRYSRG__.TTF differ
diff --git a/mp/game/momentum/shadereditorui/CRYSRG__readme.txt b/mp/game/momentum/shadereditorui/CRYSRG__readme.txt
new file mode 100644
index 0000000000..2a89a325f4
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/CRYSRG__readme.txt
@@ -0,0 +1,98 @@
+
+******* Crystal Font: Disclaimer and Conditions of Use ***********
+* *
+* Although every attempt has been made to ensure the quality and *
+* integrity of the Crystal font, no guarantee is expressed or *
+* implied. *
+* *
+* You may use the Crystal font family FREE OF CHARGE for any *
+* personal or commercial software application or document. *
+* However, if you use the font in a publicly distributed *
+* application or document, a byline in the online and/or paper *
+* acknowledgements would be appreciated. *
+* *
+******************************************************************
+
+---------------------------- History -----------------------------
+
+Version 5.1 25-Mar-99
+
+ * Symmetry of the number 8 improved.
+
+ * Curvature of tilde exagerated to prevent it from looking
+ like a straight line at low point sizes.
+
+------------------------------------------------------------------
+
+Version 5.0 16-Feb-99
+
+ * Several character shapes have been changed to improve
+ distinctiveness and legibility.
+
+ * All character outlines have been made more precise
+ and uniform, resulting in better on-screen legibility
+ and consistency (i.e. improved "color").
+
+ * The hints for every character have been reviewed and
+ improved. Because the font does not use delta hints,
+ however, it's on-screen appearance is not quite as good
+ at low point sizes as fonts that do.
+
+ * Direct support for bold, oblique, and bold oblique
+ family members has been dropped. The shapes calculated by
+ the rasterizer look better.
+
+------------------------------------------------------------------
+
+Version 4.0 11-Dec-97
+
+ * The on-screen appearance has been improved considerably.
+
+ * Characters are slightly (about 2%) narrower, allowing
+ more characters per line.
+
+ * MS-DOS graphics characters have been added. As a result
+ the character keymap has changed somewhat. The keycodes
+ for the standard characters has not changed, but the
+ keycodes of special characters such as '(c)' (copyright)
+ have changed.
+
+------------------------------------------------------------------
+
+Version 3.0 24-Jan-97
+
+ * Fixed a problem with the attributes of the oblique
+ family members.
+
+------------------------------------------------------------------
+
+Version 2.0 5-May-96
+
+ * The entire font family (regular, oblique, bold, and
+ bold oblique is supported.
+ * The weight of the font has been made considerably
+ more uniform.
+ * Character shapes have been tweaked for a better
+ screen appearance.
+ * Additional character positions have been filled to
+ prevent problems with desktop publishing applications.
+
+------------------------------------------------------------------
+
+Version 1.0 3-Oct-95
+
+ * Origination
+
+------------------------------------------------------------------
+
+******************************************************************
+* *
+* My thanks to all of you who have downloaded the Crystal font, *
+* especially to those who have provided feedback: most recently *
+* Paul Newbauer and Maximillian A. Bond. *
+* *
+* Please send your comments, criticisms, or suggestions to: *
+* *
+* Jerry Fitzpatrick jerryf@braveidea.com *
+* *
+******************************************************************
diff --git a/mp/game/momentum/shadereditorui/ShaderEditorScheme.res b/mp/game/momentum/shadereditorui/ShaderEditorScheme.res
new file mode 100644
index 0000000000..c14cdedc7f
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/ShaderEditorScheme.res
@@ -0,0 +1,1271 @@
+///////////////////////////////////////////////////////////
+// Tracker scheme resource file
+//
+// sections:
+// Colors - all the colors used by the scheme
+// BaseSettings - contains settings for app to use to draw controls
+// Fonts - list of all the fonts used by app
+// Borders - description of all the borders
+//
+///////////////////////////////////////////////////////////
+Scheme
+{
+ //////////////////////// COLORS ///////////////////////////
+ // color details
+ // this is a list of all the colors used by the scheme
+ Colors
+ {
+ // base colors
+ "White" "255 255 255 255"
+ "OffWhite" "216 216 216 255"
+ "DullWhite" "142 142 142 255"
+ "Orange" "16 170 255 255" //"255 155 0 255" // blue is the new orange.
+ "TransparentBlack" "0 0 0 128"
+ "Black" "0 0 0 255"
+
+ "Blank" "0 0 0 0"
+
+ "SteamLightGreen" "157 194 80 255"
+ "AchievementsLightGrey" "79 79 79 255"
+ "AchievementsDarkGrey" "55 55 55 255"
+ "AchievementsInactiveFG" "130 130 130 255"
+
+ "Grey" "48 48 48 255" //"96 96 96 255"
+ "Grey_Dark" "32 32 32 255" //"64 64 64 255"
+ "Grey_Faint" "32 32 32 255" //"64 64 64 255"
+ "Grey_Light" "110 110 110 255" //"160 160 160 255"
+ "White" "255 255 255 255"
+
+ "Grey_t" "32 32 32 216" //"64 64 64 216"
+ "Grey_Faint_t" "24 24 24 216" //"32 32 32 216"
+ }
+
+ ///////////////////// BASE SETTINGS ////////////////////////
+ //
+ // default settings for all panels
+ // controls use these to determine their settings
+ BaseSettings
+ {
+ "FgColor" "White"
+ "BgColor" "Grey"
+
+ "Panel.FgColor" "White"
+ "Panel.BgColor" "Grey"
+
+ "Frame.FgColor" "White"
+ "Frame.BgColor" "Grey"
+ "Frame.OutOfFocusBgColor" "Grey_Faint"
+
+ NodeView.Bg "92 92 92 255"
+ NodeView.Grid "80 80 80 255" //"110 110 110 255"
+ NodeView.Vignette "0 0 0 112"
+
+ EditorRoot.OutOfDate "40 80 120 255"
+ EditorRoot.Error "200 64 32 255"
+
+ SmartText.SelectionBG "Orange"
+ SmartText.SelectionFG "16 16 16 255"
+
+ Button.TextColor "White"
+ Button.ArmedTextColor "Grey_Dark"
+ Button.ArmedBgColor "Grey_Light"
+
+ Menu.SeparatorColor "0 0 0 255"
+ Menu.BgColor "Grey_t"
+
+ // vgui_controls color specifications
+ Border.Bright "180 180 180 164" //"200 200 200 196" // the lit side of a control
+ Border.Dark "40 40 40 196" // the dark/unlit side of a control
+ Border.Selection "Black" // the additional border color for displaying the default/selected button
+
+ Button.BgColor "Blank"
+ Button.ArmedBgColor "Blank"
+ Button.DepressedTextColor "White"
+ Button.DepressedBgColor "Blank"
+ Button.FocusBorderColor "Black"
+
+ CheckButton.TextColor "White"
+ CheckButton.SelectedTextColor "White"
+ CheckButton.BgColor "TransparentBlack"
+ CheckButton.Border1 "Border.Dark" // the left checkbutton border
+ CheckButton.Border2 "Border.Bright" // the right checkbutton border
+ CheckButton.Check "White" // color of the check itself
+ CheckButton.HighlightFgColor "OffWhite"
+ CheckButton.ArmedBgColor "Blank"
+ CheckButton.DepressedBgColor "Blank"
+ CheckButton.DisabledBgColor "TransparentBlack"
+ CheckButton.TextArmedColor "OffWhite"
+ CheckButton.TextDepressedColor "Grey_Light"
+ CheckButton.TextDefaultColor "DullWhite"
+
+
+ ComboBoxButton.ArrowColor "DullWhite"
+ ComboBoxButton.ArmedArrowColor "White"
+ ComboBoxButton.BgColor "Blank"
+ ComboBoxButton.DisabledBgColor "Blank"
+
+ Frame.TitleTextInsetX 16
+ Frame.ClientInsetX 8
+ Frame.ClientInsetY 6
+ Frame.FocusTransitionEffectTime "0.3" // time it takes for a window to fade in/out on focus/out of focus
+ Frame.TransitionEffectTime "0.3" // time it takes for a window to fade in/out on open/close
+ Frame.AutoSnapRange "0"
+ FrameGrip.Color1 "200 200 200 196"
+ FrameGrip.Color2 "0 0 0 196"
+ FrameTitleButton.FgColor "200 200 200 196"
+ FrameTitleButton.BgColor "Blank"
+ FrameTitleButton.DisabledFgColor "255 255 255 192"
+ FrameTitleButton.DisabledBgColor "Blank"
+ FrameSystemButton.FgColor "Blank"
+ FrameSystemButton.BgColor "Blank"
+ FrameSystemButton.Icon ""
+ FrameSystemButton.DisabledIcon ""
+ FrameTitleBar.Font "UiBold"
+ FrameTitleBar.Font "DefaultLarge"
+ FrameTitleBar.TextColor "White"
+ FrameTitleBar.BgColor "Blank"
+ FrameTitleBar.DisabledTextColor "255 255 255 192"
+ FrameTitleBar.DisabledBgColor "Blank"
+
+ GraphPanel.FgColor "White"
+ GraphPanel.BgColor "TransparentBlack"
+
+ Label.TextDullColor "DullWhite"
+ Label.TextColor "OffWhite"
+ Label.TextBrightColor "White"
+ Label.SelectedTextColor "White"
+ Label.BgColor "Blank"
+ Label.DisabledFgColor1 "117 117 117 255"
+ Label.DisabledFgColor2 "30 30 30 255"
+
+ ListPanel.TextColor "OffWhite"
+ ListPanel.TextBgColor "Blank"
+ ListPanel.BgColor "TransparentBlack"
+ ListPanel.SelectedTextColor "Black"
+ ListPanel.SelectedBgColor "Orange"
+ ListPanel.SelectedOutOfFocusBgColor "255 155 0 128"
+ ListPanel.EmptyListInfoTextColor "OffWhite"
+
+ Menu.TextColor "White"
+ Menu.BgColor "160 160 160 64"
+ Menu.ArmedTextColor "Black"
+ Menu.ArmedBgColor "Grey_Light" //"Orange"
+ Menu.TextInset "6"
+
+ Panel.FgColor "DullWhite"
+ Panel.BgColor "Blank"
+
+ ProgressBar.FgColor "White"
+ ProgressBar.BgColor "TransparentBlack"
+
+ PropertySheet.TextColor "OffWhite"
+ PropertySheet.SelectedTextColor "White"
+ PropertySheet.TransitionEffectTime "0.25" // time to change from one tab to another
+
+ RadioButton.TextColor "DullWhite"
+ RadioButton.SelectedTextColor "White"
+
+ RichText.TextColor "OffWhite"
+ RichText.BgColor "TransparentBlack"
+ RichText.SelectedTextColor "Black"
+ RichText.SelectedBgColor "Orange"
+
+ ScrollBar.Wide 17
+
+ ScrollBarButton.FgColor "White"
+ ScrollBarButton.BgColor "Blank"
+ ScrollBarButton.ArmedFgColor "White"
+ ScrollBarButton.ArmedBgColor "Blank"
+ ScrollBarButton.DepressedFgColor "White"
+ ScrollBarButton.DepressedBgColor "Blank"
+
+ ScrollBarSlider.FgColor "Blank" // nob color
+ ScrollBarSlider.BgColor "255 255 255 64" // slider background color
+
+ SectionedListPanel.HeaderTextColor "White"
+ SectionedListPanel.HeaderBgColor "Blank"
+ SectionedListPanel.DividerColor "Black"
+ SectionedListPanel.TextColor "DullWhite"
+ SectionedListPanel.BrightTextColor "White"
+ SectionedListPanel.BgColor "TransparentBlack"
+ SectionedListPanel.SelectedTextColor "Black"
+ SectionedListPanel.SelectedBgColor "Orange"
+ SectionedListPanel.OutOfFocusSelectedTextColor "Black"
+ SectionedListPanel.OutOfFocusSelectedBgColor "255 155 0 128"
+
+ Slider.NobColor "108 108 108 255"
+ Slider.TextColor "180 180 180 255"
+ Slider.TrackColor "31 31 31 255"
+ Slider.DisabledTextColor1 "117 117 117 255"
+ Slider.DisabledTextColor2 "30 30 30 255"
+
+ TextEntry.TextColor "OffWhite"
+ TextEntry.BgColor "TransparentBlack"
+ TextEntry.CursorColor "OffWhite"
+ TextEntry.DisabledTextColor "DullWhite"
+ TextEntry.DisabledBgColor "Blank"
+ TextEntry.SelectedTextColor "Black"
+ TextEntry.SelectedBgColor "Orange"
+ TextEntry.OutOfFocusSelectedBgColor "255 155 0 128"
+ TextEntry.FocusEdgeColor "0 0 0 196"
+
+ ToggleButton.SelectedTextColor "White"
+
+ Tooltip.TextColor "0 0 0 196"
+ Tooltip.BgColor "Orange"
+
+ TreeView.BgColor "TransparentBlack"
+
+ WizardSubPanel.BgColor "Blank"
+
+ // scheme-specific colors
+ MainMenu.TextColor "White"
+ MainMenu.ArmedTextColor "200 200 200 255"
+ MainMenu.DepressedTextColor "192 186 80 255"
+ MainMenu.MenuItemHeight "30"
+
+ MainMenu.Inset "32"
+ MainMenu.Backdrop "0 0 0 156"
+
+ Console.TextColor "OffWhite"
+ Console.DevTextColor "White"
+
+ NewGame.TextColor "White"
+ NewGame.FillColor "0 0 0 255"
+ NewGame.SelectionColor "Orange"
+ NewGame.DisabledColor "128 128 128 196"
+
+
+ "QuickListBGDeselected" "AchievementsDarkGrey"
+ "QuickListBGSelected" "AchievementsLightGrey"
+ }
+
+ //////////////////////// BITMAP FONT FILES /////////////////////////////
+ //
+ // Bitmap Fonts are ****VERY*** expensive static memory resources so they are purposely sparse
+ BitmapFontFiles
+ {
+ // UI buttons, custom font, (256x64)
+ "Buttons" "materials/vgui/fonts/buttons_32.vbf"
+ }
+
+ //////////////////////// FONTS /////////////////////////////
+ //
+ // describes all the fonts
+ Fonts
+ {
+ // fonts are used in order that they are listed
+ // fonts listed later in the order will only be used if they fulfill a range not already filled
+ // if a font fails to load then the subsequent fonts will replace
+ // fonts are used in order that they are listed
+ "DebugFixed"
+ {
+ "1"
+ {
+ "name" "Courier New"
+ "tall" "10"
+ "weight" "500"
+ "antialias" "1"
+ }
+ }
+ // fonts are used in order that they are listed
+ "DebugFixedSmall"
+ {
+ "1"
+ {
+ "name" "Courier New"
+ "tall" "7"
+ "weight" "500"
+ "antialias" "1"
+ }
+ }
+ "DefaultFixedOutline"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "tall_lodef" "15"
+ "tall_hidef" "20"
+ "weight" "0"
+ "outline" "1"
+ }
+ }
+ "DefaultBold"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "1000"
+ }
+ }
+ "DefaultUnderline"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "500"
+ "underline" "1"
+ }
+ }
+ "DefaultSmallDropShadow"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "13"
+ "weight" "0"
+ "dropshadow" "1"
+ }
+ }
+ Default
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "14"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "15"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Verdana"
+ "tall" "17"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1200 6000"
+ "antialias" "1"
+ }
+ }
+ "DefaultSmall"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "14"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "15"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Verdana"
+ "tall" "17"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1200 6000"
+ "antialias" "1"
+ } }
+ "DefaultVerySmall"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "9"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "10"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Verdana"
+ "tall" "11"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Verdana"
+ "tall" "11"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Verdana"
+ "tall" "12"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1200 6000"
+ "antialias" "1"
+ }
+ }
+
+
+ "DefaultLarge"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "18"
+ "weight" "0"
+ }
+ }
+ "UiBold"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "12"
+ "weight" "1000"
+ }
+ }
+ "MenuLarge"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "600"
+ "antialias" "1"
+ }
+ }
+ "AchievementTitleFont"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "20"
+ "weight" "1200"
+ "antialias" "1"
+ "outline" "1"
+ }
+ }
+
+ "AchievementTitleFontSmaller"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "18"
+ "weight" "1200"
+ "antialias" "1"
+ //"outline" "1"
+ }
+ }
+
+
+ "AchievementDescriptionFont"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "15"
+ "weight" "1200"
+ "antialias" "1"
+ "outline" "1"
+ "yres" "0 480"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "20"
+ "weight" "1200"
+ "antialias" "1"
+ "outline" "1"
+ "yres" "481 10000"
+ }
+ }
+
+ GameUIButtons
+ {
+
+ }
+ "ConsoleText"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "weight" "500"
+ }
+ }
+
+ // this is the symbol font
+ "Marlett"
+ {
+ "1"
+ {
+ "name" "Marlett"
+ "tall" "14"
+ "weight" "0"
+ "symbol" "1"
+ }
+ }
+
+ "Trebuchet24"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "24"
+ "weight" "900"
+ }
+ }
+
+ "Trebuchet20"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "20"
+ "weight" "900"
+ }
+ }
+
+ "Trebuchet18"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "18"
+ "weight" "900"
+ }
+ }
+
+ // HUD numbers
+ // We use multiple fonts to 'pulse' them in the HUD, hence the need for many of near size
+ "HUDNumber"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "40"
+ "weight" "900"
+ }
+ }
+ "HUDNumber1"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "41"
+ "weight" "900"
+ }
+ }
+ "HUDNumber2"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "42"
+ "weight" "900"
+ }
+ }
+ "HUDNumber3"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "43"
+ "weight" "900"
+ }
+ }
+ "HUDNumber4"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "44"
+ "weight" "900"
+ }
+ }
+ "HUDNumber5"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "45"
+ "weight" "900"
+ }
+ }
+ "DefaultFixed"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "weight" "0"
+ }
+// "1"
+// {
+// "name" "FixedSys"
+// "tall" "20"
+// "weight" "0"
+// }
+ }
+
+ "DefaultFixedDropShadow"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "weight" "0"
+ "dropshadow" "1"
+ }
+// "1"
+// {
+// "name" "FixedSys"
+// "tall" "20"
+// "weight" "0"
+// }
+ }
+
+ "CloseCaption_Normal"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "500"
+ }
+ }
+ "CloseCaption_Italic"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "500"
+ "italic" "1"
+ }
+ }
+ "CloseCaption_Bold"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "900"
+ }
+ }
+ "CloseCaption_BoldItalic"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "900"
+ "italic" "1"
+ }
+ }
+
+ TitleFont
+ {
+ "1"
+ {
+ "name" "HalfLife2"
+ "tall" "72"
+ "weight" "400"
+ "antialias" "1"
+ "custom" "1"
+ }
+ }
+
+ TitleFont2
+ {
+ "1"
+ {
+ "name" "HalfLife2"
+ "tall" "120"
+ "weight" "400"
+ "antialias" "1"
+ "custom" "1"
+ }
+ }
+
+ StatsTitle
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "2000"
+ "tall" "20"
+ "antialias" "1"
+ }
+ }
+
+ StatsText
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "2000"
+ "tall" "18"
+ "antialias" "1"
+ }
+ }
+
+ AchievementItemTitle
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "1500"
+ "tall" "16"
+ "antialias" "1"
+ }
+ }
+
+ AchievementItemTitleLarge
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "1500"
+ "tall" "18"
+ "antialias" "1"
+ }
+ }
+
+ AchievementItemDescription
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "1000"
+ "tall" "14"
+ "antialias" "1"
+ }
+ }
+
+
+ "ServerBrowserTitle"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "35"
+ "tall_lodef" "40"
+ "weight" "500"
+ "additive" "0"
+ "antialias" "1"
+ }
+ }
+
+ "ServerBrowserSmall"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Tahoma"
+ "tall" "19"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Tahoma"
+ "tall" "19"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1200 6000"
+ "antialias" "1"
+ }
+ }
+
+ }
+
+ //
+ //////////////////// BORDERS //////////////////////////////
+ //
+ // describes all the border types
+ Borders
+ {
+ BaseBorder DepressedBorder
+ ButtonBorder RaisedBorder
+ ComboBoxBorder DepressedBorder
+ MenuBorder RaisedBorder
+ BrowserBorder DepressedBorder
+ PropertySheetBorder RaisedBorder
+
+ FrameBorder
+ {
+ // rounded corners for frames
+ "backgroundtype" "2"
+ }
+
+ DepressedBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+ }
+ RaisedBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ TitleButtonBorder
+ {
+ "backgroundtype" "0"
+ }
+
+ TitleButtonDisabledBorder
+ {
+ "backgroundtype" "0"
+ }
+
+ TitleButtonDepressedBorder
+ {
+ "backgroundtype" "0"
+ }
+
+ ScrollBarButtonBorder
+ {
+ "inset" "2 2 0 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ ScrollBarButtonDepressedBorder
+ {
+ "inset" "2 2 0 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ TabBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ }
+
+ TabActiveBorder
+ {
+ "inset" "0 0 1 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ }
+
+
+ ToolTipBorder
+ {
+ "inset" "0 0 1 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ // this is the border used for default buttons (the button that gets pressed when you hit enter)
+ ButtonKeyFocusBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ ButtonDepressedBorder
+ {
+ "inset" "2 1 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+ }
+ }
+
+ //////////////////////// CUSTOM FONT FILES /////////////////////////////
+ //
+ // specifies all the custom (non-system) font files that need to be loaded to service the above described fonts
+ CustomFontFiles
+ {
+ //"1" "resource/HALFLIFE2.ttf"
+ //"2" "resource/HL2EP2.ttf"
+ //"1" "shadereditorui/consola.ttf"
+ "1" "shadereditorui/monof55.ttf"
+ "2" "shadereditorui/CRYSRG__.ttf"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/ShaderEditorScheme_Old.res b/mp/game/momentum/shadereditorui/ShaderEditorScheme_Old.res
new file mode 100644
index 0000000000..80515d5180
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/ShaderEditorScheme_Old.res
@@ -0,0 +1,1344 @@
+///////////////////////////////////////////////////////////
+// Tracker scheme resource file
+//
+// sections:
+// Colors - all the colors used by the scheme
+// BaseSettings - contains settings for app to use to draw controls
+// Fonts - list of all the fonts used by app
+// Borders - description of all the borders
+//
+///////////////////////////////////////////////////////////
+Scheme
+{
+ //////////////////////// COLORS ///////////////////////////
+ // color details
+ // this is a list of all the colors used by the scheme
+ Colors
+ {
+ // base colors
+ "White" "255 255 255 255"
+ "OffWhite" "216 216 216 255"
+ "DullWhite" "142 142 142 255"
+ "Orange" "255 155 0 255"
+ "TransparentBlack" "0 0 0 128"
+ "Black" "0 0 0 255"
+
+ "Blank" "0 0 0 0"
+
+ "SteamLightGreen" "157 194 80 255"
+ "AchievementsLightGrey" "79 79 79 255"
+ "AchievementsDarkGrey" "55 55 55 255"
+ "AchievementsInactiveFG" "130 130 130 255"
+
+ "Grey" "96 96 96 255"
+ "Grey_Dark" "64 64 64 255"
+ "Grey_Faint" "64 64 64 255"
+ "Grey_Light" "160 160 160 255"
+ "White" "255 255 255 255"
+
+ "Grey_t" "64 64 64 216"
+ "Grey_Faint_t" "32 32 32 216"
+ }
+
+ ///////////////////// BASE SETTINGS ////////////////////////
+ //
+ // default settings for all panels
+ // controls use these to determine their settings
+ BaseSettings
+ {
+ "FgColor" "White"
+ "BgColor" "Grey"
+
+ "Panel.FgColor" "White"
+ "Panel.BgColor" "Grey"
+
+ "Frame.FgColor" "White"
+ "Frame.BgColor" "Grey"
+ "Frame.OutOfFocusBgColor" "Grey_Faint"
+
+ "NodeView.Bg" "Grey_Light"
+
+ Button.TextColor "White"
+ Button.ArmedTextColor "Grey_Dark"
+ Button.ArmedBgColor "Grey_Light"
+
+ Menu.SeparatorColor "0 0 0 255"
+ Menu.BgColor "Grey_t"
+
+ // vgui_controls color specifications
+ Border.Bright "200 200 200 196" // the lit side of a control
+ Border.Dark "40 40 40 196" // the dark/unlit side of a control
+ Border.Selection "Black" // the additional border color for displaying the default/selected button
+
+ Button.BgColor "Blank"
+ Button.ArmedBgColor "Blank" [$WIN32]
+ Button.DepressedTextColor "White"
+ Button.DepressedBgColor "Blank"
+ Button.FocusBorderColor "Black"
+
+ CheckButton.TextColor "White"
+ CheckButton.SelectedTextColor "White"
+ CheckButton.BgColor "TransparentBlack"
+ CheckButton.Border1 "Border.Dark" // the left checkbutton border
+ CheckButton.Border2 "Border.Bright" // the right checkbutton border
+ CheckButton.Check "White" // color of the check itself
+ CheckButton.HighlightFgColor "OffWhite"
+ CheckButton.ArmedBgColor "Blank"
+ CheckButton.DepressedBgColor "Blank"
+ CheckButton.DisabledBgColor "TransparentBlack"
+
+ ComboBoxButton.ArrowColor "DullWhite"
+ ComboBoxButton.ArmedArrowColor "White"
+ ComboBoxButton.BgColor "Blank"
+ ComboBoxButton.DisabledBgColor "Blank"
+
+ Frame.TitleTextInsetX 16
+ Frame.ClientInsetX 8
+ Frame.ClientInsetY 6
+ Frame.FocusTransitionEffectTime "0.3" // time it takes for a window to fade in/out on focus/out of focus
+ Frame.TransitionEffectTime "0.3" [$WIN32] // time it takes for a window to fade in/out on open/close
+ Frame.TransitionEffectTime "0.2" [$X360] // time it takes for a window to fade in/out on open/close
+ Frame.AutoSnapRange "0"
+ FrameGrip.Color1 "200 200 200 196"
+ FrameGrip.Color2 "0 0 0 196"
+ FrameTitleButton.FgColor "200 200 200 196"
+ FrameTitleButton.BgColor "Blank"
+ FrameTitleButton.DisabledFgColor "255 255 255 192"
+ FrameTitleButton.DisabledBgColor "Blank"
+ FrameSystemButton.FgColor "Blank"
+ FrameSystemButton.BgColor "Blank"
+ FrameSystemButton.Icon ""
+ FrameSystemButton.DisabledIcon ""
+ FrameTitleBar.Font "UiBold" [$WIN32]
+ FrameTitleBar.Font "DefaultLarge" [$WIN32]
+ FrameTitleBar.TextColor "White"
+ FrameTitleBar.BgColor "Blank"
+ FrameTitleBar.DisabledTextColor "255 255 255 192"
+ FrameTitleBar.DisabledBgColor "Blank"
+
+ GraphPanel.FgColor "White"
+ GraphPanel.BgColor "TransparentBlack"
+
+ Label.TextDullColor "DullWhite"
+ Label.TextColor "OffWhite"
+ Label.TextBrightColor "White"
+ Label.SelectedTextColor "White"
+ Label.BgColor "Blank"
+ Label.DisabledFgColor1 "117 117 117 255"
+ Label.DisabledFgColor2 "30 30 30 255"
+
+ ListPanel.TextColor "OffWhite"
+ ListPanel.TextBgColor "Blank"
+ ListPanel.BgColor "TransparentBlack"
+ ListPanel.SelectedTextColor "Black"
+ ListPanel.SelectedBgColor "Orange"
+ ListPanel.SelectedOutOfFocusBgColor "255 155 0 128"
+ ListPanel.EmptyListInfoTextColor "OffWhite"
+
+ Menu.TextColor "White"
+ Menu.BgColor "160 160 160 64"
+ Menu.ArmedTextColor "Black"
+ Menu.ArmedBgColor "Orange"
+ Menu.TextInset "6"
+
+ Panel.FgColor "DullWhite"
+ Panel.BgColor "Blank"
+
+ ProgressBar.FgColor "White"
+ ProgressBar.BgColor "TransparentBlack"
+
+ PropertySheet.TextColor "OffWhite"
+ PropertySheet.SelectedTextColor "White"
+ PropertySheet.TransitionEffectTime "0.25" // time to change from one tab to another
+
+ RadioButton.TextColor "DullWhite"
+ RadioButton.SelectedTextColor "White"
+
+ RichText.TextColor "OffWhite"
+ RichText.BgColor "TransparentBlack"
+ RichText.SelectedTextColor "Black"
+ RichText.SelectedBgColor "Orange"
+
+ ScrollBar.Wide 17
+
+ ScrollBarButton.FgColor "White"
+ ScrollBarButton.BgColor "Blank"
+ ScrollBarButton.ArmedFgColor "White"
+ ScrollBarButton.ArmedBgColor "Blank"
+ ScrollBarButton.DepressedFgColor "White"
+ ScrollBarButton.DepressedBgColor "Blank"
+
+ ScrollBarSlider.FgColor "Blank" // nob color
+ ScrollBarSlider.BgColor "255 255 255 64" // slider background color
+
+ SectionedListPanel.HeaderTextColor "White"
+ SectionedListPanel.HeaderBgColor "Blank"
+ SectionedListPanel.DividerColor "Black"
+ SectionedListPanel.TextColor "DullWhite"
+ SectionedListPanel.BrightTextColor "White"
+ SectionedListPanel.BgColor "TransparentBlack"
+ SectionedListPanel.SelectedTextColor "Black"
+ SectionedListPanel.SelectedBgColor "Orange"
+ SectionedListPanel.OutOfFocusSelectedTextColor "Black"
+ SectionedListPanel.OutOfFocusSelectedBgColor "255 155 0 128"
+
+ Slider.NobColor "108 108 108 255"
+ Slider.TextColor "180 180 180 255"
+ Slider.TrackColor "31 31 31 255"
+ Slider.DisabledTextColor1 "117 117 117 255"
+ Slider.DisabledTextColor2 "30 30 30 255"
+
+ TextEntry.TextColor "OffWhite"
+ TextEntry.BgColor "TransparentBlack"
+ TextEntry.CursorColor "OffWhite"
+ TextEntry.DisabledTextColor "DullWhite"
+ TextEntry.DisabledBgColor "Blank"
+ TextEntry.SelectedTextColor "Black"
+ TextEntry.SelectedBgColor "Orange"
+ TextEntry.OutOfFocusSelectedBgColor "255 155 0 128"
+ TextEntry.FocusEdgeColor "0 0 0 196"
+
+ ToggleButton.SelectedTextColor "White"
+
+ Tooltip.TextColor "0 0 0 196"
+ Tooltip.BgColor "Orange"
+
+ TreeView.BgColor "TransparentBlack"
+
+ WizardSubPanel.BgColor "Blank"
+
+ // scheme-specific colors
+ MainMenu.TextColor "White" [$WIN32]
+ MainMenu.TextColor "200 200 200 255" [$X360]
+ MainMenu.ArmedTextColor "200 200 200 255" [$WIN32]
+ MainMenu.ArmedTextColor "White" [$X360]
+ MainMenu.DepressedTextColor "192 186 80 255"
+ MainMenu.MenuItemHeight "30" [$WIN32]
+ MainMenu.MenuItemHeight "22" [$X360]
+ MainMenu.MenuItemHeight_hidef "32" [$X360]
+ MainMenu.Inset "32"
+ MainMenu.Backdrop "0 0 0 156"
+
+ Console.TextColor "OffWhite"
+ Console.DevTextColor "White"
+
+ NewGame.TextColor "White"
+ NewGame.FillColor "0 0 0 255"
+ NewGame.SelectionColor "Orange" [$WIN32]
+ NewGame.SelectionColor "0 0 0 255" [$X360]
+ NewGame.DisabledColor "128 128 128 196"
+
+ MessageDialog.MatchmakingBG "46 43 42 255" [$X360]
+ MessageDialog.MatchmakingBGBlack "22 22 22 255" [$X360]
+
+ MatchmakingMenuItemTitleColor "200 184 151 255" [$X360]
+ MatchmakingMenuItemDescriptionColor "200 184 151 255" [$X360]
+
+ "QuickListBGDeselected" "AchievementsDarkGrey"
+ "QuickListBGSelected" "AchievementsLightGrey"
+ }
+
+ //////////////////////// BITMAP FONT FILES /////////////////////////////
+ //
+ // Bitmap Fonts are ****VERY*** expensive static memory resources so they are purposely sparse
+ BitmapFontFiles
+ {
+ // UI buttons, custom font, (256x64)
+ "Buttons" "materials/vgui/fonts/buttons_32.vbf"
+ }
+
+ //////////////////////// FONTS /////////////////////////////
+ //
+ // describes all the fonts
+ Fonts
+ {
+ // fonts are used in order that they are listed
+ // fonts listed later in the order will only be used if they fulfill a range not already filled
+ // if a font fails to load then the subsequent fonts will replace
+ // fonts are used in order that they are listed
+ "DebugFixed"
+ {
+ "1"
+ {
+ "name" "Courier New"
+ "tall" "10"
+ "weight" "500"
+ "antialias" "1"
+ }
+ }
+ // fonts are used in order that they are listed
+ "DebugFixedSmall"
+ {
+ "1"
+ {
+ "name" "Courier New"
+ "tall" "7"
+ "weight" "500"
+ "antialias" "1"
+ }
+ }
+ "DefaultFixedOutline"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "tall_lodef" "15"
+ "tall_hidef" "20"
+ "weight" "0"
+ "outline" "1"
+ }
+ }
+ "DefaultBold"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "1000"
+ }
+ }
+ "DefaultUnderline"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "500"
+ "underline" "1"
+ }
+ }
+ "DefaultSmallDropShadow"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "13"
+ "weight" "0"
+ "dropshadow" "1"
+ }
+ }
+ Default
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "14"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "15"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Verdana"
+ "tall" "17"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1200 6000"
+ "antialias" "1"
+ }
+ }
+ "DefaultSmall"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "14"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "15"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Verdana"
+ "tall" "17"
+ "weight" "0"
+ "range" "0x0000 0x017F"
+ "yres" "1200 6000"
+ "antialias" "1"
+ } }
+ "DefaultVerySmall"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "9"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "10"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Verdana"
+ "tall" "11"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Verdana"
+ "tall" "11"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Verdana"
+ "tall" "12"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1200 6000"
+ "antialias" "1"
+ }
+ }
+
+
+ "DefaultLarge"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "18"
+ "weight" "0"
+ }
+ }
+ "UiBold"
+ {
+ "1" [$WIN32]
+ {
+ "name" "Tahoma"
+ "tall" "12"
+ "weight" "1000"
+ }
+ "1" [$X360]
+ {
+ "name" "Tahoma"
+ "tall" "24"
+ "weight" "2000"
+ "outline" "1"
+ }
+ }
+ "ChapterTitle" [$X360]
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "20"
+ "tall_hidef" "28"
+ "weight" "2000"
+ "outline" "1"
+ }
+ }
+ "ChapterTitleBlur" [$X360]
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "20"
+ "tall_hidef" "28"
+ "weight" "2000"
+ "blur" "3"
+ "blur_hidef" "5"
+ }
+ }
+ "MenuLarge"
+ {
+ "1" [$WIN32]
+ {
+ "name" "Verdana"
+ "tall" "16"
+ "weight" "600"
+ "antialias" "1"
+ }
+ "1" [$X360]
+ {
+ "name" "Verdana"
+ "tall" "14"
+ "tall_hidef" "20"
+ "weight" "1200"
+ "antialias" "1"
+ "outline" "1"
+ }
+ }
+ "AchievementTitleFont"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "20"
+ "weight" "1200"
+ "antialias" "1"
+ "outline" "1"
+ }
+ }
+
+ "AchievementTitleFontSmaller"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "18"
+ "weight" "1200"
+ "antialias" "1"
+ //"outline" "1"
+ }
+ }
+
+
+ "AchievementDescriptionFont"
+ {
+ "1"
+ {
+ "name" "Verdana"
+ "tall" "15"
+ "weight" "1200"
+ "antialias" "1"
+ "outline" "1"
+ "yres" "0 480"
+ }
+ "2"
+ {
+ "name" "Verdana"
+ "tall" "20"
+ "weight" "1200"
+ "antialias" "1"
+ "outline" "1"
+ "yres" "481 10000"
+ }
+ }
+
+ GameUIButtons
+ {
+ "1" [$X360]
+ {
+ "bitmap" "1"
+ "name" "Buttons"
+ "scalex" "0.63"
+ "scaley" "0.63"
+ "scalex_hidef" "1.0"
+ "scaley_hidef" "1.0"
+ "scalex_lodef" "0.75"
+ "scaley_lodef" "0.75"
+ }
+ }
+ "ConsoleText"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "weight" "500"
+ }
+ }
+
+ // this is the symbol font
+ "Marlett"
+ {
+ "1"
+ {
+ "name" "Marlett"
+ "tall" "14"
+ "weight" "0"
+ "symbol" "1"
+ }
+ }
+
+ "Trebuchet24"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "24"
+ "weight" "900"
+ }
+ }
+
+ "Trebuchet20"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "20"
+ "weight" "900"
+ }
+ }
+
+ "Trebuchet18"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "18"
+ "weight" "900"
+ }
+ }
+
+ // HUD numbers
+ // We use multiple fonts to 'pulse' them in the HUD, hence the need for many of near size
+ "HUDNumber"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "40"
+ "weight" "900"
+ }
+ }
+ "HUDNumber1"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "41"
+ "weight" "900"
+ }
+ }
+ "HUDNumber2"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "42"
+ "weight" "900"
+ }
+ }
+ "HUDNumber3"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "43"
+ "weight" "900"
+ }
+ }
+ "HUDNumber4"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "44"
+ "weight" "900"
+ }
+ }
+ "HUDNumber5"
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "45"
+ "weight" "900"
+ }
+ }
+ "DefaultFixed"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "weight" "0"
+ }
+// "1"
+// {
+// "name" "FixedSys"
+// "tall" "20"
+// "weight" "0"
+// }
+ }
+
+ "DefaultFixedDropShadow"
+ {
+ "1"
+ {
+ "name" "Lucida Console"
+ "tall" "10"
+ "weight" "0"
+ "dropshadow" "1"
+ }
+// "1"
+// {
+// "name" "FixedSys"
+// "tall" "20"
+// "weight" "0"
+// }
+ }
+
+ "CloseCaption_Normal"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "500"
+ }
+ }
+ "CloseCaption_Italic"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "500"
+ "italic" "1"
+ }
+ }
+ "CloseCaption_Bold"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "900"
+ }
+ }
+ "CloseCaption_BoldItalic"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "900"
+ "italic" "1"
+ }
+ }
+
+ TitleFont
+ {
+ "1"
+ {
+ "name" "HalfLife2"
+ "tall" "72"
+ "weight" "400"
+ "antialias" "1"
+ "custom" "1"
+ }
+ }
+
+ TitleFont2
+ {
+ "1"
+ {
+ "name" "HalfLife2"
+ "tall" "120"
+ "weight" "400"
+ "antialias" "1"
+ "custom" "1"
+ }
+ }
+
+ AppchooserGameTitleFont [$X360]
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "16"
+ "tall_hidef" "24"
+ "weight" "900"
+ "antialias" "1"
+ }
+ }
+
+ AppchooserGameTitleFontBlur [$X360]
+ {
+ "1"
+ {
+ "name" "Trebuchet MS"
+ "tall" "16"
+ "tall_hidef" "24"
+ "weight" "900"
+ "blur" "3"
+ "blur_hidef" "5"
+ "antialias" "1"
+ }
+ }
+
+ StatsTitle [$WIN32]
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "2000"
+ "tall" "20"
+ "antialias" "1"
+ }
+ }
+
+ StatsText [$WIN32]
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "2000"
+ "tall" "18"
+ "antialias" "1"
+ }
+ }
+
+ AchievementItemTitle [$WIN32]
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "1500"
+ "tall" "16"
+ "antialias" "1"
+ }
+ }
+
+ AchievementItemTitleLarge [$WIN32]
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "1500"
+ "tall" "18"
+ "antialias" "1"
+ }
+ }
+
+ AchievementItemDescription [$WIN32]
+ {
+ "1"
+ {
+ "name" "Arial"
+ "weight" "1000"
+ "tall" "14"
+ "antialias" "1"
+ }
+ }
+
+
+ "ServerBrowserTitle"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "35"
+ "tall_lodef" "40"
+ "weight" "500"
+ "additive" "0"
+ "antialias" "1"
+ }
+ }
+
+ "ServerBrowserSmall"
+ {
+ "1"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "480 599"
+ }
+ "2"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "600 767"
+ }
+ "3"
+ {
+ "name" "Tahoma"
+ "tall" "16"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "768 1023"
+ "antialias" "1"
+ }
+ "4"
+ {
+ "name" "Tahoma"
+ "tall" "19"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1024 1199"
+ "antialias" "1"
+ }
+ "5"
+ {
+ "name" "Tahoma"
+ "tall" "19"
+ "weight" "0"
+ "range" "0x0000 0x017F" // Basic Latin, Latin-1 Supplement, Latin Extended-A
+ "yres" "1200 6000"
+ "antialias" "1"
+ }
+ }
+
+ }
+
+ //
+ //////////////////// BORDERS //////////////////////////////
+ //
+ // describes all the border types
+ Borders
+ {
+ BaseBorder DepressedBorder
+ ButtonBorder RaisedBorder
+ ComboBoxBorder DepressedBorder
+ MenuBorder RaisedBorder
+ BrowserBorder DepressedBorder
+ PropertySheetBorder RaisedBorder
+
+ FrameBorder
+ {
+ // rounded corners for frames
+ "backgroundtype" "2"
+ }
+
+ DepressedBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+ }
+ RaisedBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ TitleButtonBorder
+ {
+ "backgroundtype" "0"
+ }
+
+ TitleButtonDisabledBorder
+ {
+ "backgroundtype" "0"
+ }
+
+ TitleButtonDepressedBorder
+ {
+ "backgroundtype" "0"
+ }
+
+ ScrollBarButtonBorder
+ {
+ "inset" "2 2 0 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ ScrollBarButtonDepressedBorder
+ {
+ "inset" "2 2 0 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ TabBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ }
+
+ TabActiveBorder
+ {
+ "inset" "0 0 1 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+
+ }
+
+
+ ToolTipBorder
+ {
+ "inset" "0 0 1 0"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ // this is the border used for default buttons (the button that gets pressed when you hit enter)
+ ButtonKeyFocusBorder
+ {
+ "inset" "0 0 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Bright"
+ "offset" "0 1"
+ }
+ }
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Dark"
+ "offset" "1 0"
+ }
+ }
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Selection"
+ "offset" "0 0"
+ }
+ "2"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+ }
+
+ ButtonDepressedBorder
+ {
+ "inset" "2 1 1 1"
+ Left
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 1"
+ }
+ }
+
+ Right
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "1 0"
+ }
+ }
+
+ Top
+ {
+ "1"
+ {
+ "color" "Border.Dark"
+ "offset" "0 0"
+ }
+ }
+
+ Bottom
+ {
+ "1"
+ {
+ "color" "Border.Bright"
+ "offset" "0 0"
+ }
+ }
+ }
+ }
+
+ //////////////////////// CUSTOM FONT FILES /////////////////////////////
+ //
+ // specifies all the custom (non-system) font files that need to be loaded to service the above described fonts
+ CustomFontFiles
+ {
+ //"1" "resource/HALFLIFE2.ttf"
+ //"2" "resource/HL2EP2.ttf"
+ //"1" "shadereditorui/consola.ttf"
+ "1" "shadereditorui/monof55.ttf"
+ "2" "shadereditorui/CRYSRG__.ttf"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/detail_prop_shader.txt b/mp/game/momentum/shadereditorui/canvas/detail_prop_shader.txt
new file mode 100644
index 0000000000..28b62a5ca7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/detail_prop_shader.txt
@@ -0,0 +1,2454 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "2"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "19"
+ "pos_x" "-260.753021"
+ "pos_y" "760.815491"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_001"
+ {
+ "iType" "12"
+ "pos_x" "-804.412964"
+ "pos_y" "525.144775"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_002"
+ {
+ "iType" "25"
+ "pos_x" "-442.075836"
+ "pos_y" "823.553894"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "19"
+ "pos_x" "-654.543091"
+ "pos_y" "455.273590"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-651.201294"
+ "pos_y" "371.780212"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "27"
+ "pos_x" "431.312683"
+ "pos_y" "-321.697998"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_006"
+ {
+ "iType" "27"
+ "pos_x" "432.105347"
+ "pos_y" "-429.063171"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_007"
+ {
+ "iType" "20"
+ "pos_x" "572.857422"
+ "pos_y" "-431.040955"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "76"
+ "pos_x" "689.503052"
+ "pos_y" "-323.053223"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "2"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_009"
+ {
+ "iType" "33"
+ "pos_x" "829.247314"
+ "pos_y" "-456.004333"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "33"
+ "pos_x" "744.027893"
+ "pos_y" "883.847656"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "szName" "FL_proj_pos"
+ "pos_x" "463.612610"
+ "pos_y" "1023.904114"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_012"
+ {
+ "iType" "75"
+ "pos_x" "610.703186"
+ "pos_y" "874.641602"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_013"
+ {
+ "iType" "19"
+ "pos_x" "635.189392"
+ "pos_y" "806.456787"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_014"
+ {
+ "iType" "8"
+ "pos_x" "512.416504"
+ "pos_y" "-181.127701"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_015"
+ {
+ "iType" "13"
+ "pos_x" "422.261200"
+ "pos_y" "466.276276"
+ "size_x" "83.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_016"
+ {
+ "iType" "27"
+ "pos_x" "768.562500"
+ "pos_y" "802.917419"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_017"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "532.982605"
+ "pos_y" "786.923828"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "138.086517"
+ "container_extents_y" "690.243896"
+ "container_extents_z" "-138.086517"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "995.199097"
+ "pos_y" "728.171082"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_019"
+ {
+ "iType" "26"
+ "pos_x" "973.722717"
+ "pos_y" "819.162292"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "18"
+ "pos_x" "851.304688"
+ "pos_y" "724.114624"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_021"
+ {
+ "iType" "26"
+ "pos_x" "1111.044800"
+ "pos_y" "785.601990"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "27"
+ "pos_x" "705.587036"
+ "pos_y" "735.928833"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_023"
+ {
+ "iType" "33"
+ "pos_x" "1139.266235"
+ "pos_y" "722.609924"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "32"
+ "pos_x" "762.756104"
+ "pos_y" "539.323120"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "5"
+ "pos_x" "613.827454"
+ "pos_y" "713.556152"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_026"
+ {
+ "iType" "32"
+ "pos_x" "581.291565"
+ "pos_y" "1019.431885"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "98"
+ "pos_x" "146.369308"
+ "pos_y" "-954.124817"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "318.160645"
+ "pos_y" "-444.422852"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "179.525009"
+ "container_extents_y" "602.023865"
+ "container_extents_z" "-179.525009"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_029"
+ {
+ "iType" "19"
+ "pos_x" "573.476379"
+ "pos_y" "552.843018"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_030"
+ {
+ "iType" "17"
+ "pos_x" "266.785706"
+ "pos_y" "546.573242"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "19"
+ "pos_x" "159.088821"
+ "pos_y" "1050.899658"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_032"
+ {
+ "iType" "5"
+ "pos_x" "-178.867935"
+ "pos_y" "310.404816"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_033"
+ {
+ "iType" "17"
+ "pos_x" "350.482666"
+ "pos_y" "674.064758"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_034"
+ {
+ "iType" "19"
+ "pos_x" "160.781464"
+ "pos_y" "956.448181"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_035"
+ {
+ "iType" "19"
+ "pos_x" "24.159842"
+ "pos_y" "897.168152"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_036"
+ {
+ "iType" "19"
+ "pos_x" "-314.461975"
+ "pos_y" "1150.903198"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_037"
+ {
+ "iType" "17"
+ "pos_x" "261.159363"
+ "pos_y" "1011.600952"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "23"
+ "pos_x" "-440.161743"
+ "pos_y" "1163.443970"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "18"
+ "pos_x" "-254.264008"
+ "pos_y" "1020.619751"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "18"
+ "pos_x" "-586.701660"
+ "pos_y" "740.200073"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_041"
+ {
+ "iType" "17"
+ "pos_x" "-500.569916"
+ "pos_y" "438.919556"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "17"
+ "pos_x" "436.266144"
+ "pos_y" "209.803329"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "19"
+ "pos_x" "299.648865"
+ "pos_y" "221.872864"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_044"
+ {
+ "iType" "5"
+ "pos_x" "-203.541214"
+ "pos_y" "866.957581"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_045"
+ {
+ "iType" "62"
+ "pos_x" "-315.857269"
+ "pos_y" "334.000641"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "53"
+ "pos_x" "-199.028336"
+ "pos_y" "433.538513"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_047"
+ {
+ "iType" "53"
+ "pos_x" "166.078720"
+ "pos_y" "380.954987"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_048"
+ {
+ "iType" "27"
+ "szName" "anim amt normalized"
+ "pos_x" "-216.400436"
+ "pos_y" "194.818085"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_049"
+ {
+ "iType" "61"
+ "pos_x" "-64.917480"
+ "pos_y" "256.189392"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "19"
+ "pos_x" "-85.787109"
+ "pos_y" "724.681580"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_051"
+ {
+ "iType" "19"
+ "pos_x" "-102.521576"
+ "pos_y" "625.934204"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_052"
+ {
+ "iType" "5"
+ "pos_x" "-81.208313"
+ "pos_y" "822.724731"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.9"
+ }
+ "Node_053"
+ {
+ "iType" "19"
+ "pos_x" "430.335724"
+ "pos_y" "-824.242126"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_054"
+ {
+ "iType" "5"
+ "pos_x" "148.602814"
+ "pos_y" "183.851547"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_055"
+ {
+ "iType" "17"
+ "pos_x" "122.996101"
+ "pos_y" "-804.804871"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "3"
+ "pos_x" "-693.788818"
+ "pos_y" "-590.314514"
+ "size_x" "55.000000"
+ "size_y" "-72.000000"
+ "iPreview" "0"
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "uv"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "color"
+ "numTexcoord_Flag_2" "8"
+ "numTexcoord_Name_2" "flproj"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "projpos"
+ "numTexcoord_Flag_4" "4"
+ "numTexcoord_Name_4" "pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Name_5" "normal"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "1"
+ "numColor_Name_0" "specscale"
+ "numColor_Flag_1" "8"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-184.411621"
+ "pos_y" "-369.120667"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "18"
+ "pos_x" "-87.342422"
+ "pos_y" "-884.942322"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "120"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "19"
+ "pos_x" "9.357773"
+ "pos_y" "-368.627136"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_060"
+ {
+ "iType" "5"
+ "szName" "Diffuse"
+ "pos_x" "201.630646"
+ "pos_y" "-160.096283"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_061"
+ {
+ "iType" "5"
+ "szName" "Spec"
+ "pos_x" "-24.080154"
+ "pos_y" "-163.237701"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_062"
+ {
+ "iType" "32"
+ "pos_x" "297.598022"
+ "pos_y" "-192.459778"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "32"
+ "pos_x" "77.462357"
+ "pos_y" "-168.677460"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "33"
+ "pos_x" "204.936996"
+ "pos_y" "-472.199707"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_065"
+ {
+ "iType" "33"
+ "pos_x" "77.462349"
+ "pos_y" "-496.877258"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "39"
+ "pos_x" "56.088203"
+ "pos_y" "413.703094"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_067"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-616.596313"
+ "pos_y" "-411.769287"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "167.818665"
+ "container_extents_y" "859.688965"
+ "container_extents_z" "-167.818665"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_068"
+ {
+ "iType" "49"
+ "pos_x" "708.118286"
+ "pos_y" "106.054733"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_069"
+ {
+ "iType" "27"
+ "pos_x" "252.916077"
+ "pos_y" "143.966583"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "5"
+ }
+ }
+ "swizzleString" "rgb"
+ }
+ "Node_070"
+ {
+ "iType" "23"
+ "pos_x" "297.023468"
+ "pos_y" "342.689117"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "124.819153"
+ "pos_y" "292.898560"
+ "size_x" "50.000000"
+ "size_y" "-38.000000"
+ "iPreview" "1"
+ "szConstantString" "0.333333 0.333333 0.333333"
+ }
+ "Node_072"
+ {
+ "iType" "5"
+ "pos_x" "591.400269"
+ "pos_y" "160.455322"
+ "size_x" "50.000000"
+ "size_y" "-38.000000"
+ "iPreview" "1"
+ "szConstantString" "0.333333 0.333333 0.333333"
+ }
+ "Node_073"
+ {
+ "iType" "23"
+ "pos_x" "706.196655"
+ "pos_y" "184.918854"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_074"
+ {
+ "iType" "19"
+ "pos_x" "-17.601318"
+ "pos_y" "504.507019"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_075"
+ {
+ "iType" "19"
+ "pos_x" "131.110794"
+ "pos_y" "539.224060"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_076"
+ {
+ "iType" "49"
+ "pos_x" "-73.894524"
+ "pos_y" "368.152557"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "5"
+ "pos_x" "616.668457"
+ "pos_y" "270.264832"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_078"
+ {
+ "iType" "5"
+ "pos_x" "551.160645"
+ "pos_y" "72.186981"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_079"
+ {
+ "iType" "19"
+ "pos_x" "661.074707"
+ "pos_y" "-145.101913"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_080"
+ {
+ "iType" "5"
+ "pos_x" "516.784546"
+ "pos_y" "-78.933830"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_081"
+ {
+ "iType" "29"
+ "pos_x" "-587.519653"
+ "pos_y" "-698.343567"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "detail\grass_sprites"
+ "szFallbackTexturePath" "detail\grass_sprites"
+ "iFallbackMode" "4"
+ }
+ "Node_082"
+ {
+ "iType" "34"
+ "pos_x" "-385.397949"
+ "pos_y" "-435.492462"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "122"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_083"
+ {
+ "iType" "27"
+ "szName" "plane pos"
+ "pos_x" "-202.939804"
+ "pos_y" "517.529419"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_084"
+ {
+ "iType" "19"
+ "pos_x" "863.176880"
+ "pos_y" "165.369736"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_085"
+ {
+ "iType" "2"
+ "pos_x" "1141.853271"
+ "pos_y" "384.199097"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "uv"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "color"
+ "numTexcoord_Flag_2" "8"
+ "numTexcoord_Name_2" "flproj"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "projpos"
+ "numTexcoord_Flag_4" "4"
+ "numTexcoord_Name_4" "pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Name_5" "normal"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "1"
+ "numColor_Name_0" "specscale"
+ "numColor_Flag_1" "8"
+ }
+ "Node_086"
+ {
+ "iType" "5"
+ "pos_x" "-752.276978"
+ "pos_y" "426.040680"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_087"
+ {
+ "iType" "5"
+ "pos_x" "-766.689453"
+ "pos_y" "349.310883"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.005"
+ }
+ "Node_088"
+ {
+ "iType" "19"
+ "pos_x" "-293.498077"
+ "pos_y" "597.576477"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_089"
+ {
+ "iType" "27"
+ "pos_x" "-1545.565186"
+ "pos_y" "160.049988"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_090"
+ {
+ "iType" "1"
+ "pos_x" "-793.653076"
+ "pos_y" "17.190144"
+ "size_x" "55.000000"
+ "size_y" "-72.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "3"
+ "numColor" "1"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "4"
+ "dTFlag_Texcoords_2" "4"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_091"
+ {
+ "iType" "19"
+ "pos_x" "-1218.400024"
+ "pos_y" "403.982178"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "1"
+ }
+ "Node_092"
+ {
+ "iType" "19"
+ "pos_x" "-1392.616333"
+ "pos_y" "393.769684"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "1"
+ }
+ "Node_093"
+ {
+ "iType" "19"
+ "pos_x" "-1245.032715"
+ "pos_y" "206.904587"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "1"
+ }
+ "Node_094"
+ {
+ "iType" "19"
+ "pos_x" "-1394.172485"
+ "pos_y" "217.557419"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "1"
+ }
+ "Node_095"
+ {
+ "iType" "17"
+ "pos_x" "-1285.687134"
+ "pos_y" "82.699554"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_096"
+ {
+ "iType" "27"
+ "pos_x" "-1556.057129"
+ "pos_y" "242.098434"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_097"
+ {
+ "iType" "27"
+ "pos_x" "-1015.464233"
+ "pos_y" "205.809219"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_098"
+ {
+ "iType" "26"
+ "pos_x" "-1008.328003"
+ "pos_y" "320.207581"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_099"
+ {
+ "iType" "26"
+ "pos_x" "-877.709045"
+ "pos_y" "260.411926"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_100"
+ {
+ "iType" "23"
+ "pos_x" "-444.115967"
+ "pos_y" "596.359863"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_101"
+ {
+ "iType" "18"
+ "pos_x" "-1257.564209"
+ "pos_y" "304.189575"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_102"
+ {
+ "iType" "40"
+ "pos_x" "-1514.830933"
+ "pos_y" "377.478973"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_103"
+ {
+ "iType" "39"
+ "pos_x" "-1524.207520"
+ "pos_y" "308.102936"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_104"
+ {
+ "iType" "78"
+ "szName" "wind angle radians"
+ "pos_x" "-1708.058594"
+ "pos_y" "292.689484"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "i_vp_mutable_param" "1"
+ "i_vp_mutable_nc" "0"
+ "szConstantString" "3.926991"
+ }
+ "Node_105"
+ {
+ "iType" "78"
+ "szName" "wind dir"
+ "pos_x" "-885.587769"
+ "pos_y" "659.094116"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "i_vp_mutable_param" "0"
+ "i_vp_mutable_nc" "2"
+ "szConstantString" "1 0 0"
+ }
+ "Node_106"
+ {
+ "iType" "33"
+ "pos_x" "300.676270"
+ "pos_y" "-722.016968"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_107"
+ {
+ "iType" "27"
+ "pos_x" "355.619995"
+ "pos_y" "-1312.390259"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_108"
+ {
+ "iType" "27"
+ "pos_x" "348.915955"
+ "pos_y" "-1263.633057"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_109"
+ {
+ "iType" "4"
+ "pos_x" "1064.963013"
+ "pos_y" "-1014.729187"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_110"
+ {
+ "iType" "27"
+ "pos_x" "361.002441"
+ "pos_y" "-1196.228760"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_111"
+ {
+ "iType" "7"
+ "pos_x" "246.124329"
+ "pos_y" "-1136.630981"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_112"
+ {
+ "iType" "70"
+ "pos_x" "363.045990"
+ "pos_y" "-1097.674683"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_113"
+ {
+ "iType" "72"
+ "pos_x" "811.238525"
+ "pos_y" "-1046.211426"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "2"
+ "i_final_wdepth" "1"
+ }
+ "Node_114"
+ {
+ "iType" "71"
+ "pos_x" "546.117493"
+ "pos_y" "-1103.009888"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_115"
+ {
+ "iType" "21"
+ "pos_x" "730.561646"
+ "pos_y" "385.101074"
+ "size_x" "80.000000"
+ "size_y" "-39.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_116"
+ {
+ "iType" "19"
+ "pos_x" "535.981140"
+ "pos_y" "374.840973"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_117"
+ {
+ "iType" "19"
+ "pos_x" "1016.289673"
+ "pos_y" "270.429626"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_118"
+ {
+ "iType" "19"
+ "pos_x" "859.266663"
+ "pos_y" "304.502686"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_119"
+ {
+ "iType" "79"
+ "pos_x" "-246.514587"
+ "pos_y" "-496.945984"
+ "size_x" "116.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "grass_spec_color"
+ "i_vp_static_nc" "2"
+ "szConstantString" "0.90575 1 0.675"
+ }
+ "Node_120"
+ {
+ "iType" "5"
+ "pos_x" "-197.822449"
+ "pos_y" "-838.229126"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_121"
+ {
+ "iType" "5"
+ "pos_x" "-497.986206"
+ "pos_y" "-477.809631"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_122"
+ {
+ "iType" "5"
+ "pos_x" "-483.170898"
+ "pos_y" "-367.835846"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.29"
+ }
+ "Node_123"
+ {
+ "iType" "99"
+ "szName" "waveanim"
+ "pos_x" "-349.008728"
+ "pos_y" "457.091827"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "varType_In_0" "4"
+ "varType_Out_0" "4"
+ "iInline" "1"
+ "szcode_global_num_strings" "1"
+ "szcode_global_partial_00" "float3 triangle( float3 a )\r\n{\r\n return abs( frac( a + 0.5f ) * 2.0f - 1.0f );\r\n}\n"
+ "szcode_body_num_strings" "1"
+ "szcode_body_partial_00" " var_01 = triangle( var_00 );\r\n\r\n var_01 = ( 3.0 - 2.000000000001 * var_01 ) * var_01 * var_01;"
+ "iEnvFlags" "0"
+ }
+ "Node_124"
+ {
+ "iType" "26"
+ "pos_x" "614.226990"
+ "pos_y" "-862.025452"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_125"
+ {
+ "iType" "27"
+ "szName" "anim amt heightscale"
+ "pos_x" "-17.176344"
+ "pos_y" "984.560730"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/drews_post_bloodfx.txt b/mp/game/momentum/shadereditorui/canvas/drews_post_bloodfx.txt
new file mode 100644
index 0000000000..44b7aa2127
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/drews_post_bloodfx.txt
@@ -0,0 +1,299 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_normal_compression" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "27"
+ "pos_x" "97.909302"
+ "pos_y" "234.289230"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-318.953522"
+ "pos_y" "-349.487518"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "numTexcoords" "2"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "noiseCoords"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Name_2" "NoiseTC.zw"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "2"
+ "pos_x" "548.470947"
+ "pos_y" "182.190765"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "2"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "noiseCoords"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Name_2" "NoiseTC.zw"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-54.000084"
+ "pos_y" "10.352503"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "12"
+ "pos_x" "-306.697083"
+ "pos_y" "-14.148090"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_006"
+ {
+ "iType" "5"
+ "szName" "speed of water ( time )"
+ "pos_x" "-305.144135"
+ "pos_y" "-78.769691"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_007"
+ {
+ "iType" "94"
+ "szName" "Framebuffer"
+ "pos_x" "-325.044800"
+ "pos_y" "-505.134583"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "szFallbackTexturePath" "black"
+ "iFallbackMode" "1"
+ }
+ "Node_008"
+ {
+ "iType" "4"
+ "pos_x" "401.079163"
+ "pos_y" "-438.672424"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_009"
+ {
+ "iType" "99"
+ "szName" "Pixel Shader"
+ "pos_x" "5.122215"
+ "pos_y" "-385.596191"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "varName_In_0" "texCoords"
+ "varType_In_0" "2"
+ "varName_In_1" "noiseCoords"
+ "varType_In_1" "8"
+ "varName_In_2" "waterNormal"
+ "varType_In_2" "128"
+ "varName_In_3" "frameBuffer"
+ "varType_In_3" "128"
+ "varName_Out_0" "finalColor"
+ "varType_Out_0" "8"
+ "szFunctionName" "doBlood"
+ "iInline" "1"
+ "szcode_global_num_strings" "1"
+ "szcode_global_partial_00" "// Cryteks method. - Converted & modified by Drew \r\n// www.drewwatts.net\r\n// Enjoy ya dingus!\r\n\r\nstatic float4 bloodColor = float4(1.0, 0.20, 0.20, 0.0);\n"
+ "szcode_body_num_strings" "2"
+ "szcode_body_partial_00" " float4 noise0 = tex2D(waterNormal, noiseCoords.xy);\r\n float4 noise1 = tex2D(waterNormal, noiseCoords.zw);\r\n\r\n float4 noiseVec;\r\n noiseVec.z = (noise0.z * 2.0 - 1.0) * 0.5 + (2.0 * noise1.w - 1.0);\r\n noiseVec.xy = (noise0.xy * 2.0 - 1.0);\r\n\r\n // refraction vector\r\n float3 refraction = normalize(noiseVec.xyz * float3(0.01, 0.01, 1.0));\r\n\r\n // distort the framebuffer\r\n float4 frameColor = tex2D(frameBuffer, texCoords - refraction.xy*0.25);\r\n\r\n // gray frame\r\n float4 frameBloody = dot(frameColor, float4(0.3, 0.59, 0.11, 0.0)); \r\n // give it some color\r\n frameBloody = (frameBloody * bloodColor);\r\n\r\n // to mask our blood effect\r\n float bloodMask = refraction.b;\r\n bloodMask = pow(bloodMask, 5.0);\r\n\r\n // modified refraction vector for our highlight\r\n refraction = normalize(noiseVec.xyz * float3(0.025, 0.025, 1.0));\r\n\r\n // do the highlight\r\n float highlight = saturate(pow(refraction.x, 10.0) * 0.5) * 1.0;\r\n\r\n // lerp between our blood, the and the frame, then a"
+ "szcode_body_partial_01" "dd the highlight\r\n finalColor.rgb = lerp(frameBloody.rgb, frameColor.rgb, bloodMask) + highlight;\r\n\r\n //assign an alpha\r\n finalColor.a = 1.0;\n"
+ "iEnvFlags" "0"
+ }
+ "Node_010"
+ {
+ "iType" "94"
+ "pos_x" "-327.920715"
+ "pos_y" "-409.590027"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szParamname" "waterNormal"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "texture_samples\drew\water_droplets"
+ "szFallbackTexturePath" "texture_samples\drew\water_droplets"
+ "iFallbackMode" "4"
+ }
+ "Node_011"
+ {
+ "iType" "99"
+ "szName" "Vertex Shader"
+ "pos_x" "114.897171"
+ "pos_y" "75.757309"
+ "size_x" "89.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "varName_In_0" "texCoords"
+ "varType_In_0" "2"
+ "varName_In_1" "time"
+ "varType_In_1" "1"
+ "varName_Out_0" "noiseCoords"
+ "varType_Out_0" "8"
+ "szFunctionName" "noiseCoords"
+ "iInline" "1"
+ "szcode_body_num_strings" "1"
+ "szcode_body_partial_00" " //this will be the var we will use to modify the coords\r\n float4 distortedCoords;\r\n\r\n //modify the texture coords\r\n distortedCoords.xy = texCoords * 0.5; \r\n\r\n //modify the texture coords ( z and w ) with time\r\n distortedCoords.zw = texCoords * float2(1.0, 0.25) * 0.5 + float2(0.0, -time);\r\n\r\n //modify the texture coords ( z ) with time\r\n distortedCoords.z += (sin(time) + sin(time*0.5))*0.5 + 0.5;\r\n\r\n //output our ( distortedCoords ) to our output named ( noiseCoords )\r\n noiseCoords = distortedCoords;\r\n "
+ "iEnvFlags" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/drews_post_waterfx.txt b/mp/game/momentum/shadereditorui/canvas/drews_post_waterfx.txt
new file mode 100644
index 0000000000..d6815af421
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/drews_post_waterfx.txt
@@ -0,0 +1,299 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_normal_compression" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "27"
+ "pos_x" "97.909302"
+ "pos_y" "234.289230"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_002"
+ {
+ "iType" "4"
+ "pos_x" "486.601898"
+ "pos_y" "-345.167480"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_003"
+ {
+ "iType" "3"
+ "pos_x" "-318.953522"
+ "pos_y" "-349.487518"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "numTexcoords" "2"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "noiseCoords"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Name_2" "NoiseTC.zw"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_004"
+ {
+ "iType" "2"
+ "pos_x" "548.470947"
+ "pos_y" "182.190765"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "2"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "noiseCoords"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Name_2" "NoiseTC.zw"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_005"
+ {
+ "iType" "94"
+ "pos_x" "-325.796722"
+ "pos_y" "-415.253204"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szParamname" "waterNormal"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "texture_samples\drew\water_droplets"
+ "szFallbackTexturePath" "texture_samples\drew\water_droplets"
+ "iFallbackMode" "4"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-54.000084"
+ "pos_y" "10.352503"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "12"
+ "pos_x" "-306.697083"
+ "pos_y" "-14.148090"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_008"
+ {
+ "iType" "94"
+ "szName" "Framebuffer"
+ "pos_x" "-323.070618"
+ "pos_y" "-518.036499"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "szFallbackTexturePath" "black"
+ "iFallbackMode" "1"
+ }
+ "Node_009"
+ {
+ "iType" "5"
+ "szName" "speed of water ( time )"
+ "pos_x" "-318.425201"
+ "pos_y" "-104.446396"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_010"
+ {
+ "iType" "99"
+ "szName" "Vertex Shader"
+ "pos_x" "122.860550"
+ "pos_y" "84.691269"
+ "size_x" "89.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "varName_In_0" "texCoords"
+ "varType_In_0" "2"
+ "varName_In_1" "time"
+ "varType_In_1" "1"
+ "varName_Out_0" "noiseCoords"
+ "varType_Out_0" "8"
+ "szFunctionName" "noiseCoords"
+ "iInline" "1"
+ "szcode_body_num_strings" "1"
+ "szcode_body_partial_00" " //this will be the var we will use to modify the coords\r\n float4 distortedCoords;\r\n\r\n //modify the texture coords\r\n distortedCoords.xy = texCoords * 0.5; \r\n\r\n //modify the texture coords ( z and w ) with time\r\n distortedCoords.zw = texCoords * float2(1.0, 0.25) * 0.5 + float2(0.0, -time);\r\n\r\n //modify the texture coords ( z ) with time\r\n distortedCoords.z += (sin(time) + sin(time*0.5))*0.5 + 0.5;\r\n\r\n //output our ( distortedCoords ) to our output named ( noiseCoords )\r\n noiseCoords = distortedCoords;\r\n "
+ "iEnvFlags" "0"
+ }
+ "Node_011"
+ {
+ "iType" "99"
+ "szName" "Pixel Shader"
+ "pos_x" "57.687988"
+ "pos_y" "-367.631165"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "varName_In_0" "texCoords"
+ "varType_In_0" "2"
+ "varName_In_1" "noiseCoords"
+ "varType_In_1" "8"
+ "varName_In_2" "waterNormal"
+ "varType_In_2" "128"
+ "varName_In_3" "frameBuffer"
+ "varType_In_3" "128"
+ "varName_Out_0" "finalColor"
+ "varType_Out_0" "8"
+ "szFunctionName" "doWater"
+ "iInline" "1"
+ "szcode_global_num_strings" "1"
+ "szcode_global_partial_00" "// Cryteks method. - Converted & modified by Drew \r\n// www.drewwatts.net\r\n// Enjoy ya dingus!\r\nstatic bool useChromaticAbberation = true;\r\nstatic float abberationStrength = 3.0; //chromatic aberration strength\n"
+ "szcode_body_num_strings" "2"
+ "szcode_body_partial_00" " float4 noise0 = tex2D(waterNormal, noiseCoords.xy);\r\n float4 noise1 = tex2D(waterNormal, noiseCoords.zw);\r\n\r\n float4 noiseVec;\r\n noiseVec.z = (noise0.z * 2.0 - 1.0) * 0.5 + (2.0 * noise1.w - 1.0);\r\n noiseVec.xy = (noise0.xy * 2.0 - 1.0);\r\n\r\n //refraction vector\r\n float3 refraction = normalize(noiseVec.xyz * float3(0.01, 0.01, 1.0));\r\n\r\n //distort the framebuffer \r\n float4 frameColor = tex2D(frameBuffer, texCoords - refraction.xy*0.25);\r\n\r\n //are we going to use chromatic abberation?\r\n if (useChromaticAbberation)\r\n {\r\n //chromatic aberration value. It's a small value, but we can mutlply with abberationStrength\r\n float3 ca = (0.0, 0.0, 0.0001) * abberationStrength; \r\n\r\n //get the new refraction vectors \r\n float3 refraction0 = normalize(noiseVec.xyz * float3(0.01, 0.01, 1.0) + ca ); \r\n float3 refraction1 = normalize(noiseVec.xyz * float3(0.01, 0.01, 1.0) - ca);\r\n\r\n //distort the red channel with refraction0\r\n frameColor.r = tex2D(frameBuffer, texCoords - r"
+ "szcode_body_partial_01" "efraction0.xy*0.25).r;\r\n //distort the red channel with refraction1\r\n frameColor.b = tex2D(frameBuffer, texCoords - refraction1.xy*0.25).b;\r\n }\r\n\r\n //modified refraction vector for our highlight\r\n refraction = normalize(noiseVec.xyz*float3(0.025, 0.025, 1));\r\n\r\n //do the highlight\r\n float highlight = saturate(pow(refraction.x, 10.0) * 0.5) * 1.0;\r\n //add the highlight to the distorted framebuffer\r\n finalColor.rgb = frameColor.rgb + highlight;\r\n\r\n //assign an alpha\r\n finalColor.a = 1.0;\n"
+ "iEnvFlags" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/lightmap_blend_bump_detail.txt b/mp/game/momentum/shadereditorui/canvas/lightmap_blend_bump_detail.txt
new file mode 100644
index 0000000000..d64a0ff0bf
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/lightmap_blend_bump_detail.txt
@@ -0,0 +1,3057 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#002"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "14"
+ "pos_x" "-67.148407"
+ "pos_y" "608.769470"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "75"
+ "pos_x" "-196.710205"
+ "pos_y" "-1098.514526"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_002"
+ {
+ "iType" "19"
+ "pos_x" "-56.518372"
+ "pos_y" "-1030.090332"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_003"
+ {
+ "iType" "70"
+ "pos_x" "696.218628"
+ "pos_y" "-1370.956421"
+ "size_x" "59.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_004"
+ {
+ "iType" "7"
+ "pos_x" "587.300537"
+ "pos_y" "-1374.990112"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_005"
+ {
+ "iType" "27"
+ "pos_x" "566.130981"
+ "pos_y" "-1572.309692"
+ "size_x" "124.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_006"
+ {
+ "iType" "71"
+ "pos_x" "870.033813"
+ "pos_y" "-1449.873169"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "72"
+ "pos_x" "878.133667"
+ "pos_y" "-1563.149536"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_008"
+ {
+ "iType" "4"
+ "pos_x" "1147.363525"
+ "pos_y" "-1584.058716"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_009"
+ {
+ "iType" "27"
+ "pos_x" "693.328247"
+ "pos_y" "-1421.504028"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_010"
+ {
+ "iType" "27"
+ "pos_x" "687.685059"
+ "pos_y" "-1465.105347"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_011"
+ {
+ "iType" "27"
+ "pos_x" "687.422974"
+ "pos_y" "-1513.970825"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "8"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_012"
+ {
+ "iType" "17"
+ "pos_x" "-195.430313"
+ "pos_y" "154.320465"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "23"
+ "pos_x" "-1063.938477"
+ "pos_y" "-436.916229"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "23"
+ "pos_x" "-1068.266357"
+ "pos_y" "-540.778015"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "19"
+ "pos_x" "-594.653809"
+ "pos_y" "-490.616608"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "128"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "128"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_016"
+ {
+ "iType" "29"
+ "pos_x" "-415.631012"
+ "pos_y" "-373.722748"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_017"
+ {
+ "iType" "29"
+ "pos_x" "-414.728546"
+ "pos_y" "-476.595612"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "-566.974243"
+ "pos_y" "-343.340485"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_019"
+ {
+ "iType" "27"
+ "pos_x" "-394.948639"
+ "pos_y" "-590.862610"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_020"
+ {
+ "iType" "27"
+ "pos_x" "-388.216217"
+ "pos_y" "-635.082581"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_021"
+ {
+ "iType" "27"
+ "pos_x" "-390.140411"
+ "pos_y" "-683.180481"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_022"
+ {
+ "iType" "19"
+ "pos_x" "-161.960602"
+ "pos_y" "-387.228058"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_023"
+ {
+ "iType" "19"
+ "pos_x" "-159.075714"
+ "pos_y" "-498.778900"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_024"
+ {
+ "iType" "23"
+ "pos_x" "-1062.441406"
+ "pos_y" "-333.783966"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "26"
+ "pos_x" "-906.676575"
+ "pos_y" "-496.152222"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "127"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "23"
+ "pos_x" "-397.109283"
+ "pos_y" "-777.056580"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "19"
+ "pos_x" "-163.883820"
+ "pos_y" "-283.370331"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_028"
+ {
+ "iType" "17"
+ "pos_x" "-12.768341"
+ "pos_y" "-348.850494"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "17"
+ "pos_x" "-10.572052"
+ "pos_y" "-471.832733"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_030"
+ {
+ "iType" "80"
+ "pos_x" "-157.359894"
+ "pos_y" "-676.886658"
+ "size_x" "88.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "1"
+ }
+ "Node_031"
+ {
+ "iType" "20"
+ "pos_x" "-14.695099"
+ "pos_y" "-694.812683"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "27"
+ "pos_x" "-565.747803"
+ "pos_y" "-391.027374"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "zw"
+ }
+ "Node_033"
+ {
+ "iType" "19"
+ "pos_x" "180.579437"
+ "pos_y" "-564.280090"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_034"
+ {
+ "iType" "29"
+ "pos_x" "-419.033722"
+ "pos_y" "-266.936951"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_035"
+ {
+ "iType" "17"
+ "pos_x" "-178.732437"
+ "pos_y" "104.991516"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_036"
+ {
+ "iType" "33"
+ "pos_x" "452.038361"
+ "pos_y" "-1002.346069"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_037"
+ {
+ "iType" "32"
+ "pos_x" "121.640915"
+ "pos_y" "-78.065155"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "5"
+ "pos_x" "27.518646"
+ "pos_y" "-76.322235"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_039"
+ {
+ "iType" "5"
+ "pos_x" "-1422.707764"
+ "pos_y" "-1283.585449"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "1"
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "-1426.320435"
+ "pos_y" "-1212.233398"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "2"
+ }
+ "Node_041"
+ {
+ "iType" "87"
+ "pos_x" "-1305.974487"
+ "pos_y" "-306.997589"
+ "size_x" "60.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_042"
+ {
+ "iType" "17"
+ "pos_x" "-200.096085"
+ "pos_y" "211.243134"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "5"
+ "pos_x" "-440.065643"
+ "pos_y" "-1060.233765"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_044"
+ {
+ "iType" "17"
+ "pos_x" "-306.051117"
+ "pos_y" "-1156.147827"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_045"
+ {
+ "iType" "15"
+ "pos_x" "-371.334473"
+ "pos_y" "557.775269"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_046"
+ {
+ "iType" "19"
+ "pos_x" "-233.099228"
+ "pos_y" "492.737457"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_047"
+ {
+ "iType" "19"
+ "pos_x" "51.116302"
+ "pos_y" "546.808105"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_048"
+ {
+ "iType" "26"
+ "pos_x" "50.448524"
+ "pos_y" "210.450958"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "19"
+ "pos_x" "-199.013474"
+ "pos_y" "366.788788"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_050"
+ {
+ "iType" "19"
+ "pos_x" "-199.809982"
+ "pos_y" "427.296539"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_051"
+ {
+ "iType" "19"
+ "pos_x" "-200.112106"
+ "pos_y" "314.781982"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_052"
+ {
+ "iType" "25"
+ "pos_x" "-23.853540"
+ "pos_y" "421.195313"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_053"
+ {
+ "iType" "25"
+ "pos_x" "-25.137175"
+ "pos_y" "372.060944"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_054"
+ {
+ "iType" "25"
+ "pos_x" "-30.844557"
+ "pos_y" "304.999237"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_055"
+ {
+ "iType" "19"
+ "pos_x" "-1333.921997"
+ "pos_y" "-1175.556763"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_056"
+ {
+ "iType" "73"
+ "pos_x" "-994.208618"
+ "pos_y" "-1151.497192"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-867.843018"
+ "pos_y" "-1042.185181"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-1476.140625"
+ "pos_y" "-543.904968"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "406.346802"
+ "container_extents_y" "1871.088501"
+ "container_extents_z" "-406.346802"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_059"
+ {
+ "iType" "26"
+ "pos_x" "-361.982300"
+ "pos_y" "173.638031"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "3"
+ "pos_x" "-1825.982910"
+ "pos_y" "-680.488953"
+ "size_x" "60.000000"
+ "size_y" "-116.000000"
+ "iPreview" "0"
+ "numTexcoords" "8"
+ "numColor" "2"
+ "numTexcoord_Flag_0" "8"
+ "numTexcoord_Name_0" "UV0_UV1"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Lightmap3_UV2"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "2"
+ "numTexcoord_Name_7" "UV3"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "8"
+ "numColor_Name_1" "VColor"
+ }
+ "Node_061"
+ {
+ "iType" "38"
+ "pos_x" "-2391.331055"
+ "pos_y" "-1873.999023"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_062"
+ {
+ "iType" "37"
+ "pos_x" "-2397.001465"
+ "pos_y" "-1758.363525"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "5"
+ "pos_x" "-1929.521240"
+ "pos_y" "-1836.425293"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_064"
+ {
+ "iType" "21"
+ "pos_x" "-2181.092285"
+ "pos_y" "-1804.968750"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_065"
+ {
+ "iType" "21"
+ "pos_x" "-226.086639"
+ "pos_y" "-1716.042603"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "1"
+ "pos_x" "-487.314331"
+ "pos_y" "376.227325"
+ "size_x" "55.000000"
+ "size_y" "-94.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "3"
+ "numColor" "1"
+ "dTFlag_Texcoords" "2"
+ "dTFlag_Color" "8"
+ }
+ "Node_067"
+ {
+ "iType" "27"
+ "szName" "UV_0"
+ "pos_x" "-2712.511963"
+ "pos_y" "-1025.396240"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_068"
+ {
+ "iType" "27"
+ "pos_x" "-1659.697632"
+ "pos_y" "-702.284546"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_069"
+ {
+ "iType" "27"
+ "pos_x" "-2065.214844"
+ "pos_y" "-1382.465454"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_070"
+ {
+ "iType" "5"
+ "pos_x" "-1911.742676"
+ "pos_y" "-1742.304443"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "-2020.983521"
+ "pos_y" "-1486.264771"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_072"
+ {
+ "iType" "34"
+ "pos_x" "-1781.460938"
+ "pos_y" "-1834.016479"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_073"
+ {
+ "iType" "27"
+ "szName" "Blendfactor"
+ "pos_x" "-2999.025391"
+ "pos_y" "-1210.270142"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "9"
+ }
+ }
+ "swizzleString" "a"
+ }
+ "Node_074"
+ {
+ "iType" "27"
+ "pos_x" "-2058.352539"
+ "pos_y" "-1276.277588"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_075"
+ {
+ "iType" "17"
+ "pos_x" "-1913.657471"
+ "pos_y" "-1274.521729"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_076"
+ {
+ "iType" "60"
+ "pos_x" "-1798.421509"
+ "pos_y" "-1357.539673"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "26"
+ "pos_x" "-1669.875977"
+ "pos_y" "-1356.279053"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "4"
+ }
+ }
+ }
+ "Node_078"
+ {
+ "iType" "27"
+ "pos_x" "-2089.752930"
+ "pos_y" "-1075.220703"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "137"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_079"
+ {
+ "iType" "5"
+ "pos_x" "-2045.520996"
+ "pos_y" "-1179.020020"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_080"
+ {
+ "iType" "17"
+ "pos_x" "-1924.610840"
+ "pos_y" "-959.815247"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_081"
+ {
+ "iType" "60"
+ "pos_x" "-1809.374878"
+ "pos_y" "-1042.833252"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "27"
+ "pos_x" "-2069.305908"
+ "pos_y" "-961.571106"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_083"
+ {
+ "iType" "21"
+ "pos_x" "-1558.262573"
+ "pos_y" "-1201.800293"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_084"
+ {
+ "iType" "26"
+ "pos_x" "-1672.170532"
+ "pos_y" "-1038.686157"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "4"
+ }
+ }
+ }
+ "Node_085"
+ {
+ "iType" "34"
+ "pos_x" "-673.558960"
+ "pos_y" "-1814.640015"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "150"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "144"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_086"
+ {
+ "iType" "19"
+ "pos_x" "-517.855469"
+ "pos_y" "-1834.309570"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "139"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_087"
+ {
+ "iType" "19"
+ "pos_x" "-466.807709"
+ "pos_y" "-1512.285889"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "142"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_088"
+ {
+ "iType" "5"
+ "pos_x" "-628.369629"
+ "pos_y" "178.154312"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_089"
+ {
+ "iType" "27"
+ "szName" "UV_1"
+ "pos_x" "-2715.317139"
+ "pos_y" "-1088.656860"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "zw"
+ }
+ "Node_090"
+ {
+ "iType" "19"
+ "szName" "albedo"
+ "pos_x" "-509.562744"
+ "pos_y" "183.744797"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_091"
+ {
+ "iType" "19"
+ "szName" "blendmod"
+ "pos_x" "-510.514801"
+ "pos_y" "115.176933"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_092"
+ {
+ "iType" "26"
+ "pos_x" "18.183060"
+ "pos_y" "124.666214"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_093"
+ {
+ "iType" "19"
+ "szName" "bump detail"
+ "pos_x" "-501.669891"
+ "pos_y" "43.917274"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_094"
+ {
+ "iType" "55"
+ "szName" "albedo detail"
+ "pos_x" "-120.064636"
+ "pos_y" "19.680410"
+ "size_x" "91.000000"
+ "size_y" "-39.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "0"
+ }
+ "Node_095"
+ {
+ "iType" "5"
+ "pos_x" "-259.115723"
+ "pos_y" "-35.150818"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "szConstantString" "4 4"
+ }
+ "Node_096"
+ {
+ "iType" "5"
+ "pos_x" "-629.694946"
+ "pos_y" "99.771034"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.12"
+ }
+ "Node_097"
+ {
+ "iType" "5"
+ "pos_x" "-620.850037"
+ "pos_y" "28.511381"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "szConstantString" "5 5"
+ }
+ "Node_098"
+ {
+ "iType" "5"
+ "pos_x" "-258.490936"
+ "pos_y" "10.209181"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "45"
+ }
+ "Node_099"
+ {
+ "iType" "27"
+ "szName" "UV_2"
+ "pos_x" "-2717.112549"
+ "pos_y" "-1148.516113"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "zw"
+ }
+ "Node_100"
+ {
+ "iType" "27"
+ "szName" "UV_3"
+ "pos_x" "-2715.248291"
+ "pos_y" "-1212.243896"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "7"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_101"
+ {
+ "iType" "19"
+ "pos_x" "-469.712891"
+ "pos_y" "-1162.810669"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_102"
+ {
+ "iType" "27"
+ "pos_x" "-795.516663"
+ "pos_y" "-1215.000977"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "8"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_103"
+ {
+ "iType" "18"
+ "pos_x" "-1945.470337"
+ "pos_y" "-1087.021240"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_104"
+ {
+ "iType" "18"
+ "pos_x" "-1928.026245"
+ "pos_y" "-1405.411865"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_105"
+ {
+ "iType" "27"
+ "pos_x" "-799.045593"
+ "pos_y" "-1153.658813"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "8"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_106"
+ {
+ "iType" "20"
+ "pos_x" "-662.635864"
+ "pos_y" "-1166.493774"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_107"
+ {
+ "iType" "18"
+ "szName" "world normal"
+ "pos_x" "-1333.018677"
+ "pos_y" "-1258.650146"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_108"
+ {
+ "iType" "32"
+ "pos_x" "381.721954"
+ "pos_y" "-59.704079"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_109"
+ {
+ "iType" "5"
+ "pos_x" "287.599701"
+ "pos_y" "-57.961159"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_110"
+ {
+ "iType" "33"
+ "pos_x" "205.443649"
+ "pos_y" "-775.707031"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_111"
+ {
+ "iType" "33"
+ "pos_x" "67.943016"
+ "pos_y" "-863.456238"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "120"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_112"
+ {
+ "iType" "80"
+ "pos_x" "-736.657410"
+ "pos_y" "-857.165527"
+ "size_x" "83.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "2"
+ }
+ "Node_113"
+ {
+ "iType" "19"
+ "pos_x" "74.953384"
+ "pos_y" "-1608.965698"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_114"
+ {
+ "iType" "17"
+ "pos_x" "289.578796"
+ "pos_y" "-1599.203369"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_115"
+ {
+ "iType" "19"
+ "pos_x" "11.461742"
+ "pos_y" "-1995.069458"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_116"
+ {
+ "iType" "29"
+ "pos_x" "-940.992371"
+ "pos_y" "-736.380432"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "6"
+ "IsCubemap" "1"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\cubemap_uffizi"
+ "szFallbackTexturePath" "texture_samples\cubemap_uffizi"
+ "iFallbackMode" "4"
+ }
+ "Node_117"
+ {
+ "iType" "19"
+ "pos_x" "-754.686890"
+ "pos_y" "-742.683899"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "126"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_118"
+ {
+ "iType" "5"
+ "pos_x" "-488.589386"
+ "pos_y" "-832.720154"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_119"
+ {
+ "iType" "58"
+ "pos_x" "-1090.977783"
+ "pos_y" "-739.681824"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "122"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_120"
+ {
+ "iType" "19"
+ "pos_x" "-592.522644"
+ "pos_y" "-753.312927"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_121"
+ {
+ "iType" "7"
+ "pos_x" "-1348.588989"
+ "pos_y" "-605.653320"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_122"
+ {
+ "iType" "18"
+ "pos_x" "-1372.264893"
+ "pos_y" "-703.250244"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_123"
+ {
+ "iType" "21"
+ "szName" ">_>"
+ "pos_x" "-1250.754639"
+ "pos_y" "-812.523010"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_124"
+ {
+ "iType" "5"
+ "pos_x" "-1385.573608"
+ "pos_y" "-848.149536"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9"
+ }
+ "Node_125"
+ {
+ "iType" "19"
+ "pos_x" "-207.982040"
+ "pos_y" "-1995.794678"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "139"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_126"
+ {
+ "iType" "5"
+ "pos_x" "-838.264832"
+ "pos_y" "-847.795044"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.04"
+ }
+ "Node_127"
+ {
+ "iType" "26"
+ "pos_x" "-905.731750"
+ "pos_y" "-382.483826"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_128"
+ {
+ "iType" "60"
+ "pos_x" "-752.578552"
+ "pos_y" "-495.620361"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_129"
+ {
+ "iType" "2"
+ "pos_x" "279.593658"
+ "pos_y" "385.779694"
+ "size_x" "60.000000"
+ "size_y" "-127.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_08"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_09"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_10"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "7"
+ }
+ }
+ "numTexcoords" "8"
+ "numColor" "2"
+ "numTexcoord_Flag_0" "8"
+ "numTexcoord_Name_0" "UV0_UV1"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Lightmap3_UV2"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "2"
+ "numTexcoord_Name_7" "UV3"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "8"
+ "numColor_Name_1" "VColor"
+ }
+ "Node_130"
+ {
+ "iType" "25"
+ "pos_x" "-707.195374"
+ "pos_y" "-1040.824951"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_131"
+ {
+ "iType" "33"
+ "pos_x" "330.795410"
+ "pos_y" "-1184.193848"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_132"
+ {
+ "iType" "76"
+ "pos_x" "158.351791"
+ "pos_y" "-1028.830322"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "130"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_133"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-1108.683105"
+ "pos_y" "-1134.154785"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "159.032974"
+ "container_extents_y" "1481.676880"
+ "container_extents_z" "-159.032974"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_134"
+ {
+ "iType" "29"
+ "szName" "bump 1"
+ "pos_x" "-2211.359863"
+ "pos_y" "-1267.533203"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "bumpmap2"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\cavewall005a_normal"
+ "szFallbackTexturePath" "nature\cavewall005a_normal"
+ "iFallbackMode" "4"
+ }
+ "Node_135"
+ {
+ "iType" "29"
+ "szName" "bump detail 1"
+ "pos_x" "-2224.604980"
+ "pos_y" "-1390.370972"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "bump_detail_1"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\normal_2"
+ "szFallbackTexturePath" "texture_samples\normal_2"
+ "iFallbackMode" "4"
+ }
+ "Node_136"
+ {
+ "iType" "29"
+ "szName" "bump 0"
+ "pos_x" "-2243.601074"
+ "pos_y" "-930.626282"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\sandfloor009a_normal"
+ "szFallbackTexturePath" "nature\sandfloor009a_normal"
+ "iFallbackMode" "4"
+ }
+ "Node_137"
+ {
+ "iType" "29"
+ "szName" "bump detail 0"
+ "pos_x" "-2278.729980"
+ "pos_y" "-1072.367310"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "bump_detail_0"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\dirtfloor011a_normal"
+ "szFallbackTexturePath" "nature\dirtfloor011a_normal"
+ "iFallbackMode" "4"
+ }
+ "Node_138"
+ {
+ "iType" "29"
+ "pos_x" "-2630.740234"
+ "pos_y" "-1789.353271"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "blendnoise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_4"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_4"
+ "iFallbackMode" "4"
+ }
+ "Node_139"
+ {
+ "iType" "29"
+ "szName" "base 1"
+ "pos_x" "-895.053101"
+ "pos_y" "-1892.732788"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "basetexture2"
+ "iSRGB" "1"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\cavewall005a"
+ "szFallbackTexturePath" "nature\cavewall005a"
+ "iFallbackMode" "4"
+ }
+ "Node_140"
+ {
+ "iType" "29"
+ "szName" "base 0"
+ "pos_x" "-826.090576"
+ "pos_y" "-1518.820313"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "base_0"
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\sandfloor009a"
+ "szFallbackTexturePath" "nature\sandfloor009a"
+ "iFallbackMode" "4"
+ }
+ "Node_141"
+ {
+ "iType" "29"
+ "szName" "base detail 0"
+ "pos_x" "-852.661438"
+ "pos_y" "-1385.302612"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "base_detail_0"
+ "iSRGB" "1"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "detail\noise_detail_01"
+ "szFallbackTexturePath" "detail\noise_detail_01"
+ "iFallbackMode" "4"
+ }
+ "Node_142"
+ {
+ "iType" "34"
+ "pos_x" "-629.920105"
+ "pos_y" "-1495.852783"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "145"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "141"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_143"
+ {
+ "iType" "5"
+ "pos_x" "-652.070679"
+ "pos_y" "-1972.257568"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_144"
+ {
+ "iType" "29"
+ "szName" "base detail 1"
+ "pos_x" "-897.593201"
+ "pos_y" "-1748.421021"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "base_detail_1"
+ "iSRGB" "1"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "overlays\macro01a"
+ "szFallbackTexturePath" "overlays\macro01a"
+ "iFallbackMode" "4"
+ }
+ "Node_145"
+ {
+ "iType" "27"
+ "pos_x" "-520.208984"
+ "pos_y" "-1334.852417"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_146"
+ {
+ "iType" "79"
+ "pos_x" "-707.968872"
+ "pos_y" "-1324.332153"
+ "size_x" "143.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "base_detail_0_smoothing"
+ "i_vp_static_nc" "1"
+ "szConstantString" "-0.5 0.7"
+ }
+ "Node_147"
+ {
+ "iType" "27"
+ "pos_x" "-614.767517"
+ "pos_y" "-1411.649658"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_148"
+ {
+ "iType" "27"
+ "pos_x" "-641.937317"
+ "pos_y" "-1727.754883"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "149"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_149"
+ {
+ "iType" "79"
+ "pos_x" "-822.747437"
+ "pos_y" "-1646.760010"
+ "size_x" "143.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "base_detail_1_smoothing"
+ "i_vp_static_nc" "1"
+ "szConstantString" "0.1 0.3"
+ }
+ "Node_150"
+ {
+ "iType" "27"
+ "pos_x" "-588.923706"
+ "pos_y" "-1658.183350"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "149"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/lightmap_parallax.txt b/mp/game/momentum/shadereditorui/canvas/lightmap_parallax.txt
new file mode 100644
index 0000000000..b748f11576
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/lightmap_parallax.txt
@@ -0,0 +1,2815 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#002"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "75"
+ "pos_x" "-196.710205"
+ "pos_y" "-1098.514526"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "19"
+ "pos_x" "-56.518372"
+ "pos_y" "-1030.090332"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_002"
+ {
+ "iType" "70"
+ "pos_x" "753.508606"
+ "pos_y" "-1626.157104"
+ "size_x" "59.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_003"
+ {
+ "iType" "7"
+ "pos_x" "644.590515"
+ "pos_y" "-1630.190796"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_004"
+ {
+ "iType" "27"
+ "pos_x" "623.420959"
+ "pos_y" "-1827.510376"
+ "size_x" "124.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_005"
+ {
+ "iType" "72"
+ "pos_x" "935.423645"
+ "pos_y" "-1818.350220"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_006"
+ {
+ "iType" "27"
+ "pos_x" "750.618225"
+ "pos_y" "-1676.704712"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_007"
+ {
+ "iType" "27"
+ "pos_x" "744.975037"
+ "pos_y" "-1720.306030"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_008"
+ {
+ "iType" "27"
+ "pos_x" "744.712952"
+ "pos_y" "-1769.171509"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_009"
+ {
+ "iType" "19"
+ "pos_x" "445.182526"
+ "pos_y" "-1830.886597"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_010"
+ {
+ "iType" "17"
+ "pos_x" "-195.430313"
+ "pos_y" "154.320465"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "23"
+ "pos_x" "-1063.938477"
+ "pos_y" "-436.916229"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "23"
+ "pos_x" "-1068.266357"
+ "pos_y" "-540.778015"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "19"
+ "pos_x" "-594.653809"
+ "pos_y" "-490.616608"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_014"
+ {
+ "iType" "26"
+ "pos_x" "-754.523193"
+ "pos_y" "-383.833893"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "29"
+ "pos_x" "-415.631012"
+ "pos_y" "-373.722748"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_016"
+ {
+ "iType" "29"
+ "pos_x" "-414.728546"
+ "pos_y" "-476.595612"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "4"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_017"
+ {
+ "iType" "27"
+ "pos_x" "-566.974243"
+ "pos_y" "-343.340485"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "-394.948639"
+ "pos_y" "-590.862610"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_019"
+ {
+ "iType" "27"
+ "pos_x" "-388.216217"
+ "pos_y" "-635.082581"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_020"
+ {
+ "iType" "27"
+ "pos_x" "-390.140411"
+ "pos_y" "-683.180481"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_021"
+ {
+ "iType" "19"
+ "pos_x" "-161.960602"
+ "pos_y" "-387.228058"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_022"
+ {
+ "iType" "19"
+ "pos_x" "-159.075714"
+ "pos_y" "-498.778900"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_023"
+ {
+ "iType" "23"
+ "pos_x" "-1062.441406"
+ "pos_y" "-333.783966"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "60"
+ "pos_x" "-915.271729"
+ "pos_y" "-335.673615"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "60"
+ "pos_x" "-914.173828"
+ "pos_y" "-439.988922"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "26"
+ "pos_x" "-755.468018"
+ "pos_y" "-497.502289"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "60"
+ "pos_x" "-906.487305"
+ "pos_y" "-547.598328"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "23"
+ "pos_x" "-397.109283"
+ "pos_y" "-777.056580"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "5"
+ "pos_x" "-488.589386"
+ "pos_y" "-832.720154"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_030"
+ {
+ "iType" "19"
+ "pos_x" "-163.883820"
+ "pos_y" "-283.370331"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_031"
+ {
+ "iType" "17"
+ "pos_x" "-12.768341"
+ "pos_y" "-348.850494"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "17"
+ "pos_x" "-10.572052"
+ "pos_y" "-471.832733"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_033"
+ {
+ "iType" "80"
+ "pos_x" "-157.359894"
+ "pos_y" "-676.886658"
+ "size_x" "88.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "1"
+ }
+ "Node_034"
+ {
+ "iType" "20"
+ "pos_x" "-14.695099"
+ "pos_y" "-694.812683"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "27"
+ "pos_x" "-565.747803"
+ "pos_y" "-391.027374"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "zw"
+ }
+ "Node_036"
+ {
+ "iType" "19"
+ "pos_x" "180.579437"
+ "pos_y" "-564.280090"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_037"
+ {
+ "iType" "29"
+ "pos_x" "-419.033722"
+ "pos_y" "-266.936951"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_038"
+ {
+ "iType" "17"
+ "pos_x" "-178.732437"
+ "pos_y" "104.991516"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "33"
+ "pos_x" "452.038361"
+ "pos_y" "-1002.346069"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "130"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "32"
+ "pos_x" "121.640915"
+ "pos_y" "-78.065155"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_041"
+ {
+ "iType" "33"
+ "pos_x" "279.624786"
+ "pos_y" "-1132.339722"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "5"
+ "pos_x" "-1373.278076"
+ "pos_y" "-1435.535889"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "1"
+ }
+ "Node_043"
+ {
+ "iType" "5"
+ "pos_x" "-1376.890747"
+ "pos_y" "-1364.183838"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "2"
+ }
+ "Node_044"
+ {
+ "iType" "87"
+ "pos_x" "-1305.974487"
+ "pos_y" "-306.997589"
+ "size_x" "60.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_045"
+ {
+ "iType" "17"
+ "pos_x" "-200.096085"
+ "pos_y" "211.243134"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "27"
+ "pos_x" "-762.945190"
+ "pos_y" "-1153.852905"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_047"
+ {
+ "iType" "27"
+ "pos_x" "-777.594360"
+ "pos_y" "-1211.987183"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_048"
+ {
+ "iType" "20"
+ "pos_x" "-617.374634"
+ "pos_y" "-1162.267212"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "17"
+ "pos_x" "-306.051117"
+ "pos_y" "-1156.147827"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "15"
+ "pos_x" "-371.334473"
+ "pos_y" "557.775269"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_051"
+ {
+ "iType" "26"
+ "pos_x" "50.448524"
+ "pos_y" "210.450958"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_052"
+ {
+ "iType" "1"
+ "pos_x" "-381.067932"
+ "pos_y" "384.642883"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "3"
+ "numColor" "0"
+ "dTFlag_Texcoords" "2"
+ "dTFlag_Color" "8"
+ }
+ "Node_053"
+ {
+ "iType" "19"
+ "pos_x" "-200.112106"
+ "pos_y" "314.781982"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_054"
+ {
+ "iType" "25"
+ "pos_x" "-25.137175"
+ "pos_y" "372.060944"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_055"
+ {
+ "iType" "25"
+ "pos_x" "-30.844557"
+ "pos_y" "304.999237"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "2"
+ "pos_x" "279.593658"
+ "pos_y" "385.779694"
+ "size_x" "58.000000"
+ "size_y" "-94.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "4"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "7"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Name_4" "Lightmap3"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "1"
+ "numTexcoord_Name_7" "view vec"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "2"
+ "numColor_Name_1" "parallax uv"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-1284.492310"
+ "pos_y" "-1327.507202"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "25"
+ "pos_x" "-707.195374"
+ "pos_y" "-1040.824951"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-1476.140625"
+ "pos_y" "-543.904968"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "406.346802"
+ "container_extents_y" "1871.088501"
+ "container_extents_z" "-406.346802"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_060"
+ {
+ "iType" "18"
+ "pos_x" "-1283.588989"
+ "pos_y" "-1410.600586"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "19"
+ "pos_x" "-199.809982"
+ "pos_y" "430.784729"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_062"
+ {
+ "iType" "25"
+ "pos_x" "-40.596832"
+ "pos_y" "422.590576"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "19"
+ "pos_x" "-199.612503"
+ "pos_y" "497.620972"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_064"
+ {
+ "iType" "17"
+ "pos_x" "97.343826"
+ "pos_y" "595.173096"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_065"
+ {
+ "iType" "19"
+ "pos_x" "56.863014"
+ "pos_y" "508.450470"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_066"
+ {
+ "iType" "19"
+ "pos_x" "240.028519"
+ "pos_y" "627.172485"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_067"
+ {
+ "iType" "14"
+ "pos_x" "118.727341"
+ "pos_y" "707.575928"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_068"
+ {
+ "iType" "19"
+ "pos_x" "-199.013474"
+ "pos_y" "366.788788"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_069"
+ {
+ "iType" "19"
+ "pos_x" "-2512.718262"
+ "pos_y" "-1056.819580"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_070"
+ {
+ "iType" "18"
+ "pos_x" "-2677.724609"
+ "pos_y" "-1097.021729"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "7"
+ "pos_x" "-2791.159180"
+ "pos_y" "-1273.835205"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_072"
+ {
+ "iType" "73"
+ "pos_x" "-2650.385742"
+ "pos_y" "-914.091858"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_073"
+ {
+ "iType" "27"
+ "pos_x" "-2492.824707"
+ "pos_y" "-1592.227295"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_074"
+ {
+ "iType" "19"
+ "pos_x" "-2310.402344"
+ "pos_y" "-1597.063232"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "6"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_075"
+ {
+ "iType" "19"
+ "pos_x" "-2316.643066"
+ "pos_y" "-1460.595093"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_076"
+ {
+ "iType" "27"
+ "pos_x" "-2494.773438"
+ "pos_y" "-1467.157104"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_077"
+ {
+ "iType" "27"
+ "pos_x" "-1367.511475"
+ "pos_y" "-1852.267090"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_078"
+ {
+ "iType" "4"
+ "pos_x" "1162.152466"
+ "pos_y" "-1984.264282"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "1"
+ }
+ "Node_079"
+ {
+ "iType" "60"
+ "pos_x" "998.196960"
+ "pos_y" "-1996.091309"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_080"
+ {
+ "iType" "19"
+ "pos_x" "-951.207275"
+ "pos_y" "-1046.062744"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_081"
+ {
+ "iType" "17"
+ "pos_x" "-2154.526367"
+ "pos_y" "-1511.363892"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "17"
+ "pos_x" "-2163.355469"
+ "pos_y" "-1667.053955"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_083"
+ {
+ "iType" "90"
+ "pos_x" "-1702.652710"
+ "pos_y" "-1691.203491"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "i_c_matrix" "2"
+ }
+ "Node_084"
+ {
+ "iType" "29"
+ "pos_x" "-383.250671"
+ "pos_y" "-1906.867676"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "albedo"
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\grass_color"
+ "szFallbackTexturePath" "Dev\bump"
+ "iFallbackMode" "2"
+ }
+ "Node_085"
+ {
+ "iType" "19"
+ "pos_x" "-2311.552246"
+ "pos_y" "-1727.441650"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_086"
+ {
+ "iType" "27"
+ "pos_x" "-2613.898926"
+ "pos_y" "-1735.171997"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_087"
+ {
+ "iType" "19"
+ "pos_x" "-2456.119141"
+ "pos_y" "-1745.289795"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_088"
+ {
+ "iType" "61"
+ "pos_x" "-358.207275"
+ "pos_y" "-2057.225098"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_089"
+ {
+ "iType" "19"
+ "pos_x" "-165.058868"
+ "pos_y" "-2058.266113"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_090"
+ {
+ "iType" "27"
+ "pos_x" "-1363.537354"
+ "pos_y" "-1738.334473"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_091"
+ {
+ "iType" "20"
+ "pos_x" "-1190.612915"
+ "pos_y" "-1787.352051"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_092"
+ {
+ "iType" "19"
+ "szName" "Proj pos"
+ "pos_x" "-1535.178101"
+ "pos_y" "-1643.949585"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_093"
+ {
+ "iType" "79"
+ "pos_x" "-87.515335"
+ "pos_y" "555.068115"
+ "size_x" "74.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "parallax_geo_height"
+ "i_vp_static_nc" "0"
+ "szConstantString" "20"
+ }
+ "Node_094"
+ {
+ "iType" "79"
+ "pos_x" "-2909.488770"
+ "pos_y" "-1538.401367"
+ "size_x" "124.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "parallax_geo_height"
+ "i_vp_static_nc" "0"
+ "szConstantString" "20"
+ }
+ "Node_095"
+ {
+ "iType" "5"
+ "pos_x" "-440.065643"
+ "pos_y" "-1060.233765"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_096"
+ {
+ "iType" "19"
+ "pos_x" "1.480953"
+ "pos_y" "-1982.012207"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_097"
+ {
+ "iType" "76"
+ "pos_x" "-71.402504"
+ "pos_y" "-1159.996460"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_098"
+ {
+ "iType" "18"
+ "pos_x" "-696.153564"
+ "pos_y" "-1541.703247"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_099"
+ {
+ "iType" "19"
+ "pos_x" "-468.979584"
+ "pos_y" "-1162.267212"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_100"
+ {
+ "iType" "19"
+ "pos_x" "-536.150208"
+ "pos_y" "-1539.743286"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_101"
+ {
+ "iType" "71"
+ "pos_x" "927.323792"
+ "pos_y" "-1705.073853"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_102"
+ {
+ "iType" "25"
+ "pos_x" "-381.552979"
+ "pos_y" "-1545.974731"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_103"
+ {
+ "iType" "97"
+ "pos_x" "-798.133545"
+ "pos_y" "-1621.602661"
+ "size_x" "68.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_104"
+ {
+ "iType" "5"
+ "pos_x" "-411.761017"
+ "pos_y" "-1651.956421"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_105"
+ {
+ "iType" "3"
+ "pos_x" "-2113.470703"
+ "pos_y" "-510.755493"
+ "size_x" "58.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "numTexcoords" "7"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Name_4" "Lightmap3"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "1"
+ "numTexcoord_Name_7" "view vec"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "2"
+ "numColor_Name_1" "parallax uv"
+ }
+ "Node_106"
+ {
+ "iType" "18"
+ "szName" "worldpos"
+ "pos_x" "-1980.675903"
+ "pos_y" "-1636.844849"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_107"
+ {
+ "iType" "5"
+ "pos_x" "-2034.864746"
+ "pos_y" "-671.338745"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0"
+ }
+ "Node_108"
+ {
+ "iType" "32"
+ "pos_x" "-1951.772461"
+ "pos_y" "-671.430359"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_109"
+ {
+ "iType" "5"
+ "pos_x" "-2036.767334"
+ "pos_y" "-746.184998"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_110"
+ {
+ "iType" "32"
+ "pos_x" "-1947.676147"
+ "pos_y" "-746.184998"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_111"
+ {
+ "iType" "33"
+ "pos_x" "-1733.652710"
+ "pos_y" "-1156.823486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_112"
+ {
+ "iType" "33"
+ "pos_x" "-1733.652710"
+ "pos_y" "-1232.602173"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_113"
+ {
+ "iType" "18"
+ "szName" "view vec"
+ "pos_x" "-2584.543213"
+ "pos_y" "-1283.304443"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_114"
+ {
+ "iType" "33"
+ "pos_x" "-1738.851685"
+ "pos_y" "-1004.842529"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_115"
+ {
+ "iType" "33"
+ "pos_x" "-1738.851685"
+ "pos_y" "-929.063904"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_116"
+ {
+ "iType" "33"
+ "szName" "UV"
+ "pos_x" "-1577.166504"
+ "pos_y" "-1015.541138"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_117"
+ {
+ "iType" "33"
+ "szName" "Tan offset"
+ "pos_x" "-1579.332031"
+ "pos_y" "-1138.959229"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_118"
+ {
+ "iType" "29"
+ "pos_x" "-1419.363281"
+ "pos_y" "-1172.393799"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "bm"
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\grass_normal"
+ "szFallbackTexturePath" "dev\flat_normal"
+ "iFallbackMode" "3"
+ }
+ "Node_119"
+ {
+ "iType" "19"
+ "pos_x" "-1868.161499"
+ "pos_y" "-1225.338989"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "133"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_120"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-1108.683105"
+ "pos_y" "-1388.545898"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "413.423889"
+ "container_extents_y" "1469.025513"
+ "container_extents_z" "-413.423889"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_121"
+ {
+ "iType" "19"
+ "pos_x" "70.658966"
+ "pos_y" "-1533.324707"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_122"
+ {
+ "iType" "92"
+ "pos_x" "-895.288208"
+ "pos_y" "-1581.739258"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "126"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ }
+ "container_extents_x" "143.460693"
+ "container_extents_y" "1053.137939"
+ "container_extents_z" "-143.460693"
+ "i_combo_condition" "1"
+ }
+ "Node_123"
+ {
+ "iType" "32"
+ "pos_x" "137.100784"
+ "pos_y" "-1208.368652"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_124"
+ {
+ "iType" "5"
+ "pos_x" "-941.400452"
+ "pos_y" "-1651.138184"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_125"
+ {
+ "iType" "5"
+ "pos_x" "-937.632019"
+ "pos_y" "-1364.398804"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_126"
+ {
+ "iType" "23"
+ "pos_x" "-858.575806"
+ "pos_y" "-1337.272095"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_127"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-2235.203125"
+ "pos_y" "-977.922729"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "101.288597"
+ "container_extents_y" "566.823730"
+ "container_extents_z" "-101.288597"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_128"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-2227.527344"
+ "pos_y" "-1211.360718"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "101.288597"
+ "container_extents_y" "543.557251"
+ "container_extents_z" "-101.288597"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_129"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-1024.437256"
+ "pos_y" "-1525.820313"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "248.715515"
+ "container_extents_y" "1236.277344"
+ "container_extents_z" "-248.715515"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHTSHADOWS"
+ }
+ "Node_130"
+ {
+ "iType" "33"
+ "pos_x" "305.748413"
+ "pos_y" "-738.557129"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_131"
+ {
+ "iType" "5"
+ "pos_x" "27.518646"
+ "pos_y" "-76.322235"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_132"
+ {
+ "iType" "94"
+ "szName" "heightmap"
+ "pos_x" "-2298.809570"
+ "pos_y" "-1363.049683"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szParamname" "heightmap"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "texture_samples\grass_height"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_133"
+ {
+ "iType" "5"
+ "pos_x" "-1938.670654"
+ "pos_y" "-1132.127930"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9"
+ }
+ "Node_134"
+ {
+ "iType" "96"
+ "pos_x" "-182.564484"
+ "pos_y" "-1529.073975"
+ "size_x" "154.000000"
+ "size_y" "-83.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "3"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_135"
+ {
+ "iType" "95"
+ "szName" "faster"
+ "pos_x" "-2126.414063"
+ "pos_y" "-1178.743774"
+ "size_x" "176.000000"
+ "size_y" "-83.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "3"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "2"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_samples_min" "8"
+ "i_samples_max" "15"
+ "i_samples_binary" "5"
+ "i_dtest" "1"
+ "i_gradient" "0"
+ "i_prlx_mode" "1"
+ }
+ "Node_136"
+ {
+ "iType" "95"
+ "pos_x" "-2099.908691"
+ "pos_y" "-946.600525"
+ "size_x" "176.000000"
+ "size_y" "-83.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "3"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "2"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_samples_min" "10"
+ "i_samples_max" "30"
+ "i_samples_binary" "5"
+ "i_dtest" "1"
+ "i_gradient" "1"
+ "i_prlx_mode" "1"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/model_chromatic_aberration.txt b/mp/game/momentum/shadereditorui/canvas/model_chromatic_aberration.txt
new file mode 100644
index 0000000000..557b77f9d6
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/model_chromatic_aberration.txt
@@ -0,0 +1,1877 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "1"
+ "depth_test" "1"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "14"
+ "pos_x" "-647.764465"
+ "pos_y" "285.069031"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "20"
+ "pos_x" "-1388.291016"
+ "pos_y" "-799.043396"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_002"
+ {
+ "iType" "19"
+ "pos_x" "-1268.348755"
+ "pos_y" "-802.109558"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_003"
+ {
+ "iType" "7"
+ "pos_x" "-935.472961"
+ "pos_y" "51.506767"
+ "size_x" "54.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_004"
+ {
+ "iType" "18"
+ "pos_x" "-796.831604"
+ "pos_y" "101.513138"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "29"
+ "pos_x" "-140.076401"
+ "pos_y" "-9.756973"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "6"
+ "IsCubemap" "1"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\cubemap_uffizi"
+ "iFallbackMode" "0"
+ }
+ "Node_006"
+ {
+ "iType" "34"
+ "pos_x" "-251.899414"
+ "pos_y" "-598.792358"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "37"
+ "pos_x" "-84.290161"
+ "pos_y" "-528.804810"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "19"
+ "pos_x" "85.949188"
+ "pos_y" "-9.428284"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_009"
+ {
+ "iType" "80"
+ "pos_x" "-13.737656"
+ "pos_y" "-137.386475"
+ "size_x" "83.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "2"
+ }
+ "Node_010"
+ {
+ "iType" "19"
+ "pos_x" "-579.370422"
+ "pos_y" "219.337234"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_011"
+ {
+ "iType" "19"
+ "pos_x" "96.923294"
+ "pos_y" "-525.365540"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_012"
+ {
+ "iType" "19"
+ "pos_x" "-351.240875"
+ "pos_y" "-1116.107056"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_013"
+ {
+ "iType" "18"
+ "pos_x" "-194.613312"
+ "pos_y" "-989.564514"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "18"
+ "pos_x" "-180.601181"
+ "pos_y" "-1122.800049"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "18"
+ "pos_x" "-178.645813"
+ "pos_y" "-1236.340698"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "29"
+ "pos_x" "4.239304"
+ "pos_y" "-1108.083618"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_017"
+ {
+ "iType" "29"
+ "pos_x" "12.409531"
+ "pos_y" "-1228.316895"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_018"
+ {
+ "iType" "29"
+ "pos_x" "13.134766"
+ "pos_y" "-985.817139"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_019"
+ {
+ "iType" "25"
+ "pos_x" "-1107.622314"
+ "pos_y" "-362.602478"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "27"
+ "pos_x" "-256.129883"
+ "pos_y" "-839.570068"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_021"
+ {
+ "iType" "34"
+ "pos_x" "7.491058"
+ "pos_y" "-840.701172"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "5"
+ "pos_x" "-8.170990"
+ "pos_y" "-756.032532"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_023"
+ {
+ "iType" "5"
+ "pos_x" "77.153168"
+ "pos_y" "-764.872192"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2.5"
+ }
+ "Node_024"
+ {
+ "iType" "5"
+ "pos_x" "425.127014"
+ "pos_y" "-540.026672"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_025"
+ {
+ "iType" "4"
+ "pos_x" "922.219788"
+ "pos_y" "-633.796204"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_026"
+ {
+ "iType" "19"
+ "pos_x" "-581.837646"
+ "pos_y" "-1110.458984"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_027"
+ {
+ "iType" "34"
+ "pos_x" "-253.313782"
+ "pos_y" "-489.523865"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "5"
+ "pos_x" "-401.233887"
+ "pos_y" "-573.992249"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.5"
+ }
+ "Node_029"
+ {
+ "iType" "5"
+ "pos_x" "-1003.952454"
+ "pos_y" "-628.234924"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.05"
+ }
+ "Node_030"
+ {
+ "iType" "5"
+ "pos_x" "-1007.125549"
+ "pos_y" "-712.955994"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.1"
+ }
+ "Node_031"
+ {
+ "iType" "58"
+ "pos_x" "-359.691315"
+ "pos_y" "-41.721138"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "5"
+ "pos_x" "-1362.502563"
+ "pos_y" "-702.817200"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 -0.5"
+ }
+ "Node_033"
+ {
+ "iType" "5"
+ "pos_x" "-1236.417603"
+ "pos_y" "-719.204773"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_034"
+ {
+ "iType" "27"
+ "pos_x" "-1554.661255"
+ "pos_y" "-723.390137"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_035"
+ {
+ "iType" "27"
+ "pos_x" "-1554.070679"
+ "pos_y" "-856.757690"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_036"
+ {
+ "iType" "17"
+ "pos_x" "-1145.594360"
+ "pos_y" "-795.171448"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_037"
+ {
+ "iType" "68"
+ "pos_x" "-837.549377"
+ "pos_y" "228.737885"
+ "size_x" "116.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_038"
+ {
+ "iType" "25"
+ "pos_x" "-610.794006"
+ "pos_y" "109.864792"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "25"
+ "pos_x" "-609.364990"
+ "pos_y" "67.764343"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "25"
+ "pos_x" "-609.522949"
+ "pos_y" "153.130676"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_041"
+ {
+ "iType" "19"
+ "pos_x" "-1166.606567"
+ "pos_y" "-56.777264"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_042"
+ {
+ "iType" "73"
+ "pos_x" "-1331.898560"
+ "pos_y" "-249.729523"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "5"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_043"
+ {
+ "iType" "29"
+ "pos_x" "-1521.829590"
+ "pos_y" "-36.577095"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "dev\flat_normal"
+ "szFallbackTexturePath" "dev\flat_normal"
+ "iFallbackMode" "3"
+ }
+ "Node_044"
+ {
+ "iType" "5"
+ "pos_x" "-1469.456909"
+ "pos_y" "-154.580475"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.5 1"
+ }
+ "Node_045"
+ {
+ "iType" "21"
+ "pos_x" "-1360.501099"
+ "pos_y" "-109.382309"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "5"
+ "pos_x" "-1563.923096"
+ "pos_y" "-191.747452"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_047"
+ {
+ "iType" "34"
+ "pos_x" "-861.502319"
+ "pos_y" "-660.642456"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_048"
+ {
+ "iType" "19"
+ "pos_x" "-580.458130"
+ "pos_y" "-635.156311"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_049"
+ {
+ "iType" "17"
+ "pos_x" "-530.163513"
+ "pos_y" "-763.278687"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "5"
+ "pos_x" "-682.298401"
+ "pos_y" "-779.141785"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.005"
+ }
+ "Node_051"
+ {
+ "iType" "5"
+ "pos_x" "-677.900330"
+ "pos_y" "-854.373291"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_052"
+ {
+ "iType" "5"
+ "pos_x" "-677.188904"
+ "pos_y" "-921.752563"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.015"
+ }
+ "Node_053"
+ {
+ "iType" "17"
+ "pos_x" "-540.605652"
+ "pos_y" "-881.624634"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_054"
+ {
+ "iType" "19"
+ "pos_x" "-351.621307"
+ "pos_y" "-999.042480"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_055"
+ {
+ "iType" "17"
+ "pos_x" "-530.300049"
+ "pos_y" "-815.210266"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "19"
+ "pos_x" "-353.669952"
+ "pos_y" "-1221.458130"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_057"
+ {
+ "iType" "5"
+ "pos_x" "-692.294067"
+ "pos_y" "-674.035156"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_058"
+ {
+ "iType" "61"
+ "pos_x" "-716.565125"
+ "pos_y" "-502.484192"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "53"
+ "pos_x" "-821.769714"
+ "pos_y" "-542.470581"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "19"
+ "pos_x" "-1186.895264"
+ "pos_y" "-229.618896"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_061"
+ {
+ "iType" "25"
+ "pos_x" "-1028.359863"
+ "pos_y" "-224.751968"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_062"
+ {
+ "iType" "18"
+ "pos_x" "-1168.517944"
+ "pos_y" "-126.203758"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "5"
+ "pos_x" "-1331.355469"
+ "pos_y" "2.757445"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_064"
+ {
+ "iType" "5"
+ "pos_x" "-1329.737915"
+ "pos_y" "93.868431"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_065"
+ {
+ "iType" "23"
+ "pos_x" "-816.429016"
+ "pos_y" "-364.397369"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "19"
+ "pos_x" "-726.012573"
+ "pos_y" "-1010.647583"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_067"
+ {
+ "iType" "5"
+ "pos_x" "-704.274780"
+ "pos_y" "-1226.731201"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 -1"
+ }
+ "Node_068"
+ {
+ "iType" "27"
+ "pos_x" "-921.018250"
+ "pos_y" "-1016.406128"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_069"
+ {
+ "iType" "5"
+ "pos_x" "-396.912292"
+ "pos_y" "-492.412292"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_070"
+ {
+ "iType" "5"
+ "pos_x" "-399.686707"
+ "pos_y" "-658.182861"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "-32.795933"
+ "pos_y" "-395.923889"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_072"
+ {
+ "iType" "26"
+ "pos_x" "243.368134"
+ "pos_y" "-1025.155518"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_073"
+ {
+ "iType" "26"
+ "pos_x" "330.836212"
+ "pos_y" "-1142.115601"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "4"
+ }
+ }
+ }
+ "Node_074"
+ {
+ "iType" "19"
+ "pos_x" "300.771576"
+ "pos_y" "-856.256287"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_075"
+ {
+ "iType" "34"
+ "pos_x" "-379.667908"
+ "pos_y" "-285.590210"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_076"
+ {
+ "iType" "21"
+ "pos_x" "-76.830170"
+ "pos_y" "-282.314117"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "5"
+ "pos_x" "-482.454865"
+ "pos_y" "-338.634247"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_078"
+ {
+ "iType" "5"
+ "pos_x" "-491.592682"
+ "pos_y" "-250.302246"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_079"
+ {
+ "iType" "5"
+ "pos_x" "-80.656036"
+ "pos_y" "-199.326721"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_080"
+ {
+ "iType" "19"
+ "pos_x" "512.720825"
+ "pos_y" "-624.486511"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_081"
+ {
+ "iType" "21"
+ "pos_x" "508.255188"
+ "pos_y" "-771.252136"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "21"
+ "pos_x" "627.052856"
+ "pos_y" "-449.030701"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_083"
+ {
+ "iType" "26"
+ "pos_x" "731.230835"
+ "pos_y" "-621.902832"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_084"
+ {
+ "iType" "5"
+ "pos_x" "477.657623"
+ "pos_y" "-409.862579"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_085"
+ {
+ "iType" "49"
+ "pos_x" "-222.728058"
+ "pos_y" "-293.505585"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_086"
+ {
+ "iType" "5"
+ "pos_x" "-294.972382"
+ "pos_y" "-393.787567"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_087"
+ {
+ "iType" "49"
+ "pos_x" "251.504730"
+ "pos_y" "-190.611115"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_088"
+ {
+ "iType" "19"
+ "pos_x" "434.697479"
+ "pos_y" "-208.576843"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_089"
+ {
+ "iType" "5"
+ "pos_x" "179.260391"
+ "pos_y" "-290.893158"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "20"
+ }
+ "Node_090"
+ {
+ "iType" "5"
+ "pos_x" "332.328156"
+ "pos_y" "-293.599121"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_091"
+ {
+ "iType" "5"
+ "pos_x" "-183.079437"
+ "pos_y" "-214.177261"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.83 0.8674 1"
+ }
+ "Node_092"
+ {
+ "iType" "19"
+ "pos_x" "-1094.484985"
+ "pos_y" "-1055.342041"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "1"
+ }
+ "Node_093"
+ {
+ "iType" "90"
+ "pos_x" "-1257.147461"
+ "pos_y" "-1126.587158"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "i_c_matrix" "2"
+ }
+ "Node_094"
+ {
+ "iType" "3"
+ "pos_x" "-1488.052856"
+ "pos_y" "-360.776703"
+ "size_x" "55.000000"
+ "size_y" "-72.000000"
+ "iPreview" "0"
+ "numTexcoords" "6"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "uv"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "normal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "eye2world"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "projpos"
+ "numTexcoord_Flag_4" "4"
+ "numTexcoord_Name_4" "tan s"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan t"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "4"
+ "numColor_Name_0" "tan s"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "tan t"
+ }
+ "Node_095"
+ {
+ "iType" "1"
+ "pos_x" "-1070.338989"
+ "pos_y" "147.499344"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "1"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_096"
+ {
+ "iType" "101"
+ "pos_x" "-1017.886597"
+ "pos_y" "246.208832"
+ "size_x" "95.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "4"
+ }
+ }
+ "iCompMode" "1"
+ }
+ "Node_097"
+ {
+ "iType" "2"
+ "pos_x" "-328.332397"
+ "pos_y" "181.464386"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "6"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "uv"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "normal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "eye2world"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "projpos"
+ "numTexcoord_Flag_4" "4"
+ "numTexcoord_Name_4" "tan s"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan t"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "4"
+ "numColor_Name_0" "tan s"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "tan t"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/model_cubemap.txt b/mp/game/momentum/shadereditorui/canvas/model_cubemap.txt
new file mode 100644
index 0000000000..2d4953852b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/model_cubemap.txt
@@ -0,0 +1,338 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "68"
+ "pos_x" "-112.120033"
+ "pos_y" "239.317734"
+ "size_x" "106.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "1"
+ }
+ "Node_001"
+ {
+ "iType" "14"
+ "pos_x" "-47.893364"
+ "pos_y" "321.064423"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_002"
+ {
+ "iType" "19"
+ "pos_x" "74.873322"
+ "pos_y" "255.213364"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_003"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "2"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "4"
+ "numTexcoord_Name_0" "eyeworld"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "n"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_004"
+ {
+ "iType" "7"
+ "pos_x" "-107.554504"
+ "pos_y" "117.208954"
+ "size_x" "54.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_005"
+ {
+ "iType" "25"
+ "pos_x" "139.651077"
+ "pos_y" "138.786652"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "18"
+ "pos_x" "20.277752"
+ "pos_y" "133.524475"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "4"
+ "pos_x" "357.088928"
+ "pos_y" "-106.977783"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_008"
+ {
+ "iType" "3"
+ "pos_x" "-390.382233"
+ "pos_y" "-97.111115"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "numTexcoords" "2"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "4"
+ "numTexcoord_Name_0" "eyeworld"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "n"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_009"
+ {
+ "iType" "58"
+ "pos_x" "-244.940002"
+ "pos_y" "-86.831085"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "pos_x" "-30.262245"
+ "pos_y" "4.071152"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_011"
+ {
+ "iType" "72"
+ "pos_x" "112.599976"
+ "pos_y" "-86.173302"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_012"
+ {
+ "iType" "1"
+ "pos_x" "-366.702240"
+ "pos_y" "190.657776"
+ "size_x" "55.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_013"
+ {
+ "iType" "101"
+ "pos_x" "-246.806671"
+ "pos_y" "154.646667"
+ "size_x" "95.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "3"
+ }
+ }
+ "iCompMode" "0"
+ }
+ "Node_014"
+ {
+ "iType" "29"
+ "pos_x" "-74.162224"
+ "pos_y" "-91.392258"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "6"
+ "IsCubemap" "1"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\cubemap_uffizi"
+ "szFallbackTexturePath" "white"
+ "iFallbackMode" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/model_litsphere.txt b/mp/game/momentum/shadereditorui/canvas/model_litsphere.txt
new file mode 100644
index 0000000000..e6716a5290
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/model_litsphere.txt
@@ -0,0 +1,1024 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "68"
+ "pos_x" "-358.589020"
+ "pos_y" "440.458923"
+ "size_x" "106.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "1"
+ }
+ "Node_001"
+ {
+ "iType" "14"
+ "pos_x" "-250.440155"
+ "pos_y" "516.961548"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_002"
+ {
+ "iType" "32"
+ "pos_x" "180.499054"
+ "pos_y" "525.032959"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "33"
+ "pos_x" "211.875641"
+ "pos_y" "332.860168"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "75"
+ "pos_x" "78.550774"
+ "pos_y" "323.654175"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "103.037239"
+ "pos_y" "255.469284"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "5"
+ "szName" "FL_proj_pos"
+ "pos_x" "73.762772"
+ "pos_y" "526.378784"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_007"
+ {
+ "iType" "20"
+ "pos_x" "111.173798"
+ "pos_y" "-65.359604"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "33"
+ "pos_x" "367.563507"
+ "pos_y" "-90.323036"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "5"
+ "szName" "Diffuse"
+ "pos_x" "-254.613297"
+ "pos_y" "172.946304"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_010"
+ {
+ "iType" "33"
+ "szName" "Diffuse_component"
+ "pos_x" "-163.760132"
+ "pos_y" "-256.532654"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "70"
+ "pos_x" "403.806580"
+ "pos_y" "-442.488403"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_012"
+ {
+ "iType" "72"
+ "pos_x" "452.659241"
+ "pos_y" "-685.794800"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_013"
+ {
+ "iType" "76"
+ "pos_x" "227.819275"
+ "pos_y" "42.628021"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "4"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_014"
+ {
+ "iType" "32"
+ "pos_x" "-164.085693"
+ "pos_y" "173.221390"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "27"
+ "pos_x" "-30.370899"
+ "pos_y" "43.983246"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_016"
+ {
+ "iType" "27"
+ "pos_x" "-29.578266"
+ "pos_y" "-63.381824"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_017"
+ {
+ "iType" "71"
+ "pos_x" "427.059143"
+ "pos_y" "-532.128906"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "0.830316"
+ "pos_y" "281.186646"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "92.836716"
+ "container_extents_y" "242.092712"
+ "container_extents_z" "-92.836716"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_019"
+ {
+ "iType" "4"
+ "pos_x" "670.140625"
+ "pos_y" "-674.985779"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_020"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-581.447205"
+ "pos_y" "-37.021721"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "136.993286"
+ "container_extents_y" "362.855988"
+ "container_extents_z" "-136.993286"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_021"
+ {
+ "iType" "33"
+ "pos_x" "-276.003357"
+ "pos_y" "23.152893"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "66"
+ "pos_x" "-142.517090"
+ "pos_y" "352.053162"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vlight_static" "0"
+ "i_vlight_hl" "0"
+ }
+ "Node_023"
+ {
+ "iType" "67"
+ "pos_x" "-467.593597"
+ "pos_y" "1.790497"
+ "size_x" "156.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "6"
+ }
+ }
+ "i_plight_static" "0"
+ "i_plight_ao" "0"
+ "i_plight_hl" "0"
+ }
+ "Node_024"
+ {
+ "iType" "29"
+ "szName" "Albedo"
+ "pos_x" "-525.442932"
+ "pos_y" "-572.312988"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Models\Combine_soldier\combinesoldiersheet_prisonguard"
+ "iFallbackMode" "0"
+ }
+ "Node_025"
+ {
+ "iType" "27"
+ "pos_x" "240.059113"
+ "pos_y" "-510.583191"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_026"
+ {
+ "iType" "7"
+ "pos_x" "98.827866"
+ "pos_y" "-435.766724"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_027"
+ {
+ "iType" "27"
+ "pos_x" "239.658447"
+ "pos_y" "-557.094055"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_028"
+ {
+ "iType" "27"
+ "pos_x" "238.527435"
+ "pos_y" "-467.388367"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_029"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-143.523071"
+ "pos_y" "-37.679588"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "138.463028"
+ "container_extents_y" "602.023865"
+ "container_extents_z" "-138.463028"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_030"
+ {
+ "iType" "19"
+ "pos_x" "-103.441597"
+ "pos_y" "477.592010"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_031"
+ {
+ "iType" "19"
+ "pos_x" "-101.664513"
+ "pos_y" "527.423462"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_032"
+ {
+ "iType" "2"
+ "pos_x" "392.240631"
+ "pos_y" "424.522766"
+ "size_x" "55.000000"
+ "size_y" "-94.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "4"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "6"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WPos"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WNormal"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "Proj pos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "FL proj pos"
+ "numTexcoord_Flag_5" "8"
+ "numTexcoord_Name_5" "Proj normal"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "VAttn"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "VLight"
+ }
+ "Node_033"
+ {
+ "iType" "17"
+ "pos_x" "-501.628326"
+ "pos_y" "-1013.498718"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_034"
+ {
+ "iType" "90"
+ "pos_x" "-1058.235107"
+ "pos_y" "-791.251282"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "i_c_matrix" "0"
+ }
+ "Node_035"
+ {
+ "iType" "3"
+ "pos_x" "-861.401611"
+ "pos_y" "-343.558258"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "numTexcoords" "6"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WPos"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WNormal"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "Proj pos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "FL proj pos"
+ "numTexcoord_Flag_5" "8"
+ "numTexcoord_Name_5" "Proj normal"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "VAttn"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "VLight"
+ }
+ "Node_036"
+ {
+ "iType" "19"
+ "pos_x" "-896.610962"
+ "pos_y" "-741.489136"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "1"
+ }
+ "Node_037"
+ {
+ "iType" "27"
+ "pos_x" "-747.837769"
+ "pos_y" "-740.086792"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_038"
+ {
+ "iType" "19"
+ "pos_x" "-500.976593"
+ "pos_y" "-862.359985"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_039"
+ {
+ "iType" "19"
+ "pos_x" "-517.505432"
+ "pos_y" "-753.256958"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "-691.714172"
+ "pos_y" "-969.373230"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_041"
+ {
+ "iType" "5"
+ "pos_x" "-689.851501"
+ "pos_y" "-861.392944"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 -1"
+ }
+ "Node_042"
+ {
+ "iType" "29"
+ "szName" "view space lightmap"
+ "pos_x" "-317.680603"
+ "pos_y" "-949.684326"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "litsphere"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\matball_02"
+ "szFallbackTexturePath" "texture_samples\matball_02"
+ "iFallbackMode" "4"
+ }
+ "Node_043"
+ {
+ "iType" "26"
+ "pos_x" "60.556091"
+ "pos_y" "-670.144714"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_044"
+ {
+ "iType" "19"
+ "pos_x" "-132.765060"
+ "pos_y" "-581.510315"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_045"
+ {
+ "iType" "17"
+ "pos_x" "-313.510101"
+ "pos_y" "-500.159729"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "1"
+ "pos_x" "-520.492310"
+ "pos_y" "383.104004"
+ "size_x" "55.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_047"
+ {
+ "iType" "101"
+ "pos_x" "-402.342346"
+ "pos_y" "303.141663"
+ "size_x" "95.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "3"
+ }
+ }
+ "iCompMode" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/model_snowy.txt b/mp/game/momentum/shadereditorui/canvas/model_snowy.txt
new file mode 100644
index 0000000000..27c4d741b4
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/model_snowy.txt
@@ -0,0 +1,3652 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "25"
+ "pos_x" "-299.034607"
+ "pos_y" "595.806274"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_001"
+ {
+ "iType" "25"
+ "pos_x" "-299.034607"
+ "pos_y" "559.898193"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_002"
+ {
+ "iType" "31"
+ "szName" "ON"
+ "pos_x" "331.559204"
+ "pos_y" "-16.809479"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "182.742737"
+ "container_extents_y" "823.093750"
+ "container_extents_z" "-182.742737"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_003"
+ {
+ "iType" "53"
+ "pos_x" "-910.638489"
+ "pos_y" "304.940155"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "23"
+ "pos_x" "-1037.434326"
+ "pos_y" "291.404266"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "-1431.031494"
+ "pos_y" "-34.527313"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "14"
+ "pos_x" "-220.561584"
+ "pos_y" "820.312744"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_007"
+ {
+ "iType" "27"
+ "pos_x" "-682.632568"
+ "pos_y" "-344.424011"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_008"
+ {
+ "iType" "18"
+ "pos_x" "-161.562836"
+ "pos_y" "610.327026"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "32"
+ "pos_x" "82.485123"
+ "pos_y" "584.654907"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "31"
+ "pos_x" "-62.823177"
+ "pos_y" "473.883698"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "62.811218"
+ "container_extents_y" "232.919769"
+ "container_extents_z" "-62.811218"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_011"
+ {
+ "iType" "75"
+ "pos_x" "14.602026"
+ "pos_y" "445.455353"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_012"
+ {
+ "iType" "33"
+ "pos_x" "137.882080"
+ "pos_y" "491.238495"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "18"
+ "pos_x" "-1402.897461"
+ "pos_y" "117.985107"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-1479.457153"
+ "pos_y" "274.916229"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "szName" "diffuse"
+ "pos_x" "387.497437"
+ "pos_y" "275.393494"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_016"
+ {
+ "iType" "5"
+ "szName" "Specular"
+ "pos_x" "31.314459"
+ "pos_y" "267.249542"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_017"
+ {
+ "iType" "32"
+ "pos_x" "485.332031"
+ "pos_y" "272.623810"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "33"
+ "pos_x" "1026.863770"
+ "pos_y" "91.808105"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "168"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "33"
+ "pos_x" "973.598694"
+ "pos_y" "-27.113068"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "168"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "7"
+ "pos_x" "-181.255676"
+ "pos_y" "543.788696"
+ "size_x" "54.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_021"
+ {
+ "iType" "27"
+ "pos_x" "-688.071106"
+ "pos_y" "677.496948"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "175"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xyz"
+ }
+ "Node_022"
+ {
+ "iType" "27"
+ "pos_x" "-687.730408"
+ "pos_y" "612.119995"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "175"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_023"
+ {
+ "iType" "26"
+ "pos_x" "-524.809265"
+ "pos_y" "659.291626"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "69"
+ "pos_x" "-700.568176"
+ "pos_y" "813.892212"
+ "size_x" "101.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "175"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "2"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_025"
+ {
+ "iType" "19"
+ "pos_x" "14.134359"
+ "pos_y" "499.710602"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "-3.727656"
+ "pos_y" "591.317993"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_027"
+ {
+ "iType" "25"
+ "pos_x" "-299.712097"
+ "pos_y" "633.069214"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "19"
+ "pos_x" "-64.499283"
+ "pos_y" "792.782715"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_029"
+ {
+ "iType" "19"
+ "pos_x" "-1401.849609"
+ "pos_y" "187.411621"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "166"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "167"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_030"
+ {
+ "iType" "73"
+ "szName" "Tangentspace"
+ "pos_x" "-1619.572632"
+ "pos_y" "-38.087097"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_031"
+ {
+ "iType" "71"
+ "pos_x" "709.196106"
+ "pos_y" "-673.911560"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "70"
+ "pos_x" "712.336243"
+ "pos_y" "-577.848145"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_033"
+ {
+ "iType" "7"
+ "pos_x" "410.617889"
+ "pos_y" "-572.928528"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_034"
+ {
+ "iType" "27"
+ "szName" "proj_z"
+ "pos_x" "409.736786"
+ "pos_y" "-660.502380"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_035"
+ {
+ "iType" "27"
+ "pos_x" "553.371521"
+ "pos_y" "-707.137146"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "2"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_036"
+ {
+ "iType" "72"
+ "pos_x" "1152.481812"
+ "pos_y" "-898.468079"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_037"
+ {
+ "iType" "68"
+ "pos_x" "-412.877258"
+ "pos_y" "783.290527"
+ "size_x" "116.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "3"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "1"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_038"
+ {
+ "iType" "61"
+ "pos_x" "-1043.730957"
+ "pos_y" "168.753326"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "19"
+ "szName" "world2eye"
+ "pos_x" "-1116.969604"
+ "pos_y" "412.146057"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "-1112.923096"
+ "pos_y" "511.305420"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_041"
+ {
+ "iType" "27"
+ "pos_x" "550.036255"
+ "pos_y" "-572.179993"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_042"
+ {
+ "iType" "17"
+ "szName" "Specular"
+ "pos_x" "137.071884"
+ "pos_y" "-1149.045654"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "130"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "17"
+ "szName" "writes_to_A"
+ "pos_x" "-299.836426"
+ "pos_y" "-711.265137"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "143"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_044"
+ {
+ "iType" "19"
+ "pos_x" "-984.810486"
+ "pos_y" "-713.365967"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_045"
+ {
+ "iType" "80"
+ "pos_x" "-1141.202881"
+ "pos_y" "-848.905884"
+ "size_x" "83.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "2"
+ }
+ "Node_046"
+ {
+ "iType" "58"
+ "pos_x" "-1358.624512"
+ "pos_y" "-720.599304"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_047"
+ {
+ "iType" "49"
+ "pos_x" "-887.519653"
+ "pos_y" "165.745148"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_048"
+ {
+ "iType" "5"
+ "pos_x" "-1004.388733"
+ "pos_y" "56.160908"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_049"
+ {
+ "iType" "38"
+ "pos_x" "-699.437439"
+ "pos_y" "231.170700"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "173"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "5"
+ "pos_x" "-536.772766"
+ "pos_y" "255.797729"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_051"
+ {
+ "iType" "32"
+ "pos_x" "144.554855"
+ "pos_y" "266.021149"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_052"
+ {
+ "iType" "5"
+ "pos_x" "-1043.420410"
+ "pos_y" "-338.782898"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "150"
+ }
+ "Node_053"
+ {
+ "iType" "19"
+ "pos_x" "-1011.019775"
+ "pos_y" "-227.396942"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_054"
+ {
+ "iType" "29"
+ "szName" "Envmap"
+ "pos_x" "-1177.321899"
+ "pos_y" "-720.104126"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "6"
+ "IsCubemap" "1"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\cubemap_uffizi"
+ "szFallbackTexturePath" "cable\black"
+ "iFallbackMode" "1"
+ }
+ "Node_055"
+ {
+ "iType" "33"
+ "pos_x" "114.758011"
+ "pos_y" "-7.808853"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "33"
+ "pos_x" "41.676437"
+ "pos_y" "-104.377495"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "170"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_057"
+ {
+ "iType" "74"
+ "pos_x" "-302.706024"
+ "pos_y" "46.073608"
+ "size_x" "155.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_ao" "0"
+ }
+ "Node_058"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-544.598694"
+ "pos_y" "-64.903015"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "185.521713"
+ "container_extents_y" "736.290649"
+ "container_extents_z" "-185.521713"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_059"
+ {
+ "iType" "33"
+ "szName" "Diffuse"
+ "pos_x" "-106.033875"
+ "pos_y" "-429.474274"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "33"
+ "szName" "Specular"
+ "pos_x" "-102.639160"
+ "pos_y" "-542.013611"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-1454.844971"
+ "pos_y" "-768.641785"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "171.600098"
+ "container_extents_y" "1247.736938"
+ "container_extents_z" "-171.600098"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_062"
+ {
+ "iType" "66"
+ "pos_x" "-73.426224"
+ "pos_y" "737.022339"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vlight_static" "0"
+ "i_vlight_hl" "0"
+ }
+ "Node_063"
+ {
+ "iType" "26"
+ "pos_x" "-1718.759521"
+ "pos_y" "-612.743591"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "19"
+ "pos_x" "-1548.065186"
+ "pos_y" "-1207.617188"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "152"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_065"
+ {
+ "iType" "17"
+ "pos_x" "-1392.416382"
+ "pos_y" "-1278.056885"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "19"
+ "pos_x" "-1526.478516"
+ "pos_y" "-1349.632446"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "153"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_067"
+ {
+ "iType" "19"
+ "pos_x" "-1525.342407"
+ "pos_y" "-1484.830688"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_068"
+ {
+ "iType" "27"
+ "pos_x" "-1912.851074"
+ "pos_y" "-1476.891235"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_069"
+ {
+ "iType" "27"
+ "pos_x" "-1937.175537"
+ "pos_y" "-1146.866333"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "zy"
+ }
+ "Node_070"
+ {
+ "iType" "3"
+ "pos_x" "-2026.228271"
+ "pos_y" "-261.145721"
+ "size_x" "74.000000"
+ "size_y" "-116.000000"
+ "iPreview" "0"
+ "numTexcoords" "8"
+ "numColor" "2"
+ "numTexcoord_Flag_0" "8"
+ "numTexcoord_Name_0" "UV_seamless_xy"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "8"
+ "numColor_Name_1" "seamlessweights_z"
+ }
+ "Node_071"
+ {
+ "iType" "27"
+ "pos_x" "-679.146423"
+ "pos_y" "-453.478424"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_072"
+ {
+ "iType" "20"
+ "szName" "screenpos"
+ "pos_x" "-506.001495"
+ "pos_y" "-416.027191"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_073"
+ {
+ "iType" "29"
+ "pos_x" "-1194.053223"
+ "pos_y" "-163.643906"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "phongexp"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "models\combine_soldier\combine_elite_phong"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_074"
+ {
+ "iType" "29"
+ "pos_x" "-1776.444214"
+ "pos_y" "-1447.851929"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "snow"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\ice_2"
+ "szFallbackTexturePath" "texture_samples\ice_2"
+ "iFallbackMode" "4"
+ }
+ "Node_075"
+ {
+ "iType" "17"
+ "pos_x" "-1382.711548"
+ "pos_y" "-1430.089844"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_076"
+ {
+ "iType" "29"
+ "pos_x" "-1805.055786"
+ "pos_y" "-1111.949829"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "snow"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\ice_2"
+ "szFallbackTexturePath" "texture_samples\ice_2"
+ "iFallbackMode" "4"
+ }
+ "Node_077"
+ {
+ "iType" "29"
+ "pos_x" "-1770.472656"
+ "pos_y" "-1287.368286"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "snow"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\ice_2"
+ "szFallbackTexturePath" "texture_samples\ice_2"
+ "iFallbackMode" "4"
+ }
+ "Node_078"
+ {
+ "iType" "27"
+ "szName" "snow mask"
+ "pos_x" "-1352.929932"
+ "pos_y" "-1637.036255"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "a"
+ }
+ "Node_079"
+ {
+ "iType" "37"
+ "pos_x" "-867.100830"
+ "pos_y" "-1696.989868"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "151"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_080"
+ {
+ "iType" "38"
+ "pos_x" "-864.120850"
+ "pos_y" "-1804.272705"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "151"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_081"
+ {
+ "iType" "21"
+ "pos_x" "-678.889343"
+ "pos_y" "-1723.810547"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "151"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "5"
+ "pos_x" "-710.274109"
+ "pos_y" "-1477.828247"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_083"
+ {
+ "iType" "49"
+ "pos_x" "-1151.160767"
+ "pos_y" "-1745.914429"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_084"
+ {
+ "iType" "19"
+ "pos_x" "-745.416016"
+ "pos_y" "-1360.643066"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "126"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_085"
+ {
+ "iType" "27"
+ "szName" "snow rgb"
+ "pos_x" "-952.283508"
+ "pos_y" "-1330.547729"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "rgb"
+ }
+ "Node_086"
+ {
+ "iType" "61"
+ "pos_x" "-999.219666"
+ "pos_y" "-83.768295"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_087"
+ {
+ "iType" "17"
+ "pos_x" "-834.148438"
+ "pos_y" "-164.519714"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_088"
+ {
+ "iType" "25"
+ "szName" "World_normal"
+ "pos_x" "-1285.157959"
+ "pos_y" "-38.549469"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_089"
+ {
+ "iType" "26"
+ "szName" "Comp"
+ "pos_x" "960.000549"
+ "pos_y" "-977.740479"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "174"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_090"
+ {
+ "iType" "17"
+ "pos_x" "797.163208"
+ "pos_y" "-976.985840"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "154"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_091"
+ {
+ "iType" "21"
+ "pos_x" "-190.661224"
+ "pos_y" "-2235.453857"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "122"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_092"
+ {
+ "iType" "19"
+ "pos_x" "-37.573780"
+ "pos_y" "-2215.153564"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_093"
+ {
+ "iType" "27"
+ "szName" "seamless_z"
+ "pos_x" "-1633.566284"
+ "pos_y" "-524.397888"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "9"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_094"
+ {
+ "iType" "27"
+ "szName" "seamless_xy"
+ "pos_x" "-1784.055054"
+ "pos_y" "-525.625244"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "zw"
+ }
+ "Node_095"
+ {
+ "iType" "27"
+ "pos_x" "-119.553162"
+ "pos_y" "698.925232"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_096"
+ {
+ "iType" "26"
+ "pos_x" "40.939655"
+ "pos_y" "696.274231"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "8"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_097"
+ {
+ "iType" "19"
+ "pos_x" "-2172.214355"
+ "pos_y" "-1304.651367"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_098"
+ {
+ "iType" "27"
+ "pos_x" "-1946.000366"
+ "pos_y" "-1305.078125"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xz"
+ }
+ "Node_099"
+ {
+ "iType" "2"
+ "pos_x" "194.688385"
+ "pos_y" "735.048462"
+ "size_x" "74.000000"
+ "size_y" "-127.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_08"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_09"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_10"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "8"
+ "numColor" "2"
+ "numTexcoord_Flag_0" "8"
+ "numTexcoord_Name_0" "UV_seamless_xy"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "8"
+ "numColor_Name_1" "seamlessweights_z"
+ }
+ "Node_100"
+ {
+ "iType" "27"
+ "pos_x" "-115.968925"
+ "pos_y" "654.399353"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_101"
+ {
+ "iType" "26"
+ "pos_x" "45.943745"
+ "pos_y" "648.356995"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "177"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_102"
+ {
+ "iType" "5"
+ "pos_x" "-640.474243"
+ "pos_y" "-1482.885986"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_103"
+ {
+ "iType" "19"
+ "pos_x" "-732.367004"
+ "pos_y" "-2087.064697"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_104"
+ {
+ "iType" "5"
+ "pos_x" "-704.429138"
+ "pos_y" "-2209.495850"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_105"
+ {
+ "iType" "23"
+ "pos_x" "-269.223053"
+ "pos_y" "-2075.442627"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_106"
+ {
+ "iType" "25"
+ "pos_x" "-1403.243652"
+ "pos_y" "-371.557922"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "7"
+ }
+ }
+ }
+ "Node_107"
+ {
+ "iType" "5"
+ "pos_x" "-588.744324"
+ "pos_y" "-2214.453857"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_108"
+ {
+ "iType" "27"
+ "szName" "UV"
+ "pos_x" "-1799.573853"
+ "pos_y" "-220.167374"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_109"
+ {
+ "iType" "25"
+ "pos_x" "-436.152405"
+ "pos_y" "-2087.322021"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_110"
+ {
+ "iType" "19"
+ "pos_x" "-1555.931885"
+ "pos_y" "-2389.616699"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "120"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "152"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_111"
+ {
+ "iType" "19"
+ "pos_x" "-1534.345337"
+ "pos_y" "-2531.630371"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "153"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_112"
+ {
+ "iType" "19"
+ "pos_x" "-1533.209229"
+ "pos_y" "-2666.829102"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_113"
+ {
+ "iType" "27"
+ "pos_x" "-1920.718018"
+ "pos_y" "-2658.889648"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_114"
+ {
+ "iType" "17"
+ "pos_x" "-1390.578369"
+ "pos_y" "-2612.088379"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_115"
+ {
+ "iType" "27"
+ "pos_x" "-1953.867188"
+ "pos_y" "-2487.076172"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xz"
+ }
+ "Node_116"
+ {
+ "iType" "29"
+ "pos_x" "-1783.485840"
+ "pos_y" "-2476.251465"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_3d"
+ "szFallbackTexturePath" "texture_samples\noise_3d"
+ "iFallbackMode" "4"
+ }
+ "Node_117"
+ {
+ "iType" "29"
+ "pos_x" "-1770.887817"
+ "pos_y" "-2649.026367"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_3d"
+ "szFallbackTexturePath" "texture_samples\noise_3d"
+ "iFallbackMode" "4"
+ }
+ "Node_118"
+ {
+ "iType" "17"
+ "pos_x" "-1400.283203"
+ "pos_y" "-2460.055664"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_119"
+ {
+ "iType" "18"
+ "pos_x" "-579.935608"
+ "pos_y" "-2086.314209"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_120"
+ {
+ "iType" "29"
+ "pos_x" "-1781.389038"
+ "pos_y" "-2320.619629"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_3d"
+ "szFallbackTexturePath" "texture_samples\noise_3d"
+ "iFallbackMode" "4"
+ }
+ "Node_121"
+ {
+ "iType" "34"
+ "pos_x" "-70.140060"
+ "pos_y" "-2014.990723"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "141"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "128"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_122"
+ {
+ "iType" "5"
+ "pos_x" "-127.292732"
+ "pos_y" "-2348.871338"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.7 1"
+ }
+ "Node_123"
+ {
+ "iType" "5"
+ "pos_x" "-234.634232"
+ "pos_y" "-2361.655029"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9 0.95 1"
+ }
+ "Node_124"
+ {
+ "iType" "27"
+ "pos_x" "-605.565063"
+ "pos_y" "-2343.872803"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_125"
+ {
+ "iType" "27"
+ "pos_x" "-1945.042480"
+ "pos_y" "-2328.865234"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "zy"
+ }
+ "Node_126"
+ {
+ "iType" "5"
+ "pos_x" "-903.229797"
+ "pos_y" "-1455.116577"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.54 0.57 0.6"
+ }
+ "Node_127"
+ {
+ "iType" "4"
+ "pos_x" "1372.744873"
+ "pos_y" "-1066.363281"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_128"
+ {
+ "iType" "5"
+ "pos_x" "-21.431444"
+ "pos_y" "-1929.341675"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.996"
+ }
+ "Node_129"
+ {
+ "iType" "34"
+ "pos_x" "-665.002380"
+ "pos_y" "-1585.585327"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_130"
+ {
+ "iType" "19"
+ "pos_x" "-16.084276"
+ "pos_y" "-1164.572754"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "163"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_131"
+ {
+ "iType" "27"
+ "pos_x" "-2696.305176"
+ "pos_y" "-2363.271484"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_132"
+ {
+ "iType" "17"
+ "pos_x" "-2319.975586"
+ "pos_y" "-2451.517090"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "137"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_133"
+ {
+ "iType" "5"
+ "pos_x" "-2572.278809"
+ "pos_y" "-2241.552979"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "50"
+ }
+ "Node_134"
+ {
+ "iType" "34"
+ "pos_x" "-2469.800293"
+ "pos_y" "-2279.497314"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "133"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_135"
+ {
+ "iType" "19"
+ "pos_x" "-2180.081543"
+ "pos_y" "-2486.649414"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_136"
+ {
+ "iType" "5"
+ "pos_x" "-2402.507324"
+ "pos_y" "-2555.752930"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_137"
+ {
+ "iType" "19"
+ "pos_x" "-2465.617188"
+ "pos_y" "-2430.706543"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "139"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_138"
+ {
+ "iType" "5"
+ "pos_x" "-2574.880371"
+ "pos_y" "-2334.270508"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_139"
+ {
+ "iType" "5"
+ "pos_x" "-2570.144043"
+ "pos_y" "-2520.909668"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_140"
+ {
+ "iType" "5"
+ "pos_x" "-2299.881836"
+ "pos_y" "-1348.744141"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.015"
+ }
+ "Node_141"
+ {
+ "iType" "5"
+ "pos_x" "-128.220657"
+ "pos_y" "-1926.510986"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.995"
+ }
+ "Node_142"
+ {
+ "iType" "19"
+ "szName" "normal_map_alpha_mask"
+ "pos_x" "-808.039856"
+ "pos_y" "-669.865967"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "173"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_143"
+ {
+ "iType" "19"
+ "pos_x" "-471.085480"
+ "pos_y" "-692.006287"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "144"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "172"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_144"
+ {
+ "iType" "19"
+ "szName" "scale_by_fresnel"
+ "pos_x" "-615.345093"
+ "pos_y" "-671.797791"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "145"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_145"
+ {
+ "iType" "21"
+ "pos_x" "-708.089783"
+ "pos_y" "-806.220398"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "142"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "129"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_146"
+ {
+ "iType" "5"
+ "pos_x" "-1290.406250"
+ "pos_y" "-1763.358643"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "10"
+ }
+ "Node_147"
+ {
+ "iType" "17"
+ "pos_x" "-350.031494"
+ "pos_y" "-1706.450684"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "149"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_148"
+ {
+ "iType" "5"
+ "pos_x" "-511.937866"
+ "pos_y" "-1627.724121"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_149"
+ {
+ "iType" "19"
+ "pos_x" "-494.626312"
+ "pos_y" "-1712.140381"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_150"
+ {
+ "iType" "5"
+ "pos_x" "-1265.601196"
+ "pos_y" "-1572.631348"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 1"
+ }
+ "Node_151"
+ {
+ "iType" "23"
+ "pos_x" "-1100.441406"
+ "pos_y" "-1563.682495"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "150"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_152"
+ {
+ "iType" "27"
+ "pos_x" "-1937.289551"
+ "pos_y" "-1992.133057"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "9"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_153"
+ {
+ "iType" "27"
+ "pos_x" "-1944.175049"
+ "pos_y" "-2040.441406"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "9"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_154"
+ {
+ "iType" "19"
+ "pos_x" "313.377472"
+ "pos_y" "-1685.320313"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "155"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "129"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_155"
+ {
+ "iType" "19"
+ "pos_x" "124.399261"
+ "pos_y" "-1725.150513"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "171"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_156"
+ {
+ "iType" "29"
+ "pos_x" "-2109.548828"
+ "pos_y" "-1598.152954"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "snow_normal"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0_normal"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_0_normal"
+ "iFallbackMode" "4"
+ }
+ "Node_157"
+ {
+ "iType" "19"
+ "pos_x" "-1889.794800"
+ "pos_y" "-1625.452515"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "156"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "152"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_158"
+ {
+ "iType" "19"
+ "pos_x" "-1884.719360"
+ "pos_y" "-1688.581177"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "161"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "153"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_159"
+ {
+ "iType" "19"
+ "pos_x" "-1883.583130"
+ "pos_y" "-1761.403687"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "162"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_160"
+ {
+ "iType" "17"
+ "pos_x" "-1746.988037"
+ "pos_y" "-1650.027832"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "157"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "158"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_161"
+ {
+ "iType" "29"
+ "pos_x" "-2102.644043"
+ "pos_y" "-1713.995972"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "snow_normal"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0_normal"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_0_normal"
+ "iFallbackMode" "4"
+ }
+ "Node_162"
+ {
+ "iType" "29"
+ "pos_x" "-2104.316406"
+ "pos_y" "-1819.379028"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "snow_normal"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0_normal"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_0_normal"
+ "iFallbackMode" "4"
+ }
+ "Node_163"
+ {
+ "iType" "21"
+ "pos_x" "-192.615692"
+ "pos_y" "-1378.050171"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "174"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "164"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_164"
+ {
+ "iType" "37"
+ "pos_x" "-297.751404"
+ "pos_y" "-1508.793213"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "129"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_165"
+ {
+ "iType" "17"
+ "pos_x" "-1753.794434"
+ "pos_y" "-1723.174194"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "160"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "159"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_166"
+ {
+ "iType" "21"
+ "pos_x" "-1621.433228"
+ "pos_y" "88.963646"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "173"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "165"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "164"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_167"
+ {
+ "iType" "5"
+ "pos_x" "-1567.767212"
+ "pos_y" "268.307159"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_168"
+ {
+ "iType" "76"
+ "pos_x" "732.506531"
+ "pos_y" "93.800934"
+ "size_x" "168.000000"
+ "size_y" "-83.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "8"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "1"
+ }
+ "Node_169"
+ {
+ "iType" "27"
+ "pos_x" "-1946.678467"
+ "pos_y" "-2092.731689"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "9"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_170"
+ {
+ "iType" "67"
+ "pos_x" "-302.819305"
+ "pos_y" "-74.045364"
+ "size_x" "156.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_static" "0"
+ "i_plight_ao" "0"
+ "i_plight_hl" "0"
+ }
+ "Node_171"
+ {
+ "iType" "5"
+ "pos_x" "151.938049"
+ "pos_y" "-1846.089600"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_172"
+ {
+ "iType" "5"
+ "pos_x" "-444.519226"
+ "pos_y" "-806.678040"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_173"
+ {
+ "iType" "29"
+ "szName" "Normalmap"
+ "pos_x" "-1682.656860"
+ "pos_y" "206.380386"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "models\combine_soldier\combine_elite_normal"
+ "szFallbackTexturePath" "dev\flat_normal"
+ "iFallbackMode" "3"
+ }
+ "Node_174"
+ {
+ "iType" "29"
+ "szName" "Albedo"
+ "pos_x" "-921.624634"
+ "pos_y" "-1181.807007"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "models\combine_soldier\combine_elite"
+ "szFallbackTexturePath" "grey"
+ "iFallbackMode" "2"
+ }
+ "Node_175"
+ {
+ "iType" "101"
+ "pos_x" "-870.226379"
+ "pos_y" "760.902283"
+ "size_x" "95.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "6"
+ }
+ }
+ "iCompMode" "1"
+ }
+ "Node_176"
+ {
+ "iType" "1"
+ "pos_x" "-874.404907"
+ "pos_y" "629.058594"
+ "size_x" "55.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "enable_flex" "1"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "1"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_177"
+ {
+ "iType" "19"
+ "pos_x" "-278.928955"
+ "pos_y" "687.992615"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "175"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "175"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_blur_viewmodel.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_blur_viewmodel.txt
new file mode 100644
index 0000000000..f4f59e275c
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_blur_viewmodel.txt
@@ -0,0 +1,397 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "4"
+ "config_ppe"
+ {
+ "updatefbcopy" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2001"
+ "pos_x" "-399.867645"
+ "pos_y" "200.284698"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbhalf_rgba_0"
+ "pos_x" "-507.830566"
+ "pos_y" "-115.098801"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbhalf_rgba_0"
+ }
+ "Node_002"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbhalf_rgba_1"
+ "pos_x" "-517.584412"
+ "pos_y" "-332.170502"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbhalf_rgba_1"
+ }
+ "Node_003"
+ {
+ "iType" "2011"
+ "pos_x" "-269.079987"
+ "pos_y" "-805.249084"
+ "size_x" "158.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "2002"
+ "pos_x" "809.365051"
+ "pos_y" "-777.390442"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbhalf_rgba_2"
+ "pos_x" "-440.479248"
+ "pos_y" "-939.310242"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbhalf_rgba_2"
+ }
+ "Node_006"
+ {
+ "iType" "2010"
+ "pos_x" "453.915344"
+ "pos_y" "-903.704590"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'unlitgeneric\'\r\n{\r\n \'$basetexture\' \'_rt_fbhalf_rgba_2\'\r\n \'$translucent\' 1\r\n}"
+ }
+ "Node_007"
+ {
+ "iType" "2012"
+ "pos_x" "-221.603882"
+ "pos_y" "150.628510"
+ "size_x" "181.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "szVRCName" "Viewmodel_view"
+ "options_bool_amt" "7"
+ "options_int_amt" "7"
+ "options_float_amt" "3"
+ "options_string_amt" "0"
+ "options_bool_0" "1"
+ "options_bool_1" "1"
+ "options_bool_2" "1"
+ "options_bool_3" "0"
+ "options_bool_4" "0"
+ "options_bool_5" "0"
+ "options_bool_6" "1"
+ "options_int_0" "0"
+ "options_int_1" "0"
+ "options_int_2" "0"
+ "options_int_3" "0"
+ "options_int_4" "0"
+ "options_int_5" "0"
+ "options_int_6" "0"
+ "options_float_0" "0.000000"
+ "options_float_1" "0.000000"
+ "options_float_2" "1.000000"
+ "iSceneDraw" "0"
+ }
+ "Node_008"
+ {
+ "iType" "2004"
+ "pos_x" "-210.247681"
+ "pos_y" "-429.678284"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_009"
+ {
+ "iType" "2004"
+ "pos_x" "-196.906036"
+ "pos_y" "-196.958389"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_010"
+ {
+ "iType" "2010"
+ "pos_x" "-397.973328"
+ "pos_y" "-227.517029"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_7_half_aceil_x\'\r\n\r\n \'$basetexture\' \'_rt_fbhalf_rgba_0\'\r\n}"
+ }
+ "Node_011"
+ {
+ "iType" "2010"
+ "pos_x" "-398.202271"
+ "pos_y" "-481.477325"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_7_half_aceil_y\'\r\n\r\n \'$basetexture\' \'_rt_fbhalf_rgba_1\'\r\n}"
+ }
+ "Node_012"
+ {
+ "iType" "2004"
+ "pos_x" "567.805664"
+ "pos_y" "-749.825623"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_013"
+ {
+ "iType" "2004"
+ "pos_x" "0.811378"
+ "pos_y" "-802.618103"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_014"
+ {
+ "iType" "2010"
+ "pos_x" "-135.732941"
+ "pos_y" "-987.250549"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'basetexture_accum\'\r\n\r\n \'$basetexture\' \'_rt_fbhalf_rgba_0\'\r\n \'$basetexture2\' \'_rt_fbhalf_rgba_1\'\r\n}"
+ }
+ "Node_015"
+ {
+ "iType" "1001"
+ "szName" "Blur"
+ "pos_x" "-660.086426"
+ "pos_y" "-310.937012"
+ "size_x" "84.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "292.976227"
+ "container_extents_y" "608.041748"
+ "container_extents_z" "-292.976227"
+ "szConstantString" "0.116582 0.302179 0.078568 0.75"
+ }
+ "Node_016"
+ {
+ "iType" "1001"
+ "szName" "Accumulation"
+ "pos_x" "-616.056152"
+ "pos_y" "-887.311157"
+ "size_x" "84.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "191.910278"
+ "container_extents_y" "759.715332"
+ "container_extents_z" "-191.910278"
+ "szConstantString" "0.343832 0.461946 0.81629 0.75"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_gaussian_blur.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_gaussian_blur.txt
new file mode 100644
index 0000000000..8492556359
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_gaussian_blur.txt
@@ -0,0 +1,245 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "4"
+ "config_ppe"
+ {
+ "updatefbcopy" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2001"
+ "pos_x" "-343.579529"
+ "pos_y" "213.420929"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "2010"
+ "szName" "downsample"
+ "pos_x" "-265.588318"
+ "pos_y" "94.636635"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'downsample_4\'\r\n}"
+ }
+ "Node_002"
+ {
+ "iType" "2010"
+ "szName" "blur x"
+ "pos_x" "-267.894592"
+ "pos_y" "-112.755157"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_x\'\r\n\r\n \'$BaseTexture\' \'_rt_fbquarter_0\'\r\n}"
+ }
+ "Node_003"
+ {
+ "iType" "2010"
+ "szName" "blur y"
+ "pos_x" "-262.868835"
+ "pos_y" "-270.207031"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_y\'\r\n\r\n \'$BaseTexture\' \'_rt_fbquarter_1\'\r\n}"
+ }
+ "Node_004"
+ {
+ "iType" "2002"
+ "pos_x" "438.386444"
+ "pos_y" "-233.359741"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "2010"
+ "szName" "blend base textures"
+ "pos_x" "39.418751"
+ "pos_y" "-372.709290"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'basetexture_blend\'\r\n\r\n \'$BaseTexture\' \'_rt_fullframefb\'\r\n \'$BaseTexture2\' \'_rt_fbquarter_0\'\r\n}"
+ }
+ "Node_006"
+ {
+ "iType" "2004"
+ "pos_x" "-54.079861"
+ "pos_y" "118.084595"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "0"
+ }
+ "Node_007"
+ {
+ "iType" "2004"
+ "pos_x" "-54.189266"
+ "pos_y" "-66.460052"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ }
+ "Node_008"
+ {
+ "iType" "2004"
+ "pos_x" "-52.769436"
+ "pos_y" "-232.025208"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ }
+ "Node_009"
+ {
+ "iType" "2004"
+ "pos_x" "216.783936"
+ "pos_y" "-232.278564"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "0"
+ }
+ "Node_010"
+ {
+ "iType" "2009"
+ "szName" "small rt 0"
+ "pos_x" "-384.307068"
+ "pos_y" "6.584007"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_0"
+ }
+ "Node_011"
+ {
+ "iType" "2009"
+ "szName" "small rt 1"
+ "pos_x" "-402.464539"
+ "pos_y" "-175.510132"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_1"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_glow.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_glow.txt
new file mode 100644
index 0000000000..d19bd32366
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_glow.txt
@@ -0,0 +1,374 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "4"
+ "config_ppe"
+ {
+ "updatefbcopy" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2001"
+ "pos_x" "-320.000000"
+ "pos_y" "15.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbquarter_1"
+ "pos_x" "-471.106934"
+ "pos_y" "-392.282166"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_1"
+ }
+ "Node_002"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbquarter_0"
+ "pos_x" "-466.076111"
+ "pos_y" "-154.170120"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_0"
+ }
+ "Node_003"
+ {
+ "iType" "2004"
+ "pos_x" "-137.303177"
+ "pos_y" "-419.544556"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_004"
+ {
+ "iType" "2010"
+ "pos_x" "-335.240234"
+ "pos_y" "-531.473999"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_y\'\r\n\r\n \'$basetexture\' \'_rt_fbquarter_1\'\r\n}"
+ }
+ "Node_005"
+ {
+ "iType" "2010"
+ "pos_x" "423.332336"
+ "pos_y" "-416.715942"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'unlitgeneric\'\r\n{\r\n \'$basetexture\' \'_rt_fullframefb\'\r\n \'$additive\' 1\r\n}"
+ }
+ "Node_006"
+ {
+ "iType" "2011"
+ "pos_x" "113.682846"
+ "pos_y" "-502.520996"
+ "size_x" "158.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "2009"
+ "pos_x" "-39.379333"
+ "pos_y" "-674.412415"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_FullFrameFB"
+ }
+ "Node_008"
+ {
+ "iType" "2004"
+ "pos_x" "594.897278"
+ "pos_y" "-499.985840"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_009"
+ {
+ "iType" "2002"
+ "pos_x" "840.652588"
+ "pos_y" "-511.548279"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "2012"
+ "pos_x" "332.495667"
+ "pos_y" "-505.895020"
+ "size_x" "181.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "szVRCName" "General_view"
+ "options_bool_amt" "17"
+ "options_int_amt" "7"
+ "options_float_amt" "3"
+ "options_string_amt" "0"
+ "options_bool_0" "1"
+ "options_bool_1" "1"
+ "options_bool_2" "1"
+ "options_bool_3" "1"
+ "options_bool_4" "0"
+ "options_bool_5" "0"
+ "options_bool_6" "0"
+ "options_bool_7" "0"
+ "options_bool_8" "0"
+ "options_bool_9" "0"
+ "options_bool_10" "0"
+ "options_bool_11" "0"
+ "options_bool_12" "1"
+ "options_bool_13" "0"
+ "options_bool_14" "0"
+ "options_bool_15" "1"
+ "options_bool_16" "1"
+ "options_int_0" "0"
+ "options_int_1" "0"
+ "options_int_2" "0"
+ "options_int_3" "0"
+ "options_int_4" "0"
+ "options_int_5" "0"
+ "options_int_6" "0"
+ "options_float_0" "0.000000"
+ "options_float_1" "0.000000"
+ "options_float_2" "1.000000"
+ "iSceneDraw" "0"
+ }
+ "Node_011"
+ {
+ "iType" "2012"
+ "pos_x" "-139.545654"
+ "pos_y" "-37.145393"
+ "size_x" "181.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "szVRCName" "General_view"
+ "options_bool_amt" "17"
+ "options_int_amt" "7"
+ "options_float_amt" "3"
+ "options_string_amt" "0"
+ "options_bool_0" "1"
+ "options_bool_1" "1"
+ "options_bool_2" "1"
+ "options_bool_3" "1"
+ "options_bool_4" "0"
+ "options_bool_5" "0"
+ "options_bool_6" "0"
+ "options_bool_7" "0"
+ "options_bool_8" "0"
+ "options_bool_9" "0"
+ "options_bool_10" "0"
+ "options_bool_11" "1"
+ "options_bool_12" "0"
+ "options_bool_13" "0"
+ "options_bool_14" "0"
+ "options_bool_15" "1"
+ "options_bool_16" "1"
+ "options_int_0" "0"
+ "options_int_1" "0"
+ "options_int_2" "0"
+ "options_int_3" "0"
+ "options_int_4" "150"
+ "options_int_5" "255"
+ "options_int_6" "200"
+ "options_float_0" "0.000000"
+ "options_float_1" "0.000000"
+ "options_float_2" "1.000000"
+ "iSceneDraw" "0"
+ }
+ "Node_012"
+ {
+ "iType" "2004"
+ "pos_x" "-126.738861"
+ "pos_y" "-232.900467"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.500000"
+ "flSrcUV_y0" "0.500000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "-1"
+ "iSrc_h" "-1"
+ }
+ "Node_013"
+ {
+ "iType" "2010"
+ "pos_x" "-339.970551"
+ "pos_y" "-278.838318"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_x\'\r\n\r\n \'$basetexture\' \'_rt_fbquarter_0\'\r\n}"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_glow_viewmodel.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_glow_viewmodel.txt
new file mode 100644
index 0000000000..848c7cee42
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_glow_viewmodel.txt
@@ -0,0 +1,354 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "4"
+ "config_ppe"
+ {
+ "updatefbcopy" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2001"
+ "pos_x" "-320.000000"
+ "pos_y" "15.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbquarter_1"
+ "pos_x" "-471.106934"
+ "pos_y" "-392.282166"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_1"
+ }
+ "Node_002"
+ {
+ "iType" "2004"
+ "pos_x" "-137.303177"
+ "pos_y" "-419.544556"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_003"
+ {
+ "iType" "2010"
+ "pos_x" "-335.240234"
+ "pos_y" "-531.473999"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_y\'\r\n\r\n \'$basetexture\' \'_rt_fbquarter_1\'\r\n}"
+ }
+ "Node_004"
+ {
+ "iType" "2010"
+ "pos_x" "-339.970551"
+ "pos_y" "-278.838318"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_x\'\r\n\r\n \'$basetexture\' \'_rt_fbquarter_0\'\r\n}"
+ }
+ "Node_005"
+ {
+ "iType" "2011"
+ "pos_x" "113.682846"
+ "pos_y" "-502.520996"
+ "size_x" "158.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "2004"
+ "pos_x" "594.897278"
+ "pos_y" "-499.985840"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_007"
+ {
+ "iType" "2002"
+ "pos_x" "840.652588"
+ "pos_y" "-511.548279"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbquarter_0"
+ "pos_x" "-466.076111"
+ "pos_y" "-154.170120"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_0"
+ }
+ "Node_009"
+ {
+ "iType" "2012"
+ "pos_x" "-139.545654"
+ "pos_y" "-37.145393"
+ "size_x" "181.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "szVRCName" "Viewmodel_view"
+ "options_bool_amt" "7"
+ "options_int_amt" "7"
+ "options_float_amt" "3"
+ "options_string_amt" "0"
+ "options_bool_0" "0"
+ "options_bool_1" "1"
+ "options_bool_2" "0"
+ "options_bool_3" "0"
+ "options_bool_4" "0"
+ "options_bool_5" "1"
+ "options_bool_6" "1"
+ "options_int_0" "0"
+ "options_int_1" "0"
+ "options_int_2" "0"
+ "options_int_3" "0"
+ "options_int_4" "255"
+ "options_int_5" "32"
+ "options_int_6" "0"
+ "options_float_0" "0.000000"
+ "options_float_1" "0.000000"
+ "options_float_2" "1.000000"
+ "iSceneDraw" "0"
+ }
+ "Node_010"
+ {
+ "iType" "2010"
+ "pos_x" "423.332336"
+ "pos_y" "-416.715942"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'unlitgeneric\'\r\n{\r\n \'$basetexture\' \'_rt_fullframefb\'\r\n \'$additive\' 1\r\n}"
+ }
+ "Node_011"
+ {
+ "iType" "2009"
+ "pos_x" "68.256104"
+ "pos_y" "-681.967102"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_FullFrameFB"
+ }
+ "Node_012"
+ {
+ "iType" "2012"
+ "pos_x" "337.155212"
+ "pos_y" "-504.341858"
+ "size_x" "181.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "szVRCName" "Viewmodel_view"
+ "options_bool_amt" "7"
+ "options_int_amt" "7"
+ "options_float_amt" "3"
+ "options_string_amt" "0"
+ "options_bool_0" "0"
+ "options_bool_1" "0"
+ "options_bool_2" "1"
+ "options_bool_3" "0"
+ "options_bool_4" "0"
+ "options_bool_5" "1"
+ "options_bool_6" "1"
+ "options_int_0" "0"
+ "options_int_1" "0"
+ "options_int_2" "0"
+ "options_int_3" "0"
+ "options_int_4" "0"
+ "options_int_5" "0"
+ "options_int_6" "0"
+ "options_float_0" "0.000000"
+ "options_float_1" "0.000000"
+ "options_float_2" "1.000000"
+ "iSceneDraw" "0"
+ }
+ "Node_013"
+ {
+ "iType" "2004"
+ "pos_x" "-126.738861"
+ "pos_y" "-232.900467"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.500000"
+ "flSrcUV_y0" "0.500000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "-1"
+ "iSrc_h" "-1"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_ssao.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_ssao.txt
new file mode 100644
index 0000000000..454fd3553a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_ssao.txt
@@ -0,0 +1,456 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "4"
+ "config_ppe"
+ {
+ "updatefbcopy" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2001"
+ "pos_x" "-639.639282"
+ "pos_y" "44.434204"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "2010"
+ "szName" "ssao calc"
+ "pos_x" "-665.678101"
+ "pos_y" "-40.037277"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'ssao_calc\'\r\n}"
+ }
+ "Node_002"
+ {
+ "iType" "2010"
+ "szName" "mat blur x"
+ "pos_x" "-354.201935"
+ "pos_y" "-273.364471"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_half_3_x\'\r\n\r\n \'$basetexture\' \'_rt_ssao_0\'\r\n}"
+ }
+ "Node_003"
+ {
+ "iType" "2004"
+ "szName" "blur x"
+ "pos_x" "-128.456192"
+ "pos_y" "-278.041840"
+ "size_x" "80.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "1"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_004"
+ {
+ "iType" "2004"
+ "pos_x" "191.269501"
+ "pos_y" "-410.958984"
+ "size_x" "80.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_005"
+ {
+ "iType" "2004"
+ "szName" "blur y"
+ "pos_x" "-129.468536"
+ "pos_y" "-423.294128"
+ "size_x" "80.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "1"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_006"
+ {
+ "iType" "2010"
+ "szName" "combine from 0"
+ "pos_x" "15.523769"
+ "pos_y" "-576.691467"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'ssao_combine\'\r\n\r\n \'$ssao_ref\' \'_rt_ssao_0\'\r\n}"
+ }
+ "Node_007"
+ {
+ "iType" "2010"
+ "szName" "mat blur y"
+ "pos_x" "-380.703430"
+ "pos_y" "-468.416138"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_half_3_x\'\r\n\r\n \'$basetexture\' \'_rt_ssao_1\'\r\n}"
+ }
+ "Node_008"
+ {
+ "iType" "2010"
+ "szName" "ssao fxaa"
+ "pos_x" "-494.226166"
+ "pos_y" "-869.928467"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'ssao_fxaa\'\r\n\r\n \'$basetexture\' \'_rt_ssao_0\'\r\n}"
+ }
+ "Node_009"
+ {
+ "iType" "2002"
+ "pos_x" "518.236450"
+ "pos_y" "-616.246094"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "2009"
+ "szName" "_rt_ssao_0"
+ "pos_x" "-698.619568"
+ "pos_y" "-268.649231"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_ssao_0"
+ }
+ "Node_011"
+ {
+ "iType" "2009"
+ "szName" "_rt_ssao_1"
+ "pos_x" "-713.984192"
+ "pos_y" "-440.760040"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_ssao_1"
+ }
+ "Node_012"
+ {
+ "iType" "2004"
+ "pos_x" "196.442749"
+ "pos_y" "-549.532715"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_013"
+ {
+ "iType" "2010"
+ "szName" "dbg"
+ "pos_x" "135.663971"
+ "pos_y" "-333.128235"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'unlitgeneric\'\r\n{\r\n \'$basetexture\' \'_rt_ssao_0\'\r\n}"
+ }
+ "Node_014"
+ {
+ "iType" "2004"
+ "pos_x" "192.325592"
+ "pos_y" "-746.695801"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "1"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_015"
+ {
+ "iType" "2010"
+ "szName" "combine from 1"
+ "pos_x" "-18.312183"
+ "pos_y" "-729.276367"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'ssao_combine\'\r\n\r\n \'$ssao_ref\' \'_rt_ssao_1\'\r\n}"
+ }
+ "Node_016"
+ {
+ "iType" "2011"
+ "pos_x" "-480.804901"
+ "pos_y" "-686.924622"
+ "size_x" "158.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "2004"
+ "szName" "calc SSAO"
+ "pos_x" "-449.402863"
+ "pos_y" "-67.169373"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ "Node_018"
+ {
+ "iType" "2004"
+ "szName" "ssao fxaa"
+ "pos_x" "-214.860336"
+ "pos_y" "-764.314209"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "1"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "0"
+ "iDst_x" "0"
+ "iDst_y" "0"
+ "iDst_w" "0"
+ "iDst_h" "0"
+ "flSrcUV_x0" "0.000000"
+ "flSrcUV_y0" "0.000000"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ "iSrc_w" "0"
+ "iSrc_h" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_sunrays.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_sunrays.txt
new file mode 100644
index 0000000000..00bed5aaa3
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_graphs/ppe_sunrays.txt
@@ -0,0 +1,269 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "4"
+ "config_ppe"
+ {
+ "updatefbcopy" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2004"
+ "szName" "blur x"
+ "pos_x" "-128.456192"
+ "pos_y" "-278.041840"
+ "size_x" "80.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "1"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ }
+ "Node_001"
+ {
+ "iType" "2004"
+ "szName" "blur y"
+ "pos_x" "-129.468536"
+ "pos_y" "-423.294128"
+ "size_x" "80.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "1"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "1"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ }
+ "Node_002"
+ {
+ "iType" "2001"
+ "pos_x" "-405.610535"
+ "pos_y" "-35.478058"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_003"
+ {
+ "iType" "2004"
+ "szName" "calc sunrays"
+ "pos_x" "-238.206161"
+ "pos_y" "-91.904114"
+ "size_x" "160.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "1"
+ "iSHEETHINT_enable_tg" "1"
+ "iSHEETHINT_enable_src" "0"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ }
+ "Node_004"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbquarter_0"
+ "pos_x" "-579.521973"
+ "pos_y" "-250.991974"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_0"
+ }
+ "Node_005"
+ {
+ "iType" "2009"
+ "szName" "_rt_fbquarter_1"
+ "pos_x" "-596.074402"
+ "pos_y" "-435.138184"
+ "size_x" "96.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "szRTName" "_rt_fbquarter_1"
+ }
+ "Node_006"
+ {
+ "iType" "2010"
+ "szName" "mat blur y"
+ "pos_x" "-372.900238"
+ "pos_y" "-412.679138"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_y\'\r\n\r\n \'$basetexture\' \'_rt_fbquarter_1\'\r\n}"
+ }
+ "Node_007"
+ {
+ "iType" "2004"
+ "pos_x" "56.956039"
+ "pos_y" "-407.798676"
+ "size_x" "80.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSizingMode_Tg" "0"
+ "iSizingMode_Src" "0"
+ "iPushTg" "0"
+ "iSHEETHINT_enable_tg" "0"
+ "iSHEETHINT_enable_src" "0"
+ "flSrcUV_x" "0.000000"
+ "flSrcUV_y" "0.000000"
+ }
+ "Node_008"
+ {
+ "iType" "2002"
+ "pos_x" "211.028748"
+ "pos_y" "-410.396179"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "2010"
+ "szName" "mat blur x"
+ "pos_x" "-328.562927"
+ "pos_y" "-233.233780"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'gauss_blur_5_x\'\r\n\r\n \'$basetexture\' \'_rt_fbquarter_0\'\r\n}"
+ }
+ "Node_010"
+ {
+ "iType" "2010"
+ "szName" "sunrays calc"
+ "pos_x" "-467.699493"
+ "pos_y" "-122.206451"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'EDITOR_SHADER\'\r\n{\r\n \'$SHADERNAME\' \'sunrays_calc\'\r\n}"
+ }
+ "Node_011"
+ {
+ "iType" "2010"
+ "szName" "add"
+ "pos_x" "-112.357910"
+ "pos_y" "-534.670959"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'unlitgeneric\'\r\n{\r\n \'$basetexture\' \'_rt_fbquarter_0\'\r\n \'$additive\' 1\r\n \'$ignorez\' 1\r\n \'$nofog\' 1\r\n}"
+ }
+ "Node_012"
+ {
+ "iType" "2010"
+ "szName" "dbg"
+ "pos_x" "-103.265686"
+ "pos_y" "-610.516968"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "iInline" "1"
+ "szVMTString_num_strings" "1"
+ "szVMTString_partial_00" "\'unlitgeneric\'\r\n{\r\n \'$basetexture\' \'_rt_fbquarter_0\'\r\n \'$ignorez\' 1\r\n \'$nofog\' 1\r\n}"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/basetexture_accum.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/basetexture_accum.txt
new file mode 100644
index 0000000000..897da8be01
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/basetexture_accum.txt
@@ -0,0 +1,277 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "3"
+ "pos_x" "-320.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_004"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "-188.879868"
+ "pos_y" "-77.726189"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_005"
+ {
+ "iType" "29"
+ "szName" "Basetexture2"
+ "pos_x" "-203.332230"
+ "pos_y" "-216.236984"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "Basetexture2"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_006"
+ {
+ "iType" "21"
+ "pos_x" "55.389984"
+ "pos_y" "-236.050568"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "5"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "26"
+ "pos_x" "201.175720"
+ "pos_y" "-199.420914"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "21"
+ "pos_x" "55.702660"
+ "pos_y" "-106.348114"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "4"
+ "pos_x" "269.920227"
+ "pos_y" "-53.529984"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "pos_x" "-36.824833"
+ "pos_y" "-319.077026"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "pos_x" "-37.558701"
+ "pos_y" "-16.691994"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/basetexture_blend.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/basetexture_blend.txt
new file mode 100644
index 0000000000..e0ce667a5a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/basetexture_blend.txt
@@ -0,0 +1,287 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-320.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_004"
+ {
+ "iType" "29"
+ "szName" "basetex"
+ "pos_x" "-61.199524"
+ "pos_y" "27.885666"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_005"
+ {
+ "iType" "100"
+ "pos_x" "-150.667175"
+ "pos_y" "-255.192978"
+ "size_x" "61.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "29"
+ "szName" "basetex2"
+ "pos_x" "-105.759727"
+ "pos_y" "-121.315430"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "Basetexture2"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_007"
+ {
+ "iType" "4"
+ "pos_x" "297.824402"
+ "pos_y" "-148.630081"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_008"
+ {
+ "iType" "34"
+ "pos_x" "-25.419247"
+ "pos_y" "-281.618896"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "5"
+ "pos_x" "-303.495056"
+ "pos_y" "-270.386505"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.5"
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "pos_x" "-191.867004"
+ "pos_y" "-369.058960"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_011"
+ {
+ "iType" "21"
+ "pos_x" "136.930084"
+ "pos_y" "-159.159485"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "5"
+ "pos_x" "-124.366096"
+ "pos_y" "-434.090332"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/downsample_4.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/downsample_4.txt
new file mode 100644
index 0000000000..c1dcdd4fd4
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/downsample_4.txt
@@ -0,0 +1,403 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "32"
+ "pos_x" "-261.912659"
+ "pos_y" "-174.010757"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "91"
+ "pos_x" "-278.615356"
+ "pos_y" "-338.251709"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "4"
+ "i_array_size_y" "1"
+ "i_array_datatype" "2"
+ "pfl_arraydata_000" "0.000000 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "2.000000 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.000000 2.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "2.000000 2.000000 0.000000 0.000000"
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "-146.646912"
+ "pos_y" "-302.934937"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "30"
+ "pos_x" "-382.640015"
+ "pos_y" "-256.756958"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "168.149933"
+ "container_extents_y" "785.499146"
+ "container_extents_z" "-168.149933"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "4"
+ }
+ "Node_007"
+ {
+ "iType" "3"
+ "pos_x" "-640.157349"
+ "pos_y" "57.285873"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_008"
+ {
+ "iType" "17"
+ "pos_x" "-458.723206"
+ "pos_y" "-6.085495"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "32"
+ "pos_x" "158.521561"
+ "pos_y" "-11.135345"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "pos_x" "20.930641"
+ "pos_y" "0.491470"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_011"
+ {
+ "iType" "17"
+ "pos_x" "-15.899483"
+ "pos_y" "-218.003494"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "17"
+ "pos_x" "311.555176"
+ "pos_y" "-172.222610"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "29"
+ "szName" "Source tex"
+ "pos_x" "149.414978"
+ "pos_y" "-255.802490"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "szFallbackTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "4"
+ }
+ "Node_014"
+ {
+ "iType" "4"
+ "pos_x" "746.150818"
+ "pos_y" "-221.021912"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_015"
+ {
+ "iType" "19"
+ "pos_x" "-555.757446"
+ "pos_y" "-132.216568"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_016"
+ {
+ "iType" "5"
+ "pos_x" "-677.293823"
+ "pos_y" "-170.162491"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_017"
+ {
+ "iType" "19"
+ "pos_x" "583.907410"
+ "pos_y" "-216.510773"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "pos_x" "505.340881"
+ "pos_y" "-334.257751"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.25"
+ }
+ "Node_019"
+ {
+ "iType" "65"
+ "pos_x" "-633.804260"
+ "pos_y" "-312.201782"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_half_aceil_x.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_half_aceil_x.txt
new file mode 100644
index 0000000000..a8f866a49e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_half_aceil_x.txt
@@ -0,0 +1,426 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0"
+ }
+ "Node_006"
+ {
+ "iType" "32"
+ "pos_x" "236.617126"
+ "pos_y" "-19.775772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_008"
+ {
+ "iType" "4"
+ "pos_x" "593.042542"
+ "pos_y" "-237.108063"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_009"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_010"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "5"
+ }
+ "Node_011"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_012"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3 0"
+ }
+ "Node_013"
+ {
+ "iType" "65"
+ "pos_x" "-581.786926"
+ "pos_y" "-207.983063"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_014"
+ {
+ "iType" "91"
+ "pos_x" "-174.190094"
+ "pos_y" "-306.377716"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "5"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.054489 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.402620 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_004" "0.054489 0.000000 0.000000 0.000000"
+ }
+ "Node_015"
+ {
+ "iType" "17"
+ "pos_x" "-216.634644"
+ "pos_y" "-151.114883"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "-74.834290"
+ "pos_y" "-153.075058"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_017"
+ {
+ "iType" "19"
+ "pos_x" "259.984253"
+ "pos_y" "-305.213104"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_018"
+ {
+ "iType" "17"
+ "pos_x" "410.944824"
+ "pos_y" "-265.616486"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "26"
+ "pos_x" "179.168472"
+ "pos_y" "-148.129318"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "52"
+ "pos_x" "44.910141"
+ "pos_y" "-268.859100"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_half_aceil_y.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_half_aceil_y.txt
new file mode 100644
index 0000000000..6f72d82137
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_half_aceil_y.txt
@@ -0,0 +1,387 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "32"
+ "pos_x" "236.617126"
+ "pos_y" "-19.775772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_007"
+ {
+ "iType" "4"
+ "pos_x" "593.042542"
+ "pos_y" "-237.108063"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_008"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_009"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "5"
+ }
+ "Node_010"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_011"
+ {
+ "iType" "65"
+ "pos_x" "-581.786926"
+ "pos_y" "-207.983063"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_012"
+ {
+ "iType" "91"
+ "pos_x" "-174.190094"
+ "pos_y" "-306.377716"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "5"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.054489 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.402620 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_004" "0.054489 0.000000 0.000000 0.000000"
+ }
+ "Node_013"
+ {
+ "iType" "17"
+ "pos_x" "-216.634644"
+ "pos_y" "-151.114883"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "-74.834290"
+ "pos_y" "-153.075058"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_015"
+ {
+ "iType" "17"
+ "pos_x" "410.944824"
+ "pos_y" "-265.616486"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 3"
+ }
+ "Node_017"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_018"
+ {
+ "iType" "19"
+ "pos_x" "208.174164"
+ "pos_y" "-278.705597"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_x.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_x.txt
new file mode 100644
index 0000000000..4b4893c09a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_x.txt
@@ -0,0 +1,388 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_002"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0"
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "212.829498"
+ "pos_y" "-265.861786"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "17"
+ "pos_x" "381.332489"
+ "pos_y" "-224.614197"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "32"
+ "pos_x" "236.617126"
+ "pos_y" "-19.775772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_008"
+ {
+ "iType" "4"
+ "pos_x" "593.042542"
+ "pos_y" "-237.108063"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_009"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "39.528137"
+ "pos_y" "-171.755798"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_010"
+ {
+ "iType" "17"
+ "pos_x" "-116.086060"
+ "pos_y" "-170.705902"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "5"
+ }
+ "Node_012"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_013"
+ {
+ "iType" "91"
+ "pos_x" "-24.112915"
+ "pos_y" "-305.494904"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "5"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.054489 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.402620 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_004" "0.054489 0.000000 0.000000 0.000000"
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3 0"
+ }
+ "Node_015"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_016"
+ {
+ "iType" "65"
+ "pos_x" "-636.945313"
+ "pos_y" "-203.866547"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "4.000000"
+ }
+ "Node_017"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_018"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_normal_compression" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_y.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_y.txt
new file mode 100644
index 0000000000..00f70093cd
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_5_y.txt
@@ -0,0 +1,387 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "212.829498"
+ "pos_y" "-265.861786"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "17"
+ "pos_x" "381.332489"
+ "pos_y" "-224.614197"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "32"
+ "pos_x" "236.617126"
+ "pos_y" "-19.775772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_009"
+ {
+ "iType" "4"
+ "pos_x" "593.042542"
+ "pos_y" "-237.108063"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_010"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_011"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "39.528137"
+ "pos_y" "-171.755798"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_012"
+ {
+ "iType" "17"
+ "pos_x" "-116.086060"
+ "pos_y" "-170.705902"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_015"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "5"
+ }
+ "Node_016"
+ {
+ "iType" "91"
+ "pos_x" "-24.112915"
+ "pos_y" "-305.494904"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "5"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.054489 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.402620 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "0.244201 0.000000 0.000000 0.000000"
+ "pfl_arraydata_004" "0.054489 0.000000 0.000000 0.000000"
+ }
+ "Node_017"
+ {
+ "iType" "65"
+ "pos_x" "-581.786926"
+ "pos_y" "-207.983063"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "4.000000"
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 3"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_7_half_aceil_x.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_7_half_aceil_x.txt
new file mode 100644
index 0000000000..361d83732a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_7_half_aceil_x.txt
@@ -0,0 +1,588 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0"
+ }
+ "Node_006"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_007"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_008"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_009"
+ {
+ "iType" "17"
+ "pos_x" "-216.634644"
+ "pos_y" "-151.114883"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "-74.834290"
+ "pos_y" "-153.075058"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_011"
+ {
+ "iType" "19"
+ "pos_x" "259.984253"
+ "pos_y" "-305.213104"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_012"
+ {
+ "iType" "17"
+ "pos_x" "410.944824"
+ "pos_y" "-265.616486"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "26"
+ "pos_x" "179.168472"
+ "pos_y" "-148.129318"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "4 0"
+ }
+ "Node_015"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "7"
+ }
+ "Node_016"
+ {
+ "iType" "65"
+ "pos_x" "-581.786926"
+ "pos_y" "-207.983063"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_017"
+ {
+ "iType" "32"
+ "pos_x" "161.546570"
+ "pos_y" "-18.687790"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "91"
+ "pos_x" "-174.190094"
+ "pos_y" "-306.377716"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "7"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.167839 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.684901 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "1.592437 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "2.109639 0.000000 0.000000 0.000000"
+ "pfl_arraydata_004" "1.592437 0.000000 0.000000 0.000000"
+ "pfl_arraydata_005" "0.684901 0.000000 0.000000 0.000000"
+ "pfl_arraydata_006" "0.167839 0.000000 0.000000 0.000000"
+ }
+ "Node_019"
+ {
+ "iType" "52"
+ "pos_x" "-14.484085"
+ "pos_y" "-302.268311"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "17"
+ "pos_x" "110.206512"
+ "pos_y" "-326.754730"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_021"
+ {
+ "iType" "5"
+ "pos_x" "355.721619"
+ "pos_y" "-17.060547"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_022"
+ {
+ "iType" "32"
+ "pos_x" "446.040955"
+ "pos_y" "-21.417908"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_023"
+ {
+ "iType" "27"
+ "pos_x" "597.386292"
+ "pos_y" "-302.693115"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "a"
+ }
+ "Node_024"
+ {
+ "iType" "20"
+ "pos_x" "608.026794"
+ "pos_y" "-439.866333"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "20"
+ "pos_x" "609.138672"
+ "pos_y" "-554.029724"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "493.890076"
+ "pos_y" "-548.868958"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "7"
+ }
+ "Node_027"
+ {
+ "iType" "26"
+ "pos_x" "758.327759"
+ "pos_y" "-484.139374"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "27"
+ "pos_x" "598.730164"
+ "pos_y" "-180.384979"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "rgb"
+ }
+ "Node_029"
+ {
+ "iType" "4"
+ "pos_x" "829.138428"
+ "pos_y" "-356.611115"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_7_half_aceil_y.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_7_half_aceil_y.txt
new file mode 100644
index 0000000000..f2864f4110
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_7_half_aceil_y.txt
@@ -0,0 +1,566 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "32"
+ "pos_x" "236.617126"
+ "pos_y" "-19.775772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_007"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_008"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_009"
+ {
+ "iType" "17"
+ "pos_x" "-216.634644"
+ "pos_y" "-151.114883"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "-74.834290"
+ "pos_y" "-153.075058"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_011"
+ {
+ "iType" "17"
+ "pos_x" "410.944824"
+ "pos_y" "-265.616486"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_013"
+ {
+ "iType" "65"
+ "pos_x" "-581.786926"
+ "pos_y" "-207.983063"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 4"
+ }
+ "Node_015"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "7"
+ }
+ "Node_016"
+ {
+ "iType" "52"
+ "pos_x" "-56.824356"
+ "pos_y" "-288.890015"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "5"
+ "pos_x" "313.381317"
+ "pos_y" "-3.682236"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_018"
+ {
+ "iType" "32"
+ "pos_x" "403.700653"
+ "pos_y" "-8.039597"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "91"
+ "pos_x" "-174.190094"
+ "pos_y" "-306.377716"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "7"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.167839 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.684901 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "1.592437 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "2.109639 0.000000 0.000000 0.000000"
+ "pfl_arraydata_004" "1.592437 0.000000 0.000000 0.000000"
+ "pfl_arraydata_005" "0.684901 0.000000 0.000000 0.000000"
+ "pfl_arraydata_006" "0.167839 0.000000 0.000000 0.000000"
+ }
+ "Node_020"
+ {
+ "iType" "19"
+ "pos_x" "236.399139"
+ "pos_y" "-255.856812"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_021"
+ {
+ "iType" "17"
+ "pos_x" "94.327011"
+ "pos_y" "-284.605896"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "4"
+ "pos_x" "928.526123"
+ "pos_y" "-438.840302"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_023"
+ {
+ "iType" "27"
+ "pos_x" "631.622620"
+ "pos_y" "-146.095581"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "rgb"
+ }
+ "Node_024"
+ {
+ "iType" "27"
+ "pos_x" "630.278748"
+ "pos_y" "-268.403717"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "a"
+ }
+ "Node_025"
+ {
+ "iType" "20"
+ "pos_x" "640.919250"
+ "pos_y" "-405.576935"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "20"
+ "pos_x" "642.031128"
+ "pos_y" "-519.740295"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "5"
+ "pos_x" "526.782532"
+ "pos_y" "-514.579590"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "7"
+ }
+ "Node_028"
+ {
+ "iType" "26"
+ "pos_x" "791.220215"
+ "pos_y" "-449.849915"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_half_3_x.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_half_3_x.txt
new file mode 100644
index 0000000000..fdb2bf6801
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_half_3_x.txt
@@ -0,0 +1,385 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "212.829498"
+ "pos_y" "-265.861786"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "17"
+ "pos_x" "381.332489"
+ "pos_y" "-224.614197"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "32"
+ "pos_x" "236.617126"
+ "pos_y" "-19.775772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_010"
+ {
+ "iType" "4"
+ "pos_x" "593.042542"
+ "pos_y" "-237.108063"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_011"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_012"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "39.528137"
+ "pos_y" "-171.755798"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_013"
+ {
+ "iType" "17"
+ "pos_x" "-116.086060"
+ "pos_y" "-170.705902"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_015"
+ {
+ "iType" "65"
+ "pos_x" "-581.786926"
+ "pos_y" "-207.983063"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_016"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "3"
+ }
+ "Node_017"
+ {
+ "iType" "91"
+ "pos_x" "-24.112915"
+ "pos_y" "-305.494904"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "3"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.196842 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.606316 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.196842 0.000000 0.000000 0.000000"
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2 0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_half_3_y.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_half_3_y.txt
new file mode 100644
index 0000000000..fefb98c39c
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/gauss_blur_half_3_y.txt
@@ -0,0 +1,385 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "18"
+ "pos_x" "-204.083435"
+ "pos_y" "21.515930"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-391.139374"
+ "pos_y" "-64.831940"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "212.829498"
+ "pos_y" "-265.861786"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "17"
+ "pos_x" "381.332489"
+ "pos_y" "-224.614197"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "32"
+ "pos_x" "236.617126"
+ "pos_y" "-19.775772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "5"
+ "pos_x" "75.223198"
+ "pos_y" "-20.241486"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_009"
+ {
+ "iType" "4"
+ "pos_x" "593.042542"
+ "pos_y" "-237.108063"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_010"
+ {
+ "iType" "3"
+ "pos_x" "-480.944702"
+ "pos_y" "63.377457"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_011"
+ {
+ "iType" "29"
+ "szName" "Basetexture"
+ "pos_x" "39.528137"
+ "pos_y" "-171.755798"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_012"
+ {
+ "iType" "17"
+ "pos_x" "-116.086060"
+ "pos_y" "-170.705902"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "19"
+ "pos_x" "-418.328369"
+ "pos_y" "-316.456818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-584.292053"
+ "pos_y" "-318.338257"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "pos_x" "-576.380432"
+ "pos_y" "-75.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 2"
+ }
+ "Node_016"
+ {
+ "iType" "65"
+ "pos_x" "-581.786926"
+ "pos_y" "-207.983063"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_017"
+ {
+ "iType" "91"
+ "pos_x" "-24.112915"
+ "pos_y" "-305.494904"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "3"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.196842 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.606316 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.196842 0.000000 0.000000 0.000000"
+ }
+ "Node_018"
+ {
+ "iType" "30"
+ "pos_x" "-311.446960"
+ "pos_y" "-252.893036"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "169.419739"
+ "container_extents_y" "794.226563"
+ "container_extents_z" "-169.419739"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "3"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_calc.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_calc.txt
new file mode 100644
index 0000000000..16aef829ec
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_calc.txt
@@ -0,0 +1,218 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-348.387299"
+ "pos_y" "-95.935318"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_004"
+ {
+ "iType" "94"
+ "pos_x" "-332.935516"
+ "pos_y" "-230.558411"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "szFallbackTexturePath" "white"
+ "iFallbackMode" "0"
+ }
+ "Node_005"
+ {
+ "iType" "65"
+ "pos_x" "-327.089508"
+ "pos_y" "-148.880356"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_006"
+ {
+ "iType" "4"
+ "pos_x" "293.722473"
+ "pos_y" "-125.284317"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_007"
+ {
+ "iType" "27"
+ "pos_x" "123.001160"
+ "pos_y" "-120.086807"
+ "size_x" "121.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "r r r 1"
+ }
+ "Node_008"
+ {
+ "iType" "99"
+ "pos_x" "-117.711853"
+ "pos_y" "-117.288940"
+ "size_x" "155.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "varName_In_0" "uv"
+ "varType_In_0" "2"
+ "varName_In_1" "texelSize"
+ "varType_In_1" "2"
+ "varName_In_2" "color_depth"
+ "varType_In_2" "128"
+ "varName_Out_0" "ao_out"
+ "varType_Out_0" "1"
+ "szFunctionName" "DoSSAO"
+ "iInline" "1"
+ "szcode_global_num_strings" "4"
+ "szcode_global_partial_00" "#define PI 3.14159265\r\n\r\n//--------------------------------------------------------\r\n//a list of user parameters\r\n\r\n#define METHOD 0\r\n\r\nstatic float near = 7; //Z-near\r\nstatic float far = 192.0; //Z-far\r\nstatic float zScaleLinear = near / far;\r\nstatic float zScaleLinearRev = far / near;\r\n\r\n#if ( METHOD == 0 )\r\nstatic int samples = 3; //samples on the first ring (3 - 5)\r\nstatic int rings = 3; //ring count (3 - 5)\r\nstatic float radius_close = 6.0; //ao radius\r\nstatic float radius_far = 0.5; //ao radius\r\n#else\r\nstatic int samples = 24; //samples on the first ring (3 - 5)\r\nstatic float radius_close = 7.0; //ao radius\r\nstatic float radius_far = 1.5; //ao radius\r\n#endif\r\n\r\nstatic float dist_exp = 6.0f;\r\n\r\nstatic float diffarea = 0.45; //self-shadowing reduction\r\nstatic float gdisplace = 0.4; //gauss bell center\r\n\r\nstatic float lumInfluence = 0.4; //how much luminance affects occlusion\r\nstatic float aoBoost_far = 2.5f;\r\nstatic float aoBoost_close = 6.0f;\"
+ "szcode_global_partial_01" "r\n\r\nstatic bool noise = true; //use noise instead of pattern for sample dithering?\r\nstatic bool onlyAO = true; //use only ambient occlusion pass?\r\nstatic bool fadeout = true;\r\n\r\n//--------------------------------------------------------\r\n\r\nfloat2 rand(float2 coord, float2 size) //generating noise/pattern texture for dithering\r\n{\r\n float noiseX = ((frac(1.0-coord.x*(size.x/2.0))*0.25)+(frac(coord.y*(size.y/2.0))*0.75))*2.0-1.0;\r\n float noiseY = ((frac(1.0-coord.x*(size.x/2.0))*0.75)+(frac(coord.y*(size.y/2.0))*0.25))*2.0-1.0;\r\n \r\n if (noise)\r\n {\r\n noiseX = frac(sin(dot(coord ,float2(12.9898,78.233))) * 43758.5453) * 2.0-1.0;\r\n noiseY = frac(sin(dot(coord ,float2(12.9898,78.233)*2.0)) * 43758.5453) * 2.0-1.0;\r\n }\r\n return float2(noiseX,noiseY)*0.001;\r\n}\r\n\r\nfloat readDepth(in float2 coord, sampler tex)\r\n{\r\n return tex2D(tex, coord ).a * zScaleLinear;\r\n //return (2.0 * near) / (far + near - tex2D(tex, coord ).a * (far-near));\r\n}\r\n\r\nfloat readDepth(float linD"
+ "szcode_global_partial_02" "epth)\r\n{\r\n return linDepth * zScaleLinear;\r\n}\r\n\r\nfloat compareDepths(in float depth1, in float depth2,inout int far)\r\n{\r\n float garea = 2.0; //gauss bell width \r\n float diff = (depth1 - depth2)*100.0; //depth difference (0-100)\r\n //reduce left bell width to avoid self-shadowing \r\n\r\n\r\n if ( diff < gdisplace )\r\n {\r\n garea = diffarea;\r\n }else{\r\n far = 1;\r\n }\r\n \r\n float gauss = pow(2.7182,-2.0*(diff-gdisplace)*(diff-gdisplace)/(garea*garea));\r\n return gauss;\r\n}\r\n\r\nfloat calAO(float2 uv,float localDepth, float depth, float dw, float dh, sampler tex)\r\n{\r\n float dd = (1.0-depth)*lerp( radius_far, radius_close, localDepth );\r\n\r\n float temp = 0.0;\r\n float temp2 = 0.0;\r\n float coordw = uv.x + dw*dd;\r\n float coordh = uv.y + dh*dd;\r\n float coordw2 = uv.x - dw*dd;\r\n float coordh2 = uv.y - dh*dd;\r\n \r\n float2 coord = float2(coordw , coordh);\r\n float2 coord2 = float2(coordw2, coordh2);\r\n \r\n int far = 0;\r\n temp = compareDepths(depth, readDepth(coo"
+ "szcode_global_partial_03" "rd,tex),far);\r\n //DEPTH EXTRAPOLATION:\r\n if (far > 0)\r\n {\r\n temp2 = compareDepths(readDepth(coord2,tex),depth,far);\r\n temp += (1.0-temp)*temp2;\r\n }\r\n \r\n return temp;\r\n}\n"
+ "szcode_body_num_strings" "2"
+ "szcode_body_partial_00" " float2 size = 1.0f / texelSize;\r\n\r\n float2 noise = rand(uv,size);\r\n float depthSample = tex2D(color_depth, uv ).a;\r\n float depth = readDepth(depthSample);\r\n depthSample = pow( (1.0f - depthSample), dist_exp );\r\n float d;\r\n \r\n float w = texelSize.x/clamp(depth,0.25,1.0)+(noise.x*(1.0-noise.x));\r\n float h = texelSize.y/clamp(depth,0.25,1.0)+(noise.y*(1.0-noise.y));\r\n \r\n float pw;\r\n float ph;\r\n \r\n float ao;\r\n float s;\r\n \r\n int ringsamples;\r\n\r\n#if (METHOD == 0)\r\n for (int i = 1; i <= rings; i++)\r\n {\r\n ringsamples = i * samples;\r\n for (int j = 0 ; j < ringsamples ; j += 1)\r\n {\r\n float step = PI*2.0 / float(ringsamples);\r\n pw = (cos(float(j)*step)*float(i));\r\n ph = (sin(float(j)*step)*float(i));\r\n ao += calAO( uv, depthSample, depth, pw*w, ph*h, color_depth );\r\n s += 1.0;\r\n }\r\n }\r\n ao /= s;\r\n ao = 1.0-ao;\r\n#else\r\n float dl = PI*(3.0-sqrt(5.0));\r\n float dz = 1.0/float(samples);\r\n float l = 0.0;\r\n float z = 1.0 - dz/2.0;\r\n\r"
+ "szcode_body_partial_01" "\n for (int i = 0; i <= samples; i ++)\r\n {\r\n float r = sqrt(1.0-z);\r\n\r\n pw = cos(l)*r;\r\n ph = sin(l)*r;\r\n ao += calAO(uv,depthSample,depth,pw*w,ph*h,color_depth);\r\n z = z - dz;\r\n l = l + dl;\r\n }\r\n\r\n ao /= float(samples);\r\n ao = 1.0-ao;\r\n#endif\r\n\r\n float3 color = tex2D(color_depth,uv).rgb;\r\n \r\n float3 lumcoeff = float3(0.299,0.587,0.114);\r\n float lum = dot(color.rgb, lumcoeff);\r\n float3 luminance = float3(lum, lum, lum);\r\n\r\n ao = pow( ao, lerp( aoBoost_far, aoBoost_close, depthSample ) );\r\n\r\n //lum = lerp(ao,1.0,luminance*lumInfluence);\r\n ao_out = lerp(ao,1.0,luminance*lumInfluence);\r\n\r\n if ( fadeout )\r\n {\r\n float fade = depth * zScaleLinearRev;\r\n ao_out = lerp( ao_out, 0.65, pow( fade, 3 ) );\r\n }\r\n\r\n //if(onlyAO)\r\n // ao = lum; //ambient occlusion only\r\n //else\r\n // col = color * lum;"
+ "iEnvFlags" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_combine.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_combine.txt
new file mode 100644
index 0000000000..8e32fa59ae
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_combine.txt
@@ -0,0 +1,291 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_003"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-160.933746"
+ "pos_y" "-77.726196"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_004"
+ {
+ "iType" "3"
+ "pos_x" "-379.810669"
+ "pos_y" "-127.009460"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_005"
+ {
+ "iType" "4"
+ "pos_x" "413.917175"
+ "pos_y" "-372.455292"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_006"
+ {
+ "iType" "26"
+ "pos_x" "334.980042"
+ "pos_y" "-168.996613"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "29"
+ "szName" "ssao"
+ "pos_x" "-312.903229"
+ "pos_y" "-255.193512"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "ssao_ref"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "white"
+ "szFallbackTexturePath" "white"
+ "iFallbackMode" "0"
+ }
+ "Node_008"
+ {
+ "iType" "5"
+ "pos_x" "-237.566864"
+ "pos_y" "-396.292816"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_009"
+ {
+ "iType" "19"
+ "pos_x" "-108.813339"
+ "pos_y" "-262.461884"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_010"
+ {
+ "iType" "19"
+ "pos_x" "56.939232"
+ "pos_y" "-107.739929"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_011"
+ {
+ "iType" "19"
+ "pos_x" "193.619293"
+ "pos_y" "-115.752502"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_012"
+ {
+ "iType" "5"
+ "pos_x" "75.800476"
+ "pos_y" "-255.146667"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.85"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_fxaa.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_fxaa.txt
new file mode 100644
index 0000000000..abec4989ea
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/ssao_fxaa.txt
@@ -0,0 +1,198 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-320.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "4"
+ "pos_x" "265.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_004"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_005"
+ {
+ "iType" "65"
+ "pos_x" "-215.473480"
+ "pos_y" "-208.660767"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "2.000000"
+ }
+ "Node_006"
+ {
+ "iType" "94"
+ "pos_x" "-235.637070"
+ "pos_y" "-44.984234"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "_rt_fullframefb"
+ "szFallbackTexturePath" "_rt_fullframefb"
+ "iFallbackMode" "4"
+ }
+ "Node_007"
+ {
+ "iType" "99"
+ "pos_x" "-7.115566"
+ "pos_y" "-108.856155"
+ "size_x" "133.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "varName_In_0" "tex"
+ "varType_In_0" "128"
+ "varName_In_1" "uv"
+ "varType_In_1" "2"
+ "varName_In_2" "texelsize"
+ "varType_In_2" "2"
+ "varName_Out_0" "col"
+ "varType_Out_0" "8"
+ "szFunctionName" "DoFXAA"
+ "szFilePath" "shadereditorui\user_functions\call_fxaa.ufunc"
+ "iInline" "1"
+ "szcode_global_num_strings" "1"
+ "szcode_global_partial_00" "#define FXAA_PC 1\r\n#define FXAA_HLSL_3 1\r\n#define FXAA_GREEN_AS_LUMA 1\r\n#define FXAA_DISCARD 1\r\n#define FXAA_QUALITY__PRESET 10\r\n\r\n#include \'fxaa3_11.h\'\n"
+ "szcode_body_num_strings" "2"
+ "szcode_body_partial_00" " col = FxaaPixelShader( uv,\r\n (float4)0,\r\n tex,\r\n tex,\r\n tex,\r\n texelsize,\r\n (float4)0,\r\n (float4)0,\r\n (float4)0,\r\n // fxaaQualitySubpix\r\n // This used to be the FXAA_QUALITY__SUBPIX define.\r\n // It is here now to allow easier tuning.\r\n // Choose the amount of sub-pixel aliasing removal.\r\n // This can effect sharpness.\r\n // 1.00 - upper limit (softer)\r\n // 0.75 - default amount of filtering\r\n // 0.50 - lower limit (sharper, less sub-pixel aliasing removal)\r\n // 0.25 - almost off\r\n // 0.00 - completely off\r\n 0.5,\r\n // This used to be the FXAA_QUALITY__EDGE_THRESHOLD define.\r\n // It is here now to allow easier tuning.\r\n // The minimum amount of local contrast required to apply algorithm.\r\n // 0.333 - too little (faster)\r\n // 0.250 - low quality\r\n // 0.166 - default\r\n // 0.125 - high quality \r\n // 0.063 - overkill (slower)\r\n // fxaaQualityEdgeThreshold\r\n 0.2,\r\n // This used to be the"
+ "szcode_body_partial_01" " FXAA_QUALITY__EDGE_THRESHOLD_MIN define.\r\n // It is here now to allow easier tuning.\r\n // Trims the algorithm from processing darks.\r\n // 0.0833 - upper limit (default, the start of visible unfiltered edges)\r\n // 0.0625 - high quality (faster)\r\n // 0.0312 - visible limit (slower)\r\n // Special notes when using FXAA_GREEN_AS_LUMA,\r\n // Likely want to set this to zero.\r\n // As colors that are mostly not-green\r\n // will appear very dark in the green channel!\r\n // Tune by looking at mostly non-green content,\r\n // then start at zero and increase until aliasing is a problem.\r\n 0.0833,\r\n 0, 0, 0, (float4)0 );"
+ "iEnvFlags" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/sunrays_calc.txt b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/sunrays_calc.txt
new file mode 100644
index 0000000000..c51dc00499
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/post_processing_shaders/sunrays_calc.txt
@@ -0,0 +1,690 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-369.133759"
+ "pos_y" "413.831604"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_normal_compression" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "27"
+ "pos_x" "-97.007080"
+ "pos_y" "438.414795"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_002"
+ {
+ "iType" "19"
+ "pos_x" "-615.955444"
+ "pos_y" "119.945175"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_003"
+ {
+ "iType" "29"
+ "pos_x" "-594.301880"
+ "pos_y" "-364.289246"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "skymask"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_SEdit_Skymask"
+ "szFallbackTexturePath" "_rt_SEdit_Skymask"
+ "iFallbackMode" "4"
+ }
+ "Node_004"
+ {
+ "iType" "32"
+ "pos_x" "-29.150803"
+ "pos_y" "85.170311"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "32"
+ "pos_x" "-294.139954"
+ "pos_y" "59.593613"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "17"
+ "pos_x" "6.081223"
+ "pos_y" "-174.885757"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "19"
+ "pos_x" "-365.196777"
+ "pos_y" "-357.511566"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_008"
+ {
+ "iType" "19"
+ "pos_x" "-219.009598"
+ "pos_y" "-129.055420"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_009"
+ {
+ "iType" "77"
+ "pos_x" "-1579.997070"
+ "pos_y" "17.428398"
+ "size_x" "87.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "sz_callbackname" "sun_data"
+ "i_numc" "4"
+ }
+ "Node_010"
+ {
+ "iType" "27"
+ "pos_x" "-1398.426025"
+ "pos_y" "27.421875"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_011"
+ {
+ "iType" "24"
+ "pos_x" "-1250.151611"
+ "pos_y" "-120.341331"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "18"
+ "pos_x" "-1231.405273"
+ "pos_y" "32.186623"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "20"
+ "pos_x" "-1021.170715"
+ "pos_y" "29.846634"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "19"
+ "pos_x" "-858.426941"
+ "pos_y" "29.865776"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "pos_x" "-1146.366211"
+ "pos_y" "-245.801086"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_016"
+ {
+ "iType" "34"
+ "pos_x" "-1030.961792"
+ "pos_y" "-119.189270"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "5"
+ "pos_x" "-1013.829529"
+ "pos_y" "-257.518433"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_018"
+ {
+ "iType" "60"
+ "pos_x" "-966.421631"
+ "pos_y" "-763.218994"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "27"
+ "pos_x" "-1171.092407"
+ "pos_y" "-758.590881"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_020"
+ {
+ "iType" "32"
+ "pos_x" "-658.067200"
+ "pos_y" "-88.285919"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_021"
+ {
+ "iType" "32"
+ "pos_x" "-1044.753418"
+ "pos_y" "-388.183014"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "19"
+ "pos_x" "-156.000977"
+ "pos_y" "-344.667419"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_023"
+ {
+ "iType" "18"
+ "pos_x" "-543.765747"
+ "pos_y" "-172.061813"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "3"
+ "pos_x" "-1774.872437"
+ "pos_y" "-427.163544"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "1"
+ "numTexcoord_Name_1" "noisescale"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_025"
+ {
+ "iType" "2"
+ "pos_x" "215.866226"
+ "pos_y" "413.831604"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "1"
+ "numTexcoord_Name_1" "noisescale"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "-386.296631"
+ "pos_y" "61.181686"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_027"
+ {
+ "iType" "5"
+ "pos_x" "-103.737068"
+ "pos_y" "88.013390"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_028"
+ {
+ "iType" "4"
+ "pos_x" "164.190826"
+ "pos_y" "-850.315674"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_029"
+ {
+ "iType" "27"
+ "pos_x" "-8.718872"
+ "pos_y" "-847.757568"
+ "size_x" "123.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "r g b 1"
+ }
+ "Node_030"
+ {
+ "iType" "30"
+ "pos_x" "-809.897095"
+ "pos_y" "-277.381805"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "264.560059"
+ "container_extents_y" "916.935791"
+ "container_extents_z" "-264.560059"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "35"
+ }
+ "Node_031"
+ {
+ "iType" "5"
+ "pos_x" "-450.963867"
+ "pos_y" "-657.008728"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.06"
+ }
+ "Node_032"
+ {
+ "iType" "5"
+ "szName" "decay"
+ "pos_x" "-332.019897"
+ "pos_y" "-73.928772"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.95"
+ }
+ "Node_033"
+ {
+ "iType" "5"
+ "szName" "sample delta"
+ "pos_x" "-812.319031"
+ "pos_y" "167.148071"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.011"
+ }
+ "Node_034"
+ {
+ "iType" "19"
+ "pos_x" "-302.042847"
+ "pos_y" "-631.567932"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_035"
+ {
+ "iType" "19"
+ "pos_x" "-147.744141"
+ "pos_y" "-832.504517"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_depthglow.txt b/mp/game/momentum/shadereditorui/canvas/postproc_depthglow.txt
new file mode 100644
index 0000000000..5d05e4c13b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_depthglow.txt
@@ -0,0 +1,597 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_002"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-186.882889"
+ "pos_y" "-125.806458"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_004"
+ {
+ "iType" "3"
+ "pos_x" "-707.202209"
+ "pos_y" "-150.461899"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "-970.454651"
+ "pos_y" "-730.560852"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "32"
+ "pos_x" "-949.107361"
+ "pos_y" "-617.122009"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "17"
+ "pos_x" "-829.617004"
+ "pos_y" "-695.046082"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-686.898865"
+ "pos_y" "-690.667175"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "bloom"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_SmallFB0"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_009"
+ {
+ "iType" "32"
+ "pos_x" "-660.873047"
+ "pos_y" "-495.843262"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-695.827393"
+ "pos_y" "-260.951355"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "bloom"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_SmallFB0"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_011"
+ {
+ "iType" "60"
+ "pos_x" "-445.761688"
+ "pos_y" "-316.271759"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "38"
+ "pos_x" "-453.860870"
+ "pos_y" "-671.084290"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "60"
+ "pos_x" "-453.105011"
+ "pos_y" "-260.090179"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "18"
+ "pos_x" "-315.315582"
+ "pos_y" "-279.445435"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "18"
+ "pos_x" "-157.908783"
+ "pos_y" "-300.027252"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "60"
+ "pos_x" "-20.079220"
+ "pos_y" "-290.683014"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "5"
+ "pos_x" "-278.908142"
+ "pos_y" "-408.470215"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.005"
+ }
+ "Node_018"
+ {
+ "iType" "19"
+ "pos_x" "204.830307"
+ "pos_y" "-289.669312"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_019"
+ {
+ "iType" "26"
+ "pos_x" "549.578613"
+ "pos_y" "-329.751282"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "4"
+ "pos_x" "727.434692"
+ "pos_y" "-383.447510"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_021"
+ {
+ "iType" "17"
+ "pos_x" "367.520386"
+ "pos_y" "-188.881012"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "5"
+ "pos_x" "-752.021973"
+ "pos_y" "-483.244202"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_023"
+ {
+ "iType" "5"
+ "pos_x" "92.758163"
+ "pos_y" "-363.587585"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 1.75 2.5"
+ }
+ "Node_024"
+ {
+ "iType" "65"
+ "pos_x" "-1465.070923"
+ "pos_y" "-547.997437"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_025"
+ {
+ "iType" "5"
+ "pos_x" "-1443.670776"
+ "pos_y" "-635.571045"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "4"
+ }
+ "Node_026"
+ {
+ "iType" "32"
+ "pos_x" "-1088.257446"
+ "pos_y" "-646.643005"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "19"
+ "pos_x" "-1321.347656"
+ "pos_y" "-578.446716"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_028"
+ {
+ "iType" "30"
+ "pos_x" "-1250.229980"
+ "pos_y" "-734.594299"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "191.497070"
+ "container_extents_y" "910.800293"
+ "container_extents_z" "-191.497070"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "4"
+ }
+ "Node_029"
+ {
+ "iType" "91"
+ "pos_x" "-1131.488647"
+ "pos_y" "-772.086182"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "4"
+ "i_array_size_y" "1"
+ "i_array_datatype" "2"
+ "pfl_arraydata_000" "1.000000 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.000000 1.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "-1.000000 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "0.000000 -1.000000 0.000000 0.000000"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_drunk.txt b/mp/game/momentum/shadereditorui/canvas/postproc_drunk.txt
new file mode 100644
index 0000000000..b140ac8f88
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_drunk.txt
@@ -0,0 +1,1502 @@
+"canvas"
+{
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-516.903992"
+ "pos_y" "277.512939"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ }
+ "Node_001"
+ {
+ "iType" "18"
+ "pos_x" "-408.617828"
+ "pos_y" "47.905617"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_002"
+ {
+ "iType" "5"
+ "pos_x" "-510.847198"
+ "pos_y" "-20.011536"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.5"
+ }
+ "Node_003"
+ {
+ "iType" "5"
+ "pos_x" "-175.559967"
+ "pos_y" "121.273743"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.65"
+ }
+ "Node_004"
+ {
+ "iType" "29"
+ "pos_x" "102.379456"
+ "pos_y" "-408.637177"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_005"
+ {
+ "iType" "40"
+ "pos_x" "-669.011475"
+ "pos_y" "-767.234009"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-561.168701"
+ "pos_y" "-766.807373"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "55"
+ "pos_x" "-64.971527"
+ "pos_y" "-413.693237"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "0"
+ "iTexTrans_trans" "1"
+ }
+ "Node_008"
+ {
+ "iType" "39"
+ "pos_x" "-652.363037"
+ "pos_y" "-249.866730"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "17"
+ "pos_x" "-596.108154"
+ "pos_y" "-399.983887"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "39"
+ "pos_x" "-480.064606"
+ "pos_y" "-397.067993"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "pos_x" "-241.426331"
+ "pos_y" "122.299164"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_012"
+ {
+ "iType" "21"
+ "pos_x" "303.656982"
+ "pos_y" "-340.224884"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "5"
+ "pos_x" "-360.762238"
+ "pos_y" "-74.076584"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_014"
+ {
+ "iType" "19"
+ "pos_x" "-250.120178"
+ "pos_y" "-70.985321"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "pos_x" "-91.839912"
+ "pos_y" "-94.749863"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.65"
+ }
+ "Node_016"
+ {
+ "iType" "5"
+ "pos_x" "-629.748901"
+ "pos_y" "-863.012085"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.05"
+ }
+ "Node_017"
+ {
+ "iType" "5"
+ "pos_x" "617.534119"
+ "pos_y" "-1249.450562"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_018"
+ {
+ "iType" "17"
+ "pos_x" "819.298157"
+ "pos_y" "-1115.458740"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "8"
+ "pos_x" "-1486.527954"
+ "pos_y" "-588.008545"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_020"
+ {
+ "iType" "27"
+ "pos_x" "-1366.368042"
+ "pos_y" "-515.957520"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_021"
+ {
+ "iType" "27"
+ "pos_x" "-1371.194458"
+ "pos_y" "-636.395996"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_022"
+ {
+ "iType" "48"
+ "pos_x" "-1206.180298"
+ "pos_y" "-580.299683"
+ "size_x" "61.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_023"
+ {
+ "iType" "56"
+ "pos_x" "-1095.629272"
+ "pos_y" "-581.361450"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "20"
+ "pos_x" "-977.288696"
+ "pos_y" "-581.534424"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "5"
+ "pos_x" "-1058.765747"
+ "pos_y" "-693.790283"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "57.295776"
+ }
+ "Node_026"
+ {
+ "iType" "12"
+ "pos_x" "-1156.425171"
+ "pos_y" "-390.390503"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_027"
+ {
+ "iType" "17"
+ "pos_x" "-959.325562"
+ "pos_y" "-391.358124"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "19"
+ "pos_x" "-400.882904"
+ "pos_y" "-249.125397"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "27"
+ "pos_x" "-424.661621"
+ "pos_y" "-767.981812"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_030"
+ {
+ "iType" "19"
+ "pos_x" "18.802147"
+ "pos_y" "-91.658585"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "55"
+ "pos_x" "-73.814423"
+ "pos_y" "-274.443085"
+ "size_x" "120.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "0"
+ }
+ "Node_032"
+ {
+ "iType" "34"
+ "pos_x" "-120.042076"
+ "pos_y" "47.017868"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_033"
+ {
+ "iType" "61"
+ "pos_x" "34.517963"
+ "pos_y" "47.900482"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_034"
+ {
+ "iType" "5"
+ "pos_x" "-707.252563"
+ "pos_y" "-443.805450"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_035"
+ {
+ "iType" "5"
+ "pos_x" "-582.645508"
+ "pos_y" "-569.652344"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_036"
+ {
+ "iType" "5"
+ "pos_x" "-588.662109"
+ "pos_y" "-642.756714"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_037"
+ {
+ "iType" "34"
+ "pos_x" "-443.757294"
+ "pos_y" "-575.067444"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "5"
+ "pos_x" "-338.139496"
+ "pos_y" "-671.006348"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 1"
+ }
+ "Node_039"
+ {
+ "iType" "5"
+ "pos_x" "197.285217"
+ "pos_y" "-1411.111938"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 1"
+ }
+ "Node_040"
+ {
+ "iType" "8"
+ "pos_x" "179.054779"
+ "pos_y" "-1323.064575"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_041"
+ {
+ "iType" "19"
+ "pos_x" "672.022400"
+ "pos_y" "-1114.444824"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "23"
+ "pos_x" "314.767456"
+ "pos_y" "-1360.753296"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "5"
+ "pos_x" "359.045074"
+ "pos_y" "-1550.972290"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_044"
+ {
+ "iType" "5"
+ "pos_x" "356.362885"
+ "pos_y" "-1472.592651"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_045"
+ {
+ "iType" "34"
+ "pos_x" "450.462677"
+ "pos_y" "-1362.387329"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "19"
+ "pos_x" "550.083313"
+ "pos_y" "-1119.950562"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_047"
+ {
+ "iType" "24"
+ "pos_x" "-268.697662"
+ "pos_y" "47.995972"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_048"
+ {
+ "iType" "19"
+ "pos_x" "-386.568176"
+ "pos_y" "-392.194397"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "17"
+ "pos_x" "-280.066467"
+ "pos_y" "-575.197815"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "2"
+ "pos_x" "68.095909"
+ "pos_y" "277.512939"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_051"
+ {
+ "iType" "19"
+ "pos_x" "602.853210"
+ "pos_y" "-1351.782593"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_052"
+ {
+ "iType" "3"
+ "pos_x" "-599.670898"
+ "pos_y" "-177.963196"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_053"
+ {
+ "iType" "27"
+ "pos_x" "-258.896973"
+ "pos_y" "-848.784973"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_054"
+ {
+ "iType" "53"
+ "pos_x" "-130.638519"
+ "pos_y" "-977.708008"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_055"
+ {
+ "iType" "19"
+ "pos_x" "-132.156158"
+ "pos_y" "-1081.919556"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "5"
+ "pos_x" "-244.877563"
+ "pos_y" "-984.791260"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_057"
+ {
+ "iType" "29"
+ "pos_x" "91.298111"
+ "pos_y" "-291.983704"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_058"
+ {
+ "iType" "32"
+ "pos_x" "104.409470"
+ "pos_y" "-584.911926"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "27"
+ "pos_x" "388.715240"
+ "pos_y" "-1114.421997"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "a"
+ }
+ "Node_060"
+ {
+ "iType" "27"
+ "pos_x" "195.052719"
+ "pos_y" "-580.004272"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_061"
+ {
+ "iType" "27"
+ "pos_x" "190.681625"
+ "pos_y" "-686.546570"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_062"
+ {
+ "iType" "26"
+ "pos_x" "424.824921"
+ "pos_y" "-746.577393"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "19"
+ "pos_x" "226.367661"
+ "pos_y" "-855.003662"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "29"
+ "pos_x" "396.800781"
+ "pos_y" "-858.074280"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_065"
+ {
+ "iType" "32"
+ "pos_x" "504.789825"
+ "pos_y" "-483.075623"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "18"
+ "pos_x" "-133.858734"
+ "pos_y" "-857.044128"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_067"
+ {
+ "iType" "21"
+ "pos_x" "917.898499"
+ "pos_y" "-691.718323"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_068"
+ {
+ "iType" "19"
+ "pos_x" "1079.528931"
+ "pos_y" "-700.456787"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_069"
+ {
+ "iType" "4"
+ "pos_x" "1262.615845"
+ "pos_y" "-703.210083"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_070"
+ {
+ "iType" "17"
+ "pos_x" "388.202728"
+ "pos_y" "-629.031921"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "-262.876678"
+ "pos_y" "-1296.580566"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_072"
+ {
+ "iType" "49"
+ "pos_x" "-130.189240"
+ "pos_y" "-1185.698853"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_073"
+ {
+ "iType" "37"
+ "pos_x" "-136.346344"
+ "pos_y" "-1292.088989"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_074"
+ {
+ "iType" "5"
+ "pos_x" "-241.786591"
+ "pos_y" "-1199.889771"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_075"
+ {
+ "iType" "5"
+ "pos_x" "-251.080399"
+ "pos_y" "-1098.499268"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2.4"
+ }
+ "Node_076"
+ {
+ "iType" "5"
+ "pos_x" "123.383324"
+ "pos_y" "-892.843689"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.002"
+ }
+ "Node_077"
+ {
+ "iType" "5"
+ "pos_x" "417.996002"
+ "pos_y" "-483.076721"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_078"
+ {
+ "iType" "17"
+ "pos_x" "556.697937"
+ "pos_y" "-622.484131"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_079"
+ {
+ "iType" "30"
+ "pos_x" "5.974243"
+ "pos_y" "-758.370728"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "221.222198"
+ "container_extents_y" "636.582764"
+ "container_extents_z" "-221.222198"
+ "loop_condition" "2"
+ "loop_value_min" "-10"
+ "loop_value_max" "10"
+ }
+ "Node_080"
+ {
+ "iType" "20"
+ "pos_x" "751.894531"
+ "pos_y" "-647.807739"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_081"
+ {
+ "iType" "5"
+ "pos_x" "755.336975"
+ "pos_y" "-524.061218"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "24"
+ }
+ "Node_082"
+ {
+ "iType" "27"
+ "pos_x" "-204.608841"
+ "pos_y" "299.279816"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ }
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_filmgrain.txt b/mp/game/momentum/shadereditorui/canvas/postproc_filmgrain.txt
new file mode 100644
index 0000000000..cc2713d4ce
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_filmgrain.txt
@@ -0,0 +1,702 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#002"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "53"
+ "pos_x" "-38.968803"
+ "pos_y" "-397.294556"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_001"
+ {
+ "iType" "19"
+ "pos_x" "98.478233"
+ "pos_y" "-367.401031"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_002"
+ {
+ "iType" "17"
+ "pos_x" "247.738037"
+ "pos_y" "-373.782776"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "50"
+ "pos_x" "174.049500"
+ "pos_y" "-225.131470"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "3"
+ "pos_x" "-398.377380"
+ "pos_y" "-133.358490"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_005"
+ {
+ "iType" "18"
+ "pos_x" "-156.413239"
+ "pos_y" "-408.062256"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-173.927490"
+ "pos_y" "-229.426270"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "5"
+ "pos_x" "-290.359222"
+ "pos_y" "-295.938782"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "10"
+ }
+ "Node_008"
+ {
+ "iType" "1"
+ "pos_x" "-369.736969"
+ "pos_y" "372.816986"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords" "2"
+ "dTFlag_Color" "8"
+ }
+ "Node_009"
+ {
+ "iType" "19"
+ "pos_x" "-182.680115"
+ "pos_y" "263.937012"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_010"
+ {
+ "iType" "27"
+ "pos_x" "-46.110237"
+ "pos_y" "247.472366"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_011"
+ {
+ "iType" "55"
+ "pos_x" "80.769218"
+ "pos_y" "283.525940"
+ "size_x" "91.000000"
+ "size_y" "-39.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_012"
+ {
+ "iType" "5"
+ "pos_x" "-309.826294"
+ "pos_y" "287.558502"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_013"
+ {
+ "iType" "12"
+ "pos_x" "-324.485809"
+ "pos_y" "213.213089"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-36.294399"
+ "pos_y" "199.702240"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "szConstantString" "0.0001 0.0001"
+ }
+ "Node_015"
+ {
+ "iType" "2"
+ "pos_x" "283.738525"
+ "pos_y" "367.338959"
+ "size_x" "55.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_016"
+ {
+ "iType" "20"
+ "pos_x" "89.661728"
+ "pos_y" "528.248657"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "65"
+ "pos_x" "-31.195328"
+ "pos_y" "484.970428"
+ "size_x" "60.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "pos_x" "-30.398453"
+ "pos_y" "541.159424"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_019"
+ {
+ "iType" "5"
+ "pos_x" "85.462997"
+ "pos_y" "471.348877"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "64"
+ }
+ "Node_020"
+ {
+ "iType" "20"
+ "pos_x" "231.879395"
+ "pos_y" "502.216919"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_021"
+ {
+ "iType" "17"
+ "pos_x" "-126.988373"
+ "pos_y" "-94.674225"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "81"
+ "pos_x" "-172.072479"
+ "pos_y" "-3.334938"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_num_comps" "1"
+ "fl_value_min" "0.000000"
+ "fl_value_max" "10.000000"
+ }
+ "Node_023"
+ {
+ "iType" "19"
+ "pos_x" "-245.665894"
+ "pos_y" "-93.921539"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_024"
+ {
+ "iType" "27"
+ "pos_x" "-61.266670"
+ "pos_y" "383.796173"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_025"
+ {
+ "iType" "5"
+ "pos_x" "-194.002930"
+ "pos_y" "-807.512024"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0.59 0.11"
+ }
+ "Node_026"
+ {
+ "iType" "21"
+ "pos_x" "83.139908"
+ "pos_y" "-663.095398"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "23"
+ "pos_x" "-62.651627"
+ "pos_y" "-784.964844"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "4"
+ "pos_x" "580.325378"
+ "pos_y" "-822.471680"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_029"
+ {
+ "iType" "19"
+ "pos_x" "264.335266"
+ "pos_y" "-664.321533"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_030"
+ {
+ "iType" "26"
+ "pos_x" "387.000519"
+ "pos_y" "-817.184082"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "5"
+ "pos_x" "78.614052"
+ "pos_y" "-506.760071"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_032"
+ {
+ "iType" "5"
+ "pos_x" "220.455261"
+ "pos_y" "-506.063995"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_033"
+ {
+ "iType" "29"
+ "pos_x" "-226.464340"
+ "pos_y" "-653.181152"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_034"
+ {
+ "iType" "29"
+ "pos_x" "2.025377"
+ "pos_y" "-221.102631"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "szFallbackTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "4"
+ }
+ "Node_035"
+ {
+ "iType" "29"
+ "pos_x" "1.958828"
+ "pos_y" "-96.032845"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "szFallbackTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "4"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_flare_anamorphic.txt b/mp/game/momentum/shadereditorui/canvas/postproc_flare_anamorphic.txt
new file mode 100644
index 0000000000..e4662c8c0e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_flare_anamorphic.txt
@@ -0,0 +1,668 @@
+"canvas"
+{
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "5"
+ "pos_x" "-157.204422"
+ "pos_y" "33.748177"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_003"
+ {
+ "iType" "32"
+ "pos_x" "-24.418501"
+ "pos_y" "23.663425"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "20"
+ "pos_x" "-402.417084"
+ "pos_y" "-1020.411194"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "34"
+ "pos_x" "-24.309429"
+ "pos_y" "-426.763062"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "4"
+ "pos_x" "463.722046"
+ "pos_y" "-1543.505249"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_007"
+ {
+ "iType" "19"
+ "pos_x" "-561.513306"
+ "pos_y" "-267.008484"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "17"
+ "pos_x" "-432.975189"
+ "pos_y" "-264.029938"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "17"
+ "pos_x" "333.314392"
+ "pos_y" "-591.277466"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "19"
+ "pos_x" "163.276520"
+ "pos_y" "-590.939514"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "29"
+ "szName" "Bloom"
+ "pos_x" "-164.194427"
+ "pos_y" "-263.455719"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_SmallFB1"
+ "iFallbackMode" "0"
+ }
+ "Node_012"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-573.406555"
+ "pos_y" "-1434.893188"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_013"
+ {
+ "iType" "30"
+ "pos_x" "-728.706360"
+ "pos_y" "-603.742249"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "526.970093"
+ "container_extents_y" "1200.780762"
+ "container_extents_z" "-526.970093"
+ "loop_condition" "2"
+ "loop_value_min" "-25"
+ "loop_value_max" "25"
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-177.825836"
+ "pos_y" "-931.415527"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_015"
+ {
+ "iType" "19"
+ "pos_x" "-12.273333"
+ "pos_y" "-1252.086304"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "26"
+ "pos_x" "266.890076"
+ "pos_y" "-1550.180542"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "17"
+ "pos_x" "96.781456"
+ "pos_y" "-1455.306763"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "pos_x" "-136.875885"
+ "pos_y" "-1264.650879"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.03 0.04 0.05"
+ }
+ "Node_019"
+ {
+ "iType" "5"
+ "pos_x" "-140.895447"
+ "pos_y" "-406.119354"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.25"
+ }
+ "Node_020"
+ {
+ "iType" "5"
+ "pos_x" "-146.504105"
+ "pos_y" "-483.420868"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.35"
+ }
+ "Node_021"
+ {
+ "iType" "5"
+ "pos_x" "-557.848816"
+ "pos_y" "-153.846710"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.015 0"
+ }
+ "Node_022"
+ {
+ "iType" "27"
+ "pos_x" "-45.016327"
+ "pos_y" "212.237122"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_023"
+ {
+ "iType" "19"
+ "pos_x" "50.916218"
+ "pos_y" "-755.687866"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "27"
+ "pos_x" "-298.014740"
+ "pos_y" "-301.925079"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_025"
+ {
+ "iType" "53"
+ "pos_x" "-419.836792"
+ "pos_y" "-721.185303"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "-169.996078"
+ "pos_y" "-643.775879"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_027"
+ {
+ "iType" "5"
+ "pos_x" "-254.605698"
+ "pos_y" "-644.432983"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_028"
+ {
+ "iType" "18"
+ "pos_x" "-568.721436"
+ "pos_y" "-721.701172"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "5"
+ "pos_x" "-541.319275"
+ "pos_y" "-633.764526"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_030"
+ {
+ "iType" "49"
+ "pos_x" "-100.936623"
+ "pos_y" "-1006.324951"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "53"
+ "pos_x" "-566.569275"
+ "pos_y" "-1016.759155"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "5"
+ "pos_x" "-509.073212"
+ "pos_y" "-922.568298"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "25"
+ }
+ "Node_033"
+ {
+ "iType" "61"
+ "pos_x" "-249.872726"
+ "pos_y" "-1009.899048"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_034"
+ {
+ "iType" "34"
+ "pos_x" "-223.333755"
+ "pos_y" "-722.467529"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "3"
+ "pos_x" "-1063.911011"
+ "pos_y" "-849.217468"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ }
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_flare_naive.txt b/mp/game/momentum/shadereditorui/canvas/postproc_flare_naive.txt
new file mode 100644
index 0000000000..225b5fb178
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_flare_naive.txt
@@ -0,0 +1,1669 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#002"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords" "2"
+ "dTFlag_Color" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "5"
+ "pos_x" "-373.145477"
+ "pos_y" "-2.804920"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_003"
+ {
+ "iType" "5"
+ "pos_x" "-492.229340"
+ "pos_y" "-28.489700"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_004"
+ {
+ "iType" "5"
+ "szName" "output"
+ "pos_x" "-145.760239"
+ "pos_y" "82.311722"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_005"
+ {
+ "iType" "32"
+ "pos_x" "-46.339928"
+ "pos_y" "82.558182"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-373.798187"
+ "pos_y" "-112.726242"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "5"
+ "pos_x" "-582.036560"
+ "pos_y" "-368.062714"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.15"
+ }
+ "Node_008"
+ {
+ "iType" "19"
+ "pos_x" "-32.716183"
+ "pos_y" "-104.124298"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_009"
+ {
+ "iType" "49"
+ "pos_x" "-404.592072"
+ "pos_y" "-255.089233"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "pos_x" "-251.282608"
+ "pos_y" "-47.710831"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_011"
+ {
+ "iType" "18"
+ "pos_x" "-206.922363"
+ "pos_y" "-136.693298"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "17"
+ "pos_x" "-278.538940"
+ "pos_y" "-275.898743"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "55"
+ "pos_x" "-98.197952"
+ "pos_y" "-285.649506"
+ "size_x" "114.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "0"
+ "iTexTrans_trans" "0"
+ }
+ "Node_014"
+ {
+ "iType" "19"
+ "pos_x" "-542.763428"
+ "pos_y" "-258.621094"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "pos_x" "-520.274536"
+ "pos_y" "-458.040985"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_016"
+ {
+ "iType" "39"
+ "pos_x" "-256.101624"
+ "pos_y" "-426.406128"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "22"
+ "pos_x" "-156.423950"
+ "pos_y" "-424.548676"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "19"
+ "pos_x" "-379.441132"
+ "pos_y" "-424.497040"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_019"
+ {
+ "iType" "19"
+ "pos_x" "20.385571"
+ "pos_y" "-419.155487"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_020"
+ {
+ "iType" "5"
+ "pos_x" "-467.483948"
+ "pos_y" "-390.544159"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1.5"
+ }
+ "Node_021"
+ {
+ "iType" "5"
+ "pos_x" "-54.029976"
+ "pos_y" "-462.198883"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_022"
+ {
+ "iType" "5"
+ "pos_x" "-295.624084"
+ "pos_y" "-538.276855"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_023"
+ {
+ "iType" "5"
+ "pos_x" "-297.124481"
+ "pos_y" "-609.275879"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_024"
+ {
+ "iType" "34"
+ "szName" "green"
+ "pos_x" "-415.238953"
+ "pos_y" "-689.174622"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "5"
+ "pos_x" "-514.356873"
+ "pos_y" "-640.889526"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "-515.857239"
+ "pos_y" "-711.888550"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_027"
+ {
+ "iType" "34"
+ "szName" "red"
+ "pos_x" "-194.689728"
+ "pos_y" "-553.864502"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "34"
+ "szName" "blue"
+ "pos_x" "-60.108879"
+ "pos_y" "-720.055725"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "5"
+ "pos_x" "-159.226852"
+ "pos_y" "-671.770630"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_030"
+ {
+ "iType" "5"
+ "pos_x" "-160.727219"
+ "pos_y" "-742.769653"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_031"
+ {
+ "iType" "19"
+ "pos_x" "225.213516"
+ "pos_y" "-675.862671"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_032"
+ {
+ "iType" "19"
+ "pos_x" "227.176315"
+ "pos_y" "-556.129517"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_033"
+ {
+ "iType" "19"
+ "pos_x" "228.058212"
+ "pos_y" "-441.186523"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_034"
+ {
+ "iType" "26"
+ "pos_x" "360.540894"
+ "pos_y" "-648.373413"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "26"
+ "pos_x" "369.572754"
+ "pos_y" "-496.915955"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_036"
+ {
+ "iType" "19"
+ "pos_x" "138.719849"
+ "pos_y" "-33.374832"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_037"
+ {
+ "iType" "30"
+ "pos_x" "-659.480042"
+ "pos_y" "-398.487305"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "432.402740"
+ "container_extents_y" "1563.140137"
+ "container_extents_z" "-432.402740"
+ "loop_condition" "2"
+ "loop_value_min" "0"
+ "loop_value_max" "3"
+ }
+ "Node_038"
+ {
+ "iType" "34"
+ "pos_x" "578.553223"
+ "pos_y" "-308.513123"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "5"
+ "pos_x" "16.747173"
+ "pos_y" "-23.405376"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "448.813141"
+ "pos_y" "-322.633820"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.65"
+ }
+ "Node_041"
+ {
+ "iType" "20"
+ "pos_x" "686.968506"
+ "pos_y" "-892.565002"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "4"
+ "pos_x" "1016.840393"
+ "pos_y" "-1169.097534"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_043"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "262.657227"
+ "pos_y" "-1112.773193"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_044"
+ {
+ "iType" "17"
+ "pos_x" "667.352539"
+ "pos_y" "-1062.926025"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_045"
+ {
+ "iType" "5"
+ "pos_x" "447.980255"
+ "pos_y" "-214.512650"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_046"
+ {
+ "iType" "26"
+ "pos_x" "809.115479"
+ "pos_y" "-1163.965088"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_047"
+ {
+ "iType" "5"
+ "pos_x" "-1433.034424"
+ "pos_y" "-314.165649"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_048"
+ {
+ "iType" "5"
+ "pos_x" "-1004.106750"
+ "pos_y" "-217.775757"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_049"
+ {
+ "iType" "23"
+ "pos_x" "-1328.669434"
+ "pos_y" "-300.045288"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "5"
+ "pos_x" "-1430.579346"
+ "pos_y" "-422.879272"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0"
+ }
+ "Node_051"
+ {
+ "iType" "23"
+ "pos_x" "-1323.855957"
+ "pos_y" "-411.112427"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_052"
+ {
+ "iType" "5"
+ "pos_x" "-1031.999023"
+ "pos_y" "-391.470459"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_053"
+ {
+ "iType" "29"
+ "pos_x" "-1403.462769"
+ "pos_y" "-723.090637"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_054"
+ {
+ "iType" "18"
+ "pos_x" "-1541.432007"
+ "pos_y" "-714.656555"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_055"
+ {
+ "iType" "19"
+ "pos_x" "-916.819336"
+ "pos_y" "-270.028076"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_056"
+ {
+ "iType" "25"
+ "pos_x" "-1201.875244"
+ "pos_y" "-220.783447"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_057"
+ {
+ "iType" "17"
+ "pos_x" "-988.045471"
+ "pos_y" "-480.824036"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_058"
+ {
+ "iType" "26"
+ "pos_x" "-1051.255615"
+ "pos_y" "-285.813843"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "18"
+ "pos_x" "-1384.347168"
+ "pos_y" "-182.448853"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "5"
+ "pos_x" "-1491.032715"
+ "pos_y" "-244.454834"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_061"
+ {
+ "iType" "55"
+ "pos_x" "-874.010986"
+ "pos_y" "-389.607178"
+ "size_x" "120.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "0"
+ }
+ "Node_062"
+ {
+ "iType" "17"
+ "pos_x" "-1542.274292"
+ "pos_y" "-601.886169"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "27"
+ "pos_x" "-1713.781372"
+ "pos_y" "-607.780151"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_064"
+ {
+ "iType" "29"
+ "pos_x" "-1407.215210"
+ "pos_y" "-609.527039"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_065"
+ {
+ "iType" "19"
+ "pos_x" "-1139.460449"
+ "pos_y" "-474.685638"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_066"
+ {
+ "iType" "5"
+ "pos_x" "-1163.975586"
+ "pos_y" "-408.862793"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_067"
+ {
+ "iType" "18"
+ "pos_x" "-957.786011"
+ "pos_y" "-711.419250"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_068"
+ {
+ "iType" "19"
+ "pos_x" "-790.126343"
+ "pos_y" "-711.372681"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_069"
+ {
+ "iType" "19"
+ "pos_x" "-895.321716"
+ "pos_y" "-859.253540"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_070"
+ {
+ "iType" "24"
+ "pos_x" "-1184.229248"
+ "pos_y" "-866.380066"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "34"
+ "pos_x" "-1046.051025"
+ "pos_y" "-866.612732"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_072"
+ {
+ "iType" "5"
+ "pos_x" "-968.482544"
+ "pos_y" "-590.045898"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_073"
+ {
+ "iType" "5"
+ "pos_x" "-1169.054932"
+ "pos_y" "-968.197571"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_074"
+ {
+ "iType" "5"
+ "pos_x" "-1088.892578"
+ "pos_y" "-996.940857"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_075"
+ {
+ "iType" "5"
+ "pos_x" "-861.783386"
+ "pos_y" "-606.814392"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.03"
+ }
+ "Node_076"
+ {
+ "iType" "3"
+ "pos_x" "-943.601074"
+ "pos_y" "-63.032471"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_077"
+ {
+ "iType" "17"
+ "pos_x" "-828.965393"
+ "pos_y" "-169.034531"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_078"
+ {
+ "iType" "18"
+ "pos_x" "-524.404175"
+ "pos_y" "-110.391342"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_079"
+ {
+ "iType" "32"
+ "pos_x" "-590.957581"
+ "pos_y" "-101.495216"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_080"
+ {
+ "iType" "12"
+ "pos_x" "-1974.026733"
+ "pos_y" "-573.714478"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_081"
+ {
+ "iType" "19"
+ "pos_x" "-1851.199097"
+ "pos_y" "-600.230286"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_082"
+ {
+ "iType" "21"
+ "pos_x" "-1160.104248"
+ "pos_y" "-625.460815"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_083"
+ {
+ "iType" "27"
+ "pos_x" "-1172.208740"
+ "pos_y" "-738.422791"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_084"
+ {
+ "iType" "5"
+ "pos_x" "524.111938"
+ "pos_y" "-909.245056"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "4"
+ }
+ "Node_085"
+ {
+ "iType" "17"
+ "pos_x" "738.834778"
+ "pos_y" "-199.635727"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_086"
+ {
+ "iType" "5"
+ "pos_x" "-955.876526"
+ "pos_y" "-400.019043"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 1"
+ }
+ "Node_087"
+ {
+ "iType" "5"
+ "pos_x" "-1957.232056"
+ "pos_y" "-676.658936"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.02"
+ }
+ "Node_088"
+ {
+ "iType" "27"
+ "pos_x" "-35.491783"
+ "pos_y" "205.966721"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_089"
+ {
+ "iType" "29"
+ "pos_x" "63.010437"
+ "pos_y" "-289.299377"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_SmallFB0"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_090"
+ {
+ "iType" "21"
+ "pos_x" "273.468750"
+ "pos_y" "-291.589050"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_flare_smart.txt b/mp/game/momentum/shadereditorui/canvas/postproc_flare_smart.txt
new file mode 100644
index 0000000000..624e954b9d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_flare_smart.txt
@@ -0,0 +1,3220 @@
+"canvas"
+{
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "172"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "1"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "18"
+ "pos_x" "-1073.782959"
+ "pos_y" "-335.227600"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "5"
+ "pos_x" "-1191.430420"
+ "pos_y" "-347.576599"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.5"
+ }
+ "Node_004"
+ {
+ "iType" "27"
+ "szName" "sun_uv"
+ "pos_x" "-785.798584"
+ "pos_y" "30.320265"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_005"
+ {
+ "iType" "29"
+ "pos_x" "-244.237778"
+ "pos_y" "-180.867249"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_006"
+ {
+ "iType" "53"
+ "pos_x" "-394.807404"
+ "pos_y" "-539.491577"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "25"
+ "pos_x" "-944.817505"
+ "pos_y" "-340.982910"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "27"
+ "pos_x" "-1013.268616"
+ "pos_y" "-629.776306"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_009"
+ {
+ "iType" "52"
+ "pos_x" "-713.293762"
+ "pos_y" "-87.103424"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "27"
+ "pos_x" "-1155.658569"
+ "pos_y" "-88.437378"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_011"
+ {
+ "iType" "27"
+ "pos_x" "-1152.543579"
+ "pos_y" "-189.151825"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_012"
+ {
+ "iType" "48"
+ "pos_x" "-858.853149"
+ "pos_y" "-589.416077"
+ "size_x" "61.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "27"
+ "pos_x" "-996.649231"
+ "pos_y" "-504.898651"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_014"
+ {
+ "iType" "26"
+ "pos_x" "-7.753777"
+ "pos_y" "-2361.617676"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "17"
+ "pos_x" "-987.534607"
+ "pos_y" "-194.416321"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "5"
+ "pos_x" "-294.580139"
+ "pos_y" "-688.771912"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_017"
+ {
+ "iType" "24"
+ "pos_x" "-1660.989746"
+ "pos_y" "-208.212128"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "pos_x" "-691.280640"
+ "pos_y" "-343.411926"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1 -0.02"
+ }
+ "Node_019"
+ {
+ "iType" "20"
+ "pos_x" "-808.804688"
+ "pos_y" "-448.067749"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "171"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "27"
+ "pos_x" "-662.317017"
+ "pos_y" "-443.063690"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "0 x"
+ }
+ "Node_021"
+ {
+ "iType" "17"
+ "pos_x" "-521.736572"
+ "pos_y" "-440.267242"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "18"
+ "pos_x" "-539.280212"
+ "pos_y" "42.482239"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_023"
+ {
+ "iType" "25"
+ "pos_x" "-361.746399"
+ "pos_y" "33.377419"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "19"
+ "pos_x" "-67.351387"
+ "pos_y" "-203.181442"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "5"
+ "pos_x" "-40.075245"
+ "pos_y" "-91.403175"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_026"
+ {
+ "iType" "34"
+ "pos_x" "229.384598"
+ "pos_y" "-332.132507"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "5"
+ "pos_x" "-2.321157"
+ "pos_y" "-368.553955"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_028"
+ {
+ "iType" "17"
+ "pos_x" "68.714729"
+ "pos_y" "-398.254517"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "5"
+ "pos_x" "119.405762"
+ "pos_y" "-307.864502"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_030"
+ {
+ "iType" "17"
+ "pos_x" "69.300568"
+ "pos_y" "-200.506363"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "17"
+ "pos_x" "213.528717"
+ "pos_y" "64.059929"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "170"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "5"
+ "pos_x" "-28.373863"
+ "pos_y" "114.905762"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_033"
+ {
+ "iType" "21"
+ "pos_x" "397.994080"
+ "pos_y" "-26.689842"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_034"
+ {
+ "iType" "50"
+ "pos_x" "335.922424"
+ "pos_y" "73.988358"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "5"
+ "pos_x" "-688.313354"
+ "pos_y" "-272.314880"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0.02"
+ }
+ "Node_036"
+ {
+ "iType" "55"
+ "pos_x" "-438.995789"
+ "pos_y" "-175.792740"
+ "size_x" "125.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "1"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_037"
+ {
+ "iType" "19"
+ "pos_x" "523.675842"
+ "pos_y" "-344.878540"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "21"
+ "pos_x" "222.352356"
+ "pos_y" "-1172.412476"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "19"
+ "pos_x" "288.841492"
+ "pos_y" "-693.535889"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "17"
+ "pos_x" "427.622620"
+ "pos_y" "-700.552795"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_041"
+ {
+ "iType" "34"
+ "pos_x" "-655.911865"
+ "pos_y" "-1551.057129"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "5"
+ "pos_x" "-588.497803"
+ "pos_y" "-1483.219727"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_043"
+ {
+ "iType" "27"
+ "pos_x" "-901.761597"
+ "pos_y" "-1542.967529"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_044"
+ {
+ "iType" "5"
+ "pos_x" "129.583282"
+ "pos_y" "-1202.921021"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9 0.35 0.1"
+ }
+ "Node_045"
+ {
+ "iType" "5"
+ "pos_x" "75.191391"
+ "pos_y" "-1200.929199"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8 0.7 0.2"
+ }
+ "Node_046"
+ {
+ "iType" "49"
+ "pos_x" "-491.862305"
+ "pos_y" "-1554.693115"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_047"
+ {
+ "iType" "5"
+ "pos_x" "200.607071"
+ "pos_y" "-638.905090"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_048"
+ {
+ "iType" "34"
+ "pos_x" "-205.667984"
+ "pos_y" "-579.543152"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "160"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "19"
+ "pos_x" "-154.978561"
+ "pos_y" "-1494.360718"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "19"
+ "pos_x" "93.595276"
+ "pos_y" "-1511.530151"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_051"
+ {
+ "iType" "39"
+ "pos_x" "-8.005255"
+ "pos_y" "-1534.073120"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_052"
+ {
+ "iType" "22"
+ "pos_x" "70.627731"
+ "pos_y" "-1289.830933"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_053"
+ {
+ "iType" "5"
+ "pos_x" "-274.299072"
+ "pos_y" "-1513.540161"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "50"
+ }
+ "Node_054"
+ {
+ "iType" "19"
+ "pos_x" "247.960693"
+ "pos_y" "-1291.825439"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_055"
+ {
+ "iType" "5"
+ "pos_x" "5.360834"
+ "pos_y" "-1456.899414"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_056"
+ {
+ "iType" "34"
+ "pos_x" "-188.312073"
+ "pos_y" "-1678.934448"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_057"
+ {
+ "iType" "5"
+ "pos_x" "-261.828888"
+ "pos_y" "-1634.464966"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_058"
+ {
+ "iType" "5"
+ "pos_x" "-280.772858"
+ "pos_y" "-1706.845337"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_059"
+ {
+ "iType" "5"
+ "pos_x" "-308.601410"
+ "pos_y" "-1859.517334"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_060"
+ {
+ "iType" "17"
+ "pos_x" "-218.409744"
+ "pos_y" "-2253.378906"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "34"
+ "pos_x" "-193.741409"
+ "pos_y" "-1827.126587"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_062"
+ {
+ "iType" "5"
+ "pos_x" "-289.657440"
+ "pos_y" "-1787.136963"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_063"
+ {
+ "iType" "34"
+ "pos_x" "-196.577332"
+ "pos_y" "-1989.033081"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "5"
+ "pos_x" "-292.493561"
+ "pos_y" "-1949.043457"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_065"
+ {
+ "iType" "5"
+ "pos_x" "-311.437531"
+ "pos_y" "-2021.423706"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_066"
+ {
+ "iType" "17"
+ "pos_x" "232.376358"
+ "pos_y" "-1518.547119"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_067"
+ {
+ "iType" "19"
+ "pos_x" "60.723877"
+ "pos_y" "-1688.527466"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_068"
+ {
+ "iType" "5"
+ "pos_x" "-54.134254"
+ "pos_y" "-1645.965210"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 1"
+ }
+ "Node_069"
+ {
+ "iType" "19"
+ "pos_x" "52.990181"
+ "pos_y" "-1816.120728"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_070"
+ {
+ "iType" "19"
+ "pos_x" "48.843353"
+ "pos_y" "-1990.287354"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "-61.867943"
+ "pos_y" "-1773.558472"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1 0.2"
+ }
+ "Node_072"
+ {
+ "iType" "17"
+ "pos_x" "203.282669"
+ "pos_y" "-1780.530029"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_073"
+ {
+ "iType" "17"
+ "pos_x" "295.330383"
+ "pos_y" "-1941.735352"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_074"
+ {
+ "iType" "19"
+ "pos_x" "396.210663"
+ "pos_y" "-1212.649170"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_075"
+ {
+ "iType" "19"
+ "pos_x" "439.840607"
+ "pos_y" "-1700.120117"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_076"
+ {
+ "iType" "5"
+ "pos_x" "-67.174919"
+ "pos_y" "-1946.564941"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0 0"
+ }
+ "Node_077"
+ {
+ "iType" "5"
+ "pos_x" "-762.824707"
+ "pos_y" "-1507.393921"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.95"
+ }
+ "Node_078"
+ {
+ "iType" "5"
+ "pos_x" "-763.790405"
+ "pos_y" "-1581.220947"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_079"
+ {
+ "iType" "5"
+ "pos_x" "-574.328857"
+ "pos_y" "-140.530396"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2 0.2"
+ }
+ "Node_080"
+ {
+ "iType" "7"
+ "pos_x" "-1713.425415"
+ "pos_y" "-35.361610"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_081"
+ {
+ "iType" "19"
+ "pos_x" "-1363.654053"
+ "pos_y" "-81.133034"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "5"
+ "pos_x" "-1463.228271"
+ "pos_y" "-32.272263"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.0001"
+ }
+ "Node_083"
+ {
+ "iType" "19"
+ "pos_x" "-1476.760742"
+ "pos_y" "-238.251358"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_084"
+ {
+ "iType" "5"
+ "pos_x" "-1554.039917"
+ "pos_y" "-151.402115"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.000035"
+ }
+ "Node_085"
+ {
+ "iType" "19"
+ "pos_x" "-1483.804077"
+ "pos_y" "-404.275238"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_086"
+ {
+ "iType" "12"
+ "pos_x" "-1618.918945"
+ "pos_y" "-511.263428"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_087"
+ {
+ "iType" "5"
+ "pos_x" "-1581.039673"
+ "pos_y" "-325.186798"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_088"
+ {
+ "iType" "17"
+ "pos_x" "-734.522522"
+ "pos_y" "-651.804199"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "171"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_089"
+ {
+ "iType" "17"
+ "pos_x" "-528.160034"
+ "pos_y" "-578.732239"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_090"
+ {
+ "iType" "17"
+ "pos_x" "-1317.064331"
+ "pos_y" "-281.674896"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_091"
+ {
+ "iType" "24"
+ "pos_x" "-173.637085"
+ "pos_y" "17.982254"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_092"
+ {
+ "iType" "29"
+ "pos_x" "-204.998154"
+ "pos_y" "-324.530792"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_093"
+ {
+ "iType" "19"
+ "pos_x" "25.799347"
+ "pos_y" "-679.645569"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_094"
+ {
+ "iType" "5"
+ "pos_x" "-154.431366"
+ "pos_y" "-701.513428"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "30"
+ }
+ "Node_095"
+ {
+ "iType" "55"
+ "pos_x" "-370.348785"
+ "pos_y" "-320.215881"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_096"
+ {
+ "iType" "5"
+ "pos_x" "-582.478516"
+ "pos_y" "-1193.824707"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_097"
+ {
+ "iType" "5"
+ "pos_x" "-754.921753"
+ "pos_y" "-1219.017090"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9"
+ }
+ "Node_098"
+ {
+ "iType" "5"
+ "pos_x" "-763.141113"
+ "pos_y" "-1293.503540"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_099"
+ {
+ "iType" "27"
+ "pos_x" "-893.858643"
+ "pos_y" "-1254.590698"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_100"
+ {
+ "iType" "34"
+ "pos_x" "-648.008911"
+ "pos_y" "-1262.680176"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_101"
+ {
+ "iType" "55"
+ "pos_x" "-426.109619"
+ "pos_y" "-852.278748"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_102"
+ {
+ "iType" "24"
+ "pos_x" "-249.202332"
+ "pos_y" "-892.091125"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_103"
+ {
+ "iType" "5"
+ "pos_x" "-234.038940"
+ "pos_y" "-1011.457031"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "30"
+ }
+ "Node_104"
+ {
+ "iType" "49"
+ "pos_x" "-463.770111"
+ "pos_y" "-1277.564331"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_105"
+ {
+ "iType" "39"
+ "pos_x" "23.753057"
+ "pos_y" "-908.115967"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_106"
+ {
+ "iType" "19"
+ "pos_x" "-113.326492"
+ "pos_y" "-909.305237"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_107"
+ {
+ "iType" "5"
+ "pos_x" "-671.853760"
+ "pos_y" "-776.077942"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_108"
+ {
+ "iType" "19"
+ "pos_x" "-652.845276"
+ "pos_y" "-940.094360"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_109"
+ {
+ "iType" "5"
+ "pos_x" "-736.943054"
+ "pos_y" "-841.870178"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 -1"
+ }
+ "Node_110"
+ {
+ "iType" "5"
+ "pos_x" "-774.684570"
+ "pos_y" "-937.840942"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_111"
+ {
+ "iType" "21"
+ "pos_x" "-543.465210"
+ "pos_y" "-303.579407"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_112"
+ {
+ "iType" "21"
+ "pos_x" "-563.144836"
+ "pos_y" "-822.967407"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_113"
+ {
+ "iType" "21"
+ "pos_x" "1.917595"
+ "pos_y" "-549.481201"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_114"
+ {
+ "iType" "21"
+ "pos_x" "194.336853"
+ "pos_y" "-852.969360"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_115"
+ {
+ "iType" "39"
+ "pos_x" "32.918396"
+ "pos_y" "-802.075378"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_116"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-734.579895"
+ "pos_y" "-2355.064453"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_117"
+ {
+ "iType" "19"
+ "pos_x" "-358.633484"
+ "pos_y" "-2298.256104"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_118"
+ {
+ "iType" "34"
+ "pos_x" "-523.302246"
+ "pos_y" "-2354.985107"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "120"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_119"
+ {
+ "iType" "5"
+ "pos_x" "-651.106750"
+ "pos_y" "-2481.745605"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_120"
+ {
+ "iType" "5"
+ "pos_x" "-584.079407"
+ "pos_y" "-2523.112549"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_121"
+ {
+ "iType" "34"
+ "pos_x" "228.354996"
+ "pos_y" "-195.944366"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "122"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_122"
+ {
+ "iType" "5"
+ "pos_x" "169.977463"
+ "pos_y" "-80.820648"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_123"
+ {
+ "iType" "5"
+ "pos_x" "48.520107"
+ "pos_y" "-79.981102"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_124"
+ {
+ "iType" "27"
+ "szName" "sun_dot"
+ "pos_x" "-873.147583"
+ "pos_y" "-88.635231"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_125"
+ {
+ "iType" "77"
+ "pos_x" "-1015.988403"
+ "pos_y" "52.771278"
+ "size_x" "87.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "sz_callbackname" "sun_data"
+ "i_numc" "4"
+ }
+ "Node_126"
+ {
+ "iType" "17"
+ "pos_x" "1015.698486"
+ "pos_y" "-252.583176"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "128"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_127"
+ {
+ "iType" "61"
+ "pos_x" "1364.025391"
+ "pos_y" "-255.368134"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "149"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_128"
+ {
+ "iType" "34"
+ "pos_x" "878.307434"
+ "pos_y" "-223.455048"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "129"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "130"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_129"
+ {
+ "iType" "5"
+ "pos_x" "771.417480"
+ "pos_y" "-130.415558"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_130"
+ {
+ "iType" "17"
+ "pos_x" "703.805054"
+ "pos_y" "-275.243896"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "142"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_131"
+ {
+ "iType" "5"
+ "pos_x" "944.973938"
+ "pos_y" "19.248388"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_132"
+ {
+ "iType" "5"
+ "pos_x" "937.546082"
+ "pos_y" "-95.704262"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_133"
+ {
+ "iType" "4"
+ "pos_x" "385.560150"
+ "pos_y" "-2376.147461"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_134"
+ {
+ "iType" "77"
+ "pos_x" "563.667542"
+ "pos_y" "-1159.314453"
+ "size_x" "87.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "sz_callbackname" "sun_data"
+ "i_numc" "4"
+ }
+ "Node_135"
+ {
+ "iType" "19"
+ "pos_x" "1075.566406"
+ "pos_y" "-1668.365845"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "137"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_136"
+ {
+ "iType" "27"
+ "szName" "sun_amt"
+ "pos_x" "852.625061"
+ "pos_y" "-1390.014038"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_137"
+ {
+ "iType" "17"
+ "pos_x" "889.618347"
+ "pos_y" "-1637.982178"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "177"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "161"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_138"
+ {
+ "iType" "5"
+ "pos_x" "682.713806"
+ "pos_y" "-163.184814"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_139"
+ {
+ "iType" "19"
+ "pos_x" "1446.357178"
+ "pos_y" "-362.727936"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "127"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "154"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_140"
+ {
+ "iType" "27"
+ "szName" "sun_dot"
+ "pos_x" "679.113953"
+ "pos_y" "-728.911438"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_141"
+ {
+ "iType" "5"
+ "pos_x" "835.348938"
+ "pos_y" "-653.903381"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "4"
+ }
+ "Node_142"
+ {
+ "iType" "19"
+ "pos_x" "905.490662"
+ "pos_y" "-518.517700"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "143"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "141"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_143"
+ {
+ "iType" "61"
+ "pos_x" "749.377380"
+ "pos_y" "-514.048157"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "144"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_144"
+ {
+ "iType" "60"
+ "pos_x" "628.298889"
+ "pos_y" "-519.085693"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_145"
+ {
+ "iType" "19"
+ "pos_x" "1446.657349"
+ "pos_y" "-468.114563"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "139"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_146"
+ {
+ "iType" "5"
+ "pos_x" "987.733154"
+ "pos_y" "-614.740173"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9 0.7 0.2"
+ }
+ "Node_147"
+ {
+ "iType" "21"
+ "pos_x" "1123.090210"
+ "pos_y" "-646.864929"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "159"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_148"
+ {
+ "iType" "21"
+ "pos_x" "1285.666992"
+ "pos_y" "-648.213013"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "150"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "151"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_149"
+ {
+ "iType" "34"
+ "pos_x" "1186.970947"
+ "pos_y" "-253.649002"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "126"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_150"
+ {
+ "iType" "5"
+ "pos_x" "1136.774048"
+ "pos_y" "-763.951477"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_151"
+ {
+ "iType" "34"
+ "pos_x" "1269.425659"
+ "pos_y" "-793.443176"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "152"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "153"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_152"
+ {
+ "iType" "5"
+ "pos_x" "1126.377808"
+ "pos_y" "-844.758301"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_153"
+ {
+ "iType" "5"
+ "pos_x" "1177.468018"
+ "pos_y" "-903.457520"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.32"
+ }
+ "Node_154"
+ {
+ "iType" "34"
+ "pos_x" "1140.272827"
+ "pos_y" "-494.046082"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "156"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "155"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_155"
+ {
+ "iType" "5"
+ "pos_x" "1202.673706"
+ "pos_y" "-412.204956"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_156"
+ {
+ "iType" "5"
+ "pos_x" "1135.880371"
+ "pos_y" "-409.713287"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_157"
+ {
+ "iType" "5"
+ "pos_x" "1805.360962"
+ "pos_y" "-846.542908"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_158"
+ {
+ "iType" "5"
+ "pos_x" "1738.567627"
+ "pos_y" "-844.051270"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_159"
+ {
+ "iType" "5"
+ "pos_x" "986.545898"
+ "pos_y" "-697.820618"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0.6 0.05"
+ }
+ "Node_160"
+ {
+ "iType" "5"
+ "pos_x" "-361.363495"
+ "pos_y" "-651.064758"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.1"
+ }
+ "Node_161"
+ {
+ "iType" "19"
+ "pos_x" "1897.494385"
+ "pos_y" "-773.729248"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "166"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "162"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_162"
+ {
+ "iType" "34"
+ "pos_x" "1742.960083"
+ "pos_y" "-928.384033"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "158"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "157"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_163"
+ {
+ "iType" "34"
+ "pos_x" "1590.435913"
+ "pos_y" "-754.151917"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "168"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "167"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_164"
+ {
+ "iType" "5"
+ "pos_x" "1451.352295"
+ "pos_y" "-677.144836"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_165"
+ {
+ "iType" "19"
+ "pos_x" "1546.545654"
+ "pos_y" "-607.292175"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "145"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "164"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_166"
+ {
+ "iType" "19"
+ "pos_x" "1737.164185"
+ "pos_y" "-681.026733"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "165"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "163"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_167"
+ {
+ "iType" "5"
+ "pos_x" "1478.265869"
+ "pos_y" "-859.315247"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_168"
+ {
+ "iType" "5"
+ "pos_x" "1446.338867"
+ "pos_y" "-779.236511"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_169"
+ {
+ "iType" "3"
+ "pos_x" "-1419.227539"
+ "pos_y" "-885.006836"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "1"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_170"
+ {
+ "iType" "19"
+ "pos_x" "69.056168"
+ "pos_y" "57.635948"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_171"
+ {
+ "iType" "5"
+ "pos_x" "-843.493835"
+ "pos_y" "-674.598694"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3.141593"
+ }
+ "Node_172"
+ {
+ "iType" "27"
+ "pos_x" "-38.764900"
+ "pos_y" "216.019882"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_173"
+ {
+ "iType" "5"
+ "pos_x" "414.783478"
+ "pos_y" "-1550.855103"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_174"
+ {
+ "iType" "21"
+ "pos_x" "527.856567"
+ "pos_y" "-1494.123413"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "175"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "173"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_175"
+ {
+ "iType" "61"
+ "pos_x" "392.785370"
+ "pos_y" "-1400.816650"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "178"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_176"
+ {
+ "iType" "17"
+ "pos_x" "582.014771"
+ "pos_y" "-1628.731079"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_177"
+ {
+ "iType" "19"
+ "pos_x" "727.159241"
+ "pos_y" "-1571.791260"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "176"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "174"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_178"
+ {
+ "iType" "27"
+ "pos_x" "232.318756"
+ "pos_y" "-1404.156372"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "169"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ }
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_fxaa.txt b/mp/game/momentum/shadereditorui/canvas/postproc_fxaa.txt
new file mode 100644
index 0000000000..ee37f7e005
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_fxaa.txt
@@ -0,0 +1,198 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-320.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "4"
+ "pos_x" "265.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_004"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_005"
+ {
+ "iType" "94"
+ "pos_x" "-195.867752"
+ "pos_y" "-32.425503"
+ "size_x" "84.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "szFallbackTexturePath" "white"
+ "iFallbackMode" "0"
+ }
+ "Node_006"
+ {
+ "iType" "65"
+ "pos_x" "-220.706284"
+ "pos_y" "-191.915787"
+ "size_x" "70.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "1.000000"
+ }
+ "Node_007"
+ {
+ "iType" "99"
+ "pos_x" "-7.115566"
+ "pos_y" "-108.856155"
+ "size_x" "133.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "varName_In_0" "tex"
+ "varType_In_0" "128"
+ "varName_In_1" "uv"
+ "varType_In_1" "2"
+ "varName_In_2" "texelsize"
+ "varType_In_2" "2"
+ "varName_Out_0" "col"
+ "varType_Out_0" "8"
+ "szFunctionName" "DoFXAA"
+ "szFilePath" "shadereditorui\user_functions\call_fxaa.ufunc"
+ "iInline" "0"
+ "szcode_global_num_strings" "1"
+ "szcode_global_partial_00" "#define FXAA_PC 1\r\n#define FXAA_HLSL_3 1\r\n#define FXAA_GREEN_AS_LUMA 1\r\n#define FXAA_DISCARD 1\r\n#define FXAA_QUALITY__PRESET 12\r\n\r\n#include \'fxaa3_11.h\'\n"
+ "szcode_body_num_strings" "2"
+ "szcode_body_partial_00" " col = FxaaPixelShader( uv,\r\n (float4)0,\r\n tex,\r\n tex,\r\n tex,\r\n texelsize,\r\n (float4)0,\r\n (float4)0,\r\n (float4)0,\r\n // fxaaQualitySubpix\r\n // This used to be the FXAA_QUALITY__SUBPIX define.\r\n // It is here now to allow easier tuning.\r\n // Choose the amount of sub-pixel aliasing removal.\r\n // This can effect sharpness.\r\n // 1.00 - upper limit (softer)\r\n // 0.75 - default amount of filtering\r\n // 0.50 - lower limit (sharper, less sub-pixel aliasing removal)\r\n // 0.25 - almost off\r\n // 0.00 - completely off\r\n 0.5,\r\n // This used to be the FXAA_QUALITY__EDGE_THRESHOLD define.\r\n // It is here now to allow easier tuning.\r\n // The minimum amount of local contrast required to apply algorithm.\r\n // 0.333 - too little (faster)\r\n // 0.250 - low quality\r\n // 0.166 - default\r\n // 0.125 - high quality \r\n // 0.063 - overkill (slower)\r\n // fxaaQualityEdgeThreshold\r\n 0.2,\r\n // This used to be the"
+ "szcode_body_partial_01" " FXAA_QUALITY__EDGE_THRESHOLD_MIN define.\r\n // It is here now to allow easier tuning.\r\n // Trims the algorithm from processing darks.\r\n // 0.0833 - upper limit (default, the start of visible unfiltered edges)\r\n // 0.0625 - high quality (faster)\r\n // 0.0312 - visible limit (slower)\r\n // Special notes when using FXAA_GREEN_AS_LUMA,\r\n // Likely want to set this to zero.\r\n // As colors that are mostly not-green\r\n // will appear very dark in the green channel!\r\n // Tune by looking at mostly non-green content,\r\n // then start at zero and increase until aliasing is a problem.\r\n 0.0833,\r\n 0, 0, 0, (float4)0 );"
+ "iEnvFlags" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_nightvision.txt b/mp/game/momentum/shadereditorui/canvas/postproc_nightvision.txt
new file mode 100644
index 0000000000..37bd775488
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_nightvision.txt
@@ -0,0 +1,1877 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#002"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "53"
+ "pos_x" "463.674652"
+ "pos_y" "-210.488373"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_001"
+ {
+ "iType" "19"
+ "pos_x" "601.121765"
+ "pos_y" "-180.594849"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_002"
+ {
+ "iType" "17"
+ "pos_x" "750.381531"
+ "pos_y" "-186.976593"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "50"
+ "pos_x" "174.049500"
+ "pos_y" "-225.131470"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-173.927490"
+ "pos_y" "-229.426270"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "5"
+ "pos_x" "-290.359222"
+ "pos_y" "-295.938782"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "10"
+ }
+ "Node_006"
+ {
+ "iType" "1"
+ "pos_x" "-228.863312"
+ "pos_y" "319.150818"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords" "2"
+ "dTFlag_Color" "8"
+ }
+ "Node_007"
+ {
+ "iType" "19"
+ "pos_x" "-41.806458"
+ "pos_y" "210.270844"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_008"
+ {
+ "iType" "27"
+ "pos_x" "94.763428"
+ "pos_y" "193.806198"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_009"
+ {
+ "iType" "55"
+ "pos_x" "221.642883"
+ "pos_y" "229.859772"
+ "size_x" "91.000000"
+ "size_y" "-39.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "pos_x" "-168.952637"
+ "pos_y" "233.892334"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_011"
+ {
+ "iType" "12"
+ "pos_x" "-183.612152"
+ "pos_y" "159.546921"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_012"
+ {
+ "iType" "5"
+ "pos_x" "104.579254"
+ "pos_y" "146.036072"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "szConstantString" "0.0001 0.0001"
+ }
+ "Node_013"
+ {
+ "iType" "20"
+ "pos_x" "71.140167"
+ "pos_y" "499.231293"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "65"
+ "pos_x" "-49.716888"
+ "pos_y" "455.953003"
+ "size_x" "60.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "pos_x" "66.941437"
+ "pos_y" "442.331451"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "64"
+ }
+ "Node_016"
+ {
+ "iType" "18"
+ "pos_x" "346.230225"
+ "pos_y" "-221.256073"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "60"
+ "pos_x" "140.350861"
+ "pos_y" "-951.976807"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "3"
+ "pos_x" "-597.301880"
+ "pos_y" "-534.940308"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_019"
+ {
+ "iType" "20"
+ "pos_x" "213.357849"
+ "pos_y" "473.199463"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "5"
+ "pos_x" "-48.920013"
+ "pos_y" "512.142090"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_021"
+ {
+ "iType" "2"
+ "pos_x" "424.612183"
+ "pos_y" "313.672791"
+ "size_x" "55.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_022"
+ {
+ "iType" "5"
+ "pos_x" "-413.016083"
+ "pos_y" "-1072.758057"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0.59 0.11"
+ }
+ "Node_023"
+ {
+ "iType" "23"
+ "pos_x" "-320.019897"
+ "pos_y" "-1048.719238"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "5"
+ "pos_x" "333.525726"
+ "pos_y" "-878.604004"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0.59 0.11"
+ }
+ "Node_025"
+ {
+ "iType" "23"
+ "pos_x" "280.829102"
+ "pos_y" "-955.839111"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "20"
+ "pos_x" "13.819885"
+ "pos_y" "-956.361328"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "34"
+ "pos_x" "-149.998428"
+ "pos_y" "-1046.181152"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "5"
+ "pos_x" "-184.695190"
+ "pos_y" "-950.453674"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.1"
+ }
+ "Node_029"
+ {
+ "iType" "5"
+ "pos_x" "-155.751495"
+ "pos_y" "-1184.955444"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_030"
+ {
+ "iType" "5"
+ "pos_x" "-245.854233"
+ "pos_y" "-1184.234985"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_031"
+ {
+ "iType" "34"
+ "pos_x" "-215.099915"
+ "pos_y" "-1269.376465"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "5"
+ "pos_x" "-59.328575"
+ "pos_y" "-385.682373"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_033"
+ {
+ "iType" "18"
+ "pos_x" "-1316.010376"
+ "pos_y" "-716.106445"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_034"
+ {
+ "iType" "24"
+ "pos_x" "63.969193"
+ "pos_y" "-463.902222"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "24"
+ "pos_x" "-1163.439819"
+ "pos_y" "-712.743042"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_036"
+ {
+ "iType" "18"
+ "pos_x" "-1312.617554"
+ "pos_y" "-832.547729"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_037"
+ {
+ "iType" "24"
+ "pos_x" "-1160.047241"
+ "pos_y" "-829.184326"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "34"
+ "pos_x" "216.704910"
+ "pos_y" "-474.557556"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "5"
+ "pos_x" "196.931091"
+ "pos_y" "-388.285828"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "286.014008"
+ "pos_y" "-388.756104"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-10"
+ }
+ "Node_041"
+ {
+ "iType" "37"
+ "pos_x" "-1026.420898"
+ "pos_y" "-767.089844"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "5"
+ "pos_x" "-1406.134644"
+ "pos_y" "-701.179077"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4 0.5"
+ }
+ "Node_043"
+ {
+ "iType" "5"
+ "pos_x" "-1402.741821"
+ "pos_y" "-817.620361"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6 0.5"
+ }
+ "Node_044"
+ {
+ "iType" "34"
+ "pos_x" "-879.481873"
+ "pos_y" "-791.222168"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_045"
+ {
+ "iType" "18"
+ "pos_x" "-74.996223"
+ "pos_y" "-464.449890"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "5"
+ "pos_x" "-1450.968628"
+ "pos_y" "-1125.375366"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_047"
+ {
+ "iType" "5"
+ "pos_x" "-1432.045776"
+ "pos_y" "-989.069092"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0"
+ }
+ "Node_048"
+ {
+ "iType" "23"
+ "pos_x" "-1325.664673"
+ "pos_y" "-1133.754028"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "23"
+ "pos_x" "-1306.741577"
+ "pos_y" "-997.447693"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "25"
+ "pos_x" "-1593.267944"
+ "pos_y" "-1046.779175"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_051"
+ {
+ "iType" "19"
+ "pos_x" "-1138.864136"
+ "pos_y" "-990.283142"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_052"
+ {
+ "iType" "19"
+ "pos_x" "-1151.666382"
+ "pos_y" "-1141.724243"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_053"
+ {
+ "iType" "5"
+ "pos_x" "-940.444519"
+ "pos_y" "-1076.191040"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_054"
+ {
+ "iType" "5"
+ "pos_x" "-808.116821"
+ "pos_y" "-907.380005"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_055"
+ {
+ "iType" "18"
+ "pos_x" "-866.781982"
+ "pos_y" "-1137.014282"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "26"
+ "pos_x" "-746.701233"
+ "pos_y" "-1067.887817"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_057"
+ {
+ "iType" "18"
+ "pos_x" "-864.263672"
+ "pos_y" "-986.921021"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_058"
+ {
+ "iType" "53"
+ "pos_x" "-1006.789734"
+ "pos_y" "-991.632751"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "53"
+ "pos_x" "-1005.802185"
+ "pos_y" "-1143.723022"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "5"
+ "pos_x" "-1230.503784"
+ "pos_y" "-1076.726196"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_061"
+ {
+ "iType" "27"
+ "pos_x" "1440.168213"
+ "pos_y" "-943.351685"
+ "size_x" "123.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "r g b 1"
+ }
+ "Node_062"
+ {
+ "iType" "19"
+ "pos_x" "1289.970459"
+ "pos_y" "-936.860962"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_063"
+ {
+ "iType" "21"
+ "pos_x" "-682.400085"
+ "pos_y" "-900.576172"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "55"
+ "pos_x" "-562.799194"
+ "pos_y" "-769.083557"
+ "size_x" "120.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "0"
+ }
+ "Node_065"
+ {
+ "iType" "21"
+ "pos_x" "-74.406296"
+ "pos_y" "-719.279785"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "34"
+ "pos_x" "-340.682922"
+ "pos_y" "-578.949707"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_067"
+ {
+ "iType" "29"
+ "pos_x" "-356.698975"
+ "pos_y" "-824.546448"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_068"
+ {
+ "iType" "29"
+ "pos_x" "-360.063995"
+ "pos_y" "-718.471802"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_069"
+ {
+ "iType" "5"
+ "pos_x" "-346.845215"
+ "pos_y" "-493.701538"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_070"
+ {
+ "iType" "5"
+ "pos_x" "-278.520996"
+ "pos_y" "-496.406372"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "-816.689148"
+ "pos_y" "-708.678833"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_072"
+ {
+ "iType" "5"
+ "pos_x" "640.592468"
+ "pos_y" "-713.902466"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.35"
+ }
+ "Node_073"
+ {
+ "iType" "5"
+ "pos_x" "709.547424"
+ "pos_y" "-716.607300"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.55"
+ }
+ "Node_074"
+ {
+ "iType" "5"
+ "pos_x" "-885.644104"
+ "pos_y" "-705.973999"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_075"
+ {
+ "iType" "19"
+ "pos_x" "-261.007019"
+ "pos_y" "-97.164841"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_076"
+ {
+ "iType" "81"
+ "pos_x" "-249.904297"
+ "pos_y" "-9.620949"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_num_comps" "1"
+ "fl_value_min" "0.000000"
+ "fl_value_max" "10.000000"
+ }
+ "Node_077"
+ {
+ "iType" "17"
+ "pos_x" "-142.329498"
+ "pos_y" "-97.917526"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_078"
+ {
+ "iType" "5"
+ "pos_x" "-94.592438"
+ "pos_y" "-951.174011"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_079"
+ {
+ "iType" "4"
+ "pos_x" "1628.385742"
+ "pos_y" "-937.808289"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_080"
+ {
+ "iType" "21"
+ "pos_x" "961.547974"
+ "pos_y" "-950.942322"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_081"
+ {
+ "iType" "19"
+ "pos_x" "40.308403"
+ "pos_y" "-1097.238403"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_082"
+ {
+ "iType" "5"
+ "pos_x" "321.347473"
+ "pos_y" "-1218.275513"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9 1 0.9"
+ }
+ "Node_083"
+ {
+ "iType" "5"
+ "pos_x" "-1.634039"
+ "pos_y" "-1199.789795"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1.5 2.25 1.8"
+ }
+ "Node_084"
+ {
+ "iType" "21"
+ "pos_x" "200.846954"
+ "pos_y" "-1095.319214"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_085"
+ {
+ "iType" "5"
+ "pos_x" "111.949905"
+ "pos_y" "-1209.657715"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.762 1.78 0.5"
+ }
+ "Node_086"
+ {
+ "iType" "5"
+ "pos_x" "198.678452"
+ "pos_y" "-1265.130371"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.381 0.89 0.25"
+ }
+ "Node_087"
+ {
+ "iType" "21"
+ "pos_x" "376.618958"
+ "pos_y" "-1101.961914"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_088"
+ {
+ "iType" "19"
+ "pos_x" "539.894470"
+ "pos_y" "-1103.041626"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_089"
+ {
+ "iType" "19"
+ "pos_x" "702.871216"
+ "pos_y" "-1095.865234"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_090"
+ {
+ "iType" "5"
+ "pos_x" "654.197021"
+ "pos_y" "-1216.122925"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1.4"
+ }
+ "Node_091"
+ {
+ "iType" "5"
+ "pos_x" "723.098816"
+ "pos_y" "-319.257813"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9"
+ }
+ "Node_092"
+ {
+ "iType" "5"
+ "pos_x" "579.549622"
+ "pos_y" "-319.953796"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_093"
+ {
+ "iType" "19"
+ "pos_x" "1115.174316"
+ "pos_y" "-941.947083"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_094"
+ {
+ "iType" "61"
+ "pos_x" "815.646973"
+ "pos_y" "-791.105591"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_095"
+ {
+ "iType" "21"
+ "pos_x" "809.717651"
+ "pos_y" "-594.945251"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_096"
+ {
+ "iType" "5"
+ "pos_x" "669.171814"
+ "pos_y" "-498.493469"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.42"
+ }
+ "Node_097"
+ {
+ "iType" "5"
+ "pos_x" "600.216858"
+ "pos_y" "-495.788635"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.38"
+ }
+ "Node_098"
+ {
+ "iType" "34"
+ "pos_x" "646.754700"
+ "pos_y" "-799.150635"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_099"
+ {
+ "iType" "5"
+ "pos_x" "830.292847"
+ "pos_y" "-510.106995"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_100"
+ {
+ "iType" "34"
+ "pos_x" "606.379089"
+ "pos_y" "-581.036804"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_101"
+ {
+ "iType" "27"
+ "pos_x" "68.468102"
+ "pos_y" "330.389618"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_102"
+ {
+ "iType" "29"
+ "pos_x" "1.958828"
+ "pos_y" "-96.032845"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "szFallbackTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "4"
+ }
+ "Node_103"
+ {
+ "iType" "29"
+ "pos_x" "2.025377"
+ "pos_y" "-221.102631"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "szFallbackTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "4"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_oldfilm.txt b/mp/game/momentum/shadereditorui/canvas/postproc_oldfilm.txt
new file mode 100644
index 0000000000..8c32441ded
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_oldfilm.txt
@@ -0,0 +1,2776 @@
+"canvas"
+{
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ }
+ "Node_001"
+ {
+ "iType" "5"
+ "pos_x" "88.616852"
+ "pos_y" "-278.796997"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0.95 0.8 1"
+ }
+ "Node_002"
+ {
+ "iType" "19"
+ "pos_x" "237.931458"
+ "pos_y" "-277.880432"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "27"
+ "pos_x" "-59.436279"
+ "pos_y" "8.859213"
+ "size_x" "123.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "r g b 1"
+ }
+ "Node_004"
+ {
+ "iType" "5"
+ "pos_x" "-1059.010986"
+ "pos_y" "-204.097977"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.04"
+ }
+ "Node_005"
+ {
+ "iType" "27"
+ "pos_x" "-924.699402"
+ "pos_y" "-162.540985"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-926.008240"
+ "pos_y" "-280.759583"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "53"
+ "pos_x" "-456.948792"
+ "pos_y" "-430.845123"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_008"
+ {
+ "iType" "18"
+ "pos_x" "-611.888428"
+ "pos_y" "-431.275604"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "27"
+ "pos_x" "-769.306885"
+ "pos_y" "-431.508545"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "pos_x" "-741.143555"
+ "pos_y" "-546.359741"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "pos_x" "-1176.975220"
+ "pos_y" "-594.510803"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_012"
+ {
+ "iType" "34"
+ "pos_x" "-271.634705"
+ "pos_y" "-430.514771"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "5"
+ "pos_x" "-417.226410"
+ "pos_y" "-294.562958"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.75"
+ }
+ "Node_014"
+ {
+ "iType" "19"
+ "pos_x" "-127.659157"
+ "pos_y" "-622.664429"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "pos_x" "-174.988998"
+ "pos_y" "-525.959534"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_016"
+ {
+ "iType" "19"
+ "pos_x" "348.497162"
+ "pos_y" "-493.848145"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "19"
+ "pos_x" "458.449402"
+ "pos_y" "-407.535919"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "34"
+ "pos_x" "223.688065"
+ "pos_y" "-478.911560"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "5"
+ "pos_x" "373.025421"
+ "pos_y" "-360.817139"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_020"
+ {
+ "iType" "5"
+ "pos_x" "256.435913"
+ "pos_y" "-400.670410"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_021"
+ {
+ "iType" "5"
+ "pos_x" "163.691452"
+ "pos_y" "-390.147552"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_022"
+ {
+ "iType" "55"
+ "pos_x" "-616.682983"
+ "pos_y" "-623.840027"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_023"
+ {
+ "iType" "5"
+ "pos_x" "-731.998901"
+ "pos_y" "-655.527832"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.001 0.3"
+ }
+ "Node_024"
+ {
+ "iType" "5"
+ "pos_x" "-737.814819"
+ "pos_y" "-786.267822"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0.001"
+ }
+ "Node_025"
+ {
+ "iType" "19"
+ "pos_x" "-1094.875854"
+ "pos_y" "-624.470154"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "34"
+ "pos_x" "-274.200195"
+ "pos_y" "-619.287537"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "5"
+ "pos_x" "-273.208252"
+ "pos_y" "-524.756531"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_028"
+ {
+ "iType" "5"
+ "pos_x" "-351.231079"
+ "pos_y" "-536.567261"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_029"
+ {
+ "iType" "55"
+ "pos_x" "-619.977173"
+ "pos_y" "-760.177002"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_030"
+ {
+ "iType" "27"
+ "pos_x" "-592.366089"
+ "pos_y" "-1017.870239"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "149"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_031"
+ {
+ "iType" "12"
+ "pos_x" "-863.676941"
+ "pos_y" "-1024.266968"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_032"
+ {
+ "iType" "34"
+ "pos_x" "-271.286621"
+ "pos_y" "-752.708313"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_033"
+ {
+ "iType" "5"
+ "pos_x" "-349.413452"
+ "pos_y" "-884.769470"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.99"
+ }
+ "Node_034"
+ {
+ "iType" "5"
+ "pos_x" "-269.420288"
+ "pos_y" "-880.839722"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_035"
+ {
+ "iType" "19"
+ "pos_x" "-24.362877"
+ "pos_y" "-916.073669"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_036"
+ {
+ "iType" "19"
+ "pos_x" "253.004974"
+ "pos_y" "-913.329041"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_037"
+ {
+ "iType" "19"
+ "pos_x" "109.621811"
+ "pos_y" "-917.240234"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "27"
+ "pos_x" "-35.257870"
+ "pos_y" "-789.638184"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_039"
+ {
+ "iType" "18"
+ "pos_x" "-159.130844"
+ "pos_y" "-1251.331909"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "-306.483490"
+ "pos_y" "-1302.419556"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_041"
+ {
+ "iType" "3"
+ "pos_x" "-1427.490723"
+ "pos_y" "-1395.865601"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_042"
+ {
+ "iType" "24"
+ "pos_x" "-4.528931"
+ "pos_y" "-1249.992432"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "19"
+ "pos_x" "158.960220"
+ "pos_y" "-1244.870728"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_044"
+ {
+ "iType" "18"
+ "pos_x" "314.051971"
+ "pos_y" "-1232.278564"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_045"
+ {
+ "iType" "5"
+ "pos_x" "171.705017"
+ "pos_y" "-1072.624023"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.33"
+ }
+ "Node_046"
+ {
+ "iType" "5"
+ "pos_x" "231.112000"
+ "pos_y" "-1151.187256"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_047"
+ {
+ "iType" "27"
+ "pos_x" "-943.889038"
+ "pos_y" "-626.367859"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_048"
+ {
+ "iType" "19"
+ "pos_x" "849.699097"
+ "pos_y" "-1327.599121"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "18"
+ "pos_x" "683.233887"
+ "pos_y" "-513.124451"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "21"
+ "pos_x" "573.945984"
+ "pos_y" "-114.695465"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_051"
+ {
+ "iType" "19"
+ "pos_x" "674.693604"
+ "pos_y" "-907.310974"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_052"
+ {
+ "iType" "4"
+ "pos_x" "1153.886841"
+ "pos_y" "-1361.154297"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_053"
+ {
+ "iType" "55"
+ "pos_x" "509.857239"
+ "pos_y" "-724.095520"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_054"
+ {
+ "iType" "19"
+ "pos_x" "24.964851"
+ "pos_y" "-611.821472"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_055"
+ {
+ "iType" "18"
+ "pos_x" "155.076736"
+ "pos_y" "-609.714478"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "12"
+ "pos_x" "301.490631"
+ "pos_y" "-626.477905"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_057"
+ {
+ "iType" "17"
+ "pos_x" "975.410461"
+ "pos_y" "-909.631592"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_058"
+ {
+ "iType" "19"
+ "pos_x" "829.005005"
+ "pos_y" "-906.510071"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "5"
+ "pos_x" "784.520874"
+ "pos_y" "-626.837158"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_060"
+ {
+ "iType" "18"
+ "pos_x" "856.089600"
+ "pos_y" "-727.945007"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "53"
+ "pos_x" "971.940796"
+ "pos_y" "-728.153259"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_062"
+ {
+ "iType" "34"
+ "pos_x" "1145.247803"
+ "pos_y" "-723.378540"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "19"
+ "pos_x" "218.857697"
+ "pos_y" "-712.468201"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "19"
+ "pos_x" "231.391418"
+ "pos_y" "-809.459778"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_065"
+ {
+ "iType" "26"
+ "pos_x" "358.941772"
+ "pos_y" "-730.200684"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "5"
+ "pos_x" "132.437363"
+ "pos_y" "-744.349609"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_067"
+ {
+ "iType" "5"
+ "pos_x" "143.945496"
+ "pos_y" "-827.633667"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "4"
+ }
+ "Node_068"
+ {
+ "iType" "5"
+ "pos_x" "1017.740234"
+ "pos_y" "-615.503174"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.37"
+ }
+ "Node_069"
+ {
+ "iType" "61"
+ "pos_x" "404.025635"
+ "pos_y" "-938.388550"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_070"
+ {
+ "iType" "22"
+ "pos_x" "358.216980"
+ "pos_y" "-833.205811"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "26"
+ "pos_x" "518.059692"
+ "pos_y" "-826.194153"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_072"
+ {
+ "iType" "5"
+ "pos_x" "464.631927"
+ "pos_y" "-866.089722"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_073"
+ {
+ "iType" "38"
+ "pos_x" "1326.954590"
+ "pos_y" "-726.876282"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_074"
+ {
+ "iType" "5"
+ "pos_x" "1111.836426"
+ "pos_y" "-603.984863"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.38"
+ }
+ "Node_075"
+ {
+ "iType" "5"
+ "pos_x" "1301.262695"
+ "pos_y" "-628.961121"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_076"
+ {
+ "iType" "29"
+ "pos_x" "700.193359"
+ "pos_y" "-725.241943"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise2"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0"
+ "iFallbackMode" "0"
+ }
+ "Node_077"
+ {
+ "iType" "29"
+ "pos_x" "9.422592"
+ "pos_y" "-396.145142"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise2"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0"
+ "iFallbackMode" "0"
+ }
+ "Node_078"
+ {
+ "iType" "29"
+ "pos_x" "-443.937622"
+ "pos_y" "-624.784546"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_079"
+ {
+ "iType" "29"
+ "pos_x" "-443.022614"
+ "pos_y" "-759.274048"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_080"
+ {
+ "iType" "29"
+ "pos_x" "-231.477158"
+ "pos_y" "-988.375610"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "144"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_081"
+ {
+ "iType" "21"
+ "pos_x" "-257.953857"
+ "pos_y" "-26.590645"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "19"
+ "pos_x" "-192.712799"
+ "pos_y" "-180.072235"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_083"
+ {
+ "iType" "61"
+ "pos_x" "-310.645813"
+ "pos_y" "-185.270187"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_084"
+ {
+ "iType" "5"
+ "pos_x" "-455.970428"
+ "pos_y" "-354.991364"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_085"
+ {
+ "iType" "29"
+ "pos_x" "-622.441101"
+ "pos_y" "-172.873840"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_086"
+ {
+ "iType" "49"
+ "pos_x" "-444.257202"
+ "pos_y" "-176.947357"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_087"
+ {
+ "iType" "5"
+ "pos_x" "-414.736420"
+ "pos_y" "-95.879227"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_088"
+ {
+ "iType" "29"
+ "pos_x" "-63.663620"
+ "pos_y" "-1758.249512"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_089"
+ {
+ "iType" "53"
+ "pos_x" "-104.591232"
+ "pos_y" "-2059.511719"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_090"
+ {
+ "iType" "19"
+ "pos_x" "32.855804"
+ "pos_y" "-2029.618408"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_091"
+ {
+ "iType" "17"
+ "pos_x" "182.115509"
+ "pos_y" "-2036.000244"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_092"
+ {
+ "iType" "5"
+ "pos_x" "154.832794"
+ "pos_y" "-2168.281250"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_093"
+ {
+ "iType" "5"
+ "pos_x" "11.283646"
+ "pos_y" "-2168.977051"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_094"
+ {
+ "iType" "50"
+ "pos_x" "108.426971"
+ "pos_y" "-1887.348267"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_095"
+ {
+ "iType" "18"
+ "pos_x" "-222.035614"
+ "pos_y" "-2070.279297"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_096"
+ {
+ "iType" "29"
+ "pos_x" "-63.597092"
+ "pos_y" "-1883.319336"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_097"
+ {
+ "iType" "19"
+ "pos_x" "-239.549896"
+ "pos_y" "-1891.643188"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_098"
+ {
+ "iType" "5"
+ "pos_x" "-355.981659"
+ "pos_y" "-1958.155884"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "4"
+ }
+ "Node_099"
+ {
+ "iType" "19"
+ "pos_x" "-177.644958"
+ "pos_y" "338.985931"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_100"
+ {
+ "iType" "5"
+ "pos_x" "-310.390747"
+ "pos_y" "382.765472"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_101"
+ {
+ "iType" "12"
+ "pos_x" "-308.853088"
+ "pos_y" "293.071320"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_102"
+ {
+ "iType" "27"
+ "pos_x" "-33.235962"
+ "pos_y" "339.319672"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_103"
+ {
+ "iType" "5"
+ "pos_x" "-24.619324"
+ "pos_y" "423.256897"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "szConstantString" "0.0001 0.0001"
+ }
+ "Node_104"
+ {
+ "iType" "55"
+ "pos_x" "113.600769"
+ "pos_y" "384.914673"
+ "size_x" "91.000000"
+ "size_y" "-39.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_105"
+ {
+ "iType" "12"
+ "pos_x" "-1315.608154"
+ "pos_y" "-350.362427"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_106"
+ {
+ "iType" "22"
+ "pos_x" "-1065.969238"
+ "pos_y" "-298.455078"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_107"
+ {
+ "iType" "19"
+ "pos_x" "-1183.978027"
+ "pos_y" "-280.960510"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_108"
+ {
+ "iType" "5"
+ "pos_x" "-1285.120850"
+ "pos_y" "-225.001358"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3.5"
+ }
+ "Node_109"
+ {
+ "iType" "19"
+ "pos_x" "493.591187"
+ "pos_y" "-1068.270142"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_110"
+ {
+ "iType" "22"
+ "pos_x" "611.600098"
+ "pos_y" "-1085.764771"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_111"
+ {
+ "iType" "12"
+ "pos_x" "361.961121"
+ "pos_y" "-1137.672119"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_112"
+ {
+ "iType" "19"
+ "pos_x" "586.039856"
+ "pos_y" "-1226.986450"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_113"
+ {
+ "iType" "19"
+ "pos_x" "792.527344"
+ "pos_y" "-1098.114990"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_114"
+ {
+ "iType" "5"
+ "pos_x" "368.636688"
+ "pos_y" "-1061.125122"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "10"
+ }
+ "Node_115"
+ {
+ "iType" "5"
+ "pos_x" "448.797485"
+ "pos_y" "-1281.609863"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8 0.76 0.65 0"
+ }
+ "Node_116"
+ {
+ "iType" "29"
+ "pos_x" "-631.900024"
+ "pos_y" "-34.453377"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_117"
+ {
+ "iType" "17"
+ "pos_x" "-782.880859"
+ "pos_y" "28.917599"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "120"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_118"
+ {
+ "iType" "18"
+ "pos_x" "-1145.925659"
+ "pos_y" "157.206024"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "133"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_119"
+ {
+ "iType" "19"
+ "pos_x" "-1012.722351"
+ "pos_y" "150.760712"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "122"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_120"
+ {
+ "iType" "27"
+ "pos_x" "-1039.189941"
+ "pos_y" "19.744049"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "0 x"
+ }
+ "Node_121"
+ {
+ "iType" "5"
+ "pos_x" "-1250.066650"
+ "pos_y" "247.480118"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_122"
+ {
+ "iType" "5"
+ "pos_x" "-1108.238037"
+ "pos_y" "244.257446"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.005"
+ }
+ "Node_123"
+ {
+ "iType" "49"
+ "pos_x" "232.963470"
+ "pos_y" "-157.316925"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "142"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_124"
+ {
+ "iType" "34"
+ "pos_x" "381.233917"
+ "pos_y" "-145.096436"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "126"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "143"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_125"
+ {
+ "iType" "5"
+ "pos_x" "140.752289"
+ "pos_y" "-99.001907"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_126"
+ {
+ "iType" "5"
+ "pos_x" "285.144318"
+ "pos_y" "-68.793892"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_127"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "191.196182"
+ "size_x" "55.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "137"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "128"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_128"
+ {
+ "iType" "20"
+ "pos_x" "95.519333"
+ "pos_y" "101.174911"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_129"
+ {
+ "iType" "65"
+ "pos_x" "-164.119995"
+ "pos_y" "72.637497"
+ "size_x" "60.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_130"
+ {
+ "iType" "5"
+ "pos_x" "-167.080811"
+ "pos_y" "132.298767"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_131"
+ {
+ "iType" "5"
+ "pos_x" "-32.814423"
+ "pos_y" "70.170700"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "64"
+ }
+ "Node_132"
+ {
+ "iType" "20"
+ "pos_x" "-40.068695"
+ "pos_y" "130.849060"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "130"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "129"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_133"
+ {
+ "iType" "81"
+ "pos_x" "-1273.607910"
+ "pos_y" "68.832352"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_num_comps" "0"
+ "fl_value_min" "0.000000"
+ "fl_value_max" "1.000000"
+ }
+ "Node_134"
+ {
+ "iType" "17"
+ "pos_x" "-193.243835"
+ "pos_y" "-1775.115967"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_135"
+ {
+ "iType" "81"
+ "pos_x" "-237.796722"
+ "pos_y" "-1697.220093"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_num_comps" "1"
+ "fl_value_min" "0.000000"
+ "fl_value_max" "10.000000"
+ }
+ "Node_136"
+ {
+ "iType" "19"
+ "pos_x" "-311.921356"
+ "pos_y" "-1774.363281"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_137"
+ {
+ "iType" "27"
+ "pos_x" "-47.798840"
+ "pos_y" "215.318329"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_138"
+ {
+ "iType" "27"
+ "pos_x" "-56.801575"
+ "pos_y" "-88.906647"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_139"
+ {
+ "iType" "27"
+ "pos_x" "-72.114502"
+ "pos_y" "-157.358780"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_140"
+ {
+ "iType" "27"
+ "pos_x" "-73.227158"
+ "pos_y" "-210.862518"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_141"
+ {
+ "iType" "38"
+ "pos_x" "51.489998"
+ "pos_y" "-126.969131"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "139"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_142"
+ {
+ "iType" "38"
+ "pos_x" "52.241310"
+ "pos_y" "-201.247452"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "141"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_143"
+ {
+ "iType" "5"
+ "pos_x" "376.888702"
+ "pos_y" "-65.797997"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1.8"
+ }
+ "Node_144"
+ {
+ "iType" "17"
+ "pos_x" "-413.457550"
+ "pos_y" "-1003.933594"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "145"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_145"
+ {
+ "iType" "19"
+ "pos_x" "-562.254272"
+ "pos_y" "-1131.356445"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "153"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_146"
+ {
+ "iType" "17"
+ "pos_x" "-168.125702"
+ "pos_y" "-308.652191"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "152"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_147"
+ {
+ "iType" "17"
+ "pos_x" "-768.662415"
+ "pos_y" "-210.415329"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_148"
+ {
+ "iType" "27"
+ "pos_x" "-1064.792480"
+ "pos_y" "-773.749695"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_149"
+ {
+ "iType" "19"
+ "pos_x" "-729.438171"
+ "pos_y" "-1001.319275"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "150"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_150"
+ {
+ "iType" "5"
+ "pos_x" "-821.527588"
+ "pos_y" "-918.819763"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "5"
+ }
+ "Node_151"
+ {
+ "iType" "5"
+ "pos_x" "-964.053894"
+ "pos_y" "-897.700073"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1 1"
+ }
+ "Node_152"
+ {
+ "iType" "19"
+ "pos_x" "-888.896362"
+ "pos_y" "-750.079041"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "151"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_153"
+ {
+ "iType" "5"
+ "pos_x" "-674.109131"
+ "pos_y" "-1173.485107"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0.25"
+ }
+ }
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_videofeed.txt b/mp/game/momentum/shadereditorui/canvas/postproc_videofeed.txt
new file mode 100644
index 0000000000..2a82ad7849
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_videofeed.txt
@@ -0,0 +1,2703 @@
+"canvas"
+{
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-1615.073853"
+ "pos_y" "402.104858"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ }
+ "Node_001"
+ {
+ "iType" "27"
+ "pos_x" "-874.093201"
+ "pos_y" "727.707214"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_002"
+ {
+ "iType" "17"
+ "pos_x" "-551.495239"
+ "pos_y" "736.042419"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "139"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "53"
+ "pos_x" "-402.531921"
+ "pos_y" "734.858093"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "60"
+ "pos_x" "-267.085510"
+ "pos_y" "728.391235"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "61"
+ "pos_x" "-131.625854"
+ "pos_y" "725.241089"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "49"
+ "pos_x" "3.258621"
+ "pos_y" "729.178894"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "27"
+ "pos_x" "-477.234558"
+ "pos_y" "424.168091"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_008"
+ {
+ "iType" "18"
+ "pos_x" "526.497314"
+ "pos_y" "621.856689"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "5"
+ "pos_x" "-296.613708"
+ "pos_y" "571.151245"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_010"
+ {
+ "iType" "19"
+ "pos_x" "-180.388947"
+ "pos_y" "435.175354"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "pos_x" "393.959900"
+ "pos_y" "623.223206"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 1"
+ }
+ "Node_012"
+ {
+ "iType" "5"
+ "pos_x" "-297.255493"
+ "pos_y" "455.940063"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_013"
+ {
+ "iType" "5"
+ "pos_x" "-789.972046"
+ "pos_y" "542.498779"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.03"
+ }
+ "Node_014"
+ {
+ "iType" "5"
+ "pos_x" "-831.334473"
+ "pos_y" "618.379944"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.9"
+ }
+ "Node_015"
+ {
+ "iType" "5"
+ "pos_x" "-133.810120"
+ "pos_y" "803.688171"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "35"
+ }
+ "Node_016"
+ {
+ "iType" "53"
+ "pos_x" "-484.071899"
+ "pos_y" "-1217.587158"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "19"
+ "pos_x" "-346.624878"
+ "pos_y" "-1187.693848"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "50"
+ "pos_x" "-271.053589"
+ "pos_y" "-1045.424072"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "18"
+ "pos_x" "-601.516357"
+ "pos_y" "-1228.354980"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "19"
+ "pos_x" "-619.030640"
+ "pos_y" "-1049.719238"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_021"
+ {
+ "iType" "19"
+ "pos_x" "-1422.092896"
+ "pos_y" "319.783569"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "27"
+ "pos_x" "-1297.530151"
+ "pos_y" "303.598267"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_023"
+ {
+ "iType" "5"
+ "pos_x" "-1544.666870"
+ "pos_y" "339.157959"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_024"
+ {
+ "iType" "12"
+ "pos_x" "-1557.323608"
+ "pos_y" "279.943726"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_025"
+ {
+ "iType" "29"
+ "pos_x" "-443.077820"
+ "pos_y" "-1041.395264"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "-368.197021"
+ "pos_y" "-1327.052734"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_027"
+ {
+ "iType" "5"
+ "pos_x" "-224.647827"
+ "pos_y" "-1326.356689"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_028"
+ {
+ "iType" "19"
+ "pos_x" "-179.747131"
+ "pos_y" "550.386475"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "17"
+ "pos_x" "-197.365051"
+ "pos_y" "-1194.075439"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_030"
+ {
+ "iType" "5"
+ "pos_x" "15.188614"
+ "pos_y" "825.837708"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_031"
+ {
+ "iType" "5"
+ "pos_x" "92.750351"
+ "pos_y" "825.837708"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_032"
+ {
+ "iType" "34"
+ "pos_x" "155.183853"
+ "pos_y" "733.606873"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_033"
+ {
+ "iType" "5"
+ "pos_x" "339.682373"
+ "pos_y" "782.592102"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0"
+ }
+ "Node_034"
+ {
+ "iType" "18"
+ "pos_x" "-708.378723"
+ "pos_y" "728.092773"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "19"
+ "pos_x" "-726.148987"
+ "pos_y" "1065.703613"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "141"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_036"
+ {
+ "iType" "3"
+ "pos_x" "-889.480835"
+ "pos_y" "166.362411"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_037"
+ {
+ "iType" "27"
+ "pos_x" "-296.763550"
+ "pos_y" "1141.237305"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_038"
+ {
+ "iType" "60"
+ "pos_x" "315.559753"
+ "pos_y" "1024.600342"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "34"
+ "pos_x" "160.383743"
+ "pos_y" "1024.862305"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "61"
+ "pos_x" "453.968872"
+ "pos_y" "1028.022949"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_041"
+ {
+ "iType" "21"
+ "pos_x" "439.661499"
+ "pos_y" "740.247742"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "38"
+ "pos_x" "623.840637"
+ "pos_y" "737.942749"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "19"
+ "pos_x" "613.187988"
+ "pos_y" "1031.033447"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "127"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_044"
+ {
+ "iType" "5"
+ "pos_x" "129.708969"
+ "pos_y" "1140.010010"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.02"
+ }
+ "Node_045"
+ {
+ "iType" "5"
+ "pos_x" "222.255981"
+ "pos_y" "1130.576294"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.08"
+ }
+ "Node_046"
+ {
+ "iType" "27"
+ "pos_x" "613.832886"
+ "pos_y" "926.534973"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_047"
+ {
+ "iType" "53"
+ "pos_x" "20.701401"
+ "pos_y" "1020.860840"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_048"
+ {
+ "iType" "4"
+ "pos_x" "1724.086792"
+ "pos_y" "-895.564575"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_049"
+ {
+ "iType" "5"
+ "pos_x" "1272.329102"
+ "pos_y" "-586.940186"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "4"
+ }
+ "Node_050"
+ {
+ "iType" "5"
+ "pos_x" "1187.734009"
+ "pos_y" "-585.558105"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-2"
+ }
+ "Node_051"
+ {
+ "iType" "55"
+ "pos_x" "775.184692"
+ "pos_y" "746.714722"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_052"
+ {
+ "iType" "17"
+ "pos_x" "-270.371155"
+ "pos_y" "179.129974"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "137"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_053"
+ {
+ "iType" "5"
+ "pos_x" "-735.462280"
+ "pos_y" "-1116.231445"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "5"
+ }
+ "Node_054"
+ {
+ "iType" "12"
+ "pos_x" "-859.146790"
+ "pos_y" "1057.320557"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_055"
+ {
+ "iType" "17"
+ "pos_x" "-721.791870"
+ "pos_y" "-512.156128"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "19"
+ "pos_x" "-575.867188"
+ "pos_y" "-514.791260"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-1006.411133"
+ "pos_y" "-533.806152"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_058"
+ {
+ "iType" "27"
+ "pos_x" "-879.372681"
+ "pos_y" "-527.977295"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "0 x"
+ }
+ "Node_059"
+ {
+ "iType" "27"
+ "pos_x" "-881.142700"
+ "pos_y" "-323.338684"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_060"
+ {
+ "iType" "18"
+ "pos_x" "-732.010864"
+ "pos_y" "-322.492004"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "53"
+ "pos_x" "-597.466675"
+ "pos_y" "-320.592529"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_062"
+ {
+ "iType" "5"
+ "pos_x" "-473.858765"
+ "pos_y" "-239.791931"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_063"
+ {
+ "iType" "5"
+ "pos_x" "-408.631470"
+ "pos_y" "-232.016479"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_064"
+ {
+ "iType" "5"
+ "pos_x" "-772.145020"
+ "pos_y" "-239.738098"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.05"
+ }
+ "Node_065"
+ {
+ "iType" "34"
+ "pos_x" "-463.125366"
+ "pos_y" "-323.760681"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "61"
+ "pos_x" "-312.104340"
+ "pos_y" "-316.953735"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_067"
+ {
+ "iType" "27"
+ "pos_x" "-855.742798"
+ "pos_y" "-87.800728"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_068"
+ {
+ "iType" "53"
+ "pos_x" "-572.066772"
+ "pos_y" "-85.054573"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_069"
+ {
+ "iType" "61"
+ "pos_x" "-286.704529"
+ "pos_y" "-81.415779"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_070"
+ {
+ "iType" "18"
+ "pos_x" "-694.214233"
+ "pos_y" "-79.355598"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "38"
+ "pos_x" "-183.349396"
+ "pos_y" "-241.004700"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_072"
+ {
+ "iType" "17"
+ "pos_x" "-785.087585"
+ "pos_y" "53.951553"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_073"
+ {
+ "iType" "5"
+ "pos_x" "-882.766418"
+ "pos_y" "84.769577"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.95"
+ }
+ "Node_074"
+ {
+ "iType" "12"
+ "pos_x" "-1216.060425"
+ "pos_y" "-244.529541"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_075"
+ {
+ "iType" "5"
+ "pos_x" "-1115.882324"
+ "pos_y" "94.512009"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.05"
+ }
+ "Node_076"
+ {
+ "iType" "22"
+ "pos_x" "-1169.086182"
+ "pos_y" "-39.359444"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "19"
+ "pos_x" "-1038.513184"
+ "pos_y" "-32.467354"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_078"
+ {
+ "iType" "24"
+ "pos_x" "342.619354"
+ "pos_y" "-1696.248169"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_079"
+ {
+ "iType" "5"
+ "pos_x" "221.570984"
+ "pos_y" "-1604.864746"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.5"
+ }
+ "Node_080"
+ {
+ "iType" "18"
+ "pos_x" "195.252441"
+ "pos_y" "-1696.482788"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_081"
+ {
+ "iType" "34"
+ "pos_x" "-437.725464"
+ "pos_y" "-88.222725"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "5"
+ "pos_x" "-448.458862"
+ "pos_y" "-4.253975"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_083"
+ {
+ "iType" "5"
+ "pos_x" "-383.231628"
+ "pos_y" "3.521477"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_084"
+ {
+ "iType" "19"
+ "szName" "noise"
+ "pos_x" "1053.005493"
+ "pos_y" "-666.638184"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_085"
+ {
+ "iType" "19"
+ "szName" "vignette"
+ "pos_x" "1324.317017"
+ "pos_y" "-883.534058"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_086"
+ {
+ "iType" "21"
+ "szName" "noise_overlay"
+ "pos_x" "1550.675415"
+ "pos_y" "-685.328125"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "3"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "129"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_087"
+ {
+ "iType" "18"
+ "szName" "bands"
+ "pos_x" "1156.966431"
+ "pos_y" "-878.003052"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_088"
+ {
+ "iType" "5"
+ "pos_x" "-685.473511"
+ "pos_y" "-632.380859"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.005"
+ }
+ "Node_089"
+ {
+ "iType" "5"
+ "pos_x" "-1109.770752"
+ "pos_y" "-607.138916"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "50"
+ }
+ "Node_090"
+ {
+ "iType" "19"
+ "pos_x" "-114.556351"
+ "pos_y" "180.091766"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_091"
+ {
+ "iType" "5"
+ "pos_x" "74.659439"
+ "pos_y" "337.084351"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_092"
+ {
+ "iType" "5"
+ "pos_x" "-165.427185"
+ "pos_y" "75.487106"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 6"
+ }
+ "Node_093"
+ {
+ "iType" "29"
+ "pos_x" "45.979420"
+ "pos_y" "185.302124"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_094"
+ {
+ "iType" "26"
+ "pos_x" "1478.374634"
+ "pos_y" "-884.818481"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_095"
+ {
+ "iType" "19"
+ "pos_x" "316.771149"
+ "pos_y" "-1285.043823"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "130"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_096"
+ {
+ "iType" "18"
+ "pos_x" "162.530472"
+ "pos_y" "-1280.172119"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_097"
+ {
+ "iType" "17"
+ "pos_x" "447.219635"
+ "pos_y" "-1287.217651"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_098"
+ {
+ "iType" "27"
+ "pos_x" "22.473484"
+ "pos_y" "-1277.742798"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_099"
+ {
+ "iType" "34"
+ "pos_x" "1215.822388"
+ "pos_y" "-683.860840"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_100"
+ {
+ "iType" "34"
+ "pos_x" "473.003296"
+ "pos_y" "-1691.584839"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_101"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "589.327759"
+ "pos_y" "-708.073975"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_102"
+ {
+ "iType" "27"
+ "pos_x" "312.192841"
+ "pos_y" "-1174.524048"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_103"
+ {
+ "iType" "5"
+ "pos_x" "86.384224"
+ "pos_y" "-1408.272827"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_104"
+ {
+ "iType" "26"
+ "pos_x" "813.951172"
+ "pos_y" "-699.336670"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_105"
+ {
+ "iType" "26"
+ "pos_x" "821.816406"
+ "pos_y" "-818.186890"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "4"
+ }
+ }
+ }
+ "Node_106"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "597.291992"
+ "pos_y" "-822.509521"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_107"
+ {
+ "iType" "26"
+ "pos_x" "577.129211"
+ "pos_y" "-1287.859985"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_108"
+ {
+ "iType" "23"
+ "pos_x" "1170.148438"
+ "pos_y" "-397.836060"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_109"
+ {
+ "iType" "5"
+ "pos_x" "1042.937866"
+ "pos_y" "-412.251343"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0.59 0.11"
+ }
+ "Node_110"
+ {
+ "iType" "21"
+ "szName" "desaturate"
+ "pos_x" "1396.248291"
+ "pos_y" "-679.183716"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_111"
+ {
+ "iType" "5"
+ "pos_x" "436.359406"
+ "pos_y" "-1599.891113"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_112"
+ {
+ "iType" "5"
+ "pos_x" "525.250244"
+ "pos_y" "-1605.832397"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.2"
+ }
+ "Node_113"
+ {
+ "iType" "27"
+ "pos_x" "1301.666504"
+ "pos_y" "-394.336304"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xxx"
+ }
+ "Node_114"
+ {
+ "iType" "19"
+ "pos_x" "-271.308960"
+ "pos_y" "1015.369995"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "149"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_115"
+ {
+ "iType" "29"
+ "pos_x" "-443.144348"
+ "pos_y" "-916.325684"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "142"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise2"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_3d"
+ "iFallbackMode" "0"
+ }
+ "Node_116"
+ {
+ "iType" "19"
+ "pos_x" "189.168900"
+ "pos_y" "-505.955444"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "126"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_117"
+ {
+ "iType" "19"
+ "pos_x" "65.481606"
+ "pos_y" "-503.892944"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_118"
+ {
+ "iType" "29"
+ "pos_x" "-453.179840"
+ "pos_y" "-508.592041"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise2"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_3d"
+ "iFallbackMode" "0"
+ }
+ "Node_119"
+ {
+ "iType" "23"
+ "pos_x" "-411.816528"
+ "pos_y" "-617.233826"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "120"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_120"
+ {
+ "iType" "5"
+ "pos_x" "-506.795990"
+ "pos_y" "-652.251282"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0.59 0.11"
+ }
+ "Node_121"
+ {
+ "iType" "21"
+ "pos_x" "-229.091995"
+ "pos_y" "-517.935059"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "122"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_122"
+ {
+ "iType" "5"
+ "pos_x" "-247.699051"
+ "pos_y" "-644.753235"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_123"
+ {
+ "iType" "34"
+ "pos_x" "-79.711845"
+ "pos_y" "-507.810059"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "124"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_124"
+ {
+ "iType" "5"
+ "pos_x" "-18.228107"
+ "pos_y" "-418.644226"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_125"
+ {
+ "iType" "5"
+ "pos_x" "-84.445435"
+ "pos_y" "-420.478943"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_126"
+ {
+ "iType" "5"
+ "pos_x" "205.982681"
+ "pos_y" "-421.311829"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_127"
+ {
+ "iType" "5"
+ "pos_x" "609.593018"
+ "pos_y" "1121.825562"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.0125"
+ }
+ "Node_128"
+ {
+ "iType" "5"
+ "pos_x" "152.221176"
+ "pos_y" "337.084351"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1.4"
+ }
+ "Node_129"
+ {
+ "iType" "34"
+ "pos_x" "214.654724"
+ "pos_y" "244.853485"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "128"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_130"
+ {
+ "iType" "5"
+ "pos_x" "205.583237"
+ "pos_y" "-1412.647827"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.99"
+ }
+ "Node_131"
+ {
+ "iType" "5"
+ "pos_x" "-1332.952026"
+ "pos_y" "157.681183"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "64"
+ }
+ "Node_132"
+ {
+ "iType" "2"
+ "pos_x" "-1030.074097"
+ "pos_y" "402.104858"
+ "size_x" "55.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "151"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "3"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV 0"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Name_1" "UV 1"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Name_2" "Texel scale"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_133"
+ {
+ "iType" "20"
+ "pos_x" "-1346.862305"
+ "pos_y" "217.640137"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_134"
+ {
+ "iType" "65"
+ "pos_x" "-1466.559937"
+ "pos_y" "150.396393"
+ "size_x" "60.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ }
+ "Node_135"
+ {
+ "iType" "5"
+ "pos_x" "-1462.496216"
+ "pos_y" "219.169312"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_136"
+ {
+ "iType" "20"
+ "pos_x" "-1216.167236"
+ "pos_y" "200.418213"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "133"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_137"
+ {
+ "iType" "27"
+ "pos_x" "-432.835266"
+ "pos_y" "180.834198"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y 0"
+ }
+ "Node_138"
+ {
+ "iType" "81"
+ "pos_x" "-758.631531"
+ "pos_y" "280.125458"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_num_comps" "1"
+ "fl_value_min" "0.000000"
+ "fl_value_max" "1.000000"
+ }
+ "Node_139"
+ {
+ "iType" "19"
+ "pos_x" "-697.202942"
+ "pos_y" "611.576477"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_140"
+ {
+ "iType" "27"
+ "pos_x" "-773.541565"
+ "pos_y" "427.126160"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_141"
+ {
+ "iType" "5"
+ "pos_x" "-701.322815"
+ "pos_y" "1155.979492"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.75"
+ }
+ "Node_142"
+ {
+ "iType" "17"
+ "pos_x" "-577.822449"
+ "pos_y" "-923.374573"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "143"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "144"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_143"
+ {
+ "iType" "19"
+ "pos_x" "-696.499939"
+ "pos_y" "-922.621887"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_144"
+ {
+ "iType" "19"
+ "pos_x" "-669.645569"
+ "pos_y" "-816.723083"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "145"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_145"
+ {
+ "iType" "5"
+ "pos_x" "-855.665222"
+ "pos_y" "-885.497192"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "10"
+ }
+ "Node_146"
+ {
+ "iType" "22"
+ "pos_x" "-590.362610"
+ "pos_y" "1069.707520"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_147"
+ {
+ "iType" "18"
+ "pos_x" "-123.954468"
+ "pos_y" "1027.000244"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_148"
+ {
+ "iType" "5"
+ "pos_x" "-372.644928"
+ "pos_y" "957.891785"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_149"
+ {
+ "iType" "18"
+ "pos_x" "-454.786316"
+ "pos_y" "1058.930420"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "150"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_150"
+ {
+ "iType" "5"
+ "pos_x" "-553.716492"
+ "pos_y" "961.699402"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_151"
+ {
+ "iType" "27"
+ "pos_x" "-1325.921631"
+ "pos_y" "433.695557"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ }
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/postproc_warp.txt b/mp/game/momentum/shadereditorui/canvas/postproc_warp.txt
new file mode 100644
index 0000000000..b4a424065c
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/postproc_warp.txt
@@ -0,0 +1,3112 @@
+"canvas"
+{
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "2"
+ "pos_x" "72.538681"
+ "pos_y" "169.545181"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "165"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "1"
+ "pos_x" "-243.759338"
+ "pos_y" "169.545181"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords" "2"
+ "dTFlag_Color" "8"
+ }
+ "Node_002"
+ {
+ "iType" "32"
+ "pos_x" "-746.930725"
+ "pos_y" "-237.392456"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "153"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "24"
+ "pos_x" "-1448.351685"
+ "pos_y" "72.049553"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "164"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "19"
+ "pos_x" "-1294.620972"
+ "pos_y" "14.283691"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_005"
+ {
+ "iType" "5"
+ "pos_x" "-1395.484253"
+ "pos_y" "-37.695587"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.00125"
+ }
+ "Node_006"
+ {
+ "iType" "27"
+ "pos_x" "199.130508"
+ "pos_y" "-267.666748"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "b"
+ }
+ "Node_007"
+ {
+ "iType" "27"
+ "pos_x" "354.580200"
+ "pos_y" "-366.469299"
+ "size_x" "117.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "0 0 x"
+ }
+ "Node_008"
+ {
+ "iType" "27"
+ "pos_x" "364.254639"
+ "pos_y" "-255.419846"
+ "size_x" "117.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "0 x 0"
+ }
+ "Node_009"
+ {
+ "iType" "17"
+ "pos_x" "388.256836"
+ "pos_y" "-133.052078"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "19"
+ "pos_x" "546.167603"
+ "pos_y" "-138.177628"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "pos_x" "403.967712"
+ "pos_y" "-476.188538"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_012"
+ {
+ "iType" "17"
+ "pos_x" "769.841858"
+ "pos_y" "-253.397751"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "118"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "5"
+ "pos_x" "565.731262"
+ "pos_y" "-466.768372"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_014"
+ {
+ "iType" "34"
+ "pos_x" "-1302.177856"
+ "pos_y" "125.767792"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "25"
+ "pos_x" "-1941.864136"
+ "pos_y" "446.239166"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "164"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "5"
+ "pos_x" "-2217.276855"
+ "pos_y" "447.933624"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_017"
+ {
+ "iType" "19"
+ "pos_x" "-1107.915405"
+ "pos_y" "105.154114"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "pos_x" "-1397.191772"
+ "pos_y" "139.194778"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_019"
+ {
+ "iType" "5"
+ "pos_x" "-1456.811890"
+ "pos_y" "138.296677"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.05"
+ }
+ "Node_020"
+ {
+ "iType" "61"
+ "pos_x" "-2905.558838"
+ "pos_y" "-602.646484"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_021"
+ {
+ "iType" "27"
+ "pos_x" "-2783.698975"
+ "pos_y" "-612.247681"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_022"
+ {
+ "iType" "61"
+ "pos_x" "-2903.363770"
+ "pos_y" "-746.997986"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_023"
+ {
+ "iType" "19"
+ "pos_x" "-2224.040039"
+ "pos_y" "-404.486023"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_024"
+ {
+ "iType" "5"
+ "pos_x" "-2290.988770"
+ "pos_y" "-338.715515"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_025"
+ {
+ "iType" "19"
+ "pos_x" "-2259.857910"
+ "pos_y" "-505.241760"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "-2326.806641"
+ "pos_y" "-439.471283"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-4"
+ }
+ "Node_027"
+ {
+ "iType" "29"
+ "pos_x" "-1940.935669"
+ "pos_y" "-743.067444"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "150"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "flow"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_4"
+ "iFallbackMode" "0"
+ }
+ "Node_028"
+ {
+ "iType" "17"
+ "pos_x" "-3165.479980"
+ "pos_y" "-737.541565"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "22"
+ "pos_x" "-3049.411621"
+ "pos_y" "-737.897522"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_030"
+ {
+ "iType" "5"
+ "pos_x" "-2530.446289"
+ "pos_y" "-970.617493"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_031"
+ {
+ "iType" "39"
+ "pos_x" "-724.515930"
+ "pos_y" "250.632385"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "141"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "18"
+ "pos_x" "-2387.341797"
+ "pos_y" "-899.185730"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_033"
+ {
+ "iType" "19"
+ "pos_x" "-2089.619141"
+ "pos_y" "-896.832825"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_034"
+ {
+ "iType" "53"
+ "pos_x" "-2245.903320"
+ "pos_y" "-895.604431"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "5"
+ "pos_x" "-2191.637695"
+ "pos_y" "-1013.545837"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_036"
+ {
+ "iType" "29"
+ "pos_x" "-1934.430908"
+ "pos_y" "-597.894226"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "145"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "flow"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_4"
+ "iFallbackMode" "0"
+ }
+ "Node_037"
+ {
+ "iType" "5"
+ "pos_x" "-730.441223"
+ "pos_y" "329.861023"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3.5"
+ }
+ "Node_038"
+ {
+ "iType" "5"
+ "pos_x" "-2201.213623"
+ "pos_y" "253.545166"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 1"
+ }
+ "Node_039"
+ {
+ "iType" "17"
+ "pos_x" "-2026.588257"
+ "pos_y" "-475.982056"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "19"
+ "pos_x" "-1724.848633"
+ "pos_y" "-405.211975"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_041"
+ {
+ "iType" "12"
+ "pos_x" "-1908.058472"
+ "pos_y" "-424.729309"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_042"
+ {
+ "iType" "39"
+ "pos_x" "-1617.870728"
+ "pos_y" "-481.444122"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "53"
+ "pos_x" "-1531.823853"
+ "pos_y" "-489.107239"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_044"
+ {
+ "iType" "53"
+ "pos_x" "-1542.892578"
+ "pos_y" "-582.754517"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_045"
+ {
+ "iType" "40"
+ "pos_x" "-1645.364746"
+ "pos_y" "-586.126038"
+ "size_x" "63.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "19"
+ "pos_x" "-1757.314087"
+ "pos_y" "-506.572571"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_047"
+ {
+ "iType" "19"
+ "pos_x" "-1732.115356"
+ "pos_y" "-655.087769"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_048"
+ {
+ "iType" "19"
+ "pos_x" "-1729.285156"
+ "pos_y" "-757.928162"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_049"
+ {
+ "iType" "5"
+ "pos_x" "-1819.576172"
+ "pos_y" "-464.233185"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "20"
+ }
+ "Node_050"
+ {
+ "iType" "22"
+ "pos_x" "-3019.332275"
+ "pos_y" "-603.326050"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_051"
+ {
+ "iType" "27"
+ "pos_x" "-2781.503418"
+ "pos_y" "-756.599182"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_052"
+ {
+ "iType" "19"
+ "pos_x" "-2605.255859"
+ "pos_y" "-762.771606"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "144"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_053"
+ {
+ "iType" "5"
+ "pos_x" "-1112.093018"
+ "pos_y" "-6.715954"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_054"
+ {
+ "iType" "5"
+ "pos_x" "-2087.064697"
+ "pos_y" "-238.842804"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-0.1"
+ }
+ "Node_055"
+ {
+ "iType" "26"
+ "pos_x" "-1819.434937"
+ "pos_y" "281.896912"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "5"
+ "pos_x" "-1772.286133"
+ "pos_y" "349.935059"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-1015.181030"
+ "pos_y" "-175.563004"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "110"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "5"
+ "pos_x" "-900.981201"
+ "pos_y" "-128.303040"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.15"
+ }
+ "Node_059"
+ {
+ "iType" "34"
+ "pos_x" "-793.659485"
+ "pos_y" "-131.430038"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "156"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "19"
+ "pos_x" "-242.648682"
+ "pos_y" "-17.838028"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_061"
+ {
+ "iType" "27"
+ "pos_x" "192.576462"
+ "pos_y" "-159.604095"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "rgb"
+ }
+ "Node_062"
+ {
+ "iType" "5"
+ "pos_x" "-347.800171"
+ "pos_y" "-64.328766"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_063"
+ {
+ "iType" "12"
+ "pos_x" "-2751.356201"
+ "pos_y" "-363.631561"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_064"
+ {
+ "iType" "19"
+ "pos_x" "-2511.395020"
+ "pos_y" "-453.380249"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "111"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_065"
+ {
+ "iType" "26"
+ "pos_x" "-2661.960693"
+ "pos_y" "-422.596710"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "5"
+ "pos_x" "-328.380005"
+ "pos_y" "-397.041260"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_067"
+ {
+ "iType" "5"
+ "pos_x" "-333.742065"
+ "pos_y" "-475.403931"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_068"
+ {
+ "iType" "27"
+ "pos_x" "-34.267441"
+ "pos_y" "-423.596802"
+ "size_x" "123.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "r g b 1"
+ }
+ "Node_069"
+ {
+ "iType" "5"
+ "pos_x" "-375.701172"
+ "pos_y" "-145.784973"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_070"
+ {
+ "iType" "5"
+ "pos_x" "-195.743561"
+ "pos_y" "-137.639206"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "-3247.070557"
+ "pos_y" "-645.446289"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_072"
+ {
+ "iType" "27"
+ "pos_x" "814.095032"
+ "pos_y" "-418.384216"
+ "size_x" "123.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "r g b 1"
+ }
+ "Node_073"
+ {
+ "iType" "19"
+ "pos_x" "-2204.903076"
+ "pos_y" "-621.466980"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_074"
+ {
+ "iType" "29"
+ "pos_x" "-2366.363037"
+ "pos_y" "-742.620789"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_075"
+ {
+ "iType" "19"
+ "pos_x" "-2071.060059"
+ "pos_y" "-344.556427"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_076"
+ {
+ "iType" "5"
+ "pos_x" "-1808.071899"
+ "pos_y" "-364.147308"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "5"
+ }
+ "Node_077"
+ {
+ "iType" "5"
+ "pos_x" "-1245.960815"
+ "pos_y" "-98.100060"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_078"
+ {
+ "iType" "17"
+ "pos_x" "87.734680"
+ "pos_y" "-206.471436"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "159"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_079"
+ {
+ "iType" "26"
+ "pos_x" "-11.522202"
+ "pos_y" "-317.873779"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "158"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_080"
+ {
+ "iType" "19"
+ "pos_x" "-660.645447"
+ "pos_y" "-118.046204"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "109"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_081"
+ {
+ "iType" "34"
+ "pos_x" "-248.729630"
+ "pos_y" "-411.062622"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "27"
+ "pos_x" "-328.432373"
+ "pos_y" "-272.121338"
+ "size_x" "102.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "r"
+ }
+ "Node_083"
+ {
+ "iType" "27"
+ "pos_x" "-173.898712"
+ "pos_y" "-280.146423"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "gb"
+ }
+ "Node_084"
+ {
+ "iType" "19"
+ "pos_x" "-103.334076"
+ "pos_y" "-153.042252"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_085"
+ {
+ "iType" "17"
+ "pos_x" "-1.386536"
+ "pos_y" "-537.102295"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_086"
+ {
+ "iType" "19"
+ "pos_x" "-1195.886475"
+ "pos_y" "-190.134842"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_087"
+ {
+ "iType" "23"
+ "pos_x" "-2096.848877"
+ "pos_y" "267.665558"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_088"
+ {
+ "iType" "5"
+ "pos_x" "-2198.758545"
+ "pos_y" "144.831482"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0"
+ }
+ "Node_089"
+ {
+ "iType" "23"
+ "pos_x" "-2092.035400"
+ "pos_y" "156.598373"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_090"
+ {
+ "iType" "19"
+ "pos_x" "-1907.639893"
+ "pos_y" "93.025070"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_091"
+ {
+ "iType" "17"
+ "pos_x" "-1756.224731"
+ "pos_y" "86.886665"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_092"
+ {
+ "iType" "5"
+ "pos_x" "-1932.155029"
+ "pos_y" "158.848053"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_093"
+ {
+ "iType" "5"
+ "pos_x" "-1800.178467"
+ "pos_y" "176.240387"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_094"
+ {
+ "iType" "19"
+ "pos_x" "-2189.078125"
+ "pos_y" "-21.070053"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "116"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "117"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_095"
+ {
+ "iType" "29"
+ "pos_x" "-1788.716919"
+ "pos_y" "-135.618942"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_096"
+ {
+ "iType" "29"
+ "pos_x" "-1792.469360"
+ "pos_y" "-22.055450"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "noise"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\noise_2d"
+ "iFallbackMode" "0"
+ }
+ "Node_097"
+ {
+ "iType" "17"
+ "pos_x" "-1913.971802"
+ "pos_y" "-17.125908"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_098"
+ {
+ "iType" "27"
+ "pos_x" "-2070.565918"
+ "pos_y" "-13.530006"
+ "size_x" "110.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x 0"
+ }
+ "Node_099"
+ {
+ "iType" "21"
+ "pos_x" "-1620.674316"
+ "pos_y" "-82.548004"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_100"
+ {
+ "iType" "18"
+ "pos_x" "-1926.686401"
+ "pos_y" "-127.184525"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "107"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_101"
+ {
+ "iType" "34"
+ "pos_x" "-1043.703369"
+ "pos_y" "-35.678207"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_102"
+ {
+ "iType" "5"
+ "pos_x" "-1185.810181"
+ "pos_y" "-0.930424"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_103"
+ {
+ "iType" "19"
+ "pos_x" "-1457.940552"
+ "pos_y" "-263.622223"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "125"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "112"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_104"
+ {
+ "iType" "19"
+ "pos_x" "-23.616699"
+ "pos_y" "-833.089905"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "132"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_105"
+ {
+ "iType" "3"
+ "pos_x" "-2580.768555"
+ "pos_y" "51.191097"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_106"
+ {
+ "iType" "19"
+ "pos_x" "-1684.998657"
+ "pos_y" "297.682678"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_107"
+ {
+ "iType" "55"
+ "pos_x" "-1642.190308"
+ "pos_y" "178.103577"
+ "size_x" "120.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "106"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "108"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "0"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "0"
+ }
+ "Node_108"
+ {
+ "iType" "5"
+ "pos_x" "-1724.055786"
+ "pos_y" "167.691742"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1.5 0.25"
+ }
+ "Node_109"
+ {
+ "iType" "29"
+ "pos_x" "-714.292175"
+ "pos_y" "7.002472"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "121"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "flowmask"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_1"
+ "iFallbackMode" "0"
+ }
+ "Node_110"
+ {
+ "iType" "21"
+ "pos_x" "-1541.463135"
+ "pos_y" "-750.710938"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_111"
+ {
+ "iType" "5"
+ "pos_x" "-2579.608398"
+ "pos_y" "-359.221313"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_112"
+ {
+ "iType" "18"
+ "pos_x" "-1582.852417"
+ "pos_y" "-256.141815"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "113"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "114"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_113"
+ {
+ "iType" "27"
+ "pos_x" "-1728.334717"
+ "pos_y" "-264.838257"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_114"
+ {
+ "iType" "5"
+ "pos_x" "-1634.628174"
+ "pos_y" "-191.202515"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_115"
+ {
+ "iType" "5"
+ "pos_x" "-502.539520"
+ "pos_y" "-773.362915"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.65 1 1"
+ }
+ "Node_116"
+ {
+ "iType" "12"
+ "pos_x" "-2324.372559"
+ "pos_y" "6.277012"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_117"
+ {
+ "iType" "5"
+ "pos_x" "-2312.573975"
+ "pos_y" "-61.729652"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_118"
+ {
+ "iType" "19"
+ "pos_x" "683.679260"
+ "pos_y" "-408.747498"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "119"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_119"
+ {
+ "iType" "21"
+ "pos_x" "537.659790"
+ "pos_y" "-355.484741"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_120"
+ {
+ "iType" "19"
+ "pos_x" "-629.165283"
+ "pos_y" "293.221863"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_121"
+ {
+ "iType" "55"
+ "pos_x" "-848.082031"
+ "pos_y" "6.140163"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "120"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "123"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "122"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_122"
+ {
+ "iType" "27"
+ "pos_x" "-828.578857"
+ "pos_y" "138.593979"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "143"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_123"
+ {
+ "iType" "5"
+ "pos_x" "-937.004028"
+ "pos_y" "-66.236961"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5 0.1"
+ }
+ "Node_124"
+ {
+ "iType" "4"
+ "pos_x" "144.015549"
+ "pos_y" "-852.523254"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_125"
+ {
+ "iType" "34"
+ "pos_x" "-1370.385742"
+ "pos_y" "-145.137436"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "127"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "126"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_126"
+ {
+ "iType" "5"
+ "pos_x" "-1433.093750"
+ "pos_y" "-110.043152"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_127"
+ {
+ "iType" "5"
+ "pos_x" "-1504.222290"
+ "pos_y" "-107.493011"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_128"
+ {
+ "iType" "34"
+ "pos_x" "-597.244751"
+ "pos_y" "-850.943970"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "133"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "134"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_129"
+ {
+ "iType" "21"
+ "pos_x" "-387.444122"
+ "pos_y" "-864.004639"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "160"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "115"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "128"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_130"
+ {
+ "iType" "34"
+ "pos_x" "-607.672607"
+ "pos_y" "-1092.762939"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "136"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "135"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "131"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_131"
+ {
+ "iType" "32"
+ "pos_x" "-898.744385"
+ "pos_y" "-927.562134"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_132"
+ {
+ "iType" "19"
+ "pos_x" "-190.880692"
+ "pos_y" "-998.156738"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "129"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "137"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_133"
+ {
+ "iType" "5"
+ "pos_x" "-724.509033"
+ "pos_y" "-793.958923"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.2"
+ }
+ "Node_134"
+ {
+ "iType" "5"
+ "pos_x" "-731.817261"
+ "pos_y" "-869.094482"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.85"
+ }
+ "Node_135"
+ {
+ "iType" "5"
+ "pos_x" "-742.245117"
+ "pos_y" "-1110.913086"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_136"
+ {
+ "iType" "5"
+ "pos_x" "-733.630981"
+ "pos_y" "-1025.330566"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_137"
+ {
+ "iType" "21"
+ "pos_x" "-400.334534"
+ "pos_y" "-1091.048096"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "138"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "139"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "130"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_138"
+ {
+ "iType" "5"
+ "pos_x" "-402.652191"
+ "pos_y" "-1002.241089"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 1 1 1"
+ }
+ "Node_139"
+ {
+ "iType" "5"
+ "pos_x" "-499.215179"
+ "pos_y" "-1007.794128"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 0.975 0.95 1"
+ }
+ "Node_140"
+ {
+ "iType" "5"
+ "pos_x" "-944.454651"
+ "pos_y" "360.580658"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_141"
+ {
+ "iType" "19"
+ "pos_x" "-885.548401"
+ "pos_y" "283.058624"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "140"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "142"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_142"
+ {
+ "iType" "12"
+ "pos_x" "-1037.440186"
+ "pos_y" "251.108093"
+ "size_x" "72.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_143"
+ {
+ "iType" "22"
+ "pos_x" "-957.653442"
+ "pos_y" "138.924286"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "142"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_144"
+ {
+ "iType" "5"
+ "pos_x" "-2670.190918"
+ "pos_y" "-706.901367"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_145"
+ {
+ "iType" "55"
+ "pos_x" "-2097.305176"
+ "pos_y" "-599.887695"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "148"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_146"
+ {
+ "iType" "19"
+ "pos_x" "-2608.931641"
+ "pos_y" "-621.808655"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "152"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_147"
+ {
+ "iType" "26"
+ "pos_x" "-2510.070557"
+ "pos_y" "-553.463562"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "146"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_148"
+ {
+ "iType" "27"
+ "pos_x" "-2385.430176"
+ "pos_y" "-577.589355"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xz"
+ }
+ "Node_149"
+ {
+ "iType" "27"
+ "pos_x" "-2387.110840"
+ "pos_y" "-648.494812"
+ "size_x" "109.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "147"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "wy"
+ }
+ "Node_150"
+ {
+ "iType" "55"
+ "pos_x" "-2105.937012"
+ "pos_y" "-751.977234"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "151"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "149"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_151"
+ {
+ "iType" "19"
+ "pos_x" "-2219.461914"
+ "pos_y" "-737.491394"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_152"
+ {
+ "iType" "5"
+ "pos_x" "-2676.218262"
+ "pos_y" "-567.262268"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2.5"
+ }
+ "Node_153"
+ {
+ "iType" "5"
+ "pos_x" "-834.662903"
+ "pos_y" "-236.315186"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_154"
+ {
+ "iType" "32"
+ "pos_x" "-1209.298340"
+ "pos_y" "-334.496063"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_155"
+ {
+ "iType" "17"
+ "pos_x" "-1114.866333"
+ "pos_y" "-608.598267"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "163"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "161"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_156"
+ {
+ "iType" "5"
+ "pos_x" "-888.511292"
+ "pos_y" "-198.137222"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.8"
+ }
+ "Node_157"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-991.124084"
+ "pos_y" "-612.946045"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "155"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_158"
+ {
+ "iType" "19"
+ "pos_x" "-284.958740"
+ "pos_y" "-169.395477"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_159"
+ {
+ "iType" "17"
+ "pos_x" "-692.966431"
+ "pos_y" "-356.881042"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "168"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_160"
+ {
+ "iType" "5"
+ "pos_x" "-382.374115"
+ "pos_y" "-769.041138"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1 1 1 1"
+ }
+ "Node_161"
+ {
+ "iType" "17"
+ "pos_x" "-1247.064697"
+ "pos_y" "-588.424683"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "162"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_162"
+ {
+ "iType" "32"
+ "pos_x" "-1265.704590"
+ "pos_y" "-430.691071"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_163"
+ {
+ "iType" "19"
+ "pos_x" "-1182.972412"
+ "pos_y" "-442.971680"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "154"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "166"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_164"
+ {
+ "iType" "18"
+ "pos_x" "-2089.466309"
+ "pos_y" "463.842560"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_165"
+ {
+ "iType" "27"
+ "pos_x" "-97.894089"
+ "pos_y" "188.528839"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_166"
+ {
+ "iType" "30"
+ "pos_x" "-1348.025024"
+ "pos_y" "-520.409668"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "232.033142"
+ "container_extents_y" "753.520081"
+ "container_extents_z" "-232.033142"
+ "loop_condition" "0"
+ "loop_value_min" "0"
+ "loop_value_max" "20"
+ }
+ "Node_167"
+ {
+ "iType" "91"
+ "pos_x" "-1019.911682"
+ "pos_y" "-385.861206"
+ "size_x" "79.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "166"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_array_size_x" "20"
+ "i_array_size_y" "1"
+ "i_array_datatype" "1"
+ "pfl_arraydata_000" "0.002881 0.000000 0.000000 0.000000"
+ "pfl_arraydata_001" "0.006006 0.000000 0.000000 0.000000"
+ "pfl_arraydata_002" "0.011541 0.000000 0.000000 0.000000"
+ "pfl_arraydata_003" "0.020437 0.000000 0.000000 0.000000"
+ "pfl_arraydata_004" "0.033352 0.000000 0.000000 0.000000"
+ "pfl_arraydata_005" "0.050163 0.000000 0.000000 0.000000"
+ "pfl_arraydata_006" "0.069534 0.000000 0.000000 0.000000"
+ "pfl_arraydata_007" "0.088829 0.000000 0.000000 0.000000"
+ "pfl_arraydata_008" "0.104583 0.000000 0.000000 0.000000"
+ "pfl_arraydata_009" "0.113478 0.000000 0.000000 0.000000"
+ "pfl_arraydata_010" "0.113478 0.000000 0.000000 0.000000"
+ "pfl_arraydata_011" "0.104583 0.000000 0.000000 0.000000"
+ "pfl_arraydata_012" "0.088829 0.000000 0.000000 0.000000"
+ "pfl_arraydata_013" "0.069534 0.000000 0.000000 0.000000"
+ "pfl_arraydata_014" "0.050163 0.000000 0.000000 0.000000"
+ "pfl_arraydata_015" "0.033352 0.000000 0.000000 0.000000"
+ "pfl_arraydata_016" "0.020437 0.000000 0.000000 0.000000"
+ "pfl_arraydata_017" "0.011541 0.000000 0.000000 0.000000"
+ "pfl_arraydata_018" "0.006006 0.000000 0.000000 0.000000"
+ "pfl_arraydata_019" "0.002881 0.000000 0.000000 0.000000"
+ }
+ "Node_168"
+ {
+ "iType" "19"
+ "pos_x" "-821.666016"
+ "pos_y" "-471.079651"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "157"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "167"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ }
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/sprite_sun_nodepth.txt b/mp/game/momentum/shadereditorui/canvas/sprite_sun_nodepth.txt
new file mode 100644
index 0000000000..c4aa8b0d27
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/sprite_sun_nodepth.txt
@@ -0,0 +1,229 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "4"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "3"
+ "pos_x" "-320.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "1"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "1"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "13"
+ "pos_x" "-208.150146"
+ "pos_y" "253.604919"
+ "size_x" "83.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_003"
+ {
+ "iType" "19"
+ "pos_x" "-45.593525"
+ "pos_y" "253.914536"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_004"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-39.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "2"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "1"
+ "numTexcoord_Flag_2" "1"
+ "numTexcoord_Flag_3" "1"
+ "numTexcoord_Flag_4" "1"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_005"
+ {
+ "iType" "29"
+ "pos_x" "-194.375488"
+ "pos_y" "-1.894817"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "white"
+ "szFallbackTexturePath" "white"
+ "iFallbackMode" "0"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-173.482834"
+ "pos_y" "-144.640610"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "72"
+ "pos_x" "80.450699"
+ "pos_y" "-100.773483"
+ "size_x" "128.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "0"
+ }
+ "Node_008"
+ {
+ "iType" "5"
+ "pos_x" "-13.245262"
+ "pos_y" "-241.650299"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_009"
+ {
+ "iType" "4"
+ "pos_x" "322.989502"
+ "pos_y" "-145.223068"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/swarm_lightmapped_lava.txt b/mp/game/momentum/shadereditorui/canvas/swarm_lightmapped_lava.txt
new file mode 100644
index 0000000000..7772691eea
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/swarm_lightmapped_lava.txt
@@ -0,0 +1,1932 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "80"
+ "pos_x" "-129.184967"
+ "pos_y" "-349.526337"
+ "size_x" "88.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "1"
+ }
+ "Node_001"
+ {
+ "iType" "29"
+ "pos_x" "-213.960052"
+ "pos_y" "-204.693207"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "1"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "3"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_002"
+ {
+ "iType" "14"
+ "pos_x" "8.137299"
+ "pos_y" "175.022034"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_003"
+ {
+ "iType" "19"
+ "pos_x" "55.128418"
+ "pos_y" "-263.120819"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_004"
+ {
+ "iType" "76"
+ "pos_x" "229.911148"
+ "pos_y" "-669.693970"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_005"
+ {
+ "iType" "32"
+ "pos_x" "262.603485"
+ "pos_y" "-88.937073"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "5"
+ "pos_x" "168.481186"
+ "pos_y" "-87.194153"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_007"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-321.303345"
+ "pos_y" "-298.511169"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "682.054016"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_008"
+ {
+ "iType" "33"
+ "pos_x" "454.498901"
+ "pos_y" "-673.647034"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "33"
+ "pos_x" "273.061523"
+ "pos_y" "-324.626984"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "70"
+ "pos_x" "647.914307"
+ "pos_y" "-894.212769"
+ "size_x" "59.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_011"
+ {
+ "iType" "7"
+ "pos_x" "538.996094"
+ "pos_y" "-898.246460"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_012"
+ {
+ "iType" "27"
+ "pos_x" "517.826538"
+ "pos_y" "-1095.565918"
+ "size_x" "124.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_013"
+ {
+ "iType" "71"
+ "pos_x" "821.729492"
+ "pos_y" "-973.129272"
+ "size_x" "169.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "72"
+ "pos_x" "829.829285"
+ "pos_y" "-1086.405762"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_015"
+ {
+ "iType" "4"
+ "pos_x" "1099.059326"
+ "pos_y" "-1107.314941"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_016"
+ {
+ "iType" "27"
+ "pos_x" "639.118591"
+ "pos_y" "-1037.227051"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_017"
+ {
+ "iType" "27"
+ "pos_x" "-310.635773"
+ "pos_y" "-674.270081"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "-310.012238"
+ "pos_y" "-736.646790"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_019"
+ {
+ "iType" "20"
+ "pos_x" "-176.943695"
+ "pos_y" "-678.442078"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "19"
+ "pos_x" "-28.548599"
+ "pos_y" "-678.442078"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_021"
+ {
+ "iType" "33"
+ "pos_x" "659.732910"
+ "pos_y" "-523.961243"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "19"
+ "pos_x" "118.355759"
+ "pos_y" "-571.397705"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_023"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-412.226501"
+ "pos_y" "-661.497864"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "921.186279"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_024"
+ {
+ "iType" "5"
+ "pos_x" "-161.970367"
+ "pos_y" "-576.408630"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_025"
+ {
+ "iType" "17"
+ "pos_x" "-25.018768"
+ "pos_y" "-750.222717"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "75"
+ "pos_x" "-40.687943"
+ "pos_y" "-571.745850"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_027"
+ {
+ "iType" "19"
+ "pos_x" "-56.525158"
+ "pos_y" "69.252563"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_028"
+ {
+ "iType" "19"
+ "pos_x" "-63.943375"
+ "pos_y" "5.140073"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_029"
+ {
+ "iType" "19"
+ "pos_x" "126.402008"
+ "pos_y" "113.060600"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_030"
+ {
+ "iType" "19"
+ "pos_x" "36.758072"
+ "pos_y" "348.794312"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_031"
+ {
+ "iType" "19"
+ "pos_x" "185.832428"
+ "pos_y" "322.510803"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_032"
+ {
+ "iType" "17"
+ "pos_x" "353.099365"
+ "pos_y" "321.936584"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_033"
+ {
+ "iType" "2"
+ "pos_x" "417.505005"
+ "pos_y" "119.042267"
+ "size_x" "55.000000"
+ "size_y" "-94.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "3"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "7"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Name_5" "lava coord 2"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Name_6" "lava blend"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_034"
+ {
+ "iType" "5"
+ "pos_x" "-436.515320"
+ "pos_y" "-30.184265"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "120"
+ }
+ "Node_035"
+ {
+ "iType" "15"
+ "pos_x" "-161.579010"
+ "pos_y" "-82.294830"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_036"
+ {
+ "iType" "55"
+ "pos_x" "-216.526077"
+ "pos_y" "153.489304"
+ "size_x" "91.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_037"
+ {
+ "iType" "55"
+ "pos_x" "-292.160278"
+ "pos_y" "9.907330"
+ "size_x" "91.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "iTexTrans_center" "0"
+ "iTexTrans_rot" "1"
+ "iTexTrans_scale" "1"
+ "iTexTrans_trans" "1"
+ }
+ "Node_038"
+ {
+ "iType" "19"
+ "pos_x" "-659.667969"
+ "pos_y" "141.060120"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_039"
+ {
+ "iType" "19"
+ "pos_x" "-603.999878"
+ "pos_y" "358.460541"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_040"
+ {
+ "iType" "27"
+ "pos_x" "-657.831726"
+ "pos_y" "83.491669"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_041"
+ {
+ "iType" "27"
+ "pos_x" "-602.163635"
+ "pos_y" "300.892059"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xx"
+ }
+ "Node_042"
+ {
+ "iType" "17"
+ "pos_x" "-395.011292"
+ "pos_y" "302.908966"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "5"
+ "pos_x" "-214.918518"
+ "pos_y" "252.258362"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_044"
+ {
+ "iType" "27"
+ "pos_x" "-371.451538"
+ "pos_y" "385.035919"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y 0 0"
+ }
+ "Node_045"
+ {
+ "iType" "49"
+ "pos_x" "-93.310379"
+ "pos_y" "303.953918"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "5"
+ "pos_x" "-704.059082"
+ "pos_y" "350.267609"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.007"
+ }
+ "Node_047"
+ {
+ "iType" "5"
+ "pos_x" "-759.727173"
+ "pos_y" "132.867157"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_048"
+ {
+ "iType" "5"
+ "pos_x" "-192.413513"
+ "pos_y" "-914.584656"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3 0.59 0.11"
+ }
+ "Node_049"
+ {
+ "iType" "21"
+ "pos_x" "-254.974808"
+ "pos_y" "-1025.872681"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "23"
+ "pos_x" "-91.973450"
+ "pos_y" "-928.284668"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_051"
+ {
+ "iType" "5"
+ "pos_x" "107.172821"
+ "pos_y" "-889.868103"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_052"
+ {
+ "iType" "21"
+ "pos_x" "216.924500"
+ "pos_y" "-874.094421"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_053"
+ {
+ "iType" "17"
+ "pos_x" "193.954117"
+ "pos_y" "-988.582397"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_054"
+ {
+ "iType" "19"
+ "pos_x" "335.789948"
+ "pos_y" "-1098.298950"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_055"
+ {
+ "iType" "21"
+ "pos_x" "-949.843018"
+ "pos_y" "-733.404419"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "27"
+ "pos_x" "-794.067017"
+ "pos_y" "-733.079163"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-815.467773"
+ "pos_y" "-931.235840"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "19"
+ "pos_x" "-796.128174"
+ "pos_y" "-1084.052246"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_059"
+ {
+ "iType" "5"
+ "pos_x" "-922.842407"
+ "pos_y" "-1105.786743"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.03"
+ }
+ "Node_060"
+ {
+ "iType" "17"
+ "pos_x" "-1271.352051"
+ "pos_y" "-663.130310"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "19"
+ "pos_x" "-1341.952881"
+ "pos_y" "-545.884399"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_062"
+ {
+ "iType" "5"
+ "pos_x" "-30.901451"
+ "pos_y" "419.098389"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "20"
+ }
+ "Node_063"
+ {
+ "iType" "18"
+ "pos_x" "-1289.005493"
+ "pos_y" "-811.040833"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "19"
+ "pos_x" "-1397.108887"
+ "pos_y" "-667.251099"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_065"
+ {
+ "iType" "19"
+ "pos_x" "-1472.924927"
+ "pos_y" "-879.636108"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_066"
+ {
+ "iType" "19"
+ "pos_x" "-1474.679565"
+ "pos_y" "-781.364380"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_067"
+ {
+ "iType" "29"
+ "pos_x" "-1146.515747"
+ "pos_y" "-664.484741"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "refraction"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "liquids\water_river_normal_sharp"
+ "szFallbackTexturePath" "liquids\water_river_normal_sharp"
+ "iFallbackMode" "4"
+ }
+ "Node_068"
+ {
+ "iType" "17"
+ "pos_x" "-621.750793"
+ "pos_y" "-913.343140"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_069"
+ {
+ "iType" "17"
+ "pos_x" "-631.323486"
+ "pos_y" "-1083.002197"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_070"
+ {
+ "iType" "29"
+ "pos_x" "-1147.039063"
+ "pos_y" "-801.731873"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "refraction"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "liquids\water_river_normal_sharp"
+ "szFallbackTexturePath" "liquids\water_river_normal_sharp"
+ "iFallbackMode" "4"
+ }
+ "Node_071"
+ {
+ "iType" "5"
+ "pos_x" "-942.182007"
+ "pos_y" "-952.970276"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.3"
+ }
+ "Node_072"
+ {
+ "iType" "5"
+ "pos_x" "-984.594360"
+ "pos_y" "-624.431519"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_073"
+ {
+ "iType" "5"
+ "pos_x" "-1494.694336"
+ "pos_y" "-633.767639"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.6"
+ }
+ "Node_074"
+ {
+ "iType" "5"
+ "pos_x" "-1439.538330"
+ "pos_y" "-512.400940"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_075"
+ {
+ "iType" "29"
+ "szName" "Le Vertextexture"
+ "pos_x" "-236.089691"
+ "pos_y" "419.432007"
+ "size_x" "80.000000"
+ "size_y" "-72.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "heightmap"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "11"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_0"
+ "iFallbackMode" "4"
+ }
+ "Node_076"
+ {
+ "iType" "1"
+ "pos_x" "-729.917236"
+ "pos_y" "-5.979683"
+ "size_x" "55.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "2"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_077"
+ {
+ "iType" "19"
+ "szName" "PRE SCALE UVS"
+ "pos_x" "-610.085876"
+ "pos_y" "-124.722733"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_078"
+ {
+ "iType" "19"
+ "szName" "PRE SCALE SPEED"
+ "pos_x" "-619.978394"
+ "pos_y" "-206.679276"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_079"
+ {
+ "iType" "5"
+ "pos_x" "-733.283691"
+ "pos_y" "-130.328812"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1.5"
+ }
+ "Node_080"
+ {
+ "iType" "5"
+ "pos_x" "-738.261169"
+ "pos_y" "-237.473755"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.4"
+ }
+ "Node_081"
+ {
+ "iType" "12"
+ "pos_x" "-992.865662"
+ "pos_y" "-2.432945"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_082"
+ {
+ "iType" "29"
+ "pos_x" "-460.645630"
+ "pos_y" "-1066.889771"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "lava_1"
+ "iSRGB" "1"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "swarm\bsp\swarm_lavaunlit2"
+ "szFallbackTexturePath" "swarm\bsp\swarm_lavaunlit2"
+ "iFallbackMode" "4"
+ }
+ "Node_083"
+ {
+ "iType" "29"
+ "pos_x" "-434.088654"
+ "pos_y" "-930.070068"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "lava_0"
+ "iSRGB" "1"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "swarm\bsp\swarm_lavanotunlit"
+ "szFallbackTexturePath" "swarm\bsp\swarm_lavanotunlit"
+ "iFallbackMode" "4"
+ }
+ "Node_084"
+ {
+ "iType" "5"
+ "pos_x" "-316.378906"
+ "pos_y" "126.160881"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "szConstantString" "0.05 0.045"
+ }
+ "Node_085"
+ {
+ "iType" "5"
+ "pos_x" "-435.218872"
+ "pos_y" "-81.259903"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "szConstantString" "0.012 0.011"
+ }
+ "Node_086"
+ {
+ "iType" "5"
+ "pos_x" "-613.565491"
+ "pos_y" "212.457428"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.03"
+ }
+ "Node_087"
+ {
+ "iType" "19"
+ "pos_x" "-507.179321"
+ "pos_y" "224.904907"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_088"
+ {
+ "iType" "19"
+ "pos_x" "-454.111542"
+ "pos_y" "126.694733"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_089"
+ {
+ "iType" "5"
+ "pos_x" "-511.838104"
+ "pos_y" "37.251007"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_090"
+ {
+ "iType" "19"
+ "pos_x" "-505.986176"
+ "pos_y" "447.866364"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_091"
+ {
+ "iType" "5"
+ "pos_x" "-588.925781"
+ "pos_y" "470.237579"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.03"
+ }
+ "Node_092"
+ {
+ "iType" "3"
+ "pos_x" "-715.510925"
+ "pos_y" "-568.546143"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "numTexcoords" "7"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Name_5" "lava coord 2"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Name_6" "lava blend"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_093"
+ {
+ "iType" "34"
+ "pos_x" "557.626892"
+ "pos_y" "-26.595451"
+ "size_x" "80.000000"
+ "size_y" "-39.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "4"
+ }
+ }
+ }
+ "Node_094"
+ {
+ "iType" "5"
+ "pos_x" "-1573.509888"
+ "pos_y" "-813.035583"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.25"
+ }
+ "Node_095"
+ {
+ "iType" "5"
+ "pos_x" "423.661072"
+ "pos_y" "-96.705254"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.7"
+ }
+ "Node_096"
+ {
+ "iType" "5"
+ "pos_x" "416.941284"
+ "pos_y" "-21.813652"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0"
+ }
+ "Node_097"
+ {
+ "iType" "34"
+ "pos_x" "56.439423"
+ "pos_y" "-1011.537415"
+ "size_x" "104.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_098"
+ {
+ "iType" "5"
+ "pos_x" "-63.755844"
+ "pos_y" "-1099.378540"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_099"
+ {
+ "iType" "5"
+ "pos_x" "-70.475601"
+ "pos_y" "-1024.486938"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas/swarm_vtex_test.txt b/mp/game/momentum/shadereditorui/canvas/swarm_vtex_test.txt
new file mode 100644
index 0000000000..9af0eaff8a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas/swarm_vtex_test.txt
@@ -0,0 +1,2193 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "25"
+ "pos_x" "-299.034607"
+ "pos_y" "559.898193"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_001"
+ {
+ "iType" "20"
+ "pos_x" "611.921448"
+ "pos_y" "-73.153870"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_002"
+ {
+ "iType" "31"
+ "szName" "ON"
+ "pos_x" "331.559204"
+ "pos_y" "-16.809479"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "182.742737"
+ "container_extents_y" "823.093750"
+ "container_extents_z" "-182.742737"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_003"
+ {
+ "iType" "53"
+ "pos_x" "-910.638489"
+ "pos_y" "304.940155"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "23"
+ "pos_x" "-1037.434326"
+ "pos_y" "291.404266"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "14"
+ "pos_x" "-220.561584"
+ "pos_y" "820.312744"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_006"
+ {
+ "iType" "76"
+ "pos_x" "732.506531"
+ "pos_y" "93.800934"
+ "size_x" "168.000000"
+ "size_y" "-83.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "8"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "1"
+ }
+ "Node_007"
+ {
+ "iType" "27"
+ "pos_x" "405.623291"
+ "pos_y" "12.833313"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_008"
+ {
+ "iType" "18"
+ "pos_x" "-161.562836"
+ "pos_y" "610.327026"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "32"
+ "pos_x" "82.485123"
+ "pos_y" "584.654907"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "31"
+ "pos_x" "-62.823177"
+ "pos_y" "473.883698"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "62.811218"
+ "container_extents_y" "232.919769"
+ "container_extents_z" "-62.811218"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_011"
+ {
+ "iType" "75"
+ "pos_x" "14.602026"
+ "pos_y" "445.455353"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_012"
+ {
+ "iType" "33"
+ "pos_x" "137.882080"
+ "pos_y" "491.238495"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "5"
+ "pos_x" "-1567.767212"
+ "pos_y" "268.307159"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_014"
+ {
+ "iType" "18"
+ "pos_x" "-1402.897461"
+ "pos_y" "117.985107"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "27"
+ "pos_x" "441.474182"
+ "pos_y" "-105.211365"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_016"
+ {
+ "iType" "5"
+ "pos_x" "-1479.457153"
+ "pos_y" "274.916229"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_017"
+ {
+ "iType" "25"
+ "pos_x" "-1343.972534"
+ "pos_y" "-378.331757"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "7"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "5"
+ "szName" "diffuse"
+ "pos_x" "387.497437"
+ "pos_y" "275.393494"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_019"
+ {
+ "iType" "5"
+ "szName" "Specular"
+ "pos_x" "31.314459"
+ "pos_y" "267.249542"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_020"
+ {
+ "iType" "32"
+ "pos_x" "485.332031"
+ "pos_y" "272.623810"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_021"
+ {
+ "iType" "33"
+ "pos_x" "1026.863770"
+ "pos_y" "91.808105"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "33"
+ "pos_x" "973.598694"
+ "pos_y" "-27.113068"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_023"
+ {
+ "iType" "7"
+ "pos_x" "-181.255676"
+ "pos_y" "543.788696"
+ "size_x" "54.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_024"
+ {
+ "iType" "27"
+ "pos_x" "-687.730408"
+ "pos_y" "612.119995"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_025"
+ {
+ "iType" "19"
+ "pos_x" "14.134359"
+ "pos_y" "499.710602"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_026"
+ {
+ "iType" "5"
+ "pos_x" "-3.727656"
+ "pos_y" "591.317993"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_027"
+ {
+ "iType" "25"
+ "pos_x" "-299.712097"
+ "pos_y" "633.069214"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "19"
+ "pos_x" "-64.499283"
+ "pos_y" "792.782715"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_029"
+ {
+ "iType" "19"
+ "pos_x" "-1401.849609"
+ "pos_y" "187.411621"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_030"
+ {
+ "iType" "25"
+ "szName" "World_normal"
+ "pos_x" "-1285.157959"
+ "pos_y" "-38.549469"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "71"
+ "pos_x" "709.196106"
+ "pos_y" "-673.911560"
+ "size_x" "169.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "70"
+ "pos_x" "712.336243"
+ "pos_y" "-577.848145"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_033"
+ {
+ "iType" "7"
+ "pos_x" "410.617889"
+ "pos_y" "-572.928528"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_034"
+ {
+ "iType" "27"
+ "szName" "proj_z"
+ "pos_x" "409.736786"
+ "pos_y" "-660.502380"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_035"
+ {
+ "iType" "19"
+ "pos_x" "-890.135193"
+ "pos_y" "-581.495605"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_036"
+ {
+ "iType" "61"
+ "pos_x" "-1043.730957"
+ "pos_y" "168.753326"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_037"
+ {
+ "iType" "19"
+ "szName" "world2eye"
+ "pos_x" "-1116.969604"
+ "pos_y" "412.146057"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_038"
+ {
+ "iType" "5"
+ "pos_x" "-1112.923096"
+ "pos_y" "511.305420"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_039"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-1441.094482"
+ "pos_y" "-951.328247"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "171.600098"
+ "container_extents_y" "1247.736938"
+ "container_extents_z" "-171.600098"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_040"
+ {
+ "iType" "19"
+ "szName" "Rim_lighting"
+ "pos_x" "-163.917236"
+ "pos_y" "-109.586990"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_041"
+ {
+ "iType" "49"
+ "pos_x" "-369.549530"
+ "pos_y" "-100.639664"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "33"
+ "szName" "Diffuse"
+ "pos_x" "-141.459473"
+ "pos_y" "-510.953125"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_043"
+ {
+ "iType" "79"
+ "pos_x" "-299.620178"
+ "pos_y" "-211.795380"
+ "size_x" "89.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "rim_color"
+ "i_vp_static_nc" "2"
+ "szConstantString" "1 1 1"
+ }
+ "Node_044"
+ {
+ "iType" "27"
+ "pos_x" "-453.567078"
+ "pos_y" "-210.899246"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_045"
+ {
+ "iType" "79"
+ "pos_x" "-457.481506"
+ "pos_y" "-335.765900"
+ "size_x" "107.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "rim_boost_exp"
+ "i_vp_static_nc" "1"
+ "szConstantString" "0.05 9"
+ }
+ "Node_046"
+ {
+ "iType" "27"
+ "pos_x" "-280.265839"
+ "pos_y" "-304.126465"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_047"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-559.989563"
+ "pos_y" "-111.775040"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "293.957031"
+ "container_extents_y" "736.290649"
+ "container_extents_z" "-293.957031"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_048"
+ {
+ "iType" "26"
+ "szName" "Comp"
+ "pos_x" "147.508057"
+ "pos_y" "-901.616455"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "104"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "33"
+ "szName" "Specular"
+ "pos_x" "24.892941"
+ "pos_y" "-522.529541"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "19"
+ "szName" "RL_scale"
+ "pos_x" "-101.318184"
+ "pos_y" "-256.065887"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_051"
+ {
+ "iType" "17"
+ "szName" "Specular"
+ "pos_x" "-689.536560"
+ "pos_y" "-584.606567"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_052"
+ {
+ "iType" "33"
+ "pos_x" "118.955460"
+ "pos_y" "-242.868668"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_053"
+ {
+ "iType" "17"
+ "szName" "writes_to_A"
+ "pos_x" "-286.085938"
+ "pos_y" "-893.951599"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_054"
+ {
+ "iType" "19"
+ "pos_x" "-453.872375"
+ "pos_y" "-927.497864"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_055"
+ {
+ "iType" "19"
+ "szName" "scale_by_fresnel"
+ "pos_x" "-619.808472"
+ "pos_y" "-904.038818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_056"
+ {
+ "iType" "19"
+ "szName" "normal_map_alpha_mask"
+ "pos_x" "-806.319275"
+ "pos_y" "-893.905396"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-971.059998"
+ "pos_y" "-896.052429"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "80"
+ "pos_x" "-1127.452393"
+ "pos_y" "-1031.592407"
+ "size_x" "83.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "2"
+ }
+ "Node_059"
+ {
+ "iType" "58"
+ "pos_x" "-1344.874023"
+ "pos_y" "-903.285767"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "49"
+ "pos_x" "-887.519653"
+ "pos_y" "165.745148"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "74"
+ "pos_x" "-200.566971"
+ "pos_y" "132.821869"
+ "size_x" "155.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_ao" "0"
+ }
+ "Node_062"
+ {
+ "iType" "33"
+ "pos_x" "71.058868"
+ "pos_y" "-13.431725"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "38"
+ "pos_x" "42.977386"
+ "pos_y" "-125.018158"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "5"
+ "pos_x" "-1004.388733"
+ "pos_y" "56.160908"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_065"
+ {
+ "iType" "38"
+ "pos_x" "-699.437439"
+ "pos_y" "231.170700"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "103"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "5"
+ "pos_x" "-536.772766"
+ "pos_y" "255.797729"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_067"
+ {
+ "iType" "32"
+ "pos_x" "144.554855"
+ "pos_y" "266.021149"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_068"
+ {
+ "iType" "61"
+ "pos_x" "-870.527710"
+ "pos_y" "-76.748718"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_069"
+ {
+ "iType" "5"
+ "pos_x" "-914.728516"
+ "pos_y" "-331.763367"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "150"
+ }
+ "Node_070"
+ {
+ "iType" "17"
+ "pos_x" "-713.645935"
+ "pos_y" "-139.951248"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_071"
+ {
+ "iType" "19"
+ "pos_x" "-882.327820"
+ "pos_y" "-220.377365"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_072"
+ {
+ "iType" "29"
+ "szName" "Envmap"
+ "pos_x" "-1163.571411"
+ "pos_y" "-902.790588"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "6"
+ "IsCubemap" "1"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\cubemap_uffizi"
+ "szFallbackTexturePath" "cable\black"
+ "iFallbackMode" "1"
+ }
+ "Node_073"
+ {
+ "iType" "67"
+ "pos_x" "-179.692764"
+ "pos_y" "18.299576"
+ "size_x" "156.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_static" "0"
+ "i_plight_ao" "0"
+ "i_plight_hl" "0"
+ }
+ "Node_074"
+ {
+ "iType" "29"
+ "pos_x" "-1053.138916"
+ "pos_y" "-159.996216"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "phongexp"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\rocks_height"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_075"
+ {
+ "iType" "25"
+ "pos_x" "-300.810394"
+ "pos_y" "596.694153"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_076"
+ {
+ "iType" "26"
+ "pos_x" "-546.118164"
+ "pos_y" "663.731018"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "27"
+ "pos_x" "-688.071045"
+ "pos_y" "677.325684"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xyz"
+ }
+ "Node_078"
+ {
+ "iType" "2"
+ "pos_x" "328.636475"
+ "pos_y" "721.913696"
+ "size_x" "55.000000"
+ "size_y" "-116.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_08"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ "jackIn_09"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "8"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "1"
+ }
+ "Node_079"
+ {
+ "iType" "73"
+ "szName" "Tangentspace"
+ "pos_x" "-1632.450928"
+ "pos_y" "-100.501183"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_080"
+ {
+ "iType" "25"
+ "pos_x" "-1455.957397"
+ "pos_y" "47.028900"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_081"
+ {
+ "iType" "19"
+ "pos_x" "-1453.817505"
+ "pos_y" "-63.257446"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_082"
+ {
+ "iType" "68"
+ "pos_x" "-481.468689"
+ "pos_y" "788.189941"
+ "size_x" "116.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "3"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "101"
+ "iTarget_jack" "1"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_083"
+ {
+ "iType" "17"
+ "pos_x" "-407.824036"
+ "pos_y" "943.300720"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_084"
+ {
+ "iType" "19"
+ "pos_x" "-780.831848"
+ "pos_y" "934.197571"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "105"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_085"
+ {
+ "iType" "19"
+ "pos_x" "-591.060974"
+ "pos_y" "943.300598"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_086"
+ {
+ "iType" "4"
+ "pos_x" "1050.415771"
+ "pos_y" "-758.083557"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_087"
+ {
+ "iType" "72"
+ "pos_x" "882.893494"
+ "pos_y" "-824.755859"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_088"
+ {
+ "iType" "3"
+ "pos_x" "-1828.840942"
+ "pos_y" "-201.520660"
+ "size_x" "55.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "numTexcoords" "8"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "1"
+ }
+ "Node_089"
+ {
+ "iType" "5"
+ "pos_x" "-540.121582"
+ "pos_y" "-1030.991821"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.1"
+ }
+ "Node_090"
+ {
+ "iType" "12"
+ "pos_x" "-1408.527100"
+ "pos_y" "718.613159"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_091"
+ {
+ "iType" "101"
+ "pos_x" "-956.203674"
+ "pos_y" "619.568665"
+ "size_x" "95.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "6"
+ }
+ }
+ "iCompMode" "1"
+ }
+ "Node_092"
+ {
+ "iType" "66"
+ "pos_x" "-227.806992"
+ "pos_y" "702.447632"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vlight_static" "0"
+ "i_vlight_hl" "0"
+ }
+ "Node_093"
+ {
+ "iType" "19"
+ "pos_x" "-1315.777100"
+ "pos_y" "718.133240"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "100"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_094"
+ {
+ "iType" "19"
+ "pos_x" "-36.447227"
+ "pos_y" "677.975891"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "102"
+ "iTarget_jack" "4"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_095"
+ {
+ "iType" "17"
+ "pos_x" "-1134.211548"
+ "pos_y" "739.560486"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "96"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_096"
+ {
+ "iType" "19"
+ "pos_x" "-1262.178345"
+ "pos_y" "657.209839"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "99"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "8"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_097"
+ {
+ "iType" "1"
+ "pos_x" "-1359.996582"
+ "pos_y" "586.504761"
+ "size_x" "55.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "enable_flex" "1"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "1"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_098"
+ {
+ "iType" "27"
+ "pos_x" "-1198.148315"
+ "pos_y" "834.603943"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "95"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y 0 0"
+ }
+ "Node_099"
+ {
+ "iType" "5"
+ "pos_x" "-1362.544556"
+ "pos_y" "654.567017"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_100"
+ {
+ "iType" "5"
+ "pos_x" "-1328.114502"
+ "pos_y" "883.884949"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "0.01"
+ }
+ "Node_101"
+ {
+ "iType" "69"
+ "pos_x" "-714.160095"
+ "pos_y" "816.804871"
+ "size_x" "101.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "97"
+ "iTarget_jack" "2"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_102"
+ {
+ "iType" "29"
+ "szName" "Le Vertextexture"
+ "pos_x" "-1047.180908"
+ "pos_y" "978.007324"
+ "size_x" "80.000000"
+ "size_y" "-72.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "98"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "heightmap"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "11"
+ "szDemoTexturePath" "texture_samples\rocks_height"
+ "szFallbackTexturePath" "texture_samples\rocks_height"
+ "iFallbackMode" "4"
+ }
+ "Node_103"
+ {
+ "iType" "29"
+ "szName" "Normalmap"
+ "pos_x" "-1606.065430"
+ "pos_y" "173.350586"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\rocks_normal_2"
+ "szFallbackTexturePath" "texture_samples\rocks_normal_2"
+ "iFallbackMode" "4"
+ }
+ "Node_104"
+ {
+ "iType" "29"
+ "szName" "Albedo"
+ "pos_x" "-1124.061646"
+ "pos_y" "-584.555176"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\rocks_color"
+ "szFallbackTexturePath" "texture_samples\rocks_color"
+ "iFallbackMode" "4"
+ }
+ "Node_105"
+ {
+ "iType" "5"
+ "pos_x" "-908.645752"
+ "pos_y" "792.184448"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "szConstantString" "10"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_bump.def b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_bump.def
new file mode 100644
index 0000000000..aa5b1aef8e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_bump.def
@@ -0,0 +1,1617 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "14"
+ "pos_x" "-67.148407"
+ "pos_y" "608.769470"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "75"
+ "pos_x" "-196.710205"
+ "pos_y" "-1098.514526"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_002"
+ {
+ "iType" "19"
+ "pos_x" "-56.518372"
+ "pos_y" "-1030.090332"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_003"
+ {
+ "iType" "70"
+ "pos_x" "696.218628"
+ "pos_y" "-1370.956421"
+ "size_x" "59.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_004"
+ {
+ "iType" "7"
+ "pos_x" "587.300537"
+ "pos_y" "-1374.990112"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_005"
+ {
+ "iType" "27"
+ "pos_x" "566.130981"
+ "pos_y" "-1572.309692"
+ "size_x" "124.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_006"
+ {
+ "iType" "71"
+ "pos_x" "870.033813"
+ "pos_y" "-1449.873169"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "72"
+ "pos_x" "878.133667"
+ "pos_y" "-1563.149536"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_008"
+ {
+ "iType" "4"
+ "pos_x" "1147.363525"
+ "pos_y" "-1584.058716"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_009"
+ {
+ "iType" "27"
+ "pos_x" "693.328247"
+ "pos_y" "-1421.504028"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_010"
+ {
+ "iType" "27"
+ "pos_x" "687.685059"
+ "pos_y" "-1465.105347"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_011"
+ {
+ "iType" "27"
+ "pos_x" "687.422974"
+ "pos_y" "-1513.970825"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "7"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_012"
+ {
+ "iType" "19"
+ "pos_x" "387.892548"
+ "pos_y" "-1575.685913"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_013"
+ {
+ "iType" "17"
+ "pos_x" "-195.430313"
+ "pos_y" "154.320465"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "23"
+ "pos_x" "-1063.938477"
+ "pos_y" "-436.916229"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_015"
+ {
+ "iType" "23"
+ "pos_x" "-1068.266357"
+ "pos_y" "-540.778015"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "19"
+ "pos_x" "-594.653809"
+ "pos_y" "-490.616608"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_017"
+ {
+ "iType" "26"
+ "pos_x" "-899.019592"
+ "pos_y" "-378.204193"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_018"
+ {
+ "iType" "29"
+ "pos_x" "-415.631012"
+ "pos_y" "-373.722748"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_019"
+ {
+ "iType" "29"
+ "pos_x" "-414.728546"
+ "pos_y" "-476.595612"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "4"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_020"
+ {
+ "iType" "27"
+ "pos_x" "-566.974243"
+ "pos_y" "-343.340485"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_021"
+ {
+ "iType" "27"
+ "pos_x" "-394.948639"
+ "pos_y" "-590.862610"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_022"
+ {
+ "iType" "27"
+ "pos_x" "-388.216217"
+ "pos_y" "-635.082581"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_023"
+ {
+ "iType" "27"
+ "pos_x" "-390.140411"
+ "pos_y" "-683.180481"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_024"
+ {
+ "iType" "19"
+ "pos_x" "-161.960602"
+ "pos_y" "-387.228058"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_025"
+ {
+ "iType" "19"
+ "pos_x" "-159.075714"
+ "pos_y" "-498.778900"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_026"
+ {
+ "iType" "23"
+ "pos_x" "-397.109283"
+ "pos_y" "-777.056580"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "5"
+ "pos_x" "-488.589386"
+ "pos_y" "-832.720154"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_028"
+ {
+ "iType" "19"
+ "pos_x" "-163.883820"
+ "pos_y" "-283.370331"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_029"
+ {
+ "iType" "17"
+ "pos_x" "-12.768341"
+ "pos_y" "-348.850494"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_030"
+ {
+ "iType" "17"
+ "pos_x" "-10.572052"
+ "pos_y" "-471.832733"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "80"
+ "pos_x" "-157.359894"
+ "pos_y" "-676.886658"
+ "size_x" "88.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "1"
+ }
+ "Node_032"
+ {
+ "iType" "20"
+ "pos_x" "-14.695099"
+ "pos_y" "-694.812683"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_033"
+ {
+ "iType" "27"
+ "pos_x" "-565.747803"
+ "pos_y" "-391.027374"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "zw"
+ }
+ "Node_034"
+ {
+ "iType" "19"
+ "pos_x" "180.579437"
+ "pos_y" "-564.280090"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_035"
+ {
+ "iType" "29"
+ "pos_x" "-419.033722"
+ "pos_y" "-266.936951"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_036"
+ {
+ "iType" "17"
+ "pos_x" "-178.732437"
+ "pos_y" "104.991516"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_037"
+ {
+ "iType" "33"
+ "pos_x" "452.038361"
+ "pos_y" "-1002.346069"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "32"
+ "pos_x" "121.640915"
+ "pos_y" "-78.065155"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_039"
+ {
+ "iType" "33"
+ "pos_x" "279.624786"
+ "pos_y" "-1132.339722"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "27.518646"
+ "pos_y" "-76.322235"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_041"
+ {
+ "iType" "33"
+ "pos_x" "205.443649"
+ "pos_y" "-775.707031"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "5"
+ "pos_x" "-1422.707764"
+ "pos_y" "-1283.585449"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "1"
+ }
+ "Node_043"
+ {
+ "iType" "5"
+ "pos_x" "-1426.320435"
+ "pos_y" "-1212.233398"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "2"
+ }
+ "Node_044"
+ {
+ "iType" "87"
+ "pos_x" "-1305.974487"
+ "pos_y" "-306.997589"
+ "size_x" "60.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_045"
+ {
+ "iType" "17"
+ "pos_x" "-200.096085"
+ "pos_y" "211.243134"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_046"
+ {
+ "iType" "27"
+ "pos_x" "-762.945190"
+ "pos_y" "-1153.852905"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "7"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_047"
+ {
+ "iType" "27"
+ "pos_x" "-777.594360"
+ "pos_y" "-1211.987183"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "7"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_048"
+ {
+ "iType" "20"
+ "pos_x" "-617.374634"
+ "pos_y" "-1162.267212"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "5"
+ "pos_x" "-440.065643"
+ "pos_y" "-1060.233765"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_050"
+ {
+ "iType" "17"
+ "pos_x" "-306.051117"
+ "pos_y" "-1156.147827"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_051"
+ {
+ "iType" "19"
+ "pos_x" "-468.979584"
+ "pos_y" "-1162.267212"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_052"
+ {
+ "iType" "15"
+ "pos_x" "-371.334473"
+ "pos_y" "557.775269"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_053"
+ {
+ "iType" "19"
+ "pos_x" "-233.099228"
+ "pos_y" "492.737457"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_054"
+ {
+ "iType" "19"
+ "pos_x" "51.116302"
+ "pos_y" "546.808105"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_055"
+ {
+ "iType" "26"
+ "pos_x" "50.448524"
+ "pos_y" "210.450958"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "1"
+ "pos_x" "-381.067932"
+ "pos_y" "384.642883"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "3"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-199.013474"
+ "pos_y" "366.788788"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "19"
+ "pos_x" "-199.809982"
+ "pos_y" "427.296539"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_059"
+ {
+ "iType" "19"
+ "pos_x" "-200.112106"
+ "pos_y" "314.781982"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_060"
+ {
+ "iType" "25"
+ "pos_x" "-23.853540"
+ "pos_y" "421.195313"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "25"
+ "pos_x" "-25.137175"
+ "pos_y" "372.060944"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_062"
+ {
+ "iType" "25"
+ "pos_x" "-30.844557"
+ "pos_y" "304.999237"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "2"
+ "pos_x" "279.593658"
+ "pos_y" "385.779694"
+ "size_x" "58.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "4"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_08"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "7"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Name_4" "Lightmap3"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_064"
+ {
+ "iType" "19"
+ "pos_x" "-1333.921997"
+ "pos_y" "-1175.556763"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_065"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-1108.683105"
+ "pos_y" "-1128.395630"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "1469.025513"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_066"
+ {
+ "iType" "76"
+ "pos_x" "55.037018"
+ "pos_y" "-1128.386597"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_067"
+ {
+ "iType" "73"
+ "pos_x" "-994.208618"
+ "pos_y" "-1151.497192"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_068"
+ {
+ "iType" "19"
+ "pos_x" "-867.843018"
+ "pos_y" "-1042.185181"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_069"
+ {
+ "iType" "25"
+ "pos_x" "-707.195374"
+ "pos_y" "-1040.824951"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_070"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-1476.140625"
+ "pos_y" "-543.904968"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "406.346802"
+ "container_extents_y" "1871.088501"
+ "container_extents_z" "-406.346802"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_071"
+ {
+ "iType" "18"
+ "pos_x" "-1333.018677"
+ "pos_y" "-1258.650146"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_072"
+ {
+ "iType" "3"
+ "pos_x" "-1656.085083"
+ "pos_y" "-676.415649"
+ "size_x" "58.000000"
+ "size_y" "-94.000000"
+ "iPreview" "0"
+ "numTexcoords" "7"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Name_4" "Lightmap3"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_073"
+ {
+ "iType" "29"
+ "pos_x" "-457.046478"
+ "pos_y" "-1450.295898"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "basetexture2"
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\cavewall005a"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_074"
+ {
+ "iType" "29"
+ "pos_x" "-1438.758789"
+ "pos_y" "-1023.677917"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\cavewall005a_normal"
+ "szFallbackTexturePath" "dev\flat_normal"
+ "iFallbackMode" "3"
+ }
+ "Node_075"
+ {
+ "iType" "26"
+ "pos_x" "-899.964417"
+ "pos_y" "-491.872589"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_076"
+ {
+ "iType" "23"
+ "pos_x" "-1062.441406"
+ "pos_y" "-333.783966"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "60"
+ "pos_x" "-751.669678"
+ "pos_y" "-490.362793"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_bump_swarm.def b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_bump_swarm.def
new file mode 100644
index 0000000000..061c7617a3
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_bump_swarm.def
@@ -0,0 +1,1580 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "14"
+ "pos_x" "-67.148407"
+ "pos_y" "608.769470"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_001"
+ {
+ "iType" "75"
+ "pos_x" "-196.710205"
+ "pos_y" "-1098.514526"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_002"
+ {
+ "iType" "19"
+ "pos_x" "-56.518372"
+ "pos_y" "-1030.090332"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_003"
+ {
+ "iType" "70"
+ "pos_x" "696.218628"
+ "pos_y" "-1370.956421"
+ "size_x" "59.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_004"
+ {
+ "iType" "7"
+ "pos_x" "587.300537"
+ "pos_y" "-1374.990112"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_005"
+ {
+ "iType" "27"
+ "pos_x" "566.130981"
+ "pos_y" "-1572.309692"
+ "size_x" "124.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_006"
+ {
+ "iType" "71"
+ "pos_x" "870.033813"
+ "pos_y" "-1449.873169"
+ "size_x" "169.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_007"
+ {
+ "iType" "72"
+ "pos_x" "878.133667"
+ "pos_y" "-1563.149536"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_008"
+ {
+ "iType" "4"
+ "pos_x" "1147.363525"
+ "pos_y" "-1584.058716"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_009"
+ {
+ "iType" "27"
+ "pos_x" "687.422974"
+ "pos_y" "-1513.970825"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "7"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_010"
+ {
+ "iType" "19"
+ "pos_x" "387.892548"
+ "pos_y" "-1575.685913"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_011"
+ {
+ "iType" "17"
+ "pos_x" "-195.430313"
+ "pos_y" "154.320465"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "23"
+ "pos_x" "-1063.938477"
+ "pos_y" "-436.916229"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "23"
+ "pos_x" "-1068.266357"
+ "pos_y" "-540.778015"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "19"
+ "pos_x" "-594.653809"
+ "pos_y" "-490.616608"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_015"
+ {
+ "iType" "26"
+ "pos_x" "-899.019592"
+ "pos_y" "-378.204193"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "29"
+ "pos_x" "-415.631012"
+ "pos_y" "-373.722748"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_017"
+ {
+ "iType" "29"
+ "pos_x" "-414.728546"
+ "pos_y" "-476.595612"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "4"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "-566.974243"
+ "pos_y" "-343.340485"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_019"
+ {
+ "iType" "27"
+ "pos_x" "-394.948639"
+ "pos_y" "-590.862610"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_020"
+ {
+ "iType" "27"
+ "pos_x" "-388.216217"
+ "pos_y" "-635.082581"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_021"
+ {
+ "iType" "27"
+ "pos_x" "-390.140411"
+ "pos_y" "-683.180481"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_022"
+ {
+ "iType" "19"
+ "pos_x" "-161.960602"
+ "pos_y" "-387.228058"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_023"
+ {
+ "iType" "19"
+ "pos_x" "-159.075714"
+ "pos_y" "-498.778900"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_024"
+ {
+ "iType" "23"
+ "pos_x" "-397.109283"
+ "pos_y" "-777.056580"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "5"
+ "pos_x" "-488.589386"
+ "pos_y" "-832.720154"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_026"
+ {
+ "iType" "19"
+ "pos_x" "-163.883820"
+ "pos_y" "-283.370331"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_027"
+ {
+ "iType" "17"
+ "pos_x" "-12.768341"
+ "pos_y" "-348.850494"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_028"
+ {
+ "iType" "17"
+ "pos_x" "-10.572052"
+ "pos_y" "-471.832733"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_029"
+ {
+ "iType" "80"
+ "pos_x" "-157.359894"
+ "pos_y" "-676.886658"
+ "size_x" "88.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "1"
+ }
+ "Node_030"
+ {
+ "iType" "20"
+ "pos_x" "-14.695099"
+ "pos_y" "-694.812683"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "27"
+ "pos_x" "-565.747803"
+ "pos_y" "-391.027374"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "zw"
+ }
+ "Node_032"
+ {
+ "iType" "19"
+ "pos_x" "180.579437"
+ "pos_y" "-564.280090"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_033"
+ {
+ "iType" "29"
+ "pos_x" "-419.033722"
+ "pos_y" "-266.936951"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "4"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_034"
+ {
+ "iType" "17"
+ "pos_x" "-178.732437"
+ "pos_y" "104.991516"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "33"
+ "pos_x" "452.038361"
+ "pos_y" "-1002.346069"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_036"
+ {
+ "iType" "32"
+ "pos_x" "121.640915"
+ "pos_y" "-78.065155"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_037"
+ {
+ "iType" "33"
+ "pos_x" "279.624786"
+ "pos_y" "-1132.339722"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "5"
+ "pos_x" "27.518646"
+ "pos_y" "-76.322235"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_039"
+ {
+ "iType" "33"
+ "pos_x" "205.443649"
+ "pos_y" "-775.707031"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "5"
+ "pos_x" "-1422.707764"
+ "pos_y" "-1283.585449"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "1"
+ }
+ "Node_041"
+ {
+ "iType" "5"
+ "pos_x" "-1426.320435"
+ "pos_y" "-1212.233398"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "szConstantString" "2"
+ }
+ "Node_042"
+ {
+ "iType" "87"
+ "pos_x" "-1305.974487"
+ "pos_y" "-306.997589"
+ "size_x" "60.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_043"
+ {
+ "iType" "17"
+ "pos_x" "-200.096085"
+ "pos_y" "211.243134"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "6"
+ }
+ }
+ }
+ "Node_044"
+ {
+ "iType" "27"
+ "pos_x" "-762.945190"
+ "pos_y" "-1153.852905"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "7"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_045"
+ {
+ "iType" "27"
+ "pos_x" "-777.594360"
+ "pos_y" "-1211.987183"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "7"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_046"
+ {
+ "iType" "20"
+ "pos_x" "-617.374634"
+ "pos_y" "-1162.267212"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_047"
+ {
+ "iType" "5"
+ "pos_x" "-440.065643"
+ "pos_y" "-1060.233765"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_048"
+ {
+ "iType" "17"
+ "pos_x" "-306.051117"
+ "pos_y" "-1156.147827"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_049"
+ {
+ "iType" "19"
+ "pos_x" "-468.979584"
+ "pos_y" "-1162.267212"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_050"
+ {
+ "iType" "15"
+ "pos_x" "-371.334473"
+ "pos_y" "557.775269"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_051"
+ {
+ "iType" "19"
+ "pos_x" "-233.099228"
+ "pos_y" "492.737457"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_052"
+ {
+ "iType" "19"
+ "pos_x" "51.116302"
+ "pos_y" "546.808105"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_053"
+ {
+ "iType" "26"
+ "pos_x" "50.448524"
+ "pos_y" "210.450958"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_054"
+ {
+ "iType" "1"
+ "pos_x" "-381.067932"
+ "pos_y" "384.642883"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "3"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_055"
+ {
+ "iType" "19"
+ "pos_x" "-199.013474"
+ "pos_y" "366.788788"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_056"
+ {
+ "iType" "19"
+ "pos_x" "-199.809982"
+ "pos_y" "427.296539"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_057"
+ {
+ "iType" "19"
+ "pos_x" "-200.112106"
+ "pos_y" "314.781982"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_058"
+ {
+ "iType" "25"
+ "pos_x" "-23.853540"
+ "pos_y" "421.195313"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_059"
+ {
+ "iType" "25"
+ "pos_x" "-25.137175"
+ "pos_y" "372.060944"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_060"
+ {
+ "iType" "25"
+ "pos_x" "-30.844557"
+ "pos_y" "304.999237"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_061"
+ {
+ "iType" "2"
+ "pos_x" "279.593658"
+ "pos_y" "385.779694"
+ "size_x" "58.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "4"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ "jackIn_08"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "7"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Name_4" "Lightmap3"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_062"
+ {
+ "iType" "19"
+ "pos_x" "-1333.921997"
+ "pos_y" "-1175.556763"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_063"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-1108.683105"
+ "pos_y" "-1128.395630"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "1469.025513"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_064"
+ {
+ "iType" "76"
+ "pos_x" "55.037018"
+ "pos_y" "-1128.386597"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_065"
+ {
+ "iType" "73"
+ "pos_x" "-994.208618"
+ "pos_y" "-1151.497192"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "2"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_066"
+ {
+ "iType" "19"
+ "pos_x" "-867.843018"
+ "pos_y" "-1042.185181"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_067"
+ {
+ "iType" "25"
+ "pos_x" "-707.195374"
+ "pos_y" "-1040.824951"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_068"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-1476.140625"
+ "pos_y" "-543.904968"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "406.346802"
+ "container_extents_y" "1871.088501"
+ "container_extents_z" "-406.346802"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_069"
+ {
+ "iType" "18"
+ "pos_x" "-1333.018677"
+ "pos_y" "-1258.650146"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_070"
+ {
+ "iType" "3"
+ "pos_x" "-1656.085083"
+ "pos_y" "-676.415649"
+ "size_x" "58.000000"
+ "size_y" "-94.000000"
+ "iPreview" "0"
+ "numTexcoords" "7"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "8"
+ "numTexcoord_Name_1" "Lightmap1and2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Name_4" "Lightmap3"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "Proj pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_071"
+ {
+ "iType" "26"
+ "pos_x" "-899.964417"
+ "pos_y" "-491.872589"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_072"
+ {
+ "iType" "23"
+ "pos_x" "-1062.441406"
+ "pos_y" "-333.783966"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_073"
+ {
+ "iType" "60"
+ "pos_x" "-751.669678"
+ "pos_y" "-490.362793"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_074"
+ {
+ "iType" "29"
+ "pos_x" "-1438.758789"
+ "pos_y" "-1023.677917"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "dev\flat_normal"
+ "szFallbackTexturePath" "dev\flat_normal"
+ "iFallbackMode" "3"
+ }
+ "Node_075"
+ {
+ "iType" "29"
+ "pos_x" "-457.046478"
+ "pos_y" "-1450.295898"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "basetexture2"
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\ice_0"
+ "szFallbackTexturePath" "texture_samples\ice_0"
+ "iFallbackMode" "4"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_simple.def b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_simple.def
new file mode 100644
index 0000000000..988f22eb3d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_simple.def
@@ -0,0 +1,860 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "80"
+ "pos_x" "-129.184967"
+ "pos_y" "-349.526337"
+ "size_x" "88.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "1"
+ }
+ "Node_001"
+ {
+ "iType" "29"
+ "pos_x" "-213.960052"
+ "pos_y" "-204.693207"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "1"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "3"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-610.888855"
+ "pos_y" "-560.498291"
+ "size_x" "55.000000"
+ "size_y" "-72.000000"
+ "iPreview" "0"
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "15"
+ "pos_x" "-204.781937"
+ "pos_y" "357.356842"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_004"
+ {
+ "iType" "14"
+ "pos_x" "-38.191422"
+ "pos_y" "358.933014"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "-66.546745"
+ "pos_y" "292.319092"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-68.653336"
+ "pos_y" "230.331436"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "19"
+ "pos_x" "80.073288"
+ "pos_y" "296.971619"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_008"
+ {
+ "iType" "19"
+ "pos_x" "55.128418"
+ "pos_y" "-263.120819"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_009"
+ {
+ "iType" "76"
+ "pos_x" "229.911148"
+ "pos_y" "-669.693970"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_010"
+ {
+ "iType" "32"
+ "pos_x" "262.603485"
+ "pos_y" "-88.937073"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "pos_x" "168.481186"
+ "pos_y" "-87.194153"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_012"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-321.303345"
+ "pos_y" "-298.511169"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "682.054016"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_013"
+ {
+ "iType" "33"
+ "pos_x" "454.498901"
+ "pos_y" "-673.647034"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "1"
+ "pos_x" "-313.351654"
+ "pos_y" "188.100479"
+ "size_x" "55.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "2"
+ "numColor" "1"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_015"
+ {
+ "iType" "33"
+ "pos_x" "273.061523"
+ "pos_y" "-324.626984"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "70"
+ "pos_x" "647.914307"
+ "pos_y" "-894.212769"
+ "size_x" "59.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_017"
+ {
+ "iType" "7"
+ "pos_x" "538.996094"
+ "pos_y" "-898.246460"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "517.826538"
+ "pos_y" "-1095.565918"
+ "size_x" "124.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_019"
+ {
+ "iType" "71"
+ "pos_x" "821.729492"
+ "pos_y" "-973.129272"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "72"
+ "pos_x" "829.829285"
+ "pos_y" "-1086.405762"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_021"
+ {
+ "iType" "4"
+ "pos_x" "1099.059326"
+ "pos_y" "-1107.314941"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_022"
+ {
+ "iType" "27"
+ "pos_x" "645.023926"
+ "pos_y" "-944.760376"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_023"
+ {
+ "iType" "27"
+ "pos_x" "639.380676"
+ "pos_y" "-988.361450"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_024"
+ {
+ "iType" "27"
+ "pos_x" "639.118591"
+ "pos_y" "-1037.227051"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_025"
+ {
+ "iType" "21"
+ "pos_x" "-185.721588"
+ "pos_y" "-998.953918"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "27"
+ "pos_x" "-599.560425"
+ "pos_y" "-987.765198"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "5"
+ }
+ }
+ "swizzleString" "a"
+ }
+ "Node_027"
+ {
+ "iType" "19"
+ "pos_x" "339.588104"
+ "pos_y" "-1098.942139"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_028"
+ {
+ "iType" "27"
+ "pos_x" "-310.635773"
+ "pos_y" "-674.270081"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_029"
+ {
+ "iType" "27"
+ "pos_x" "-310.012238"
+ "pos_y" "-736.646790"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_030"
+ {
+ "iType" "2"
+ "pos_x" "347.309937"
+ "pos_y" "189.237289"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "4"
+ }
+ }
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_031"
+ {
+ "iType" "20"
+ "pos_x" "-176.943695"
+ "pos_y" "-678.442078"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "19"
+ "pos_x" "-28.548599"
+ "pos_y" "-678.442078"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_033"
+ {
+ "iType" "33"
+ "pos_x" "659.732910"
+ "pos_y" "-523.961243"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_034"
+ {
+ "iType" "19"
+ "pos_x" "118.355759"
+ "pos_y" "-571.397705"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_035"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-412.226501"
+ "pos_y" "-661.497864"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "921.186279"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_036"
+ {
+ "iType" "5"
+ "pos_x" "-161.970367"
+ "pos_y" "-576.408630"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_037"
+ {
+ "iType" "17"
+ "pos_x" "-25.018768"
+ "pos_y" "-750.222717"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_038"
+ {
+ "iType" "75"
+ "pos_x" "-40.687943"
+ "pos_y" "-571.745850"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_039"
+ {
+ "iType" "29"
+ "pos_x" "-434.073120"
+ "pos_y" "-1040.295776"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "basetexture2"
+ "iSRGB" "1"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\dirtfloor004a"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_040"
+ {
+ "iType" "29"
+ "pos_x" "-434.088654"
+ "pos_y" "-930.070068"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "basetexture2"
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\cavewall005a"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_simple_swarm.def b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_simple_swarm.def
new file mode 100644
index 0000000000..a5b904de49
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_lightmap_simple_swarm.def
@@ -0,0 +1,823 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "80"
+ "pos_x" "-129.184967"
+ "pos_y" "-349.526337"
+ "size_x" "88.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "1"
+ }
+ "Node_001"
+ {
+ "iType" "29"
+ "pos_x" "-213.960052"
+ "pos_y" "-204.693207"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "1"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "3"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Dev\bump"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-610.888855"
+ "pos_y" "-560.498291"
+ "size_x" "55.000000"
+ "size_y" "-72.000000"
+ "iPreview" "0"
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "15"
+ "pos_x" "-204.781937"
+ "pos_y" "357.356842"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_004"
+ {
+ "iType" "14"
+ "pos_x" "-38.191422"
+ "pos_y" "358.933014"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_005"
+ {
+ "iType" "19"
+ "pos_x" "-66.546745"
+ "pos_y" "292.319092"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-68.653336"
+ "pos_y" "230.331436"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "19"
+ "pos_x" "80.073288"
+ "pos_y" "296.971619"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_008"
+ {
+ "iType" "19"
+ "pos_x" "55.128418"
+ "pos_y" "-263.120819"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_009"
+ {
+ "iType" "76"
+ "pos_x" "229.911148"
+ "pos_y" "-669.693970"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_010"
+ {
+ "iType" "32"
+ "pos_x" "262.603485"
+ "pos_y" "-88.937073"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "5"
+ "pos_x" "168.481186"
+ "pos_y" "-87.194153"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_012"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-321.303345"
+ "pos_y" "-298.511169"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "682.054016"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_013"
+ {
+ "iType" "33"
+ "pos_x" "454.498901"
+ "pos_y" "-673.647034"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_014"
+ {
+ "iType" "1"
+ "pos_x" "-313.351654"
+ "pos_y" "188.100479"
+ "size_x" "55.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "2"
+ "numColor" "1"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_015"
+ {
+ "iType" "33"
+ "pos_x" "273.061523"
+ "pos_y" "-324.626984"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "70"
+ "pos_x" "647.914307"
+ "pos_y" "-894.212769"
+ "size_x" "59.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_017"
+ {
+ "iType" "7"
+ "pos_x" "538.996094"
+ "pos_y" "-898.246460"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "517.826538"
+ "pos_y" "-1095.565918"
+ "size_x" "124.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ "Node_019"
+ {
+ "iType" "71"
+ "pos_x" "821.729492"
+ "pos_y" "-973.129272"
+ "size_x" "169.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "72"
+ "pos_x" "829.829285"
+ "pos_y" "-1086.405762"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_021"
+ {
+ "iType" "4"
+ "pos_x" "1099.059326"
+ "pos_y" "-1107.314941"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_022"
+ {
+ "iType" "27"
+ "pos_x" "639.118591"
+ "pos_y" "-1037.227051"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_023"
+ {
+ "iType" "21"
+ "pos_x" "-185.721588"
+ "pos_y" "-998.953918"
+ "size_x" "100.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "27"
+ "pos_x" "-599.560425"
+ "pos_y" "-987.765198"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "5"
+ }
+ }
+ "swizzleString" "a"
+ }
+ "Node_025"
+ {
+ "iType" "19"
+ "pos_x" "339.588104"
+ "pos_y" "-1098.942139"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_026"
+ {
+ "iType" "27"
+ "pos_x" "-310.635773"
+ "pos_y" "-674.270081"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_027"
+ {
+ "iType" "27"
+ "pos_x" "-310.012238"
+ "pos_y" "-736.646790"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_028"
+ {
+ "iType" "2"
+ "pos_x" "347.309937"
+ "pos_y" "189.237289"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "4"
+ }
+ }
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "Wnormal"
+ "numTexcoord_Flag_3" "4"
+ "numTexcoord_Name_3" "WPos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_029"
+ {
+ "iType" "20"
+ "pos_x" "-176.943695"
+ "pos_y" "-678.442078"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_030"
+ {
+ "iType" "19"
+ "pos_x" "-28.548599"
+ "pos_y" "-678.442078"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_031"
+ {
+ "iType" "33"
+ "pos_x" "659.732910"
+ "pos_y" "-523.961243"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_032"
+ {
+ "iType" "19"
+ "pos_x" "118.355759"
+ "pos_y" "-571.397705"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "3"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_033"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-412.226501"
+ "pos_y" "-661.497864"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "153.273575"
+ "container_extents_y" "921.186279"
+ "container_extents_z" "-153.273575"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "0"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_034"
+ {
+ "iType" "5"
+ "pos_x" "-161.970367"
+ "pos_y" "-576.408630"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0.5"
+ }
+ "Node_035"
+ {
+ "iType" "17"
+ "pos_x" "-25.018768"
+ "pos_y" "-750.222717"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_036"
+ {
+ "iType" "75"
+ "pos_x" "-40.687943"
+ "pos_y" "-571.745850"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_037"
+ {
+ "iType" "29"
+ "pos_x" "-434.088654"
+ "pos_y" "-930.070068"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "basetexture2"
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "nature\dirtfloor004a"
+ "szFallbackTexturePath" "nature\dirtfloor004a"
+ "iFallbackMode" "4"
+ }
+ "Node_038"
+ {
+ "iType" "29"
+ "pos_x" "-434.073120"
+ "pos_y" "-1040.295776"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "basetexture2"
+ "iSRGB" "1"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_0"
+ "iFallbackMode" "4"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_model_complex.def b/mp/game/momentum/shadereditorui/canvas_default/def_model_complex.def
new file mode 100644
index 0000000000..0ce3e0e389
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_model_complex.def
@@ -0,0 +1,1991 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "25"
+ "pos_x" "-299.034607"
+ "pos_y" "595.806274"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_001"
+ {
+ "iType" "25"
+ "pos_x" "-299.034607"
+ "pos_y" "559.898193"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_002"
+ {
+ "iType" "20"
+ "pos_x" "611.921448"
+ "pos_y" "-73.153870"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "31"
+ "szName" "ON"
+ "pos_x" "331.559204"
+ "pos_y" "-16.809479"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "182.742737"
+ "container_extents_y" "823.093750"
+ "container_extents_z" "-182.742737"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_004"
+ {
+ "iType" "53"
+ "pos_x" "-910.638489"
+ "pos_y" "304.940155"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "23"
+ "pos_x" "-1037.434326"
+ "pos_y" "291.404266"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-1431.031494"
+ "pos_y" "-34.527313"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "14"
+ "pos_x" "-220.561584"
+ "pos_y" "820.312744"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_008"
+ {
+ "iType" "76"
+ "pos_x" "732.506531"
+ "pos_y" "93.800934"
+ "size_x" "168.000000"
+ "size_y" "-83.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "8"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "1"
+ }
+ "Node_009"
+ {
+ "iType" "27"
+ "pos_x" "405.623291"
+ "pos_y" "12.833313"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_010"
+ {
+ "iType" "18"
+ "pos_x" "-161.562836"
+ "pos_y" "610.327026"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "2"
+ "pos_x" "190.853882"
+ "pos_y" "734.089844"
+ "size_x" "55.000000"
+ "size_y" "-116.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "8"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_08"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_09"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "8"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_012"
+ {
+ "iType" "32"
+ "pos_x" "82.485123"
+ "pos_y" "584.654907"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "31"
+ "pos_x" "-62.823177"
+ "pos_y" "473.883698"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "62.811218"
+ "container_extents_y" "232.919769"
+ "container_extents_z" "-62.811218"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_014"
+ {
+ "iType" "75"
+ "pos_x" "14.602026"
+ "pos_y" "445.455353"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_015"
+ {
+ "iType" "33"
+ "pos_x" "137.882080"
+ "pos_y" "491.238495"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "25"
+ "pos_x" "-1404.441284"
+ "pos_y" "47.028900"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "5"
+ "pos_x" "-1567.767212"
+ "pos_y" "268.307159"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_018"
+ {
+ "iType" "18"
+ "pos_x" "-1402.897461"
+ "pos_y" "117.985107"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "27"
+ "pos_x" "441.474182"
+ "pos_y" "-105.211365"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_020"
+ {
+ "iType" "5"
+ "pos_x" "-1479.457153"
+ "pos_y" "274.916229"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_021"
+ {
+ "iType" "25"
+ "pos_x" "-1343.972534"
+ "pos_y" "-378.331757"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "7"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "5"
+ "szName" "diffuse"
+ "pos_x" "387.497437"
+ "pos_y" "275.393494"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_023"
+ {
+ "iType" "5"
+ "szName" "Specular"
+ "pos_x" "31.314459"
+ "pos_y" "267.249542"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_024"
+ {
+ "iType" "32"
+ "pos_x" "485.332031"
+ "pos_y" "272.623810"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "33"
+ "pos_x" "1026.863770"
+ "pos_y" "91.808105"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "33"
+ "pos_x" "973.598694"
+ "pos_y" "-27.113068"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "7"
+ "pos_x" "-181.255676"
+ "pos_y" "543.788696"
+ "size_x" "54.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_028"
+ {
+ "iType" "27"
+ "pos_x" "-688.071106"
+ "pos_y" "677.496948"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xyz"
+ }
+ "Node_029"
+ {
+ "iType" "27"
+ "pos_x" "-687.730408"
+ "pos_y" "612.119995"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_030"
+ {
+ "iType" "26"
+ "pos_x" "-524.809265"
+ "pos_y" "659.291626"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "69"
+ "pos_x" "-700.568176"
+ "pos_y" "813.892212"
+ "size_x" "101.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "94"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "2"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_032"
+ {
+ "iType" "19"
+ "pos_x" "14.134359"
+ "pos_y" "499.710602"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_033"
+ {
+ "iType" "5"
+ "pos_x" "-3.727656"
+ "pos_y" "591.317993"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_034"
+ {
+ "iType" "25"
+ "pos_x" "-299.712097"
+ "pos_y" "633.069214"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "66"
+ "pos_x" "-72.910965"
+ "pos_y" "703.530884"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vlight_static" "0"
+ "i_vlight_hl" "0"
+ }
+ "Node_036"
+ {
+ "iType" "19"
+ "pos_x" "-64.499283"
+ "pos_y" "792.782715"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_037"
+ {
+ "iType" "19"
+ "pos_x" "-1401.849609"
+ "pos_y" "187.411621"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_038"
+ {
+ "iType" "73"
+ "szName" "Tangentspace"
+ "pos_x" "-1619.572632"
+ "pos_y" "-38.087097"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_039"
+ {
+ "iType" "25"
+ "szName" "World_normal"
+ "pos_x" "-1285.157959"
+ "pos_y" "-38.549469"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "3"
+ "pos_x" "-1667.054810"
+ "pos_y" "-256.292023"
+ "size_x" "55.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "numTexcoords" "8"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_041"
+ {
+ "iType" "71"
+ "pos_x" "709.196106"
+ "pos_y" "-673.911560"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "70"
+ "pos_x" "712.336243"
+ "pos_y" "-577.848145"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_043"
+ {
+ "iType" "7"
+ "pos_x" "410.617889"
+ "pos_y" "-572.928528"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_044"
+ {
+ "iType" "27"
+ "szName" "proj_z"
+ "pos_x" "409.736786"
+ "pos_y" "-660.502380"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_045"
+ {
+ "iType" "27"
+ "pos_x" "553.371521"
+ "pos_y" "-707.137146"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_046"
+ {
+ "iType" "72"
+ "pos_x" "730.367249"
+ "pos_y" "-858.379089"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_047"
+ {
+ "iType" "19"
+ "pos_x" "-890.135193"
+ "pos_y" "-581.495605"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_048"
+ {
+ "iType" "68"
+ "pos_x" "-412.877258"
+ "pos_y" "783.290527"
+ "size_x" "116.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "3"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "1"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_049"
+ {
+ "iType" "61"
+ "pos_x" "-1043.730957"
+ "pos_y" "168.753326"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_050"
+ {
+ "iType" "19"
+ "szName" "world2eye"
+ "pos_x" "-1116.969604"
+ "pos_y" "412.146057"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "51"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_051"
+ {
+ "iType" "5"
+ "pos_x" "-1112.923096"
+ "pos_y" "511.305420"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_052"
+ {
+ "iType" "4"
+ "pos_x" "1066.342285"
+ "pos_y" "-871.036926"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_053"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-1441.094482"
+ "pos_y" "-951.328247"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "171.600098"
+ "container_extents_y" "1247.736938"
+ "container_extents_z" "-171.600098"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_054"
+ {
+ "iType" "19"
+ "szName" "Rim_lighting"
+ "pos_x" "-163.917236"
+ "pos_y" "-109.586990"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_055"
+ {
+ "iType" "49"
+ "pos_x" "-369.549530"
+ "pos_y" "-100.639664"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_056"
+ {
+ "iType" "33"
+ "szName" "Diffuse"
+ "pos_x" "-141.459473"
+ "pos_y" "-510.953125"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_057"
+ {
+ "iType" "79"
+ "pos_x" "-299.620178"
+ "pos_y" "-211.795380"
+ "size_x" "89.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "rim_color"
+ "i_vp_static_nc" "2"
+ "szConstantString" "1 1 1"
+ }
+ "Node_058"
+ {
+ "iType" "27"
+ "pos_x" "-453.567078"
+ "pos_y" "-210.899246"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_059"
+ {
+ "iType" "79"
+ "pos_x" "-457.481506"
+ "pos_y" "-335.765900"
+ "size_x" "107.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "rim_boost_exp"
+ "i_vp_static_nc" "1"
+ "szConstantString" "0.05 9"
+ }
+ "Node_060"
+ {
+ "iType" "27"
+ "pos_x" "-280.265839"
+ "pos_y" "-304.126465"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "59"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_061"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-559.989563"
+ "pos_y" "-111.775040"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "293.957031"
+ "container_extents_y" "736.290649"
+ "container_extents_z" "-293.957031"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_062"
+ {
+ "iType" "27"
+ "pos_x" "550.036255"
+ "pos_y" "-572.179993"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_063"
+ {
+ "iType" "26"
+ "szName" "Comp"
+ "pos_x" "147.508057"
+ "pos_y" "-901.616455"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_064"
+ {
+ "iType" "33"
+ "szName" "Specular"
+ "pos_x" "24.892941"
+ "pos_y" "-522.529541"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_065"
+ {
+ "iType" "19"
+ "szName" "RL_scale"
+ "pos_x" "-101.318184"
+ "pos_y" "-256.065887"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "60"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_066"
+ {
+ "iType" "17"
+ "szName" "Specular"
+ "pos_x" "-689.536560"
+ "pos_y" "-584.606567"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_067"
+ {
+ "iType" "33"
+ "pos_x" "118.955460"
+ "pos_y" "-242.868668"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_068"
+ {
+ "iType" "17"
+ "szName" "writes_to_A"
+ "pos_x" "-286.085938"
+ "pos_y" "-893.951599"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_069"
+ {
+ "iType" "19"
+ "pos_x" "-453.872375"
+ "pos_y" "-927.497864"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_070"
+ {
+ "iType" "5"
+ "pos_x" "-540.121582"
+ "pos_y" "-1030.991821"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_071"
+ {
+ "iType" "19"
+ "szName" "scale_by_fresnel"
+ "pos_x" "-619.808472"
+ "pos_y" "-904.038818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_072"
+ {
+ "iType" "19"
+ "szName" "normal_map_alpha_mask"
+ "pos_x" "-806.319275"
+ "pos_y" "-893.905396"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_073"
+ {
+ "iType" "19"
+ "pos_x" "-971.059998"
+ "pos_y" "-896.052429"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_074"
+ {
+ "iType" "80"
+ "pos_x" "-1127.452393"
+ "pos_y" "-1031.592407"
+ "size_x" "83.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "2"
+ }
+ "Node_075"
+ {
+ "iType" "58"
+ "pos_x" "-1344.874023"
+ "pos_y" "-903.285767"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_076"
+ {
+ "iType" "49"
+ "pos_x" "-887.519653"
+ "pos_y" "165.745148"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "80"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "74"
+ "pos_x" "-200.566971"
+ "pos_y" "132.821869"
+ "size_x" "155.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "50"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_ao" "0"
+ }
+ "Node_078"
+ {
+ "iType" "33"
+ "pos_x" "71.058868"
+ "pos_y" "-13.431725"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_079"
+ {
+ "iType" "38"
+ "pos_x" "42.977386"
+ "pos_y" "-125.018158"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_080"
+ {
+ "iType" "5"
+ "pos_x" "-1004.388733"
+ "pos_y" "56.160908"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_081"
+ {
+ "iType" "38"
+ "pos_x" "-699.437439"
+ "pos_y" "231.170700"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "5"
+ "pos_x" "-536.772766"
+ "pos_y" "255.797729"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_083"
+ {
+ "iType" "32"
+ "pos_x" "144.554855"
+ "pos_y" "266.021149"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_084"
+ {
+ "iType" "61"
+ "pos_x" "-870.527710"
+ "pos_y" "-76.748718"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_085"
+ {
+ "iType" "5"
+ "pos_x" "-914.728516"
+ "pos_y" "-331.763367"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "150"
+ }
+ "Node_086"
+ {
+ "iType" "17"
+ "pos_x" "-713.645935"
+ "pos_y" "-139.951248"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_087"
+ {
+ "iType" "19"
+ "pos_x" "-882.327820"
+ "pos_y" "-220.377365"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_088"
+ {
+ "iType" "29"
+ "szName" "Envmap"
+ "pos_x" "-1163.571411"
+ "pos_y" "-902.790588"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "6"
+ "IsCubemap" "1"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\cubemap_uffizi"
+ "szFallbackTexturePath" "cable\black"
+ "iFallbackMode" "1"
+ }
+ "Node_089"
+ {
+ "iType" "29"
+ "szName" "Albedo"
+ "pos_x" "-1124.061646"
+ "pos_y" "-584.555176"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "models\combine_soldier\combine_elite"
+ "szFallbackTexturePath" "Dev\bump"
+ "iFallbackMode" "2"
+ }
+ "Node_090"
+ {
+ "iType" "29"
+ "szName" "Normalmap"
+ "pos_x" "-1606.065430"
+ "pos_y" "173.350586"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "models\combine_soldier\combine_elite_normal"
+ "szFallbackTexturePath" "dev\flat_normal"
+ "iFallbackMode" "3"
+ }
+ "Node_091"
+ {
+ "iType" "29"
+ "pos_x" "-1053.138916"
+ "pos_y" "-159.996216"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "phongexp"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "models\combine_soldier\combine_elite_phong"
+ "szFallbackTexturePath" "Lights\White"
+ "iFallbackMode" "0"
+ }
+ "Node_092"
+ {
+ "iType" "67"
+ "pos_x" "-179.692764"
+ "pos_y" "18.299576"
+ "size_x" "156.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_static" "0"
+ "i_plight_ao" "0"
+ "i_plight_hl" "0"
+ }
+ "Node_093"
+ {
+ "iType" "1"
+ "pos_x" "-1030.582886"
+ "pos_y" "668.763306"
+ "size_x" "55.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "enable_flex" "1"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "1"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_094"
+ {
+ "iType" "101"
+ "pos_x" "-879.482849"
+ "pos_y" "676.489990"
+ "size_x" "95.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "6"
+ }
+ }
+ "iCompMode" "1"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_model_complex_swarm.def b/mp/game/momentum/shadereditorui/canvas_default/def_model_complex_swarm.def
new file mode 100644
index 0000000000..e4ba130b34
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_model_complex_swarm.def
@@ -0,0 +1,1968 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "25"
+ "pos_x" "-299.034607"
+ "pos_y" "595.806274"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_001"
+ {
+ "iType" "25"
+ "pos_x" "-299.034607"
+ "pos_y" "559.898193"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "3"
+ }
+ }
+ }
+ "Node_002"
+ {
+ "iType" "20"
+ "pos_x" "611.921448"
+ "pos_y" "-73.153870"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_003"
+ {
+ "iType" "31"
+ "szName" "ON"
+ "pos_x" "331.559204"
+ "pos_y" "-16.809479"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "182.742737"
+ "container_extents_y" "823.093750"
+ "container_extents_z" "-182.742737"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_004"
+ {
+ "iType" "53"
+ "pos_x" "-910.638489"
+ "pos_y" "304.940155"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "23"
+ "pos_x" "-1037.434326"
+ "pos_y" "291.404266"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "-1431.031494"
+ "pos_y" "-34.527313"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "38"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "14"
+ "pos_x" "-220.561584"
+ "pos_y" "820.312744"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_008"
+ {
+ "iType" "76"
+ "pos_x" "732.506531"
+ "pos_y" "93.800934"
+ "size_x" "168.000000"
+ "size_y" "-83.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "8"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "1"
+ }
+ "Node_009"
+ {
+ "iType" "27"
+ "pos_x" "405.623291"
+ "pos_y" "12.833313"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_010"
+ {
+ "iType" "18"
+ "pos_x" "-161.562836"
+ "pos_y" "610.327026"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_011"
+ {
+ "iType" "2"
+ "pos_x" "190.853882"
+ "pos_y" "734.089844"
+ "size_x" "55.000000"
+ "size_y" "-116.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "8"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_07"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_08"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ "jackIn_09"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "8"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_012"
+ {
+ "iType" "32"
+ "pos_x" "82.485123"
+ "pos_y" "584.654907"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_013"
+ {
+ "iType" "31"
+ "pos_x" "-62.823177"
+ "pos_y" "473.883698"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "62.811218"
+ "container_extents_y" "232.919769"
+ "container_extents_z" "-62.811218"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_014"
+ {
+ "iType" "75"
+ "pos_x" "14.602026"
+ "pos_y" "445.455353"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_015"
+ {
+ "iType" "33"
+ "pos_x" "137.882080"
+ "pos_y" "491.238495"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_016"
+ {
+ "iType" "25"
+ "pos_x" "-1404.441284"
+ "pos_y" "47.028900"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "5"
+ "pos_x" "-1567.767212"
+ "pos_y" "268.307159"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_018"
+ {
+ "iType" "18"
+ "pos_x" "-1402.897461"
+ "pos_y" "117.985107"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "37"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "20"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_019"
+ {
+ "iType" "27"
+ "pos_x" "441.474182"
+ "pos_y" "-105.211365"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_020"
+ {
+ "iType" "5"
+ "pos_x" "-1479.457153"
+ "pos_y" "274.916229"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_021"
+ {
+ "iType" "25"
+ "pos_x" "-1343.972534"
+ "pos_y" "-378.331757"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "7"
+ }
+ }
+ }
+ "Node_022"
+ {
+ "iType" "5"
+ "szName" "diffuse"
+ "pos_x" "387.497437"
+ "pos_y" "275.393494"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_023"
+ {
+ "iType" "5"
+ "szName" "Specular"
+ "pos_x" "31.314459"
+ "pos_y" "267.249542"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_024"
+ {
+ "iType" "32"
+ "pos_x" "485.332031"
+ "pos_y" "272.623810"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "22"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_025"
+ {
+ "iType" "33"
+ "pos_x" "1026.863770"
+ "pos_y" "91.808105"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_026"
+ {
+ "iType" "33"
+ "pos_x" "973.598694"
+ "pos_y" "-27.113068"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "7"
+ "pos_x" "-181.255676"
+ "pos_y" "543.788696"
+ "size_x" "54.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_028"
+ {
+ "iType" "27"
+ "pos_x" "-688.071106"
+ "pos_y" "677.496948"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "xyz"
+ }
+ "Node_029"
+ {
+ "iType" "27"
+ "pos_x" "-687.730408"
+ "pos_y" "612.119995"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_030"
+ {
+ "iType" "26"
+ "pos_x" "-524.809265"
+ "pos_y" "659.291626"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_031"
+ {
+ "iType" "69"
+ "pos_x" "-700.568176"
+ "pos_y" "813.892212"
+ "size_x" "101.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "89"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "2"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_032"
+ {
+ "iType" "19"
+ "pos_x" "14.134359"
+ "pos_y" "499.710602"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_033"
+ {
+ "iType" "5"
+ "pos_x" "-3.727656"
+ "pos_y" "591.317993"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_034"
+ {
+ "iType" "25"
+ "pos_x" "-299.712097"
+ "pos_y" "633.069214"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_035"
+ {
+ "iType" "66"
+ "pos_x" "-72.910965"
+ "pos_y" "703.530884"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vlight_static" "0"
+ "i_vlight_hl" "0"
+ }
+ "Node_036"
+ {
+ "iType" "19"
+ "pos_x" "-64.499283"
+ "pos_y" "792.782715"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "46"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_037"
+ {
+ "iType" "19"
+ "pos_x" "-1401.849609"
+ "pos_y" "187.411621"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_038"
+ {
+ "iType" "73"
+ "szName" "Tangentspace"
+ "pos_x" "-1619.572632"
+ "pos_y" "-38.087097"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "6"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mcomp_matrix" "16"
+ "i_mcomp_c" "0"
+ }
+ "Node_039"
+ {
+ "iType" "25"
+ "szName" "World_normal"
+ "pos_x" "-1285.157959"
+ "pos_y" "-38.549469"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_040"
+ {
+ "iType" "3"
+ "pos_x" "-1667.054810"
+ "pos_y" "-256.292023"
+ "size_x" "55.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "numTexcoords" "8"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WNormal"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WPos"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "VAttn"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "Proj pos"
+ "numTexcoord_Flag_5" "4"
+ "numTexcoord_Name_5" "tan s"
+ "numTexcoord_Flag_6" "4"
+ "numTexcoord_Name_6" "tan t"
+ "numTexcoord_Flag_7" "4"
+ "numTexcoord_Name_7" "eye2world"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "FL pos"
+ "numColor_Flag_1" "8"
+ }
+ "Node_041"
+ {
+ "iType" "71"
+ "pos_x" "709.196106"
+ "pos_y" "-673.911560"
+ "size_x" "169.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "42"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_042"
+ {
+ "iType" "70"
+ "pos_x" "712.336243"
+ "pos_y" "-577.848145"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_043"
+ {
+ "iType" "27"
+ "szName" "proj_z"
+ "pos_x" "409.736786"
+ "pos_y" "-660.502380"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "4"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_044"
+ {
+ "iType" "72"
+ "pos_x" "730.367249"
+ "pos_y" "-858.379089"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "61"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "41"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "43"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_045"
+ {
+ "iType" "19"
+ "pos_x" "-890.135193"
+ "pos_y" "-581.495605"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "54"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "1"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_046"
+ {
+ "iType" "68"
+ "pos_x" "-412.877258"
+ "pos_y" "783.290527"
+ "size_x" "116.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "4"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "3"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "31"
+ "iTarget_jack" "1"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "2"
+ }
+ "Node_047"
+ {
+ "iType" "61"
+ "pos_x" "-1043.730957"
+ "pos_y" "168.753326"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_048"
+ {
+ "iType" "19"
+ "szName" "world2eye"
+ "pos_x" "-1116.969604"
+ "pos_y" "412.146057"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "49"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_049"
+ {
+ "iType" "5"
+ "pos_x" "-1112.923096"
+ "pos_y" "511.305420"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "-1"
+ }
+ "Node_050"
+ {
+ "iType" "4"
+ "pos_x" "1066.342285"
+ "pos_y" "-871.036926"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "44"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_051"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-1441.094482"
+ "pos_y" "-951.328247"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "171.600098"
+ "container_extents_y" "1247.736938"
+ "container_extents_z" "-171.600098"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_052"
+ {
+ "iType" "19"
+ "szName" "Rim_lighting"
+ "pos_x" "-163.917236"
+ "pos_y" "-109.586990"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "53"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "55"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_053"
+ {
+ "iType" "49"
+ "pos_x" "-369.549530"
+ "pos_y" "-100.639664"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "56"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_054"
+ {
+ "iType" "33"
+ "szName" "Diffuse"
+ "pos_x" "-141.459473"
+ "pos_y" "-510.953125"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "76"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_055"
+ {
+ "iType" "79"
+ "pos_x" "-299.620178"
+ "pos_y" "-211.795380"
+ "size_x" "89.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "rim_color"
+ "i_vp_static_nc" "2"
+ "szConstantString" "1 1 1"
+ }
+ "Node_056"
+ {
+ "iType" "27"
+ "pos_x" "-453.567078"
+ "pos_y" "-210.899246"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "y"
+ }
+ "Node_057"
+ {
+ "iType" "79"
+ "pos_x" "-457.481506"
+ "pos_y" "-335.765900"
+ "size_x" "107.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_vp_static_name" "rim_boost_exp"
+ "i_vp_static_nc" "1"
+ "szConstantString" "0.05 9"
+ }
+ "Node_058"
+ {
+ "iType" "27"
+ "pos_x" "-280.265839"
+ "pos_y" "-304.126465"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "57"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x"
+ }
+ "Node_059"
+ {
+ "iType" "31"
+ "szName" "OFF"
+ "pos_x" "-559.989563"
+ "pos_y" "-111.775040"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "293.957031"
+ "container_extents_y" "736.290649"
+ "container_extents_z" "-293.957031"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_060"
+ {
+ "iType" "27"
+ "pos_x" "550.036255"
+ "pos_y" "-572.179993"
+ "size_x" "103.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "90"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_061"
+ {
+ "iType" "26"
+ "szName" "Comp"
+ "pos_x" "147.508057"
+ "pos_y" "-901.616455"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "66"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "92"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_062"
+ {
+ "iType" "33"
+ "szName" "Specular"
+ "pos_x" "24.892941"
+ "pos_y" "-522.529541"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "65"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_063"
+ {
+ "iType" "19"
+ "szName" "RL_scale"
+ "pos_x" "-101.318184"
+ "pos_y" "-256.065887"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "52"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "58"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_064"
+ {
+ "iType" "17"
+ "szName" "Specular"
+ "pos_x" "-689.536560"
+ "pos_y" "-584.606567"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "45"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "62"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_065"
+ {
+ "iType" "33"
+ "pos_x" "118.955460"
+ "pos_y" "-242.868668"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "81"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "77"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_066"
+ {
+ "iType" "17"
+ "szName" "writes_to_A"
+ "pos_x" "-286.085938"
+ "pos_y" "-893.951599"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "64"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "67"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_067"
+ {
+ "iType" "19"
+ "pos_x" "-453.872375"
+ "pos_y" "-927.497864"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "69"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "68"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_068"
+ {
+ "iType" "5"
+ "pos_x" "-540.121582"
+ "pos_y" "-1030.991821"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "1"
+ }
+ "Node_069"
+ {
+ "iType" "19"
+ "szName" "scale_by_fresnel"
+ "pos_x" "-619.808472"
+ "pos_y" "-904.038818"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "70"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_070"
+ {
+ "iType" "19"
+ "szName" "normal_map_alpha_mask"
+ "pos_x" "-806.319275"
+ "pos_y" "-893.905396"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "71"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_071"
+ {
+ "iType" "19"
+ "pos_x" "-971.059998"
+ "pos_y" "-896.052429"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "86"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "72"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_072"
+ {
+ "iType" "80"
+ "pos_x" "-1127.452393"
+ "pos_y" "-1031.592407"
+ "size_x" "83.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "i_lscale_type" "2"
+ }
+ "Node_073"
+ {
+ "iType" "58"
+ "pos_x" "-1344.874023"
+ "pos_y" "-903.285767"
+ "size_x" "111.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "21"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_074"
+ {
+ "iType" "49"
+ "pos_x" "-887.519653"
+ "pos_y" "165.745148"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "47"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "78"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_075"
+ {
+ "iType" "74"
+ "pos_x" "-200.566971"
+ "pos_y" "132.821869"
+ "size_x" "155.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "48"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "84"
+ "iTarget_jack" "0"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "79"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_ao" "0"
+ }
+ "Node_076"
+ {
+ "iType" "33"
+ "pos_x" "71.058868"
+ "pos_y" "-13.431725"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "87"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_077"
+ {
+ "iType" "38"
+ "pos_x" "42.977386"
+ "pos_y" "-125.018158"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "75"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "63"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_078"
+ {
+ "iType" "5"
+ "pos_x" "-1004.388733"
+ "pos_y" "56.160908"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "3"
+ }
+ "Node_079"
+ {
+ "iType" "38"
+ "pos_x" "-699.437439"
+ "pos_y" "231.170700"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "74"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "91"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_080"
+ {
+ "iType" "5"
+ "pos_x" "-536.772766"
+ "pos_y" "255.797729"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "2"
+ }
+ "Node_081"
+ {
+ "iType" "32"
+ "pos_x" "144.554855"
+ "pos_y" "266.021149"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_082"
+ {
+ "iType" "61"
+ "pos_x" "-870.527710"
+ "pos_y" "-76.748718"
+ "size_x" "93.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "2"
+ }
+ }
+ }
+ "Node_083"
+ {
+ "iType" "5"
+ "pos_x" "-914.728516"
+ "pos_y" "-331.763367"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "150"
+ }
+ "Node_084"
+ {
+ "iType" "17"
+ "pos_x" "-713.645935"
+ "pos_y" "-139.951248"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "82"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "85"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_085"
+ {
+ "iType" "19"
+ "pos_x" "-882.327820"
+ "pos_y" "-220.377365"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "93"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "83"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_086"
+ {
+ "iType" "29"
+ "szName" "Envmap"
+ "pos_x" "-1163.571411"
+ "pos_y" "-902.790588"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "73"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "6"
+ "IsCubemap" "1"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\cubemap_uffizi"
+ "szFallbackTexturePath" "cable\black"
+ "iFallbackMode" "1"
+ }
+ "Node_087"
+ {
+ "iType" "67"
+ "pos_x" "-179.692764"
+ "pos_y" "18.299576"
+ "size_x" "156.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "39"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "3"
+ }
+ }
+ "i_plight_static" "0"
+ "i_plight_ao" "0"
+ "i_plight_hl" "0"
+ }
+ "Node_088"
+ {
+ "iType" "1"
+ "pos_x" "-1030.582886"
+ "pos_y" "668.763306"
+ "size_x" "55.000000"
+ "size_y" "-105.000000"
+ "iPreview" "0"
+ "enable_flex" "1"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "1"
+ "enable_tangentspace_skinning" "1"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_089"
+ {
+ "iType" "101"
+ "pos_x" "-879.482849"
+ "pos_y" "676.489990"
+ "size_x" "95.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "5"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "88"
+ "iTarget_jack" "6"
+ }
+ }
+ "iCompMode" "1"
+ }
+ "Node_090"
+ {
+ "iType" "7"
+ "pos_x" "410.617889"
+ "pos_y" "-572.928528"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_091"
+ {
+ "iType" "29"
+ "szName" "Normalmap"
+ "pos_x" "-1606.065430"
+ "pos_y" "173.350586"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "2"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "dev\flat_normal"
+ "szFallbackTexturePath" "dev\flat_normal"
+ "iFallbackMode" "3"
+ }
+ "Node_092"
+ {
+ "iType" "29"
+ "szName" "Albedo"
+ "pos_x" "-1124.061646"
+ "pos_y" "-584.555176"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_0"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_0"
+ "iFallbackMode" "4"
+ }
+ "Node_093"
+ {
+ "iType" "29"
+ "pos_x" "-1053.138916"
+ "pos_y" "-159.996216"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "40"
+ "iTarget_jack" "0"
+ }
+ }
+ "szParamname" "phongexp"
+ "iSRGB" "0"
+ "iTextureType" "0"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\fx_clouds_1"
+ "szFallbackTexturePath" "texture_samples\fx_clouds_1"
+ "iFallbackMode" "4"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_model_simple.def b/mp/game/momentum/shadereditorui/canvas_default/def_model_simple.def
new file mode 100644
index 0000000000..3444732b63
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_model_simple.def
@@ -0,0 +1,807 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "68"
+ "pos_x" "-358.589020"
+ "pos_y" "440.458923"
+ "size_x" "106.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "36"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "1"
+ }
+ "Node_001"
+ {
+ "iType" "19"
+ "pos_x" "-105.454910"
+ "pos_y" "486.487061"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_002"
+ {
+ "iType" "14"
+ "pos_x" "-250.440155"
+ "pos_y" "516.961548"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_003"
+ {
+ "iType" "32"
+ "pos_x" "180.499054"
+ "pos_y" "525.032959"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "33"
+ "pos_x" "211.875641"
+ "pos_y" "332.860168"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "75"
+ "pos_x" "78.550774"
+ "pos_y" "323.654175"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "103.037239"
+ "pos_y" "255.469284"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "5"
+ "szName" "FL_proj_pos"
+ "pos_x" "73.762772"
+ "pos_y" "526.378784"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_008"
+ {
+ "iType" "20"
+ "pos_x" "111.173798"
+ "pos_y" "-65.359604"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "33"
+ "pos_x" "367.563507"
+ "pos_y" "-90.323036"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "szName" "Diffuse"
+ "pos_x" "-254.613297"
+ "pos_y" "172.946304"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_011"
+ {
+ "iType" "33"
+ "szName" "Diffuse_component"
+ "pos_x" "-163.760132"
+ "pos_y" "-256.532654"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "70"
+ "pos_x" "403.806580"
+ "pos_y" "-442.488403"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_013"
+ {
+ "iType" "72"
+ "pos_x" "452.659241"
+ "pos_y" "-685.794800"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_014"
+ {
+ "iType" "3"
+ "pos_x" "-780.725281"
+ "pos_y" "-338.638977"
+ "size_x" "55.000000"
+ "size_y" "-72.000000"
+ "iPreview" "0"
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WPos"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WNormal"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "Proj pos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "FL proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "VAttn"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "VLight"
+ }
+ "Node_015"
+ {
+ "iType" "76"
+ "pos_x" "227.819275"
+ "pos_y" "42.628021"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "4"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_016"
+ {
+ "iType" "32"
+ "pos_x" "-164.085693"
+ "pos_y" "173.221390"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "27"
+ "pos_x" "-30.370899"
+ "pos_y" "43.983246"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "-29.578266"
+ "pos_y" "-63.381824"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_019"
+ {
+ "iType" "71"
+ "pos_x" "427.059143"
+ "pos_y" "-532.128906"
+ "size_x" "170.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "29"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "0.830316"
+ "pos_y" "281.186646"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "92.836716"
+ "container_extents_y" "242.092712"
+ "container_extents_z" "-92.836716"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_021"
+ {
+ "iType" "4"
+ "pos_x" "670.140625"
+ "pos_y" "-674.985779"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_022"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-581.447205"
+ "pos_y" "-37.021721"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "136.993286"
+ "container_extents_y" "362.855988"
+ "container_extents_z" "-136.993286"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_023"
+ {
+ "iType" "33"
+ "pos_x" "-276.003357"
+ "pos_y" "23.152893"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "66"
+ "pos_x" "-142.517090"
+ "pos_y" "352.053162"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vlight_static" "0"
+ "i_vlight_hl" "0"
+ }
+ "Node_025"
+ {
+ "iType" "67"
+ "pos_x" "-467.593597"
+ "pos_y" "1.790497"
+ "size_x" "156.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_plight_static" "0"
+ "i_plight_ao" "0"
+ "i_plight_hl" "0"
+ }
+ "Node_026"
+ {
+ "iType" "26"
+ "pos_x" "-141.314819"
+ "pos_y" "-619.008423"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "19"
+ "pos_x" "-287.896240"
+ "pos_y" "-545.651184"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_028"
+ {
+ "iType" "29"
+ "szName" "Albedo"
+ "pos_x" "-525.442932"
+ "pos_y" "-572.312988"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "Models\Combine_soldier\combinesoldiersheet_prisonguard"
+ "iFallbackMode" "0"
+ }
+ "Node_029"
+ {
+ "iType" "27"
+ "pos_x" "240.059113"
+ "pos_y" "-510.583191"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_030"
+ {
+ "iType" "7"
+ "pos_x" "98.827866"
+ "pos_y" "-435.766724"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_031"
+ {
+ "iType" "2"
+ "pos_x" "392.240631"
+ "pos_y" "424.522766"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "4"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WPos"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WNormal"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "Proj pos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "FL proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "VAttn"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "VLight"
+ }
+ "Node_032"
+ {
+ "iType" "27"
+ "pos_x" "239.658447"
+ "pos_y" "-557.094055"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_033"
+ {
+ "iType" "27"
+ "pos_x" "238.527435"
+ "pos_y" "-467.388367"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_034"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-143.523071"
+ "pos_y" "-37.679588"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "138.463028"
+ "container_extents_y" "602.023865"
+ "container_extents_z" "-138.463028"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_035"
+ {
+ "iType" "1"
+ "pos_x" "-582.842224"
+ "pos_y" "370.547455"
+ "size_x" "55.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_036"
+ {
+ "iType" "101"
+ "pos_x" "-462.217804"
+ "pos_y" "302.954376"
+ "size_x" "95.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "35"
+ "iTarget_jack" "3"
+ }
+ }
+ "iCompMode" "0"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_model_simple_swarm.def b/mp/game/momentum/shadereditorui/canvas_default/def_model_simple_swarm.def
new file mode 100644
index 0000000000..8b320f446d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_model_simple_swarm.def
@@ -0,0 +1,767 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "flowgraph_type" "1"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "1"
+ "depth_write" "1"
+ "srgb_write" "1"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "68"
+ "pos_x" "-358.589020"
+ "pos_y" "440.458923"
+ "size_x" "106.000000"
+ "size_y" "-50.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "2"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "1"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "33"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vskinning_mode" "1"
+ }
+ "Node_001"
+ {
+ "iType" "19"
+ "pos_x" "-105.454910"
+ "pos_y" "486.487061"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_002"
+ {
+ "iType" "14"
+ "pos_x" "-250.440155"
+ "pos_y" "516.961548"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_003"
+ {
+ "iType" "32"
+ "pos_x" "180.499054"
+ "pos_y" "525.032959"
+ "size_x" "50.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "7"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_004"
+ {
+ "iType" "33"
+ "pos_x" "211.875641"
+ "pos_y" "332.860168"
+ "size_x" "50.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "3"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "6"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_005"
+ {
+ "iType" "75"
+ "pos_x" "78.550774"
+ "pos_y" "323.654175"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ }
+ "Node_006"
+ {
+ "iType" "19"
+ "pos_x" "103.037239"
+ "pos_y" "255.469284"
+ "size_x" "80.000000"
+ "size_y" "-28.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_007"
+ {
+ "iType" "5"
+ "szName" "FL_proj_pos"
+ "pos_x" "73.762772"
+ "pos_y" "526.378784"
+ "size_x" "50.000000"
+ "size_y" "-48.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0 0"
+ }
+ "Node_008"
+ {
+ "iType" "20"
+ "pos_x" "111.173798"
+ "pos_y" "-65.359604"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "17"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "18"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_009"
+ {
+ "iType" "33"
+ "pos_x" "367.563507"
+ "pos_y" "-90.323036"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "15"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_010"
+ {
+ "iType" "5"
+ "szName" "Diffuse"
+ "pos_x" "-254.613297"
+ "pos_y" "172.946304"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "szConstantString" "0 0 0"
+ }
+ "Node_011"
+ {
+ "iType" "33"
+ "szName" "Diffuse_component"
+ "pos_x" "-163.760132"
+ "pos_y" "-256.532654"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "9"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "23"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_012"
+ {
+ "iType" "70"
+ "pos_x" "403.806580"
+ "pos_y" "-442.488403"
+ "size_x" "71.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_013"
+ {
+ "iType" "72"
+ "pos_x" "452.659241"
+ "pos_y" "-685.794800"
+ "size_x" "130.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "26"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "19"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "30"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_final_tonemap" "1"
+ "i_final_wdepth" "1"
+ }
+ "Node_014"
+ {
+ "iType" "3"
+ "pos_x" "-780.725281"
+ "pos_y" "-338.638977"
+ "size_x" "55.000000"
+ "size_y" "-72.000000"
+ "iPreview" "0"
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WPos"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WNormal"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "Proj pos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "FL proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "VAttn"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "VLight"
+ }
+ "Node_015"
+ {
+ "iType" "76"
+ "pos_x" "227.819275"
+ "pos_y" "42.628021"
+ "size_x" "163.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "4"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "8"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_flashlight_Spec" "0"
+ }
+ "Node_016"
+ {
+ "iType" "32"
+ "pos_x" "-164.085693"
+ "pos_y" "173.221390"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "10"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_017"
+ {
+ "iType" "27"
+ "pos_x" "-30.370899"
+ "pos_y" "43.983246"
+ "size_x" "107.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "xy"
+ }
+ "Node_018"
+ {
+ "iType" "27"
+ "pos_x" "-29.578266"
+ "pos_y" "-63.381824"
+ "size_x" "105.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "w"
+ }
+ "Node_019"
+ {
+ "iType" "71"
+ "pos_x" "427.059143"
+ "pos_y" "-532.128906"
+ "size_x" "169.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "12"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "28"
+ "iTarget_jack" "0"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ }
+ }
+ "Node_020"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "0.830316"
+ "pos_y" "281.186646"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "92.836716"
+ "container_extents_y" "242.092712"
+ "container_extents_z" "-92.836716"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_021"
+ {
+ "iType" "4"
+ "pos_x" "670.140625"
+ "pos_y" "-674.985779"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "13"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_022"
+ {
+ "iType" "31"
+ "szName" "Off"
+ "pos_x" "-581.447205"
+ "pos_y" "-37.021721"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "136.993286"
+ "container_extents_y" "362.855988"
+ "container_extents_z" "-136.993286"
+ "i_combo_condition" "4"
+ "i_combo_value" "0"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_023"
+ {
+ "iType" "33"
+ "pos_x" "-276.003357"
+ "pos_y" "23.152893"
+ "size_x" "50.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "16"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "25"
+ "iTarget_jack" "0"
+ }
+ }
+ }
+ "Node_024"
+ {
+ "iType" "66"
+ "pos_x" "-142.517090"
+ "pos_y" "352.053162"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_vlight_static" "0"
+ "i_vlight_hl" "0"
+ }
+ "Node_025"
+ {
+ "iType" "67"
+ "pos_x" "-467.593597"
+ "pos_y" "1.790497"
+ "size_x" "156.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "2"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "5"
+ }
+ }
+ "i_plight_static" "0"
+ "i_plight_ao" "0"
+ "i_plight_hl" "0"
+ }
+ "Node_026"
+ {
+ "iType" "26"
+ "pos_x" "-141.314819"
+ "pos_y" "-619.008423"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "27"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "5"
+ }
+ }
+ }
+ "Node_027"
+ {
+ "iType" "19"
+ "pos_x" "-287.896240"
+ "pos_y" "-545.651184"
+ "size_x" "91.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "34"
+ "iTarget_jack" "1"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "11"
+ "iTarget_jack" "0"
+ }
+ }
+ "i_mat_rotation" "0"
+ }
+ "Node_028"
+ {
+ "iType" "7"
+ "pos_x" "98.827866"
+ "pos_y" "-435.766724"
+ "size_x" "69.000000"
+ "size_y" "-50.000000"
+ "iPreview" "1"
+ "flSmartVal0" "0.000000"
+ }
+ "Node_029"
+ {
+ "iType" "2"
+ "pos_x" "392.240631"
+ "pos_y" "424.522766"
+ "size_x" "55.000000"
+ "size_y" "-83.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "4"
+ }
+ "jackIn_02"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ "jackIn_03"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ "jackIn_04"
+ {
+ "iTarget_node" "1"
+ "iTarget_jack" "0"
+ }
+ "jackIn_05"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ "jackIn_06"
+ {
+ "iTarget_node" "24"
+ "iTarget_jack" "0"
+ }
+ }
+ "numTexcoords" "5"
+ "numColor" "1"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Name_0" "UV"
+ "numTexcoord_Flag_1" "4"
+ "numTexcoord_Name_1" "WPos"
+ "numTexcoord_Flag_2" "4"
+ "numTexcoord_Name_2" "WNormal"
+ "numTexcoord_Flag_3" "8"
+ "numTexcoord_Name_3" "Proj pos"
+ "numTexcoord_Flag_4" "8"
+ "numTexcoord_Name_4" "FL proj pos"
+ "numTexcoord_Flag_5" "1"
+ "numTexcoord_Flag_6" "1"
+ "numTexcoord_Flag_7" "1"
+ "numColor_Flag_0" "8"
+ "numColor_Name_0" "VAttn"
+ "numColor_Flag_1" "4"
+ "numColor_Name_1" "VLight"
+ }
+ "Node_030"
+ {
+ "iType" "27"
+ "pos_x" "239.658447"
+ "pos_y" "-557.094055"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "3"
+ }
+ }
+ "swizzleString" "z"
+ }
+ "Node_031"
+ {
+ "iType" "31"
+ "szName" "On"
+ "pos_x" "-143.523071"
+ "pos_y" "-37.679588"
+ "size_x" "50.000000"
+ "size_y" "-30.000000"
+ "iPreview" "0"
+ "container_extents_x" "138.463028"
+ "container_extents_y" "602.023865"
+ "container_extents_z" "-138.463028"
+ "i_combo_condition" "4"
+ "i_combo_value" "1"
+ "i_combo_static" "1"
+ "sz_cname" "FLASHLIGHT"
+ }
+ "Node_032"
+ {
+ "iType" "1"
+ "pos_x" "-582.842224"
+ "pos_y" "370.547455"
+ "size_x" "55.000000"
+ "size_y" "-61.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "1"
+ "enable_normal_compression" "1"
+ "enable_blendweights" "1"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_033"
+ {
+ "iType" "101"
+ "pos_x" "-462.217804"
+ "pos_y" "302.954376"
+ "size_x" "95.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "32"
+ "iTarget_jack" "3"
+ }
+ }
+ "iCompMode" "0"
+ }
+ "Node_034"
+ {
+ "iType" "29"
+ "szName" "Albedo"
+ "pos_x" "-525.442932"
+ "pos_y" "-572.312988"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "14"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "1"
+ "iTextureType" "1"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "texture_samples\ice_0"
+ "szFallbackTexturePath" "texture_samples\ice_0"
+ "iFallbackMode" "4"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/canvas_default/def_pp.def b/mp/game/momentum/shadereditorui/canvas_default/def_pp.def
new file mode 100644
index 0000000000..86396d63c8
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/canvas_default/def_pp.def
@@ -0,0 +1,153 @@
+"canvas"
+{
+ "cfmt_version" "canvasver#003"
+ "config"
+ {
+ "shadermodel" "1"
+ "cull_mode" "0"
+ "alpha_blending" "0"
+ "depth_test" "0"
+ "depth_write" "0"
+ "srgb_write" "0"
+ }
+ "Nodes"
+ {
+ "Node_000"
+ {
+ "iType" "1"
+ "pos_x" "-320.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "enable_flex" "0"
+ "enable_normal" "0"
+ "enable_blendweights" "0"
+ "enable_tangentspace" "0"
+ "enable_tangentspace_skinning" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "dTFlag_Texcoords_0" "2"
+ "dTFlag_Texcoords_1" "2"
+ "dTFlag_Texcoords_2" "2"
+ "dTFlag_Color_0" "8"
+ "dTFlag_Color_1" "8"
+ }
+ "Node_001"
+ {
+ "iType" "2"
+ "pos_x" "265.000000"
+ "pos_y" "190.000000"
+ "size_x" "55.000000"
+ "size_y" "-28.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "5"
+ "iTarget_jack" "0"
+ }
+ "jackIn_01"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "1"
+ }
+ }
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_002"
+ {
+ "iType" "3"
+ "pos_x" "-320.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "numTexcoords" "1"
+ "numColor" "0"
+ "numTexcoord_Flag_0" "2"
+ "numTexcoord_Flag_1" "2"
+ "numTexcoord_Flag_2" "2"
+ "numTexcoord_Flag_3" "2"
+ "numTexcoord_Flag_4" "2"
+ "numTexcoord_Flag_5" "2"
+ "numTexcoord_Flag_6" "2"
+ "numTexcoord_Flag_7" "2"
+ "numColor_Flag_0" "8"
+ "numColor_Flag_1" "8"
+ }
+ "Node_003"
+ {
+ "iType" "4"
+ "pos_x" "265.000000"
+ "pos_y" "-130.000000"
+ "size_x" "55.000000"
+ "size_y" "-17.000000"
+ "iPreview" "0"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "4"
+ "iTarget_jack" "0"
+ }
+ }
+ "numColors" "1"
+ "enable_Depth" "0"
+ }
+ "Node_004"
+ {
+ "iType" "29"
+ "szName" "Framebuffer"
+ "pos_x" "-61.199528"
+ "pos_y" "-100.750534"
+ "size_x" "122.000000"
+ "size_y" "-80.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "2"
+ "iTarget_jack" "0"
+ }
+ }
+ "iSRGB" "0"
+ "iTextureType" "5"
+ "IsCubemap" "0"
+ "iLookupoverride" "0"
+ "szDemoTexturePath" "_rt_FullFrameFB"
+ "iFallbackMode" "0"
+ }
+ "Node_005"
+ {
+ "iType" "27"
+ "pos_x" "-44.526688"
+ "pos_y" "206.208878"
+ "size_x" "80.000000"
+ "size_y" "-17.000000"
+ "iPreview" "1"
+ "bridges"
+ {
+ "jackIn_00"
+ {
+ "iTarget_node" "0"
+ "iTarget_jack" "0"
+ }
+ }
+ "swizzleString" "x y z 1"
+ }
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/basetexture_accum.dump b/mp/game/momentum/shadereditorui/dumps/basetexture_accum.dump
new file mode 100644
index 0000000000..f41ad0bcc2
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/basetexture_accum.dump
@@ -0,0 +1,47 @@
+"basetexture_accum"
+{
+ "vs_name" "basetexture_accum_vs30"
+ "ps_name" "basetexture_accum_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\basetexture_accum.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "sz_param" "Basetexture2"
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "1"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/basetexture_blend.dump b/mp/game/momentum/shadereditorui/dumps/basetexture_blend.dump
new file mode 100644
index 0000000000..31b013ad3d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/basetexture_blend.dump
@@ -0,0 +1,47 @@
+"basetexture_blend"
+{
+ "vs_name" "basetexture_blend_vs30"
+ "ps_name" "basetexture_blend_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\basetexture_blend.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "sz_param" "Basetexture2"
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "1"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/detail_prop_shader.dump b/mp/game/momentum/shadereditorui/dumps/detail_prop_shader.dump
new file mode 100644
index 0000000000..45c07de291
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/detail_prop_shader.dump
@@ -0,0 +1,209 @@
+"detail_prop_shader"
+{
+ "vs_name" "detail_prop_shader_vs30"
+ "ps_name" "detail_prop_shader_ps30"
+ "shader_filename" "shadereditorui\canvas\detail_prop_shader.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "2"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "1"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "28573959"
+ "i_vfmt_texcoords" "3"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "3"
+ "i_vfmt_texcoordDim_2" "3"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "combo_0"
+ {
+ "sz_name" "FLASHLIGHT"
+ "i_static" "1"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "9"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "16"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "2"
+ "sz_smartname" "Mutable_01"
+ "fl_smartdefault_00" "1.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_1"
+ {
+ "i_envconstidx" "16"
+ "i_normregister" "1"
+ "i_econstsize" "1"
+ "i_smartcomps" "0"
+ "sz_smartname" "Mutable_02"
+ "fl_smartdefault_00" "3.926991"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_2"
+ {
+ "i_envconstidx" "0"
+ "i_normregister" "2"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_3"
+ {
+ "i_envconstidx" "11"
+ "i_normregister" "3"
+ "i_econstsize" "4"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "combo_0"
+ {
+ "sz_name" "FLASHLIGHT"
+ "i_static" "1"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "9"
+ }
+ "combo_1"
+ {
+ "sz_name" "FLASHLIGHTDEPTHFILTERMODE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "2"
+ "i_type" "10"
+ }
+ "combo_2"
+ {
+ "sz_name" "FLASHLIGHTSHADOWS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "11"
+ }
+ "combo_3"
+ {
+ "sz_name" "PIXELFOGTYPE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "7"
+ }
+ "combo_4"
+ {
+ "sz_name" "WRITEWATERFOGTODESTALPHA"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "8"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "15"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "2"
+ "sz_smartname" "grass_spec_color"
+ "fl_smartdefault_00" "0.905750"
+ "fl_smartdefault_01" "1.000000"
+ "fl_smartdefault_02" "0.675000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_1"
+ {
+ "i_envconstidx" "2"
+ "i_normregister" "1"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_2"
+ {
+ "i_envconstidx" "7"
+ "i_normregister" "2"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_3"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "3"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_4"
+ {
+ "i_envconstidx" "12"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "detail\grass_sprites"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "i_sampidx" "1"
+ "i_texmode" "10"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_2"
+ {
+ "i_sampidx" "2"
+ "i_texmode" "11"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_3"
+ {
+ "i_sampidx" "3"
+ "i_texmode" "12"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "24"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/downsample_4.dump b/mp/game/momentum/shadereditorui/dumps/downsample_4.dump
new file mode 100644
index 0000000000..e15ef38f42
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/downsample_4.dump
@@ -0,0 +1,49 @@
+"downsample_4"
+{
+ "vs_name" "downsample_4_vs30"
+ "ps_name" "downsample_4_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\downsample_4.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_FullFrameFB"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/gauss_blur_5_x.dump b/mp/game/momentum/shadereditorui/dumps/gauss_blur_5_x.dump
new file mode 100644
index 0000000000..b5f89a7bb5
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/gauss_blur_5_x.dump
@@ -0,0 +1,49 @@
+"gauss_blur_5_x"
+{
+ "vs_name" "gauss_blur_5_x_vs30"
+ "ps_name" "gauss_blur_5_x_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\gauss_blur_5_x.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "4.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/gauss_blur_5_y.dump b/mp/game/momentum/shadereditorui/dumps/gauss_blur_5_y.dump
new file mode 100644
index 0000000000..d57cec0d32
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/gauss_blur_5_y.dump
@@ -0,0 +1,49 @@
+"gauss_blur_5_y"
+{
+ "vs_name" "gauss_blur_5_y_vs30"
+ "ps_name" "gauss_blur_5_y_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\gauss_blur_5_y.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "4.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/gauss_blur_7_half_aceil_x.dump b/mp/game/momentum/shadereditorui/dumps/gauss_blur_7_half_aceil_x.dump
new file mode 100644
index 0000000000..b240a393e5
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/gauss_blur_7_half_aceil_x.dump
@@ -0,0 +1,49 @@
+"gauss_blur_7_half_aceil_x"
+{
+ "vs_name" "gauss_blur_7_half_aceil_x_vs30"
+ "ps_name" "gauss_blur_7_half_aceil_x_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\gauss_blur_7_half_aceil_x.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "2.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/gauss_blur_7_half_aceil_y.dump b/mp/game/momentum/shadereditorui/dumps/gauss_blur_7_half_aceil_y.dump
new file mode 100644
index 0000000000..baab0a83bf
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/gauss_blur_7_half_aceil_y.dump
@@ -0,0 +1,49 @@
+"gauss_blur_7_half_aceil_y"
+{
+ "vs_name" "gauss_blur_7_half_aceil_y_vs30"
+ "ps_name" "gauss_blur_7_half_aceil_y_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\gauss_blur_7_half_aceil_y.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "2.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/gauss_blur_half_3_x.dump b/mp/game/momentum/shadereditorui/dumps/gauss_blur_half_3_x.dump
new file mode 100644
index 0000000000..cae7d93a37
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/gauss_blur_half_3_x.dump
@@ -0,0 +1,49 @@
+"gauss_blur_half_3_x"
+{
+ "vs_name" "gauss_blur_half_3_x_vs30"
+ "ps_name" "gauss_blur_half_3_x_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\gauss_blur_half_3_x.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "2.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/gauss_blur_half_3_y.dump b/mp/game/momentum/shadereditorui/dumps/gauss_blur_half_3_y.dump
new file mode 100644
index 0000000000..2a65461438
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/gauss_blur_half_3_y.dump
@@ -0,0 +1,49 @@
+"gauss_blur_half_3_y"
+{
+ "vs_name" "gauss_blur_half_3_y_vs30"
+ "ps_name" "gauss_blur_half_3_y_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\gauss_blur_half_3_y.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "2.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/lightmap_blend_bump_detail.dump b/mp/game/momentum/shadereditorui/dumps/lightmap_blend_bump_detail.dump
new file mode 100644
index 0000000000..85890e64e6
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/lightmap_blend_bump_detail.dump
@@ -0,0 +1,255 @@
+"lightmap_blend_bump_detail"
+{
+ "vs_name" "lightmap_blend_bump_detail_vs30"
+ "ps_name" "lightmap_blend_bump_detail_ps30"
+ "shader_filename" "shadereditorui\canvas\lightmap_blend_bump_detail.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "1"
+ "i_srgbw" "1"
+ "i_vfmt_flags" "19136823"
+ "i_vfmt_texcoords" "3"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "combo_0"
+ {
+ "sz_name" "PIXELFOGTYPE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "7"
+ }
+ "combo_1"
+ {
+ "sz_name" "FLASHLIGHT"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "9"
+ }
+ "combo_2"
+ {
+ "sz_name" "FLASHLIGHTDEPTHFILTERMODE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "2"
+ "i_type" "10"
+ }
+ "combo_3"
+ {
+ "sz_name" "FLASHLIGHTSHADOWS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "11"
+ }
+ "combo_4"
+ {
+ "sz_name" "WRITEWATERFOGTODESTALPHA"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "8"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "11"
+ "i_normregister" "-1"
+ "i_econstsize" "4"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_1"
+ {
+ "i_envconstidx" "15"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "sz_smartname" "base_detail_0_smoothing"
+ "fl_smartdefault_00" "-0.500000"
+ "fl_smartdefault_01" "0.700000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_2"
+ {
+ "i_envconstidx" "15"
+ "i_normregister" "1"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "sz_smartname" "base_detail_1_smoothing"
+ "fl_smartdefault_00" "0.100000"
+ "fl_smartdefault_01" "0.300000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_3"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "2"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_4"
+ {
+ "i_envconstidx" "7"
+ "i_normregister" "3"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_5"
+ {
+ "i_envconstidx" "12"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "nature\sandfloor009a_normal"
+ "i_sampidx" "0"
+ "i_texmode" "2"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "sz_param" "bump_detail_0"
+ "sz_fallback" "nature\dirtfloor011a_normal"
+ "i_sampidx" "1"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_2"
+ {
+ "sz_param" "bumpmap2"
+ "sz_fallback" "nature\cavewall005a_normal"
+ "i_sampidx" "2"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_3"
+ {
+ "sz_param" "bump_detail_1"
+ "sz_fallback" "texture_samples\normal_2"
+ "i_sampidx" "3"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_4"
+ {
+ "sz_param" "blendnoise"
+ "sz_fallback" "texture_samples\fx_clouds_4"
+ "i_sampidx" "4"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_5"
+ {
+ "sz_param" "base_0"
+ "sz_fallback" "nature\sandfloor009a"
+ "i_sampidx" "5"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_6"
+ {
+ "sz_param" "base_detail_0"
+ "sz_fallback" "detail\noise_detail_01"
+ "i_sampidx" "6"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_7"
+ {
+ "sz_param" "basetexture2"
+ "sz_fallback" "nature\cavewall005a"
+ "i_sampidx" "7"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_8"
+ {
+ "sz_param" "base_detail_1"
+ "sz_fallback" "overlays\macro01a"
+ "i_sampidx" "8"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_9"
+ {
+ "sz_fallback" "Lights\White"
+ "i_sampidx" "9"
+ "i_texmode" "4"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_10"
+ {
+ "sz_fallback" "texture_samples\cubemap_uffizi"
+ "i_sampidx" "10"
+ "i_texmode" "6"
+ "i_cubemap" "1"
+ "i_srgb" "0"
+ }
+ "texsamp_11"
+ {
+ "i_sampidx" "11"
+ "i_texmode" "10"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_12"
+ {
+ "i_sampidx" "12"
+ "i_texmode" "11"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_13"
+ {
+ "i_sampidx" "13"
+ "i_texmode" "12"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "48"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/lightmap_parallax.dump b/mp/game/momentum/shadereditorui/dumps/lightmap_parallax.dump
new file mode 100644
index 0000000000..bb2cda233d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/lightmap_parallax.dump
@@ -0,0 +1,205 @@
+"lightmap_parallax"
+{
+ "vs_name" "lightmap_parallax_vs30"
+ "ps_name" "lightmap_parallax_ps30"
+ "shader_filename" "shadereditorui\canvas\lightmap_parallax.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "1"
+ "i_srgbw" "1"
+ "i_vfmt_flags" "19136819"
+ "i_vfmt_texcoords" "3"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "15"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "0"
+ "sz_smartname" "parallax_geo_height"
+ "fl_smartdefault_00" "20.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "combo_0"
+ {
+ "sz_name" "FLASHLIGHT"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "9"
+ }
+ "combo_1"
+ {
+ "sz_name" "FLASHLIGHTSHADOWS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "11"
+ }
+ "combo_2"
+ {
+ "sz_name" "FLASHLIGHTDEPTHFILTERMODE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "2"
+ "i_type" "10"
+ }
+ "combo_3"
+ {
+ "sz_name" "PIXELFOGTYPE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "7"
+ }
+ "combo_4"
+ {
+ "sz_name" "WRITEWATERFOGTODESTALPHA"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "8"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_1"
+ {
+ "i_envconstidx" "15"
+ "i_normregister" "1"
+ "i_econstsize" "1"
+ "i_smartcomps" "0"
+ "sz_smartname" "parallax_geo_height"
+ "fl_smartdefault_00" "20.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_2"
+ {
+ "i_envconstidx" "11"
+ "i_normregister" "-1"
+ "i_econstsize" "4"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_3"
+ {
+ "i_envconstidx" "13"
+ "i_normregister" "2"
+ "i_econstsize" "4"
+ "i_smartcomps" "2"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_4"
+ {
+ "i_envconstidx" "12"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_5"
+ {
+ "i_envconstidx" "7"
+ "i_normregister" "6"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_param" "heightmap"
+ "sz_fallback" "Lights\White"
+ "i_sampidx" "0"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "sz_param" "bm"
+ "sz_fallback" "dev\flat_normal"
+ "i_sampidx" "1"
+ "i_texmode" "2"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_2"
+ {
+ "sz_param" "albedo"
+ "sz_fallback" "Dev\bump"
+ "i_sampidx" "2"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_3"
+ {
+ "sz_fallback" "Lights\White"
+ "i_sampidx" "3"
+ "i_texmode" "4"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_4"
+ {
+ "i_sampidx" "4"
+ "i_texmode" "10"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_5"
+ {
+ "i_sampidx" "5"
+ "i_texmode" "11"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_6"
+ {
+ "i_sampidx" "6"
+ "i_texmode" "12"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "48"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/model_chromatic_aberration.dump b/mp/game/momentum/shadereditorui/dumps/model_chromatic_aberration.dump
new file mode 100644
index 0000000000..c90e7e1e41
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/model_chromatic_aberration.dump
@@ -0,0 +1,90 @@
+"model_chromatic_aberration"
+{
+ "vs_name" "model_chromatic_aberration_vs30"
+ "ps_name" "model_chromatic_aberration_ps30"
+ "shader_filename" "shadereditorui\canvas\model_chromatic_aberration.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "1"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "335235"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "4"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "1"
+ "identifiers_VS"
+ {
+ "combo_0"
+ {
+ "sz_name" "COMPRESSED_VERTS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "12"
+ }
+ "combo_1"
+ {
+ "sz_name" "SKINNING"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "2"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "i_numdcombos" "4"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "13"
+ "i_normregister" "0"
+ "i_econstsize" "4"
+ "i_smartcomps" "2"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "dev\flat_normal"
+ "i_sampidx" "0"
+ "i_texmode" "2"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "i_sampidx" "1"
+ "i_texmode" "6"
+ "i_cubemap" "1"
+ "i_srgb" "0"
+ }
+ "texsamp_2"
+ {
+ "i_sampidx" "2"
+ "i_texmode" "5"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/model_cubemap.dump b/mp/game/momentum/shadereditorui/dumps/model_cubemap.dump
new file mode 100644
index 0000000000..1c8d9ab911
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/model_cubemap.dump
@@ -0,0 +1,81 @@
+"model_cubemap"
+{
+ "vs_name" "model_cubemap_vs30"
+ "ps_name" "model_cubemap_ps30"
+ "shader_filename" "shadereditorui\canvas\model_cubemap.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "1"
+ "i_srgbw" "1"
+ "i_vfmt_flags" "7555"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "combo_0"
+ {
+ "sz_name" "COMPRESSED_VERTS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "12"
+ }
+ "combo_1"
+ {
+ "sz_name" "SKINNING"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "2"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "i_numdcombos" "4"
+ }
+ "identifiers_PS"
+ {
+ "combo_0"
+ {
+ "sz_name" "PIXELFOGTYPE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "7"
+ }
+ "combo_1"
+ {
+ "sz_name" "WRITEWATERFOGTODESTALPHA"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "8"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "white"
+ "i_sampidx" "0"
+ "i_texmode" "6"
+ "i_cubemap" "1"
+ "i_srgb" "1"
+ }
+ "i_numdcombos" "4"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/model_snowy.dump b/mp/game/momentum/shadereditorui/dumps/model_snowy.dump
new file mode 100644
index 0000000000..0a082a7912
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/model_snowy.dump
@@ -0,0 +1,286 @@
+"model_snowy"
+{
+ "vs_name" "model_snowy_vs30"
+ "ps_name" "model_snowy_ps30"
+ "shader_filename" "shadereditorui\canvas\model_snowy.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "1"
+ "i_srgbw" "1"
+ "i_vfmt_flags" "335235"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "4"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "1"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "combo_0"
+ {
+ "sz_name" "COMPRESSED_VERTS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "12"
+ }
+ "combo_1"
+ {
+ "sz_name" "MORPHING"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "3"
+ }
+ "combo_2"
+ {
+ "sz_name" "SKINNING"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "2"
+ }
+ "combo_3"
+ {
+ "sz_name" "FLASHLIGHT"
+ "i_static" "1"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "9"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_1"
+ {
+ "i_envconstidx" "11"
+ "i_normregister" "1"
+ "i_econstsize" "4"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_2"
+ {
+ "i_envconstidx" "10"
+ "i_normregister" "-1"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_3"
+ {
+ "i_envconstidx" "8"
+ "i_normregister" "-1"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "i_sampidx" "0"
+ "i_texmode" "13"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "8"
+ }
+ "identifiers_PS"
+ {
+ "combo_0"
+ {
+ "sz_name" "PIXELFOGTYPE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "7"
+ }
+ "combo_1"
+ {
+ "sz_name" "FLASHLIGHT"
+ "i_static" "1"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "9"
+ }
+ "combo_2"
+ {
+ "sz_name" "FLASHLIGHTDEPTHFILTERMODE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "2"
+ "i_type" "10"
+ }
+ "combo_3"
+ {
+ "sz_name" "FLASHLIGHTSHADOWS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "11"
+ }
+ "combo_4"
+ {
+ "sz_name" "NUM_LIGHTS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "4"
+ "i_type" "6"
+ }
+ "combo_5"
+ {
+ "sz_name" "WRITEWATERFOGTODESTALPHA"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "8"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "7"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_1"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "1"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_2"
+ {
+ "i_envconstidx" "12"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_3"
+ {
+ "i_envconstidx" "9"
+ "i_normregister" "-1"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "dev\flat_normal"
+ "i_sampidx" "0"
+ "i_texmode" "2"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "sz_param" "phongexp"
+ "sz_fallback" "Lights\White"
+ "i_sampidx" "1"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_2"
+ {
+ "sz_fallback" "grey"
+ "i_sampidx" "2"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_3"
+ {
+ "sz_param" "snow_normal"
+ "sz_fallback" "texture_samples\fx_clouds_0_normal"
+ "i_sampidx" "3"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_4"
+ {
+ "sz_param" "snow"
+ "sz_fallback" "texture_samples\ice_2"
+ "i_sampidx" "4"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_5"
+ {
+ "sz_param" "noise"
+ "sz_fallback" "texture_samples\noise_3d"
+ "i_sampidx" "5"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_6"
+ {
+ "i_sampidx" "6"
+ "i_texmode" "10"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_7"
+ {
+ "i_sampidx" "7"
+ "i_texmode" "11"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_8"
+ {
+ "i_sampidx" "8"
+ "i_texmode" "12"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_9"
+ {
+ "sz_fallback" "cable\black"
+ "i_sampidx" "9"
+ "i_texmode" "6"
+ "i_cubemap" "1"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "120"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/shaderlist.txt b/mp/game/momentum/shadereditorui/dumps/shaderlist.txt
new file mode 100644
index 0000000000..1152515a52
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/shaderlist.txt
@@ -0,0 +1,22 @@
+"shaderlist"
+{
+ "shader_000" "basetexture_accum"
+ "shader_001" "basetexture_blend"
+ "shader_002" "detail_prop_shader"
+ "shader_003" "downsample_4"
+ "shader_004" "gauss_blur_5_x"
+ "shader_005" "gauss_blur_5_y"
+ "shader_006" "gauss_blur_7_half_aceil_x"
+ "shader_007" "gauss_blur_7_half_aceil_y"
+ "shader_008" "gauss_blur_half_3_x"
+ "shader_009" "gauss_blur_half_3_y"
+ "shader_010" "lightmap_blend_bump_detail"
+ "shader_011" "lightmap_parallax"
+ "shader_012" "model_chromatic_aberration"
+ "shader_013" "model_snowy"
+ "shader_014" "sprite_sun_nodepth"
+ "shader_015" "ssao_calc"
+ "shader_016" "ssao_combine"
+ "shader_017" "ssao_fxaa"
+ "shader_018" "sunrays_calc"
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/sprite_sun_nodepth.dump b/mp/game/momentum/shadereditorui/dumps/sprite_sun_nodepth.dump
new file mode 100644
index 0000000000..1b38a8a93e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/sprite_sun_nodepth.dump
@@ -0,0 +1,54 @@
+"sprite_sun_nodepth"
+{
+ "vs_name" "sprite_sun_nodepth_vs30"
+ "ps_name" "sprite_sun_nodepth_ps30"
+ "shader_filename" "shadereditorui\canvas\sprite_sun_nodepth.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "4"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "1"
+ "i_vfmt_flags" "262405"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "combo_0"
+ {
+ "sz_name" "PIXELFOGTYPE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "7"
+ }
+ "combo_1"
+ {
+ "sz_name" "WRITEWATERFOGTODESTALPHA"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "8"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "white"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "i_numdcombos" "4"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/ssao_calc.dump b/mp/game/momentum/shadereditorui/dumps/ssao_calc.dump
new file mode 100644
index 0000000000..42148b7e7a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/ssao_calc.dump
@@ -0,0 +1,49 @@
+"ssao_calc"
+{
+ "vs_name" "ssao_calc_vs30"
+ "ps_name" "ssao_calc_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\ssao_calc.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "1"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "2.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "white"
+ "i_sampidx" "0"
+ "i_texmode" "5"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/ssao_combine.dump b/mp/game/momentum/shadereditorui/dumps/ssao_combine.dump
new file mode 100644
index 0000000000..be2aab179b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/ssao_combine.dump
@@ -0,0 +1,46 @@
+"ssao_combine"
+{
+ "vs_name" "ssao_combine_vs30"
+ "ps_name" "ssao_combine_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\ssao_combine.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "1"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "texsamp_0"
+ {
+ "i_sampidx" "0"
+ "i_texmode" "5"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "sz_param" "ssao_ref"
+ "sz_fallback" "white"
+ "i_sampidx" "1"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/ssao_fxaa.dump b/mp/game/momentum/shadereditorui/dumps/ssao_fxaa.dump
new file mode 100644
index 0000000000..f8e333906a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/ssao_fxaa.dump
@@ -0,0 +1,49 @@
+"ssao_fxaa"
+{
+ "vs_name" "ssao_fxaa_vs30"
+ "ps_name" "ssao_fxaa_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\ssao_fxaa.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "6"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "2.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_fallback" "_rt_fullframefb"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/sunrays_calc.dump b/mp/game/momentum/shadereditorui/dumps/sunrays_calc.dump
new file mode 100644
index 0000000000..6c50c7ee5b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/sunrays_calc.dump
@@ -0,0 +1,51 @@
+"sunrays_calc"
+{
+ "vs_name" "sunrays_calc_vs30"
+ "ps_name" "sunrays_calc_ps30"
+ "shader_filename" "shadereditorui\canvas\post_processing_shaders\sunrays_calc.txt"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "1"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "262401"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "econst_0"
+ {
+ "i_envconstidx" "14"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "sz_smartname" "sun_data"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_param" "skymask"
+ "sz_fallback" "_rt_SEdit_Skymask"
+ "i_sampidx" "0"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/swarm_test.dump b/mp/game/momentum/shadereditorui/dumps/swarm_test.dump
new file mode 100644
index 0000000000..6eb297697b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/swarm_test.dump
@@ -0,0 +1,42 @@
+"swarm_test"
+{
+ "vs_name" "swarm_test_vs30"
+ "ps_name" "swarm_test_ps30"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "0"
+ "i_dwrite" "0"
+ "i_srgbw" "0"
+ "i_vfmt_flags" "1"
+ "i_vfmt_texcoords" "1"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "1"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "texsamp_0"
+ {
+ "i_sampidx" "0"
+ "i_texmode" "5"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_1"
+ {
+ "i_sampidx" "1"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/dumps/unnamedshader.dump b/mp/game/momentum/shadereditorui/dumps/unnamedshader.dump
new file mode 100644
index 0000000000..70a9e332d4
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/dumps/unnamedshader.dump
@@ -0,0 +1,160 @@
+"UNNAMEDSHADER"
+{
+ "vs_name" "UNNAMEDSHADER_vs30"
+ "ps_name" "UNNAMEDSHADER_ps30"
+ "dump_version" "dumpver#001"
+ "i_sm" "1"
+ "i_cull" "0"
+ "i_ablend" "0"
+ "fl_atestref" "0.500000"
+ "i_dtest" "1"
+ "i_dwrite" "1"
+ "i_srgbw" "1"
+ "i_vfmt_flags" "2359559"
+ "i_vfmt_texcoords" "2"
+ "i_vfmt_udata" "0"
+ "i_vfmt_texcoordDim_0" "2"
+ "i_vfmt_texcoordDim_1" "2"
+ "i_vfmt_texcoordDim_2" "2"
+ "i_vlit" "0"
+ "i_vrefract" "0"
+ "identifiers_VS"
+ {
+ "i_numdcombos" "1"
+ }
+ "identifiers_PS"
+ {
+ "combo_0"
+ {
+ "sz_name" "FLASHLIGHT"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "9"
+ }
+ "combo_1"
+ {
+ "sz_name" "FLASHLIGHTDEPTHFILTERMODE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "2"
+ "i_type" "10"
+ }
+ "combo_2"
+ {
+ "sz_name" "FLASHLIGHTSHADOWS"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "11"
+ }
+ "combo_3"
+ {
+ "sz_name" "PIXELFOGTYPE"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "7"
+ }
+ "combo_4"
+ {
+ "sz_name" "WRITEWATERFOGTODESTALPHA"
+ "i_static" "0"
+ "i_min" "0"
+ "i_max" "1"
+ "i_type" "8"
+ }
+ "econst_0"
+ {
+ "i_envconstidx" "11"
+ "i_normregister" "-1"
+ "i_econstsize" "4"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_1"
+ {
+ "i_envconstidx" "7"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_2"
+ {
+ "i_envconstidx" "1"
+ "i_normregister" "1"
+ "i_econstsize" "1"
+ "i_smartcomps" "1"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "econst_3"
+ {
+ "i_envconstidx" "12"
+ "i_normregister" "0"
+ "i_econstsize" "1"
+ "i_smartcomps" "3"
+ "fl_smartdefault_00" "0.000000"
+ "fl_smartdefault_01" "0.000000"
+ "fl_smartdefault_02" "0.000000"
+ "fl_smartdefault_03" "0.000000"
+ }
+ "texsamp_0"
+ {
+ "sz_param" "basetexture2"
+ "sz_fallback" "Lights\White"
+ "i_sampidx" "0"
+ "i_texmode" "1"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_1"
+ {
+ "sz_param" "basetexture2"
+ "sz_fallback" "Lights\White"
+ "i_sampidx" "1"
+ "i_texmode" "0"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_2"
+ {
+ "sz_fallback" "Lights\White"
+ "i_sampidx" "2"
+ "i_texmode" "3"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_3"
+ {
+ "i_sampidx" "3"
+ "i_texmode" "10"
+ "i_cubemap" "0"
+ "i_srgb" "1"
+ }
+ "texsamp_4"
+ {
+ "i_sampidx" "4"
+ "i_texmode" "11"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "texsamp_5"
+ {
+ "i_sampidx" "5"
+ "i_texmode" "12"
+ "i_cubemap" "0"
+ "i_srgb" "0"
+ }
+ "i_numdcombos" "48"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/editor_config.txt b/mp/game/momentum/shadereditorui/editor_config.txt
new file mode 100644
index 0000000000..185caa2c3d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/editor_config.txt
@@ -0,0 +1,21 @@
+"config"
+{
+ "preview_visible" "1"
+ "p_x" "1134"
+ "p_y" "500"
+ "p_sx" "449"
+ "p_sy" "378"
+ "draw_datatypes" "1"
+ "draw_shadows" "1"
+ "draw_all_limits" "0"
+ "compile_preview" "1"
+ "enable_nodeview_tooltips" "1"
+ "compile_always_full" "0"
+ "compile_auto_publish_to_materials" "1"
+ "precache_auto_reload" "1"
+ "warn_unsaved_changes" "1"
+ "cedit_x" "95"
+ "cedit_y" "195"
+ "cedit_sx" "918"
+ "cedit_sy" "585"
+}
diff --git a/mp/game/momentum/shadereditorui/monof55.ttf b/mp/game/momentum/shadereditorui/monof55.ttf
new file mode 100644
index 0000000000..9aebf80094
Binary files /dev/null and b/mp/game/momentum/shadereditorui/monof55.ttf differ
diff --git a/mp/game/momentum/shadereditorui/monof_tt.txt b/mp/game/momentum/shadereditorui/monof_tt.txt
new file mode 100644
index 0000000000..b2e03adc05
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/monof_tt.txt
@@ -0,0 +1,20 @@
+------------------------------------------------------------------------
+The monofur typeface by tobias b koehler (unci@tigerden.com)
+------------------------------------------------------------------------
+
+This is a monospaced geometric rounded sans serif font based on the
+eurofurence typeface family.
+
+The character set includes Roman, Greek and Cyrillic characters as well
+as box drawing characters. File format is TrueType for PC (under
+Windows, Linux etc).
+
+These fonts are freeware and can be distributed as long as they are
+together with this text file. I would appreciate it though if you could
+contact me at unci@tigerden.com if you put them on a server. Free
+samples from commercial users are always very welcome. :)
+
+For more information, please see the uncifonts WWW page at:
+http://mercurio.iet.unipi.it/users/tobias/uncifonts.html
+
+Have fun! tobias b koehler, 2000-04-02
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/node_help.txt b/mp/game/momentum/shadereditorui/node_help.txt
new file mode 100644
index 0000000000..2357dc5d06
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/node_help.txt
@@ -0,0 +1,751 @@
+"node_help"
+{
+ "0"
+ {
+ "name" "Invalid"
+ "info" "Invalid"
+ "code" "Invalid"
+ }
+
+ "1"
+ {
+ "name" "Vertex Shader Input"
+ "info" "This node allows you to declare input semantics for your vertex shader.\n\nOutput A: By default, output A is the position of each vertex.\nOutput B: By default, output B is the texcoord0 semantic."
+ }
+
+ "2"
+ {
+ "name" "Vertex Shader Output"
+ "info" "This node allows you to declare output semantics for your vertex shader. That information is then passed to the pixel shader input.\n\nInput A: By default input A is the projected position of each vertex.\nInput B: By default, input B is the texcoord0 semantic."
+ }
+
+ "3"
+ {
+ "name" "Pixel Shader Input"
+ "info" "This node allows you to access data from the vertex shader output and other data such as vertex colors.\n\nOutput A: By default, output A is texcoords0 from the vertex shader. The other outputs are only used if you define them."
+ }
+
+ "4"
+ {
+ "name" "Pixel Shader Output"
+ "info" "This node allows you to define the fragment output for your shader. The input must be four components per RT.\n\nInput A: Color0 is the default input.\nInput B: Color1-3 and Depth are optional inputs which can be enabled in the node properties."
+ }
+
+ "5"
+ {
+ "name" "Local Constant"
+ "info" "This node allows you to declare a local vector which can be used in the vertex or pixel shader stages that can have up to 4 channels.\n\nOutput: The vector you entered into the node property window."
+ "code" "float3 X = float3(1.0,0.0,0.0), Y = float3(0.0,1.0,0.0), Z = float3(0.0,0.0,1.0)"
+ }
+
+ "6"
+ {
+ "name" "NOT_USED"
+ "info" "NOT_USED"
+ "code" "NOT_USED"
+ }
+
+ "7"
+ {
+ "name" "View Origin"
+ "info" "This node represents the origin (position) of the view.\n\nOutput: The three-component view position vector."
+ }
+
+ "8"
+ {
+ "name" "View Forward"
+ "info" "This node exposes the view forward vector in worldspace.\n\nOutput: The three-component view forward vector."
+ }
+
+ "9"
+ {
+ "name" "View Right"
+ "info" "This node exposes the view right vector in worldspace.\n\nOutput: The three-component view right vector."
+ }
+
+ "10"
+ {
+ "name" "View Up"
+ "info" "This node exposes the view up vector in worldspace.\n\nOutput: The three-component view up vector."
+ }
+
+ "11"
+ {
+ "name" "View Worldspace Depth"
+ "info" "This node holds the value of zFar.\n\nOutput: The single-component zfar vector."
+ }
+
+ "12"
+ {
+ "name" "Time"
+ "info" "This node is the current time represented as a float, it can be used as an input to various other nodes, such as sine.\n\nOutput: The single component time vector."
+ }
+
+ "13"
+ {
+ "name" "ModelViewProjection"
+ "info" "This is a matrix node used only in the vertex shader to transform vertices from model- to projectionspace.\n\nOutput: The 4x4 ModelViewProjection matrix."
+ }
+
+ "14"
+ {
+ "name" "ViewProjection"
+ "info" "This is a matrix node used only in the vertex shader to transform vertices from world- to projectionspace.\n\nOutput: The 4x4 ViewProjection matrix."
+ }
+
+ "15"
+ {
+ "name" "Model"
+ "info" "This is a matrix node used only in the vertex shader to transform vertices into worldspace.\n\nOutput: The 4x3 Model matrix."
+ }
+
+ "16"
+ {
+ "name" "ViewModel"
+ "info" "This matrix is possibly used to transform from view to world space. No idea.\n\nOutput: The 4x4 ViewModel matrix."
+ }
+
+ "17"
+ {
+ "name" "Add"
+ "info" "This node is used to add two inputs.\n\nOutput: The sum of the two inputs. The datatype is determined by said inputs."
+ "code" "A + B"
+ }
+
+ "18"
+ {
+ "name" "Subtract"
+ "info" "This node is used to subtract two inputs.\n\nOutput: The difference of the two inputs. The datatype is determined by said inputs."
+ "code" "A - B"
+ }
+
+ "19"
+ {
+ "name" "Multiply"
+ "info" "This node is used to multiply two inputs.\n\nOutput: The product of the two inputs. The datatype is determined by said inputs."
+ "code" "A * B"
+ }
+
+ "20"
+ {
+ "name" "Divide"
+ "info" "This node is used to divide two inputs.\n\nOutput: The division of the two inputs. The datatype is determined by said inputs."
+ "code" "A / B"
+ }
+
+ "21"
+ {
+ "name" "Linear Interpolate"
+ "info" "This node is used to linearly interpolate two inputs based on a third.\n\nOutput: The linearly interpolated vector of the two inputs based on the third. The datatype is determined by said inputs."
+ "code" "lerp( A, B, 0.5 )"
+ }
+
+ "22"
+ {
+ "name" "Fractional Remainder"
+ "info" "This node is used to calculate the fractional remainder of the input vector.\n\nOutput: The fractional remainder of the input vector. The datatype is determined by said input."
+ "code" "frac( A )"
+ }
+
+ "23"
+ {
+ "name" "Dot product"
+ "info" "This node is used to calculate the dot product of two input vectors.\n\nOutput: The single component dot product vector."
+ "code" "dot( A, B )"
+ }
+
+ "24"
+ {
+ "name" "Length"
+ "info" "This node is used to calculate the length of an input vector.\n\nOutput: The single component length vector of the input."
+ "code" "length( A )"
+ }
+
+ "25"
+ {
+ "name" "Normalize"
+ "info" "This node is used to normalize the input vector.\n\nOutput: The normalized input vector. The datatype is determined by said input."
+ "code" "normalize( A )"
+ }
+
+ "26"
+ {
+ "name" "Append"
+ "info" "This node is used to append multiple inputs into a single multi-component vector.\n\nOutput: The appended vector of the two inputs. The two inputs must not append to more than 4 channels or the node will error."
+ "code" "float4( A.xy, B.zw )"
+ }
+
+ "27"
+ {
+ "name" "Swizzle"
+ "info" "This node is used to selectively swizzle channels of multi-component inputs.\n\nOutput: The swizzled vector of the input. The format is determined by the swizzle settings."
+ "code" "A = B.xy"
+ }
+
+ "28"
+ {
+ "name" "NOT_USED"
+ "info" "NOT_USED"
+ "code" "NOT_USED"
+ }
+
+ "29"
+ {
+ "name" "Texture Sampler"
+ "info" "This node is used to sample color from textures.\nThe 'VMT Fallback' path defines the texture which is loaded when the parameter is not defined in the VMT of a finished shader.\nThe 'DEMO' texture is SOLELY used by the editor!\n\nOutput: RGBA"
+ "code" "tex2D( sampler, texcoord )"
+ }
+
+ "30"
+ {
+ "name" "Loop"
+ "info" "This node is used in control flow, it allows you to loop code x amount of times to achieve effects such as blur.\n\nOutput: The current value of the iteration counter."
+ "code" "for( int i = 0; i < 7; i++ ) { A += tex2D( sampler, texcoord + offset * i ) / 7; }"
+ }
+
+ "31"
+ {
+ "name" "Combo"
+ "info" "This node allows you to declare combos, the nodes within the combo container will only be run if the combo condition is met.\n\nOutput: This node has no output."
+ }
+
+ "32"
+ {
+ "name" "Declare"
+ "info" "This node is used to (re)declare variables when using control flow nodes.\n\nOutput: Same as input, but re-delcared in the scope of this node."
+ }
+
+ "33"
+ {
+ "name" "Assign"
+ "info" "This node is used to assign variables to eachother, and is used with control flow nodes.\n\nOutput: Variable of input A, containing values of input B."
+ "code" "A = B"
+ }
+
+ "34"
+ {
+ "name" "Smoothstep"
+ "info" "This node is used to create a normalized hermite interpolation value for each component.\n\nOutput: The interpolated values in [0,1] range. The datatype is determined by said inputs."
+ "code" "smoothstep( -2, 4, A )"
+ }
+
+ "35"
+ {
+ "name" "Step"
+ "info" "This node is used to determine if input A is bigger or equal to input B.\n\nOutput: if X is greater than Y the output will be 1, else it will be 0."
+ "code" "step( A, B ) or ( A >= B ) ? 1 : 0"
+ }
+
+ "36"
+ {
+ "name" "Clamp"
+ "info" "This node is used to clamp the input vector.\n\nOutput: The clamped value of the input vector. The datatype is determined by the input."
+ "code" "clamp( A, 0, 2 )"
+ }
+
+ "37"
+ {
+ "name" "Min"
+ "info" "This node is used to select the smallest of the two inputs.\n\nOutput: The smallest of the two inputs. The datatype is determined by said inputs."
+ "code" "min( A, B )"
+ }
+
+ "38"
+ {
+ "name" "Max"
+ "info" "This node is used to select and return the largest of the two inputs.\n\nOutput: The largest of the two inputs. The datatype is determined by said inputs."
+ "code" "max( A, B )"
+ }
+
+ "39"
+ {
+ "name" "Sine"
+ "info" "This node is used to calculate the Sine function for the input vector.\n\nOutput: The value of the Sine function for the input vector. The datatype is determined by said input."
+ "code" "sin( A )"
+ }
+
+ "40"
+ {
+ "name" "Cosine"
+ "info" "This node is used to calculate the Cosine function for the input vector.\n\nOutput: The value of the Cosine function of the input vector. The datatype is determined by said input."
+ "code" "cos( A )"
+ }
+
+ "41"
+ {
+ "name" "Tangent"
+ "info" "This node is used to calculate the Tangent function for the input vector.\n\nOutput: The value of the Tangent function of the input vector. The datatype is determined by said input."
+ "code" "tan( A )"
+ }
+
+ "42"
+ {
+ "name" "Arc Sine"
+ "info" "This node is used to calculate the Arc Sine function for the input vector.\n\nOutput: The value of the Arc Sine function of the input vector. The datatype is determined by said input."
+ "code" "asin( A )"
+ }
+
+ "43"
+ {
+ "name" "Arc Cosine"
+ "info" "This node is used to calculate the Arc Cosine function for the input vector.\n\nOutput: The value of Arc Cosine function of the input vector. The datatype is determined by said input."
+ "code" "acos( A )"
+ }
+
+ "44"
+ {
+ "name" "Arc Tangent"
+ "info" "This node is used to calculate the Arc Tangent function for the input vector.\n\nOutput: The value of Arc Tangent function of the input vector. The datatype is determined by said input."
+ "code" "atan( A )"
+ }
+
+ "45"
+ {
+ "name" "Hyperbolic Sine"
+ "info" "This node is used to calculate the Hyperbolic Sine function for the input vector.\n\nOutput: The value of Hyperbolic Sine function of the input vector. The datatype is determined by said input."
+ "code" "sinh( A )"
+ }
+
+ "46"
+ {
+ "name" "Hyperbolic Cosine"
+ "info" "This node is used to calculate the Hyperbolic Cosine function for the input vector.\n\nOutput: The value of Hyperbolic Cosine function of the input vector. The datatype is determined by said input."
+ "code" "cosh( A )"
+ }
+
+ "47"
+ {
+ "name" "Hyperbolic Tangent"
+ "info" "This node is used to calculate the Hyperbolic Tangent function for the input vector.\n\nOutput: The value of Hyperbolic Tangent function of the input vector. The datatype is determined by said input."
+ "code" "tanh( A )"
+ }
+
+ "48"
+ {
+ "name" "Arc Tangent 2"
+ "info" "This node is used to angle of a 2D vector.\n\nOutput: The values in radians for each pair of components. The datatype is determined by said inputs."
+ "code" "atan2( A, B )"
+ }
+
+ "49"
+ {
+ "name" "Power"
+ "info" "This node is used to calculate the exponential power of input A based on input B.\n\nOutput: The exponential power of input A based on input B. The datatype is determined by said inputs."
+ "code" "pow( A, 5 )"
+ }
+
+ "50"
+ {
+ "name" "Round"
+ "info" "This node is used to round the input to the nearest whole number.\n\nOutput: The rounded input vector. The datatype is determined by said input."
+ "code" "round( A )"
+ }
+
+ "51"
+ {
+ "name" "Floor"
+ "info" "This node is used to round down the input vector.\n\nOutput: The floored input vector. The datatype is determined by said input."
+ "code" "floor( A )"
+ }
+
+ "52"
+ {
+ "name" "Ceiling"
+ "info" "This node is used to round up the input vector.\n\nOutput: The ceiling of the input vector. The datatype is determined by said input."
+ "code" "ceil( A )"
+ }
+
+ "53"
+ {
+ "name" "Absolute"
+ "info" "This node is used to make the input vector positive.\n\nOutput: The absolute of the input vector. The datatype is determined by said input."
+ "code" "abs( A )"
+ }
+
+ "54"
+ {
+ "name" "Floating Point Remainder"
+ "info" "This node is used to calculate the Floating Point Remainder of the first input divided by the second input.\n\nOutput: The Floating Point Remainder of the two divided inputs. The datatype is determined by said inputs."
+ "code" "fmod( A, B )"
+ }
+
+ "55"
+ {
+ "name" "Texture Transform"
+ "info" "This node is used to transform the texture coordinates by a matrix, this can be used to scale, translate or rotate textures.\n\nOutput: The modified two-component texture coordinate."
+ "code" "tex2D(sampler, texcoord * float(5,2) + float2(5,1)); //This will offset the texture by 5 times along x and one time along y. It will also scale the texture 5 times along x and twice along y."
+ }
+
+ "56"
+ {
+ "name" "Degrees"
+ "info" "This node is used to convert an input from radians into degrees.\n\nOutput: The input vector in degrees. The datatype is determined by said input."
+ "code" "degrees( A )"
+ }
+
+ "57"
+ {
+ "name" "Radians"
+ "info" "This node is used to convert an input from degrees into radians.\n\nOutput: The input vector in radians. The datatype is determined by said input."
+ "code" "radians( A )"
+ }
+
+ "58"
+ {
+ "name" "Reflect"
+ "info" "This node is used to reflect a vector along a normal.\n\nOutput: The reflected vector of input A. The datatype is determined by said inputs."
+ "code" "reflect( Ray, Normal )"
+ }
+
+ "59"
+ {
+ "name" "Refract"
+ "info" "This node is used to refract two inputs based on the index of refraction.\n\nOutput: The refraction of input A based on the index. The datatype is determined by said inputs."
+ "code" "refract( Ray, Normal, Index )"
+ }
+
+ "60"
+ {
+ "name" "Saturate"
+ "info" "This node is used to clamp the input vector between 0 and 1.\n\nOutput: The clamped input vector. The datatype is determined by said input."
+ "code" "saturate( A )"
+ }
+
+ "61"
+ {
+ "name" "Invert"
+ "info" "This node is used to invert the input vector.\n\nOutput: The inverse of the input. The datatype is determined by said input."
+ "code" "1 - A"
+ }
+
+ "62"
+ {
+ "name" "Sign"
+ "info" "This node is used to calculate the sign of the input vector. If the input is less than 0 it returns -1, if it's 0 it returns 0, and if it's greater than 0 it returns 1.\n\nOutput: The sign of the input vector. The datatype is detrmined by said input."
+ "code" "sign( A )"
+ }
+
+ "63"
+ {
+ "name" "Square Root"
+ "info" "This node is used to calculate the Square Root of the input vector.\n\nOutput: The Square Root per-component of the input vector. The datatype is determined by said input."
+ "code" "sqrt( A )"
+ }
+
+ "64"
+ {
+ "name" "Cross Product"
+ "info" "This node is used to calculate the cross product of the inputs.\n\nOutput: The cross product of both inputs."
+ "code" "cross( A, B )"
+ }
+
+ "65"
+ {
+ "name" "Framebuffer Texel Size"
+ "info" "This node is used to find the framebuffer texel size, useful for shaders which blur or alter the framebuffer with a loop.\n\nOutput: The two-component texel size of the framebuffer texture."
+ }
+
+ "66"
+ {
+ "name" "Studio Model Vertex Lighting"
+ "info" "This node calculates a models per-vertex lighting based on the inputs.\n\nOutput: The per-vertex lighting vector."
+ }
+
+ "67"
+ {
+ "name" "Studio Model Pixel Shader Lighting"
+ "info" "This node calculates a models per-pixel lighting based on the inputs.\n\nOutput: The four-component per-pixel lighting vector."
+ }
+
+ "68"
+ {
+ "name" "Studio Model Skinning"
+ "info" "This node skins vertices to bones of a model based on the inputs.\n\nOutput: The position of each vertex after skinning has been performed."
+ }
+
+ "69"
+ {
+ "name" "Studio Model Morph"
+ "info" "This node applies morph offsets to vertices.\n\nOutput: The position of each vertex after morphing has been performed."
+ }
+
+ "70"
+ {
+ "name" "Fog Parameters"
+ "info" "This node is used to access the fog parameters from the engine.\n\nOutput: The four-component fog parameter vector."
+ }
+
+ "71"
+ {
+ "name" "Fog"
+ "info" "This node is used to compute fog for a position based on the inputs.\n\nOutput: The four-component fog factor."
+ }
+
+ "72"
+ {
+ "name" "Final"
+ "info" "This node is used to compute the final overall colour of world geometry based on fog, color and depth inputs.\n\nOutput: The final color."
+ }
+
+ "73"
+ {
+ "name" "Matrix Compose"
+ "info" "This node is used to compose a matrix out of three or four-component inputs.\n\nOutput: Generated matrix out of the inputs. The format is determined by said inputs."
+ "code" "mat3x3 tangentSpace = mat3x3(tangent, binormal, normal)"
+ }
+
+ "74"
+ {
+ "name" "Studio Model Pixel Shader Specular"
+ "info" "This node is used to compute the per-pixel specular lighting based on the inputs.\n\nOutput: The three-component specular vector."
+ }
+
+ "75"
+ {
+ "name" "Flashlight View Projection Matrix"
+ "info" "This node is used to access the Flashlight View Projection Matrix, which is used for flashlight calculations.\n\nOutput: The 4x4 Flashlight View Projection Matrix."
+ }
+
+ "76"
+ {
+ "name" "Flashlight Calculation"
+ "info" "This node calculates the Flashlight based on the inputs.\n\nOutput: The four-component lighting vector."
+ }
+
+ "77"
+ {
+ "name" "Constant Callback"
+ "info" "This node is used to access constants defined by code.\n\nOutputs: The output of this node is determined by the datatype of the callback constant."
+ }
+
+ "78"
+ {
+ "name" "Valve Material Parameter - Mutable"
+ "info" "This node is used to access mutable VMT Parameters which can be changed on the fly via code.\n\nOutput: The output of this node is determined by the datatype of the mutable parameter."
+ }
+
+ "79"
+ {
+ "name" "Valve Material Parameter - Static"
+ "info" "This node is used to access static VMT Parameters, which cannot be altered without reloading the material.\n\nOutput: The output of this node is determined by the datatype of the static parameter."
+ }
+
+ "80"
+ {
+ "name" "Lightscale"
+ "info" "This node is used to access the per-object light scale.\n\nOutput: The single component lighting vector."
+ }
+
+ "81"
+ {
+ "name" "Random"
+ "info" "This node is used to generate random numbers.\n\nOutput: The multi-component random vector."
+ }
+
+ "82"
+ {
+ "name" "Base-e Logarithm"
+ "info" "This node calculates the Base-e Logarithm of the input vector.\n\nOutput: The Base-e Logarithmic vector of the input. The datatype is determined by said input."
+ "code" "log( A )"
+ }
+
+ "83"
+ {
+ "name" "Base-2 Logarithm"
+ "info" "This node calculates the Base-2 Logarithm of the input vector.\n\nOutput: The Base-2 Logarithmic vector of the input. The datatype is determined by said input."
+ "code" "log2( A )"
+ }
+
+ "84"
+ {
+ "name" "Base-10 Logarithm"
+ "info" "This node calculates the Base-10 Logarithm of the input vector.\n\nOutput: The Base-2 Logarithmic vector of the input. The datatype is determined by said input."
+ "code" "log10( A )"
+ }
+
+ "85"
+ {
+ "name" "Base-e Exponent"
+ "info" "This node calculates the Base-e Exponent of the input vector.\n\nOutput: The Base-e Exponent of the input vector. The datatype is determined by said input."
+ "code" "exp( A )"
+ }
+
+ "86"
+ {
+ "name" "Base-2 Exponent"
+ "info" "This node calculates the Base-2 Exponent of the input vector.\n\nOutput: The Base-2 Exponent of the input vector. The datatype is determined by said input."
+ "code" "exp2( A )"
+ }
+
+ "87"
+ {
+ "name" "Bump Basis"
+ "info" "This node is used to access Valve's Bump Basis information for BSP normalmapping.\n\nOutput: The three three-component Bump Basis vectors."
+ }
+
+ "88"
+ {
+ "name" "Directional Derivative X"
+ "info" "This node is used to calculate the Directional Derivative X vector of the input.\n\nOutput: The Directional Derivative X vector of the input. The datatype is determined by said input."
+ "code" "ddx( A )"
+ }
+
+ "89"
+ {
+ "name" "Directional Derivative Y"
+ "info" "This node is used to calculate the Directional Derivative Y vector of the input.\n\nOutput: The Directional Derivative Y vector of the input. The datatype is determined by said input."
+ "code" "ddy( A )"
+ }
+
+ "90"
+ {
+ "name" "Custom Matrix"
+ "info" "This node allows you to choose from a list of matrices to use.\n\nOutput: The Matrix chosen in the properties window. The datatype is determined by the matrix you chose."
+ }
+
+ "91"
+ {
+ "name" "Array"
+ "info" "This node allows you to declare an array for use with control flow nodes such as loops.\n\nOutput: The vector selected based on the X and Y inputs of the Array node. The format is determined by the format you set inside the Array properties window."
+ "code" "float array[7] = { 0.0, 0.5, 1.0, 1.5, 2.0, 2.5, 3.0 };"
+ }
+
+ "92"
+ {
+ "name" "Condition"
+ "info" "This node allows you to use conditional statements, and along with the assign and declare nodes, you can make complex effects.\n\nOutput: This node has no output."
+ "code" "if( A == 1 ) { B = 1; }"
+ }
+
+ "93"
+ {
+ "name" "Break"
+ "info" "This node is used to escape up a level in control flow, but sadly source is too old so it doesn't support it!"
+ "code" "for(int i = 0; i < 10; i++) { for int j = 0; j < 10; j++) { if ( condition == true; ) { break; } color += tex2D( sampler, texcoord + float2( i, j ) ) }"
+ }
+
+ "94"
+ {
+ "name" "Sampler object"
+ "info" "This node is able to load and expose a texture to the shader. Useful for custom code nodes and requires for parallax mapping.\n\nOutput: A sampler object."
+ "code" "tex2D( sampler, texcoord )"
+ }
+
+ "95"
+ {
+ "name" "Parallax Coordinate"
+ "info" "This node is used to calculate the Parallax Coordinates.\n\nOutput: A two-component warped texture coord, three-component tangent offset."
+ }
+
+ "96"
+ {
+ "name" "Parallax Shadow"
+ "info" "This node is used to calculate the Parallax Shadow.\n\nOutput: A single-component light vector."
+ }
+
+ "97"
+ {
+ "name" "Flashlight Position"
+ "info" "This node represents the flashlight position in worlsspace.\n\nOutput: A three-component position vector."
+ }
+
+ "98"
+ {
+ "name" "Clip"
+ "info" "This node is used to discard pixels of your shader.\nIf any input value is smaller than zero, the pixel won't be drawn.\n\nOutput: The output equals the input."
+ "code" "clip( tex2D( sampler, texcoord ).a - 0.5f )"
+ }
+
+ "99"
+ {
+ "name" "Custom Code"
+ "info" "This node is used to type custom code and use it inside of the flowgraph.\n\nOutput: This node outputs whatever you have set in its properties, and in the format of your choice."
+ }
+
+ "100"
+ {
+ "name" "Distance"
+ "info" "This node is used to calculate the distance between two inputs.\n\nOutput: The distance between two inputs. The format is determined by said inputs."
+ "code" "dst( A, B )"
+ }
+
+ "101"
+ {
+ "name" "Vertex decompression"
+ "info" "Decompresses vertex data in case the geometry provides it in a compressed format."
+ }
+
+
+ // PPE
+ "2001"
+ {
+ "name" "Post processing input"
+ "info" "First node of a post processing effect chain."
+ }
+
+ "2002"
+ {
+ "name" "Post processing output"
+ "info" "Last node of a post processing effect chain."
+ }
+
+ "2003"
+ {
+ "name" "Clear buffers"
+ "info" "Clear color and/or depth of the current RT. You MUST NOT clear depth if the RT does not use a depth buffer!"
+ }
+
+ "2004"
+ {
+ "name" "Draw material"
+ "info" "Draws a material onto the current RT.\nSelect 'Push target RT' to draw the material onto the reference target RT instead.\n\nBoth input RTs are used to build the UVs and viewport!"
+ }
+
+ "2005"
+ {
+ "name" "Update framebuffer"
+ "info" "Copy the current RT to the framebuffer copy texture, which shaders can access through the 'Framebuffer' parameter."
+ }
+
+ "2006"
+ {
+ "name" "Push viewport"
+ "info" "Push an RT as the new viewport onto the stack.\nEvery push must be followed by a pop."
+ }
+
+ "2007"
+ {
+ "name" "Pop viewport"
+ "info" "Pop the last RT from the stack.\nYou MUST NOT pop before having pushed anything."
+ }
+
+ "2008"
+ {
+ "name" "Set rendertarget"
+ "info" "Override the current RT and viewport without pushing."
+ }
+
+ "2009"
+ {
+ "name" "Create rendertarget"
+ "info" "Load a rendertarget by name."
+ }
+
+ "2010"
+ {
+ "name" "Create material"
+ "info" "Load a material or create a new one on the fly.\nYou can access these materials from the client if you specify a custom name on the 'general' tab!"
+ }
+
+ "2011"
+ {
+ "name" "Copy rendertarget"
+ "info" "Blit the current RT to another one."
+ }
+
+ "2012"
+ {
+ "name" "Render view"
+ "info" "Execute a view render callback.\nYou can register these from the client dll and specify the available options there.\nUse this to draw all sorts of stuff onto an RT to create masks or alike."
+ }
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/path_config.txt b/mp/game/momentum/shadereditorui/path_config.txt
new file mode 100644
index 0000000000..6e1bc136f8
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/path_config.txt
@@ -0,0 +1,6 @@
+"paths"
+{
+ "compiler" "sourcesdk/bin/source2007/bin"
+ "compiler_2006" "sourcesdk/bin/ep1/bin"
+ "compiler_swarm" "alien swarm/bin"
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/postprocessing_precache.txt b/mp/game/momentum/shadereditorui/postprocessing_precache.txt
new file mode 100644
index 0000000000..30deefaddf
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/postprocessing_precache.txt
@@ -0,0 +1,3 @@
+"pp_precache"
+{
+}
diff --git a/mp/game/momentum/shadereditorui/redistribute/compiler/mysql_wrapper.dll b/mp/game/momentum/shadereditorui/redistribute/compiler/mysql_wrapper.dll
new file mode 100644
index 0000000000..33d68ac39f
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/compiler/mysql_wrapper.dll differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/compiler/shadercompile_dll.dll b/mp/game/momentum/shadereditorui/redistribute/compiler/shadercompile_dll.dll
new file mode 100644
index 0000000000..af1dec8790
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/compiler/shadercompile_dll.dll differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/colorpicker_blend_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/colorpicker_blend_ps20.vcs
new file mode 100644
index 0000000000..66649b0c39
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/colorpicker_blend_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/colorpicker_blend_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/colorpicker_blend_vs20.vcs
new file mode 100644
index 0000000000..18a639a98d
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/colorpicker_blend_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/fallback_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/fallback_ps20.vcs
new file mode 100644
index 0000000000..0cebacceea
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/fallback_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/fallback_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/fallback_vs20.vcs
new file mode 100644
index 0000000000..b23b2d1908
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/fallback_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/fbquad_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/fbquad_ps20.vcs
new file mode 100644
index 0000000000..70e2b72a89
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/fbquad_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/fbquad_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/fbquad_vs20.vcs
new file mode 100644
index 0000000000..75b7ea66c3
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/fbquad_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/node_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/node_ps20.vcs
new file mode 100644
index 0000000000..5ef9e2dab6
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/node_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/node_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/node_vs20.vcs
new file mode 100644
index 0000000000..6b220d68c0
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/node_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/prev_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/prev_ps20.vcs
new file mode 100644
index 0000000000..3aa0e9c27d
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/prev_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/prev_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/prev_vs20.vcs
new file mode 100644
index 0000000000..2a316a6a33
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/prev_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/psin_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/psin_ps20.vcs
new file mode 100644
index 0000000000..a0ba9931b6
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/psin_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/psin_ps30.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/psin_ps30.vcs
new file mode 100644
index 0000000000..bf916ceac8
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/psin_ps30.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/psin_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/psin_vs20.vcs
new file mode 100644
index 0000000000..e8ea346ed1
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/psin_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/skymask_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/skymask_ps20.vcs
new file mode 100644
index 0000000000..0c974d8f20
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/skymask_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders/skymask_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders/skymask_vs20.vcs
new file mode 100644
index 0000000000..a9c458cce6
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders/skymask_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/colorpicker_blend_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/colorpicker_blend_ps20.vcs
new file mode 100644
index 0000000000..60597e3c0b
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/colorpicker_blend_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/colorpicker_blend_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/colorpicker_blend_vs20.vcs
new file mode 100644
index 0000000000..38a6c0e057
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/colorpicker_blend_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fallback_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fallback_ps20.vcs
new file mode 100644
index 0000000000..2c9bb6b473
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fallback_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fallback_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fallback_vs20.vcs
new file mode 100644
index 0000000000..65a27eb2aa
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fallback_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fbquad_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fbquad_ps20.vcs
new file mode 100644
index 0000000000..fbe994a5fc
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fbquad_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fbquad_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fbquad_vs20.vcs
new file mode 100644
index 0000000000..3c2e0e0978
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/fbquad_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/node_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/node_ps20.vcs
new file mode 100644
index 0000000000..3e31a7167e
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/node_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/node_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/node_vs20.vcs
new file mode 100644
index 0000000000..562150257d
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/node_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/prev_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/prev_ps20.vcs
new file mode 100644
index 0000000000..31e5a22bd3
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/prev_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/prev_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/prev_vs20.vcs
new file mode 100644
index 0000000000..7c77652e35
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/prev_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_ps20.vcs
new file mode 100644
index 0000000000..8e9e95e984
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_ps30.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_ps30.vcs
new file mode 100644
index 0000000000..b40d17b1e7
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_ps30.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_vs20.vcs
new file mode 100644
index 0000000000..688f5c0bbb
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/psin_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/skymask_ps20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/skymask_ps20.vcs
new file mode 100644
index 0000000000..b53cd1fc5c
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/skymask_ps20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/redistribute/shaders_2006/skymask_vs20.vcs b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/skymask_vs20.vcs
new file mode 100644
index 0000000000..4d60e2e9fb
Binary files /dev/null and b/mp/game/momentum/shadereditorui/redistribute/shaders_2006/skymask_vs20.vcs differ
diff --git a/mp/game/momentum/shadereditorui/rtsetup.txt b/mp/game/momentum/shadereditorui/rtsetup.txt
new file mode 100644
index 0000000000..231c131242
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/rtsetup.txt
@@ -0,0 +1,23 @@
+"rt_setup"
+{
+ "rt_00"
+ {
+ "rt_name" "_rt_fbquarter_0"
+ "rt_imgformat" "2"
+ "rt_sizemode" "3"
+ "rt_depthmode" "2"
+ "rt_flags" "32780"
+ "rt_size_x" "256"
+ "rt_size_y" "256"
+ }
+ "rt_01"
+ {
+ "rt_name" "_rt_fbquarter_1"
+ "rt_imgformat" "2"
+ "rt_sizemode" "3"
+ "rt_depthmode" "2"
+ "rt_flags" "32780"
+ "rt_size_x" "256"
+ "rt_size_y" "256"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/shader_src/Fxaa3_11.h b/mp/game/momentum/shadereditorui/shader_src/Fxaa3_11.h
new file mode 100644
index 0000000000..92a3737404
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/Fxaa3_11.h
@@ -0,0 +1,2047 @@
+/*============================================================================
+
+
+ NVIDIA FXAA 3.11 by TIMOTHY LOTTES
+
+
+------------------------------------------------------------------------------
+COPYRIGHT (C) 2010, 2011 NVIDIA CORPORATION. ALL RIGHTS RESERVED.
+------------------------------------------------------------------------------
+TO THE MAXIMUM EXTENT PERMITTED BY APPLICABLE LAW, THIS SOFTWARE IS PROVIDED
+*AS IS* AND NVIDIA AND ITS SUPPLIERS DISCLAIM ALL WARRANTIES, EITHER EXPRESS
+OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
+MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. IN NO EVENT SHALL NVIDIA
+OR ITS SUPPLIERS BE LIABLE FOR ANY SPECIAL, INCIDENTAL, INDIRECT, OR
+CONSEQUENTIAL DAMAGES WHATSOEVER (INCLUDING, WITHOUT LIMITATION, DAMAGES FOR
+LOSS OF BUSINESS PROFITS, BUSINESS INTERRUPTION, LOSS OF BUSINESS INFORMATION,
+OR ANY OTHER PECUNIARY LOSS) ARISING OUT OF THE USE OF OR INABILITY TO USE
+THIS SOFTWARE, EVEN IF NVIDIA HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
+DAMAGES.
+
+------------------------------------------------------------------------------
+ INTEGRATION CHECKLIST
+------------------------------------------------------------------------------
+(1.)
+In the shader source, setup defines for the desired configuration.
+When providing multiple shaders (for different presets),
+simply setup the defines differently in multiple files.
+Example,
+
+ #define FXAA_PC 1
+ #define FXAA_HLSL_5 1
+ #define FXAA_QUALITY__PRESET 12
+
+Or,
+
+ #define FXAA_360 1
+
+Or,
+
+ #define FXAA_PS3 1
+
+Etc.
+
+(2.)
+Then include this file,
+
+ #include "Fxaa3_11.h"
+
+(3.)
+Then call the FXAA pixel shader from within your desired shader.
+Look at the FXAA Quality FxaaPixelShader() for docs on inputs.
+As for FXAA 3.11 all inputs for all shaders are the same
+to enable easy porting between platforms.
+
+ return FxaaPixelShader(...);
+
+(4.)
+Insure pass prior to FXAA outputs RGBL (see next section).
+Or use,
+
+ #define FXAA_GREEN_AS_LUMA 1
+
+(5.)
+Setup engine to provide the following constants
+which are used in the FxaaPixelShader() inputs,
+
+ FxaaFloat2 fxaaQualityRcpFrame,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt2,
+ FxaaFloat4 fxaaConsole360RcpFrameOpt2,
+ FxaaFloat fxaaQualitySubpix,
+ FxaaFloat fxaaQualityEdgeThreshold,
+ FxaaFloat fxaaQualityEdgeThresholdMin,
+ FxaaFloat fxaaConsoleEdgeSharpness,
+ FxaaFloat fxaaConsoleEdgeThreshold,
+ FxaaFloat fxaaConsoleEdgeThresholdMin,
+ FxaaFloat4 fxaaConsole360ConstDir
+
+Look at the FXAA Quality FxaaPixelShader() for docs on inputs.
+
+(6.)
+Have FXAA vertex shader run as a full screen triangle,
+and output "pos" and "fxaaConsolePosPos"
+such that inputs in the pixel shader provide,
+
+ // {xy} = center of pixel
+ FxaaFloat2 pos,
+
+ // {xy__} = upper left of pixel
+ // {__zw} = lower right of pixel
+ FxaaFloat4 fxaaConsolePosPos,
+
+(7.)
+Insure the texture sampler(s) used by FXAA are set to bilinear filtering.
+
+
+------------------------------------------------------------------------------
+ INTEGRATION - RGBL AND COLORSPACE
+------------------------------------------------------------------------------
+FXAA3 requires RGBL as input unless the following is set,
+
+ #define FXAA_GREEN_AS_LUMA 1
+
+In which case the engine uses green in place of luma,
+and requires RGB input is in a non-linear colorspace.
+
+RGB should be LDR (low dynamic range).
+Specifically do FXAA after tonemapping.
+
+RGB data as returned by a texture fetch can be non-linear,
+or linear when FXAA_GREEN_AS_LUMA is not set.
+Note an "sRGB format" texture counts as linear,
+because the result of a texture fetch is linear data.
+Regular "RGBA8" textures in the sRGB colorspace are non-linear.
+
+If FXAA_GREEN_AS_LUMA is not set,
+luma must be stored in the alpha channel prior to running FXAA.
+This luma should be in a perceptual space (could be gamma 2.0).
+Example pass before FXAA where output is gamma 2.0 encoded,
+
+ color.rgb = ToneMap(color.rgb); // linear color output
+ color.rgb = sqrt(color.rgb); // gamma 2.0 color output
+ return color;
+
+To use FXAA,
+
+ color.rgb = ToneMap(color.rgb); // linear color output
+ color.rgb = sqrt(color.rgb); // gamma 2.0 color output
+ color.a = dot(color.rgb, FxaaFloat3(0.299, 0.587, 0.114)); // compute luma
+ return color;
+
+Another example where output is linear encoded,
+say for instance writing to an sRGB formated render target,
+where the render target does the conversion back to sRGB after blending,
+
+ color.rgb = ToneMap(color.rgb); // linear color output
+ return color;
+
+To use FXAA,
+
+ color.rgb = ToneMap(color.rgb); // linear color output
+ color.a = sqrt(dot(color.rgb, FxaaFloat3(0.299, 0.587, 0.114))); // compute luma
+ return color;
+
+Getting luma correct is required for the algorithm to work correctly.
+
+
+------------------------------------------------------------------------------
+ BEING LINEARLY CORRECT?
+------------------------------------------------------------------------------
+Applying FXAA to a framebuffer with linear RGB color will look worse.
+This is very counter intuitive, but happends to be true in this case.
+The reason is because dithering artifacts will be more visiable
+in a linear colorspace.
+
+
+------------------------------------------------------------------------------
+ COMPLEX INTEGRATION
+------------------------------------------------------------------------------
+Q. What if the engine is blending into RGB before wanting to run FXAA?
+
+A. In the last opaque pass prior to FXAA,
+ have the pass write out luma into alpha.
+ Then blend into RGB only.
+ FXAA should be able to run ok
+ assuming the blending pass did not any add aliasing.
+ This should be the common case for particles and common blending passes.
+
+A. Or use FXAA_GREEN_AS_LUMA.
+
+============================================================================*/
+
+/*============================================================================
+
+ INTEGRATION KNOBS
+
+============================================================================*/
+//
+// FXAA_PS3 and FXAA_360 choose the console algorithm (FXAA3 CONSOLE).
+// FXAA_360_OPT is a prototype for the new optimized 360 version.
+//
+// 1 = Use API.
+// 0 = Don't use API.
+//
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_PS3
+ #define FXAA_PS3 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_360
+ #define FXAA_360 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_360_OPT
+ #define FXAA_360_OPT 0
+#endif
+/*==========================================================================*/
+#ifndef FXAA_PC
+ //
+ // FXAA Quality
+ // The high quality PC algorithm.
+ //
+ #define FXAA_PC 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_PC_CONSOLE
+ //
+ // The console algorithm for PC is included
+ // for developers targeting really low spec machines.
+ // Likely better to just run FXAA_PC, and use a really low preset.
+ //
+ #define FXAA_PC_CONSOLE 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_GLSL_120
+ #define FXAA_GLSL_120 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_GLSL_130
+ #define FXAA_GLSL_130 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_HLSL_3
+ #define FXAA_HLSL_3 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_HLSL_4
+ #define FXAA_HLSL_4 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_HLSL_5
+ #define FXAA_HLSL_5 0
+#endif
+/*==========================================================================*/
+#ifndef FXAA_GREEN_AS_LUMA
+ //
+ // For those using non-linear color,
+ // and either not able to get luma in alpha, or not wanting to,
+ // this enables FXAA to run using green as a proxy for luma.
+ // So with this enabled, no need to pack luma in alpha.
+ //
+ // This will turn off AA on anything which lacks some amount of green.
+ // Pure red and blue or combination of only R and B, will get no AA.
+ //
+ // Might want to lower the settings for both,
+ // fxaaConsoleEdgeThresholdMin
+ // fxaaQualityEdgeThresholdMin
+ // In order to insure AA does not get turned off on colors
+ // which contain a minor amount of green.
+ //
+ // 1 = On.
+ // 0 = Off.
+ //
+ #define FXAA_GREEN_AS_LUMA 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_EARLY_EXIT
+ //
+ // Controls algorithm's early exit path.
+ // On PS3 turning this ON adds 2 cycles to the shader.
+ // On 360 turning this OFF adds 10ths of a millisecond to the shader.
+ // Turning this off on console will result in a more blurry image.
+ // So this defaults to on.
+ //
+ // 1 = On.
+ // 0 = Off.
+ //
+ #define FXAA_EARLY_EXIT 1
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_DISCARD
+ //
+ // Only valid for PC OpenGL currently.
+ // Probably will not work when FXAA_GREEN_AS_LUMA = 1.
+ //
+ // 1 = Use discard on pixels which don't need AA.
+ // For APIs which enable concurrent TEX+ROP from same surface.
+ // 0 = Return unchanged color on pixels which don't need AA.
+ //
+ #define FXAA_DISCARD 0
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_FAST_PIXEL_OFFSET
+ //
+ // Used for GLSL 120 only.
+ //
+ // 1 = GL API supports fast pixel offsets
+ // 0 = do not use fast pixel offsets
+ //
+ #ifdef GL_EXT_gpu_shader4
+ #define FXAA_FAST_PIXEL_OFFSET 1
+ #endif
+ #ifdef GL_NV_gpu_shader5
+ #define FXAA_FAST_PIXEL_OFFSET 1
+ #endif
+ #ifdef GL_ARB_gpu_shader5
+ #define FXAA_FAST_PIXEL_OFFSET 1
+ #endif
+ #ifndef FXAA_FAST_PIXEL_OFFSET
+ #define FXAA_FAST_PIXEL_OFFSET 0
+ #endif
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_GATHER4_ALPHA
+ //
+ // 1 = API supports gather4 on alpha channel.
+ // 0 = API does not support gather4 on alpha channel.
+ //
+ #if (FXAA_HLSL_5 == 1)
+ #define FXAA_GATHER4_ALPHA 1
+ #endif
+ #ifdef GL_ARB_gpu_shader5
+ #define FXAA_GATHER4_ALPHA 1
+ #endif
+ #ifdef GL_NV_gpu_shader5
+ #define FXAA_GATHER4_ALPHA 1
+ #endif
+ #ifndef FXAA_GATHER4_ALPHA
+ #define FXAA_GATHER4_ALPHA 0
+ #endif
+#endif
+
+/*============================================================================
+ FXAA CONSOLE PS3 - TUNING KNOBS
+============================================================================*/
+#ifndef FXAA_CONSOLE__PS3_EDGE_SHARPNESS
+ //
+ // Consoles the sharpness of edges on PS3 only.
+ // Non-PS3 tuning is done with shader input.
+ //
+ // Due to the PS3 being ALU bound,
+ // there are only two safe values here: 4 and 8.
+ // These options use the shaders ability to a free *|/ by 2|4|8.
+ //
+ // 8.0 is sharper
+ // 4.0 is softer
+ // 2.0 is really soft (good for vector graphics inputs)
+ //
+ #if 1
+ #define FXAA_CONSOLE__PS3_EDGE_SHARPNESS 8.0
+ #endif
+ #if 0
+ #define FXAA_CONSOLE__PS3_EDGE_SHARPNESS 4.0
+ #endif
+ #if 0
+ #define FXAA_CONSOLE__PS3_EDGE_SHARPNESS 2.0
+ #endif
+#endif
+/*--------------------------------------------------------------------------*/
+#ifndef FXAA_CONSOLE__PS3_EDGE_THRESHOLD
+ //
+ // Only effects PS3.
+ // Non-PS3 tuning is done with shader input.
+ //
+ // The minimum amount of local contrast required to apply algorithm.
+ // The console setting has a different mapping than the quality setting.
+ //
+ // This only applies when FXAA_EARLY_EXIT is 1.
+ //
+ // Due to the PS3 being ALU bound,
+ // there are only two safe values here: 0.25 and 0.125.
+ // These options use the shaders ability to a free *|/ by 2|4|8.
+ //
+ // 0.125 leaves less aliasing, but is softer
+ // 0.25 leaves more aliasing, and is sharper
+ //
+ #if 1
+ #define FXAA_CONSOLE__PS3_EDGE_THRESHOLD 0.125
+ #else
+ #define FXAA_CONSOLE__PS3_EDGE_THRESHOLD 0.25
+ #endif
+#endif
+
+/*============================================================================
+ FXAA QUALITY - TUNING KNOBS
+------------------------------------------------------------------------------
+NOTE the other tuning knobs are now in the shader function inputs!
+============================================================================*/
+#ifndef FXAA_QUALITY__PRESET
+ //
+ // Choose the quality preset.
+ // This needs to be compiled into the shader as it effects code.
+ // Best option to include multiple presets is to
+ // in each shader define the preset, then include this file.
+ //
+ // OPTIONS
+ // -----------------------------------------------------------------------
+ // 10 to 15 - default medium dither (10=fastest, 15=highest quality)
+ // 20 to 29 - less dither, more expensive (20=fastest, 29=highest quality)
+ // 39 - no dither, very expensive
+ //
+ // NOTES
+ // -----------------------------------------------------------------------
+ // 12 = slightly faster then FXAA 3.9 and higher edge quality (default)
+ // 13 = about same speed as FXAA 3.9 and better than 12
+ // 23 = closest to FXAA 3.9 visually and performance wise
+ // _ = the lowest digit is directly related to performance
+ // _ = the highest digit is directly related to style
+ //
+ #define FXAA_QUALITY__PRESET 12
+#endif
+
+
+/*============================================================================
+
+ FXAA QUALITY - PRESETS
+
+============================================================================*/
+
+/*============================================================================
+ FXAA QUALITY - MEDIUM DITHER PRESETS
+============================================================================*/
+#if (FXAA_QUALITY__PRESET == 10)
+ #define FXAA_QUALITY__PS 3
+ #define FXAA_QUALITY__P0 1.5
+ #define FXAA_QUALITY__P1 3.0
+ #define FXAA_QUALITY__P2 12.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 11)
+ #define FXAA_QUALITY__PS 4
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 3.0
+ #define FXAA_QUALITY__P3 12.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 12)
+ #define FXAA_QUALITY__PS 5
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 4.0
+ #define FXAA_QUALITY__P4 12.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 13)
+ #define FXAA_QUALITY__PS 6
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 4.0
+ #define FXAA_QUALITY__P5 12.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 14)
+ #define FXAA_QUALITY__PS 7
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 4.0
+ #define FXAA_QUALITY__P6 12.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 15)
+ #define FXAA_QUALITY__PS 8
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 2.0
+ #define FXAA_QUALITY__P6 4.0
+ #define FXAA_QUALITY__P7 12.0
+#endif
+
+/*============================================================================
+ FXAA QUALITY - LOW DITHER PRESETS
+============================================================================*/
+#if (FXAA_QUALITY__PRESET == 20)
+ #define FXAA_QUALITY__PS 3
+ #define FXAA_QUALITY__P0 1.5
+ #define FXAA_QUALITY__P1 2.0
+ #define FXAA_QUALITY__P2 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 21)
+ #define FXAA_QUALITY__PS 4
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 22)
+ #define FXAA_QUALITY__PS 5
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 23)
+ #define FXAA_QUALITY__PS 6
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 24)
+ #define FXAA_QUALITY__PS 7
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 3.0
+ #define FXAA_QUALITY__P6 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 25)
+ #define FXAA_QUALITY__PS 8
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 2.0
+ #define FXAA_QUALITY__P6 4.0
+ #define FXAA_QUALITY__P7 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 26)
+ #define FXAA_QUALITY__PS 9
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 2.0
+ #define FXAA_QUALITY__P6 2.0
+ #define FXAA_QUALITY__P7 4.0
+ #define FXAA_QUALITY__P8 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 27)
+ #define FXAA_QUALITY__PS 10
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 2.0
+ #define FXAA_QUALITY__P6 2.0
+ #define FXAA_QUALITY__P7 2.0
+ #define FXAA_QUALITY__P8 4.0
+ #define FXAA_QUALITY__P9 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 28)
+ #define FXAA_QUALITY__PS 11
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 2.0
+ #define FXAA_QUALITY__P6 2.0
+ #define FXAA_QUALITY__P7 2.0
+ #define FXAA_QUALITY__P8 2.0
+ #define FXAA_QUALITY__P9 4.0
+ #define FXAA_QUALITY__P10 8.0
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_QUALITY__PRESET == 29)
+ #define FXAA_QUALITY__PS 12
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.5
+ #define FXAA_QUALITY__P2 2.0
+ #define FXAA_QUALITY__P3 2.0
+ #define FXAA_QUALITY__P4 2.0
+ #define FXAA_QUALITY__P5 2.0
+ #define FXAA_QUALITY__P6 2.0
+ #define FXAA_QUALITY__P7 2.0
+ #define FXAA_QUALITY__P8 2.0
+ #define FXAA_QUALITY__P9 2.0
+ #define FXAA_QUALITY__P10 4.0
+ #define FXAA_QUALITY__P11 8.0
+#endif
+
+/*============================================================================
+ FXAA QUALITY - EXTREME QUALITY
+============================================================================*/
+#if (FXAA_QUALITY__PRESET == 39)
+ #define FXAA_QUALITY__PS 12
+ #define FXAA_QUALITY__P0 1.0
+ #define FXAA_QUALITY__P1 1.0
+ #define FXAA_QUALITY__P2 1.0
+ #define FXAA_QUALITY__P3 1.0
+ #define FXAA_QUALITY__P4 1.0
+ #define FXAA_QUALITY__P5 1.5
+ #define FXAA_QUALITY__P6 2.0
+ #define FXAA_QUALITY__P7 2.0
+ #define FXAA_QUALITY__P8 2.0
+ #define FXAA_QUALITY__P9 2.0
+ #define FXAA_QUALITY__P10 4.0
+ #define FXAA_QUALITY__P11 8.0
+#endif
+
+
+
+/*============================================================================
+
+ API PORTING
+
+============================================================================*/
+#if (FXAA_GLSL_120 == 1) || (FXAA_GLSL_130 == 1)
+ #define FxaaBool bool
+ #define FxaaDiscard discard
+ #define FxaaFloat float
+ #define FxaaFloat2 vec2
+ #define FxaaFloat3 vec3
+ #define FxaaFloat4 vec4
+ #define FxaaHalf float
+ #define FxaaHalf2 vec2
+ #define FxaaHalf3 vec3
+ #define FxaaHalf4 vec4
+ #define FxaaInt2 ivec2
+ #define FxaaSat(x) clamp(x, 0.0, 1.0)
+ #define FxaaTex sampler2D
+#else
+ #define FxaaBool bool
+ #define FxaaDiscard clip(-1)
+ #define FxaaFloat float
+ #define FxaaFloat2 float2
+ #define FxaaFloat3 float3
+ #define FxaaFloat4 float4
+ #define FxaaHalf half
+ #define FxaaHalf2 half2
+ #define FxaaHalf3 half3
+ #define FxaaHalf4 half4
+ #define FxaaSat(x) saturate(x)
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_GLSL_120 == 1)
+ // Requires,
+ // #version 120
+ // And at least,
+ // #extension GL_EXT_gpu_shader4 : enable
+ // (or set FXAA_FAST_PIXEL_OFFSET 1 to work like DX9)
+ #define FxaaTexTop(t, p) texture2DLod(t, p, 0.0)
+ #if (FXAA_FAST_PIXEL_OFFSET == 1)
+ #define FxaaTexOff(t, p, o, r) texture2DLodOffset(t, p, 0.0, o)
+ #else
+ #define FxaaTexOff(t, p, o, r) texture2DLod(t, p + (o * r), 0.0)
+ #endif
+ #if (FXAA_GATHER4_ALPHA == 1)
+ // use #extension GL_ARB_gpu_shader5 : enable
+ #define FxaaTexAlpha4(t, p) textureGather(t, p, 3)
+ #define FxaaTexOffAlpha4(t, p, o) textureGatherOffset(t, p, o, 3)
+ #define FxaaTexGreen4(t, p) textureGather(t, p, 1)
+ #define FxaaTexOffGreen4(t, p, o) textureGatherOffset(t, p, o, 1)
+ #endif
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_GLSL_130 == 1)
+ // Requires "#version 130" or better
+ #define FxaaTexTop(t, p) textureLod(t, p, 0.0)
+ #define FxaaTexOff(t, p, o, r) textureLodOffset(t, p, 0.0, o)
+ #if (FXAA_GATHER4_ALPHA == 1)
+ // use #extension GL_ARB_gpu_shader5 : enable
+ #define FxaaTexAlpha4(t, p) textureGather(t, p, 3)
+ #define FxaaTexOffAlpha4(t, p, o) textureGatherOffset(t, p, o, 3)
+ #define FxaaTexGreen4(t, p) textureGather(t, p, 1)
+ #define FxaaTexOffGreen4(t, p, o) textureGatherOffset(t, p, o, 1)
+ #endif
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_HLSL_3 == 1) || (FXAA_360 == 1) || (FXAA_PS3 == 1)
+ #define FxaaInt2 float2
+ #define FxaaTex sampler2D
+ #define FxaaTexTop(t, p) tex2Dlod(t, float4(p, 0.0, 0.0))
+ #define FxaaTexOff(t, p, o, r) tex2Dlod(t, float4(p + (o * r), 0, 0))
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_HLSL_4 == 1)
+ #define FxaaInt2 int2
+ struct FxaaTex { SamplerState smpl; Texture2D tex; };
+ #define FxaaTexTop(t, p) t.tex.SampleLevel(t.smpl, p, 0.0)
+ #define FxaaTexOff(t, p, o, r) t.tex.SampleLevel(t.smpl, p, 0.0, o)
+#endif
+/*--------------------------------------------------------------------------*/
+#if (FXAA_HLSL_5 == 1)
+ #define FxaaInt2 int2
+ struct FxaaTex { SamplerState smpl; Texture2D tex; };
+ #define FxaaTexTop(t, p) t.tex.SampleLevel(t.smpl, p, 0.0)
+ #define FxaaTexOff(t, p, o, r) t.tex.SampleLevel(t.smpl, p, 0.0, o)
+ #define FxaaTexAlpha4(t, p) t.tex.GatherAlpha(t.smpl, p)
+ #define FxaaTexOffAlpha4(t, p, o) t.tex.GatherAlpha(t.smpl, p, o)
+ #define FxaaTexGreen4(t, p) t.tex.GatherGreen(t.smpl, p)
+ #define FxaaTexOffGreen4(t, p, o) t.tex.GatherGreen(t.smpl, p, o)
+#endif
+
+
+/*============================================================================
+ GREEN AS LUMA OPTION SUPPORT FUNCTION
+============================================================================*/
+#if (FXAA_GREEN_AS_LUMA == 0)
+ FxaaFloat FxaaLuma(FxaaFloat4 rgba) { return rgba.w; }
+#else
+ FxaaFloat FxaaLuma(FxaaFloat4 rgba) { return rgba.y; }
+#endif
+
+
+
+
+/*============================================================================
+
+ FXAA3 QUALITY - PC
+
+============================================================================*/
+#if (FXAA_PC == 1)
+/*--------------------------------------------------------------------------*/
+FxaaFloat4 FxaaPixelShader(
+ //
+ // Use noperspective interpolation here (turn off perspective interpolation).
+ // {xy} = center of pixel
+ FxaaFloat2 pos,
+ //
+ // Used only for FXAA Console, and not used on the 360 version.
+ // Use noperspective interpolation here (turn off perspective interpolation).
+ // {xy__} = upper left of pixel
+ // {__zw} = lower right of pixel
+ FxaaFloat4 fxaaConsolePosPos,
+ //
+ // Input color texture.
+ // {rgb_} = color in linear or perceptual color space
+ // if (FXAA_GREEN_AS_LUMA == 0)
+ // {___a} = luma in perceptual color space (not linear)
+ FxaaTex tex,
+ //
+ // Only used on the optimized 360 version of FXAA Console.
+ // For everything but 360, just use the same input here as for "tex".
+ // For 360, same texture, just alias with a 2nd sampler.
+ // This sampler needs to have an exponent bias of -1.
+ FxaaTex fxaaConsole360TexExpBiasNegOne,
+ //
+ // Only used on the optimized 360 version of FXAA Console.
+ // For everything but 360, just use the same input here as for "tex".
+ // For 360, same texture, just alias with a 3nd sampler.
+ // This sampler needs to have an exponent bias of -2.
+ FxaaTex fxaaConsole360TexExpBiasNegTwo,
+ //
+ // Only used on FXAA Quality.
+ // This must be from a constant/uniform.
+ // {x_} = 1.0/screenWidthInPixels
+ // {_y} = 1.0/screenHeightInPixels
+ FxaaFloat2 fxaaQualityRcpFrame,
+ //
+ // Only used on FXAA Console.
+ // This must be from a constant/uniform.
+ // This effects sub-pixel AA quality and inversely sharpness.
+ // Where N ranges between,
+ // N = 0.50 (default)
+ // N = 0.33 (sharper)
+ // {x___} = -N/screenWidthInPixels
+ // {_y__} = -N/screenHeightInPixels
+ // {__z_} = N/screenWidthInPixels
+ // {___w} = N/screenHeightInPixels
+ FxaaFloat4 fxaaConsoleRcpFrameOpt,
+ //
+ // Only used on FXAA Console.
+ // Not used on 360, but used on PS3 and PC.
+ // This must be from a constant/uniform.
+ // {x___} = -2.0/screenWidthInPixels
+ // {_y__} = -2.0/screenHeightInPixels
+ // {__z_} = 2.0/screenWidthInPixels
+ // {___w} = 2.0/screenHeightInPixels
+ FxaaFloat4 fxaaConsoleRcpFrameOpt2,
+ //
+ // Only used on FXAA Console.
+ // Only used on 360 in place of fxaaConsoleRcpFrameOpt2.
+ // This must be from a constant/uniform.
+ // {x___} = 8.0/screenWidthInPixels
+ // {_y__} = 8.0/screenHeightInPixels
+ // {__z_} = -4.0/screenWidthInPixels
+ // {___w} = -4.0/screenHeightInPixels
+ FxaaFloat4 fxaaConsole360RcpFrameOpt2,
+ //
+ // Only used on FXAA Quality.
+ // This used to be the FXAA_QUALITY__SUBPIX define.
+ // It is here now to allow easier tuning.
+ // Choose the amount of sub-pixel aliasing removal.
+ // This can effect sharpness.
+ // 1.00 - upper limit (softer)
+ // 0.75 - default amount of filtering
+ // 0.50 - lower limit (sharper, less sub-pixel aliasing removal)
+ // 0.25 - almost off
+ // 0.00 - completely off
+ FxaaFloat fxaaQualitySubpix,
+ //
+ // Only used on FXAA Quality.
+ // This used to be the FXAA_QUALITY__EDGE_THRESHOLD define.
+ // It is here now to allow easier tuning.
+ // The minimum amount of local contrast required to apply algorithm.
+ // 0.333 - too little (faster)
+ // 0.250 - low quality
+ // 0.166 - default
+ // 0.125 - high quality
+ // 0.063 - overkill (slower)
+ FxaaFloat fxaaQualityEdgeThreshold,
+ //
+ // Only used on FXAA Quality.
+ // This used to be the FXAA_QUALITY__EDGE_THRESHOLD_MIN define.
+ // It is here now to allow easier tuning.
+ // Trims the algorithm from processing darks.
+ // 0.0833 - upper limit (default, the start of visible unfiltered edges)
+ // 0.0625 - high quality (faster)
+ // 0.0312 - visible limit (slower)
+ // Special notes when using FXAA_GREEN_AS_LUMA,
+ // Likely want to set this to zero.
+ // As colors that are mostly not-green
+ // will appear very dark in the green channel!
+ // Tune by looking at mostly non-green content,
+ // then start at zero and increase until aliasing is a problem.
+ FxaaFloat fxaaQualityEdgeThresholdMin,
+ //
+ // Only used on FXAA Console.
+ // This used to be the FXAA_CONSOLE__EDGE_SHARPNESS define.
+ // It is here now to allow easier tuning.
+ // This does not effect PS3, as this needs to be compiled in.
+ // Use FXAA_CONSOLE__PS3_EDGE_SHARPNESS for PS3.
+ // Due to the PS3 being ALU bound,
+ // there are only three safe values here: 2 and 4 and 8.
+ // These options use the shaders ability to a free *|/ by 2|4|8.
+ // For all other platforms can be a non-power of two.
+ // 8.0 is sharper (default!!!)
+ // 4.0 is softer
+ // 2.0 is really soft (good only for vector graphics inputs)
+ FxaaFloat fxaaConsoleEdgeSharpness,
+ //
+ // Only used on FXAA Console.
+ // This used to be the FXAA_CONSOLE__EDGE_THRESHOLD define.
+ // It is here now to allow easier tuning.
+ // This does not effect PS3, as this needs to be compiled in.
+ // Use FXAA_CONSOLE__PS3_EDGE_THRESHOLD for PS3.
+ // Due to the PS3 being ALU bound,
+ // there are only two safe values here: 1/4 and 1/8.
+ // These options use the shaders ability to a free *|/ by 2|4|8.
+ // The console setting has a different mapping than the quality setting.
+ // Other platforms can use other values.
+ // 0.125 leaves less aliasing, but is softer (default!!!)
+ // 0.25 leaves more aliasing, and is sharper
+ FxaaFloat fxaaConsoleEdgeThreshold,
+ //
+ // Only used on FXAA Console.
+ // This used to be the FXAA_CONSOLE__EDGE_THRESHOLD_MIN define.
+ // It is here now to allow easier tuning.
+ // Trims the algorithm from processing darks.
+ // The console setting has a different mapping than the quality setting.
+ // This only applies when FXAA_EARLY_EXIT is 1.
+ // This does not apply to PS3,
+ // PS3 was simplified to avoid more shader instructions.
+ // 0.06 - faster but more aliasing in darks
+ // 0.05 - default
+ // 0.04 - slower and less aliasing in darks
+ // Special notes when using FXAA_GREEN_AS_LUMA,
+ // Likely want to set this to zero.
+ // As colors that are mostly not-green
+ // will appear very dark in the green channel!
+ // Tune by looking at mostly non-green content,
+ // then start at zero and increase until aliasing is a problem.
+ FxaaFloat fxaaConsoleEdgeThresholdMin,
+ //
+ // Extra constants for 360 FXAA Console only.
+ // Use zeros or anything else for other platforms.
+ // These must be in physical constant registers and NOT immedates.
+ // Immedates will result in compiler un-optimizing.
+ // {xyzw} = float4(1.0, -1.0, 0.25, -0.25)
+ FxaaFloat4 fxaaConsole360ConstDir
+) {
+/*--------------------------------------------------------------------------*/
+ FxaaFloat2 posM;
+ posM.x = pos.x;
+ posM.y = pos.y;
+ #if (FXAA_GATHER4_ALPHA == 1)
+ #if (FXAA_DISCARD == 0)
+ FxaaFloat4 rgbyM = FxaaTexTop(tex, posM);
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ #define lumaM rgbyM.w
+ #else
+ #define lumaM rgbyM.y
+ #endif
+ #endif
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ FxaaFloat4 luma4A = FxaaTexAlpha4(tex, posM);
+ FxaaFloat4 luma4B = FxaaTexOffAlpha4(tex, posM, FxaaInt2(-1, -1));
+ #else
+ FxaaFloat4 luma4A = FxaaTexGreen4(tex, posM);
+ FxaaFloat4 luma4B = FxaaTexOffGreen4(tex, posM, FxaaInt2(-1, -1));
+ #endif
+ #if (FXAA_DISCARD == 1)
+ #define lumaM luma4A.w
+ #endif
+ #define lumaE luma4A.z
+ #define lumaS luma4A.x
+ #define lumaSE luma4A.y
+ #define lumaNW luma4B.w
+ #define lumaN luma4B.z
+ #define lumaW luma4B.x
+ #else
+ FxaaFloat4 rgbyM = FxaaTexTop(tex, posM);
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ #define lumaM rgbyM.w
+ #else
+ #define lumaM rgbyM.y
+ #endif
+ FxaaFloat lumaS = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 0, 1), fxaaQualityRcpFrame.xy));
+ FxaaFloat lumaE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 1, 0), fxaaQualityRcpFrame.xy));
+ FxaaFloat lumaN = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 0,-1), fxaaQualityRcpFrame.xy));
+ FxaaFloat lumaW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1, 0), fxaaQualityRcpFrame.xy));
+ #endif
+/*--------------------------------------------------------------------------*/
+ FxaaFloat maxSM = max(lumaS, lumaM);
+ FxaaFloat minSM = min(lumaS, lumaM);
+ FxaaFloat maxESM = max(lumaE, maxSM);
+ FxaaFloat minESM = min(lumaE, minSM);
+ FxaaFloat maxWN = max(lumaN, lumaW);
+ FxaaFloat minWN = min(lumaN, lumaW);
+ FxaaFloat rangeMax = max(maxWN, maxESM);
+ FxaaFloat rangeMin = min(minWN, minESM);
+ FxaaFloat rangeMaxScaled = rangeMax * fxaaQualityEdgeThreshold;
+ FxaaFloat range = rangeMax - rangeMin;
+ FxaaFloat rangeMaxClamped = max(fxaaQualityEdgeThresholdMin, rangeMaxScaled);
+ FxaaBool earlyExit = range < rangeMaxClamped;
+/*--------------------------------------------------------------------------*/
+ if(earlyExit)
+ #if (FXAA_DISCARD == 1)
+ FxaaDiscard;
+ #else
+ return rgbyM;
+ #endif
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_GATHER4_ALPHA == 0)
+ FxaaFloat lumaNW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1,-1), fxaaQualityRcpFrame.xy));
+ FxaaFloat lumaSE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 1, 1), fxaaQualityRcpFrame.xy));
+ FxaaFloat lumaNE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2( 1,-1), fxaaQualityRcpFrame.xy));
+ FxaaFloat lumaSW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1, 1), fxaaQualityRcpFrame.xy));
+ #else
+ FxaaFloat lumaNE = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(1, -1), fxaaQualityRcpFrame.xy));
+ FxaaFloat lumaSW = FxaaLuma(FxaaTexOff(tex, posM, FxaaInt2(-1, 1), fxaaQualityRcpFrame.xy));
+ #endif
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaNS = lumaN + lumaS;
+ FxaaFloat lumaWE = lumaW + lumaE;
+ FxaaFloat subpixRcpRange = 1.0/range;
+ FxaaFloat subpixNSWE = lumaNS + lumaWE;
+ FxaaFloat edgeHorz1 = (-2.0 * lumaM) + lumaNS;
+ FxaaFloat edgeVert1 = (-2.0 * lumaM) + lumaWE;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaNESE = lumaNE + lumaSE;
+ FxaaFloat lumaNWNE = lumaNW + lumaNE;
+ FxaaFloat edgeHorz2 = (-2.0 * lumaE) + lumaNESE;
+ FxaaFloat edgeVert2 = (-2.0 * lumaN) + lumaNWNE;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaNWSW = lumaNW + lumaSW;
+ FxaaFloat lumaSWSE = lumaSW + lumaSE;
+ FxaaFloat edgeHorz4 = (abs(edgeHorz1) * 2.0) + abs(edgeHorz2);
+ FxaaFloat edgeVert4 = (abs(edgeVert1) * 2.0) + abs(edgeVert2);
+ FxaaFloat edgeHorz3 = (-2.0 * lumaW) + lumaNWSW;
+ FxaaFloat edgeVert3 = (-2.0 * lumaS) + lumaSWSE;
+ FxaaFloat edgeHorz = abs(edgeHorz3) + edgeHorz4;
+ FxaaFloat edgeVert = abs(edgeVert3) + edgeVert4;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat subpixNWSWNESE = lumaNWSW + lumaNESE;
+ FxaaFloat lengthSign = fxaaQualityRcpFrame.x;
+ FxaaBool horzSpan = edgeHorz >= edgeVert;
+ FxaaFloat subpixA = subpixNSWE * 2.0 + subpixNWSWNESE;
+/*--------------------------------------------------------------------------*/
+ if(!horzSpan) lumaN = lumaW;
+ if(!horzSpan) lumaS = lumaE;
+ if(horzSpan) lengthSign = fxaaQualityRcpFrame.y;
+ FxaaFloat subpixB = (subpixA * (1.0/12.0)) - lumaM;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat gradientN = lumaN - lumaM;
+ FxaaFloat gradientS = lumaS - lumaM;
+ FxaaFloat lumaNN = lumaN + lumaM;
+ FxaaFloat lumaSS = lumaS + lumaM;
+ FxaaBool pairN = abs(gradientN) >= abs(gradientS);
+ FxaaFloat gradient = max(abs(gradientN), abs(gradientS));
+ if(pairN) lengthSign = -lengthSign;
+ FxaaFloat subpixC = FxaaSat(abs(subpixB) * subpixRcpRange);
+/*--------------------------------------------------------------------------*/
+ FxaaFloat2 posB;
+ posB.x = posM.x;
+ posB.y = posM.y;
+ FxaaFloat2 offNP;
+ offNP.x = (!horzSpan) ? 0.0 : fxaaQualityRcpFrame.x;
+ offNP.y = ( horzSpan) ? 0.0 : fxaaQualityRcpFrame.y;
+ if(!horzSpan) posB.x += lengthSign * 0.5;
+ if( horzSpan) posB.y += lengthSign * 0.5;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat2 posN;
+ posN.x = posB.x - offNP.x * FXAA_QUALITY__P0;
+ posN.y = posB.y - offNP.y * FXAA_QUALITY__P0;
+ FxaaFloat2 posP;
+ posP.x = posB.x + offNP.x * FXAA_QUALITY__P0;
+ posP.y = posB.y + offNP.y * FXAA_QUALITY__P0;
+ FxaaFloat subpixD = ((-2.0)*subpixC) + 3.0;
+ FxaaFloat lumaEndN = FxaaLuma(FxaaTexTop(tex, posN));
+ FxaaFloat subpixE = subpixC * subpixC;
+ FxaaFloat lumaEndP = FxaaLuma(FxaaTexTop(tex, posP));
+/*--------------------------------------------------------------------------*/
+ if(!pairN) lumaNN = lumaSS;
+ FxaaFloat gradientScaled = gradient * 1.0/4.0;
+ FxaaFloat lumaMM = lumaM - lumaNN * 0.5;
+ FxaaFloat subpixF = subpixD * subpixE;
+ FxaaBool lumaMLTZero = lumaMM < 0.0;
+/*--------------------------------------------------------------------------*/
+ lumaEndN -= lumaNN * 0.5;
+ lumaEndP -= lumaNN * 0.5;
+ FxaaBool doneN = abs(lumaEndN) >= gradientScaled;
+ FxaaBool doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P1;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P1;
+ FxaaBool doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P1;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P1;
+/*--------------------------------------------------------------------------*/
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P2;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P2;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P2;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P2;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 3)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P3;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P3;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P3;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P3;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 4)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P4;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P4;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P4;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P4;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 5)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P5;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P5;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P5;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P5;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 6)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P6;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P6;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P6;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P6;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 7)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P7;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P7;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P7;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P7;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 8)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P8;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P8;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P8;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P8;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 9)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P9;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P9;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P9;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P9;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 10)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P10;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P10;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P10;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P10;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 11)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P11;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P11;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P11;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P11;
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_QUALITY__PS > 12)
+ if(doneNP) {
+ if(!doneN) lumaEndN = FxaaLuma(FxaaTexTop(tex, posN.xy));
+ if(!doneP) lumaEndP = FxaaLuma(FxaaTexTop(tex, posP.xy));
+ if(!doneN) lumaEndN = lumaEndN - lumaNN * 0.5;
+ if(!doneP) lumaEndP = lumaEndP - lumaNN * 0.5;
+ doneN = abs(lumaEndN) >= gradientScaled;
+ doneP = abs(lumaEndP) >= gradientScaled;
+ if(!doneN) posN.x -= offNP.x * FXAA_QUALITY__P12;
+ if(!doneN) posN.y -= offNP.y * FXAA_QUALITY__P12;
+ doneNP = (!doneN) || (!doneP);
+ if(!doneP) posP.x += offNP.x * FXAA_QUALITY__P12;
+ if(!doneP) posP.y += offNP.y * FXAA_QUALITY__P12;
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+ #endif
+/*--------------------------------------------------------------------------*/
+ }
+/*--------------------------------------------------------------------------*/
+ FxaaFloat dstN = posM.x - posN.x;
+ FxaaFloat dstP = posP.x - posM.x;
+ if(!horzSpan) dstN = posM.y - posN.y;
+ if(!horzSpan) dstP = posP.y - posM.y;
+/*--------------------------------------------------------------------------*/
+ FxaaBool goodSpanN = (lumaEndN < 0.0) != lumaMLTZero;
+ FxaaFloat spanLength = (dstP + dstN);
+ FxaaBool goodSpanP = (lumaEndP < 0.0) != lumaMLTZero;
+ FxaaFloat spanLengthRcp = 1.0/spanLength;
+/*--------------------------------------------------------------------------*/
+ FxaaBool directionN = dstN < dstP;
+ FxaaFloat dst = min(dstN, dstP);
+ FxaaBool goodSpan = directionN ? goodSpanN : goodSpanP;
+ FxaaFloat subpixG = subpixF * subpixF;
+ FxaaFloat pixelOffset = (dst * (-spanLengthRcp)) + 0.5;
+ FxaaFloat subpixH = subpixG * fxaaQualitySubpix;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat pixelOffsetGood = goodSpan ? pixelOffset : 0.0;
+ FxaaFloat pixelOffsetSubpix = max(pixelOffsetGood, subpixH);
+ if(!horzSpan) posM.x += pixelOffsetSubpix * lengthSign;
+ if( horzSpan) posM.y += pixelOffsetSubpix * lengthSign;
+ #if (FXAA_DISCARD == 1)
+ return FxaaTexTop(tex, posM);
+ #else
+ return FxaaFloat4(FxaaTexTop(tex, posM).xyz, lumaM);
+ #endif
+}
+/*==========================================================================*/
+#endif
+
+
+
+
+/*============================================================================
+
+ FXAA3 CONSOLE - PC VERSION
+
+------------------------------------------------------------------------------
+Instead of using this on PC, I'd suggest just using FXAA Quality with
+ #define FXAA_QUALITY__PRESET 10
+Or
+ #define FXAA_QUALITY__PRESET 20
+Either are higher qualilty and almost as fast as this on modern PC GPUs.
+============================================================================*/
+#if (FXAA_PC_CONSOLE == 1)
+/*--------------------------------------------------------------------------*/
+FxaaFloat4 FxaaPixelShader(
+ // See FXAA Quality FxaaPixelShader() source for docs on Inputs!
+ FxaaFloat2 pos,
+ FxaaFloat4 fxaaConsolePosPos,
+ FxaaTex tex,
+ FxaaTex fxaaConsole360TexExpBiasNegOne,
+ FxaaTex fxaaConsole360TexExpBiasNegTwo,
+ FxaaFloat2 fxaaQualityRcpFrame,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt2,
+ FxaaFloat4 fxaaConsole360RcpFrameOpt2,
+ FxaaFloat fxaaQualitySubpix,
+ FxaaFloat fxaaQualityEdgeThreshold,
+ FxaaFloat fxaaQualityEdgeThresholdMin,
+ FxaaFloat fxaaConsoleEdgeSharpness,
+ FxaaFloat fxaaConsoleEdgeThreshold,
+ FxaaFloat fxaaConsoleEdgeThresholdMin,
+ FxaaFloat4 fxaaConsole360ConstDir
+) {
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaNw = FxaaLuma(FxaaTexTop(tex, fxaaConsolePosPos.xy));
+ FxaaFloat lumaSw = FxaaLuma(FxaaTexTop(tex, fxaaConsolePosPos.xw));
+ FxaaFloat lumaNe = FxaaLuma(FxaaTexTop(tex, fxaaConsolePosPos.zy));
+ FxaaFloat lumaSe = FxaaLuma(FxaaTexTop(tex, fxaaConsolePosPos.zw));
+/*--------------------------------------------------------------------------*/
+ FxaaFloat4 rgbyM = FxaaTexTop(tex, pos.xy);
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ FxaaFloat lumaM = rgbyM.w;
+ #else
+ FxaaFloat lumaM = rgbyM.y;
+ #endif
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaMaxNwSw = max(lumaNw, lumaSw);
+ lumaNe += 1.0/384.0;
+ FxaaFloat lumaMinNwSw = min(lumaNw, lumaSw);
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaMaxNeSe = max(lumaNe, lumaSe);
+ FxaaFloat lumaMinNeSe = min(lumaNe, lumaSe);
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaMax = max(lumaMaxNeSe, lumaMaxNwSw);
+ FxaaFloat lumaMin = min(lumaMinNeSe, lumaMinNwSw);
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaMaxScaled = lumaMax * fxaaConsoleEdgeThreshold;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat lumaMinM = min(lumaMin, lumaM);
+ FxaaFloat lumaMaxScaledClamped = max(fxaaConsoleEdgeThresholdMin, lumaMaxScaled);
+ FxaaFloat lumaMaxM = max(lumaMax, lumaM);
+ FxaaFloat dirSwMinusNe = lumaSw - lumaNe;
+ FxaaFloat lumaMaxSubMinM = lumaMaxM - lumaMinM;
+ FxaaFloat dirSeMinusNw = lumaSe - lumaNw;
+ if(lumaMaxSubMinM < lumaMaxScaledClamped) return rgbyM;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat2 dir;
+ dir.x = dirSwMinusNe + dirSeMinusNw;
+ dir.y = dirSwMinusNe - dirSeMinusNw;
+/*--------------------------------------------------------------------------*/
+ FxaaFloat2 dir1 = normalize(dir.xy);
+ FxaaFloat4 rgbyN1 = FxaaTexTop(tex, pos.xy - dir1 * fxaaConsoleRcpFrameOpt.zw);
+ FxaaFloat4 rgbyP1 = FxaaTexTop(tex, pos.xy + dir1 * fxaaConsoleRcpFrameOpt.zw);
+/*--------------------------------------------------------------------------*/
+ FxaaFloat dirAbsMinTimesC = min(abs(dir1.x), abs(dir1.y)) * fxaaConsoleEdgeSharpness;
+ FxaaFloat2 dir2 = clamp(dir1.xy / dirAbsMinTimesC, -2.0, 2.0);
+/*--------------------------------------------------------------------------*/
+ FxaaFloat4 rgbyN2 = FxaaTexTop(tex, pos.xy - dir2 * fxaaConsoleRcpFrameOpt2.zw);
+ FxaaFloat4 rgbyP2 = FxaaTexTop(tex, pos.xy + dir2 * fxaaConsoleRcpFrameOpt2.zw);
+/*--------------------------------------------------------------------------*/
+ FxaaFloat4 rgbyA = rgbyN1 + rgbyP1;
+ FxaaFloat4 rgbyB = ((rgbyN2 + rgbyP2) * 0.25) + (rgbyA * 0.25);
+/*--------------------------------------------------------------------------*/
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ FxaaBool twoTap = (rgbyB.w < lumaMin) || (rgbyB.w > lumaMax);
+ #else
+ FxaaBool twoTap = (rgbyB.y < lumaMin) || (rgbyB.y > lumaMax);
+ #endif
+ if(twoTap) rgbyB.xyz = rgbyA.xyz * 0.5;
+ return rgbyB; }
+/*==========================================================================*/
+#endif
+
+
+
+/*============================================================================
+
+ FXAA3 CONSOLE - 360 PIXEL SHADER
+
+------------------------------------------------------------------------------
+This optimized version thanks to suggestions from Andy Luedke.
+Should be fully tex bound in all cases.
+As of the FXAA 3.11 release, I have still not tested this code,
+however I fixed a bug which was in both FXAA 3.9 and FXAA 3.10.
+And note this is replacing the old unoptimized version.
+If it does not work, please let me know so I can fix it.
+============================================================================*/
+#if (FXAA_360 == 1)
+/*--------------------------------------------------------------------------*/
+[reduceTempRegUsage(4)]
+float4 FxaaPixelShader(
+ // See FXAA Quality FxaaPixelShader() source for docs on Inputs!
+ FxaaFloat2 pos,
+ FxaaFloat4 fxaaConsolePosPos,
+ FxaaTex tex,
+ FxaaTex fxaaConsole360TexExpBiasNegOne,
+ FxaaTex fxaaConsole360TexExpBiasNegTwo,
+ FxaaFloat2 fxaaQualityRcpFrame,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt2,
+ FxaaFloat4 fxaaConsole360RcpFrameOpt2,
+ FxaaFloat fxaaQualitySubpix,
+ FxaaFloat fxaaQualityEdgeThreshold,
+ FxaaFloat fxaaQualityEdgeThresholdMin,
+ FxaaFloat fxaaConsoleEdgeSharpness,
+ FxaaFloat fxaaConsoleEdgeThreshold,
+ FxaaFloat fxaaConsoleEdgeThresholdMin,
+ FxaaFloat4 fxaaConsole360ConstDir
+) {
+/*--------------------------------------------------------------------------*/
+ float4 lumaNwNeSwSe;
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ asm {
+ tfetch2D lumaNwNeSwSe.w___, tex, pos.xy, OffsetX = -0.5, OffsetY = -0.5, UseComputedLOD=false
+ tfetch2D lumaNwNeSwSe._w__, tex, pos.xy, OffsetX = 0.5, OffsetY = -0.5, UseComputedLOD=false
+ tfetch2D lumaNwNeSwSe.__w_, tex, pos.xy, OffsetX = -0.5, OffsetY = 0.5, UseComputedLOD=false
+ tfetch2D lumaNwNeSwSe.___w, tex, pos.xy, OffsetX = 0.5, OffsetY = 0.5, UseComputedLOD=false
+ };
+ #else
+ asm {
+ tfetch2D lumaNwNeSwSe.y___, tex, pos.xy, OffsetX = -0.5, OffsetY = -0.5, UseComputedLOD=false
+ tfetch2D lumaNwNeSwSe._y__, tex, pos.xy, OffsetX = 0.5, OffsetY = -0.5, UseComputedLOD=false
+ tfetch2D lumaNwNeSwSe.__y_, tex, pos.xy, OffsetX = -0.5, OffsetY = 0.5, UseComputedLOD=false
+ tfetch2D lumaNwNeSwSe.___y, tex, pos.xy, OffsetX = 0.5, OffsetY = 0.5, UseComputedLOD=false
+ };
+ #endif
+/*--------------------------------------------------------------------------*/
+ lumaNwNeSwSe.y += 1.0/384.0;
+ float2 lumaMinTemp = min(lumaNwNeSwSe.xy, lumaNwNeSwSe.zw);
+ float2 lumaMaxTemp = max(lumaNwNeSwSe.xy, lumaNwNeSwSe.zw);
+ float lumaMin = min(lumaMinTemp.x, lumaMinTemp.y);
+ float lumaMax = max(lumaMaxTemp.x, lumaMaxTemp.y);
+/*--------------------------------------------------------------------------*/
+ float4 rgbyM = tex2Dlod(tex, float4(pos.xy, 0.0, 0.0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ float lumaMinM = min(lumaMin, rgbyM.w);
+ float lumaMaxM = max(lumaMax, rgbyM.w);
+ #else
+ float lumaMinM = min(lumaMin, rgbyM.y);
+ float lumaMaxM = max(lumaMax, rgbyM.y);
+ #endif
+ if((lumaMaxM - lumaMinM) < max(fxaaConsoleEdgeThresholdMin, lumaMax * fxaaConsoleEdgeThreshold)) return rgbyM;
+/*--------------------------------------------------------------------------*/
+ float2 dir;
+ dir.x = dot(lumaNwNeSwSe, fxaaConsole360ConstDir.yyxx);
+ dir.y = dot(lumaNwNeSwSe, fxaaConsole360ConstDir.xyxy);
+ dir = normalize(dir);
+/*--------------------------------------------------------------------------*/
+ float4 dir1 = dir.xyxy * fxaaConsoleRcpFrameOpt.xyzw;
+/*--------------------------------------------------------------------------*/
+ float4 dir2;
+ float dirAbsMinTimesC = min(abs(dir.x), abs(dir.y)) * fxaaConsoleEdgeSharpness;
+ dir2 = saturate(fxaaConsole360ConstDir.zzww * dir.xyxy / dirAbsMinTimesC + 0.5);
+ dir2 = dir2 * fxaaConsole360RcpFrameOpt2.xyxy + fxaaConsole360RcpFrameOpt2.zwzw;
+/*--------------------------------------------------------------------------*/
+ float4 rgbyN1 = tex2Dlod(fxaaConsole360TexExpBiasNegOne, float4(pos.xy + dir1.xy, 0.0, 0.0));
+ float4 rgbyP1 = tex2Dlod(fxaaConsole360TexExpBiasNegOne, float4(pos.xy + dir1.zw, 0.0, 0.0));
+ float4 rgbyN2 = tex2Dlod(fxaaConsole360TexExpBiasNegTwo, float4(pos.xy + dir2.xy, 0.0, 0.0));
+ float4 rgbyP2 = tex2Dlod(fxaaConsole360TexExpBiasNegTwo, float4(pos.xy + dir2.zw, 0.0, 0.0));
+/*--------------------------------------------------------------------------*/
+ float4 rgbyA = rgbyN1 + rgbyP1;
+ float4 rgbyB = rgbyN2 + rgbyP2 + rgbyA * 0.5;
+/*--------------------------------------------------------------------------*/
+ float4 rgbyR = ((FxaaLuma(rgbyB) - lumaMax) > 0.0) ? rgbyA : rgbyB;
+ rgbyR = ((FxaaLuma(rgbyB) - lumaMin) > 0.0) ? rgbyR : rgbyA;
+ return rgbyR; }
+/*==========================================================================*/
+#endif
+
+
+
+/*============================================================================
+
+ FXAA3 CONSOLE - OPTIMIZED PS3 PIXEL SHADER (NO EARLY EXIT)
+
+==============================================================================
+The code below does not exactly match the assembly.
+I have a feeling that 12 cycles is possible, but was not able to get there.
+Might have to increase register count to get full performance.
+Note this shader does not use perspective interpolation.
+
+Use the following cgc options,
+
+ --fenable-bx2 --fastmath --fastprecision --nofloatbindings
+
+------------------------------------------------------------------------------
+ NVSHADERPERF OUTPUT
+------------------------------------------------------------------------------
+For reference and to aid in debug, output of NVShaderPerf should match this,
+
+Shader to schedule:
+ 0: texpkb h0.w(TRUE), v5.zyxx, #0
+ 2: addh h2.z(TRUE), h0.w, constant(0.001953, 0.000000, 0.000000, 0.000000).x
+ 4: texpkb h0.w(TRUE), v5.xwxx, #0
+ 6: addh h0.z(TRUE), -h2, h0.w
+ 7: texpkb h1.w(TRUE), v5, #0
+ 9: addh h0.x(TRUE), h0.z, -h1.w
+ 10: addh h3.w(TRUE), h0.z, h1
+ 11: texpkb h2.w(TRUE), v5.zwzz, #0
+ 13: addh h0.z(TRUE), h3.w, -h2.w
+ 14: addh h0.x(TRUE), h2.w, h0
+ 15: nrmh h1.xz(TRUE), h0_n
+ 16: minh_m8 h0.x(TRUE), |h1|, |h1.z|
+ 17: maxh h4.w(TRUE), h0, h1
+ 18: divx h2.xy(TRUE), h1_n.xzzw, h0_n
+ 19: movr r1.zw(TRUE), v4.xxxy
+ 20: madr r2.xz(TRUE), -h1, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w).zzww, r1.zzww
+ 22: minh h5.w(TRUE), h0, h1
+ 23: texpkb h0(TRUE), r2.xzxx, #0
+ 25: madr r0.zw(TRUE), h1.xzxz, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w), r1
+ 27: maxh h4.x(TRUE), h2.z, h2.w
+ 28: texpkb h1(TRUE), r0.zwzz, #0
+ 30: addh_d2 h1(TRUE), h0, h1
+ 31: madr r0.xy(TRUE), -h2, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w).xyxx, r1.zwzz
+ 33: texpkb h0(TRUE), r0, #0
+ 35: minh h4.z(TRUE), h2, h2.w
+ 36: fenct TRUE
+ 37: madr r1.xy(TRUE), h2, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w).xyxx, r1.zwzz
+ 39: texpkb h2(TRUE), r1, #0
+ 41: addh_d2 h0(TRUE), h0, h2
+ 42: maxh h2.w(TRUE), h4, h4.x
+ 43: minh h2.x(TRUE), h5.w, h4.z
+ 44: addh_d2 h0(TRUE), h0, h1
+ 45: slth h2.x(TRUE), h0.w, h2
+ 46: sgth h2.w(TRUE), h0, h2
+ 47: movh h0(TRUE), h0
+ 48: addx.c0 rc(TRUE), h2, h2.w
+ 49: movh h0(c0.NE.x), h1
+
+IPU0 ------ Simplified schedule: --------
+Pass | Unit | uOp | PC: Op
+-----+--------+------+-------------------------
+ 1 | SCT0/1 | mov | 0: TXLr h0.w, g[TEX1].zyxx, const.xxxx, TEX0;
+ | TEX | txl | 0: TXLr h0.w, g[TEX1].zyxx, const.xxxx, TEX0;
+ | SCB1 | add | 2: ADDh h2.z, h0.--w-, const.--x-;
+ | | |
+ 2 | SCT0/1 | mov | 4: TXLr h0.w, g[TEX1].xwxx, const.xxxx, TEX0;
+ | TEX | txl | 4: TXLr h0.w, g[TEX1].xwxx, const.xxxx, TEX0;
+ | SCB1 | add | 6: ADDh h0.z,-h2, h0.--w-;
+ | | |
+ 3 | SCT0/1 | mov | 7: TXLr h1.w, g[TEX1], const.xxxx, TEX0;
+ | TEX | txl | 7: TXLr h1.w, g[TEX1], const.xxxx, TEX0;
+ | SCB0 | add | 9: ADDh h0.x, h0.z---,-h1.w---;
+ | SCB1 | add | 10: ADDh h3.w, h0.---z, h1;
+ | | |
+ 4 | SCT0/1 | mov | 11: TXLr h2.w, g[TEX1].zwzz, const.xxxx, TEX0;
+ | TEX | txl | 11: TXLr h2.w, g[TEX1].zwzz, const.xxxx, TEX0;
+ | SCB0 | add | 14: ADDh h0.x, h2.w---, h0;
+ | SCB1 | add | 13: ADDh h0.z, h3.--w-,-h2.--w-;
+ | | |
+ 5 | SCT1 | mov | 15: NRMh h1.xz, h0;
+ | SRB | nrm | 15: NRMh h1.xz, h0;
+ | SCB0 | min | 16: MINh*8 h0.x, |h1|, |h1.z---|;
+ | SCB1 | max | 17: MAXh h4.w, h0, h1;
+ | | |
+ 6 | SCT0 | div | 18: DIVx h2.xy, h1.xz--, h0;
+ | SCT1 | mov | 19: MOVr r1.zw, g[TEX0].--xy;
+ | SCB0 | mad | 20: MADr r2.xz,-h1, const.z-w-, r1.z-w-;
+ | SCB1 | min | 22: MINh h5.w, h0, h1;
+ | | |
+ 7 | SCT0/1 | mov | 23: TXLr h0, r2.xzxx, const.xxxx, TEX0;
+ | TEX | txl | 23: TXLr h0, r2.xzxx, const.xxxx, TEX0;
+ | SCB0 | max | 27: MAXh h4.x, h2.z---, h2.w---;
+ | SCB1 | mad | 25: MADr r0.zw, h1.--xz, const, r1;
+ | | |
+ 8 | SCT0/1 | mov | 28: TXLr h1, r0.zwzz, const.xxxx, TEX0;
+ | TEX | txl | 28: TXLr h1, r0.zwzz, const.xxxx, TEX0;
+ | SCB0/1 | add | 30: ADDh/2 h1, h0, h1;
+ | | |
+ 9 | SCT0 | mad | 31: MADr r0.xy,-h2, const.xy--, r1.zw--;
+ | SCT1 | mov | 33: TXLr h0, r0, const.zzzz, TEX0;
+ | TEX | txl | 33: TXLr h0, r0, const.zzzz, TEX0;
+ | SCB1 | min | 35: MINh h4.z, h2, h2.--w-;
+ | | |
+ 10 | SCT0 | mad | 37: MADr r1.xy, h2, const.xy--, r1.zw--;
+ | SCT1 | mov | 39: TXLr h2, r1, const.zzzz, TEX0;
+ | TEX | txl | 39: TXLr h2, r1, const.zzzz, TEX0;
+ | SCB0/1 | add | 41: ADDh/2 h0, h0, h2;
+ | | |
+ 11 | SCT0 | min | 43: MINh h2.x, h5.w---, h4.z---;
+ | SCT1 | max | 42: MAXh h2.w, h4, h4.---x;
+ | SCB0/1 | add | 44: ADDh/2 h0, h0, h1;
+ | | |
+ 12 | SCT0 | set | 45: SLTh h2.x, h0.w---, h2;
+ | SCT1 | set | 46: SGTh h2.w, h0, h2;
+ | SCB0/1 | mul | 47: MOVh h0, h0;
+ | | |
+ 13 | SCT0 | mad | 48: ADDxc0_s rc, h2, h2.w---;
+ | SCB0/1 | mul | 49: MOVh h0(NE0.xxxx), h1;
+
+Pass SCT TEX SCB
+ 1: 0% 100% 25%
+ 2: 0% 100% 25%
+ 3: 0% 100% 50%
+ 4: 0% 100% 50%
+ 5: 0% 0% 50%
+ 6: 100% 0% 75%
+ 7: 0% 100% 75%
+ 8: 0% 100% 100%
+ 9: 0% 100% 25%
+ 10: 0% 100% 100%
+ 11: 50% 0% 100%
+ 12: 50% 0% 100%
+ 13: 25% 0% 100%
+
+MEAN: 17% 61% 67%
+
+Pass SCT0 SCT1 TEX SCB0 SCB1
+ 1: 0% 0% 100% 0% 100%
+ 2: 0% 0% 100% 0% 100%
+ 3: 0% 0% 100% 100% 100%
+ 4: 0% 0% 100% 100% 100%
+ 5: 0% 0% 0% 100% 100%
+ 6: 100% 100% 0% 100% 100%
+ 7: 0% 0% 100% 100% 100%
+ 8: 0% 0% 100% 100% 100%
+ 9: 0% 0% 100% 0% 100%
+ 10: 0% 0% 100% 100% 100%
+ 11: 100% 100% 0% 100% 100%
+ 12: 100% 100% 0% 100% 100%
+ 13: 100% 0% 0% 100% 100%
+
+MEAN: 30% 23% 61% 76% 100%
+Fragment Performance Setup: Driver RSX Compiler, GPU RSX, Flags 0x5
+Results 13 cycles, 3 r regs, 923,076,923 pixels/s
+============================================================================*/
+#if (FXAA_PS3 == 1) && (FXAA_EARLY_EXIT == 0)
+/*--------------------------------------------------------------------------*/
+#pragma regcount 7
+#pragma disablepc all
+#pragma option O3
+#pragma option OutColorPrec=fp16
+#pragma texformat default RGBA8
+/*==========================================================================*/
+half4 FxaaPixelShader(
+ // See FXAA Quality FxaaPixelShader() source for docs on Inputs!
+ FxaaFloat2 pos,
+ FxaaFloat4 fxaaConsolePosPos,
+ FxaaTex tex,
+ FxaaTex fxaaConsole360TexExpBiasNegOne,
+ FxaaTex fxaaConsole360TexExpBiasNegTwo,
+ FxaaFloat2 fxaaQualityRcpFrame,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt2,
+ FxaaFloat4 fxaaConsole360RcpFrameOpt2,
+ FxaaFloat fxaaQualitySubpix,
+ FxaaFloat fxaaQualityEdgeThreshold,
+ FxaaFloat fxaaQualityEdgeThresholdMin,
+ FxaaFloat fxaaConsoleEdgeSharpness,
+ FxaaFloat fxaaConsoleEdgeThreshold,
+ FxaaFloat fxaaConsoleEdgeThresholdMin,
+ FxaaFloat4 fxaaConsole360ConstDir
+) {
+/*--------------------------------------------------------------------------*/
+// (1)
+ half4 dir;
+ half4 lumaNe = h4tex2Dlod(tex, half4(fxaaConsolePosPos.zy, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ lumaNe.w += half(1.0/512.0);
+ dir.x = -lumaNe.w;
+ dir.z = -lumaNe.w;
+ #else
+ lumaNe.y += half(1.0/512.0);
+ dir.x = -lumaNe.y;
+ dir.z = -lumaNe.y;
+ #endif
+/*--------------------------------------------------------------------------*/
+// (2)
+ half4 lumaSw = h4tex2Dlod(tex, half4(fxaaConsolePosPos.xw, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ dir.x += lumaSw.w;
+ dir.z += lumaSw.w;
+ #else
+ dir.x += lumaSw.y;
+ dir.z += lumaSw.y;
+ #endif
+/*--------------------------------------------------------------------------*/
+// (3)
+ half4 lumaNw = h4tex2Dlod(tex, half4(fxaaConsolePosPos.xy, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ dir.x -= lumaNw.w;
+ dir.z += lumaNw.w;
+ #else
+ dir.x -= lumaNw.y;
+ dir.z += lumaNw.y;
+ #endif
+/*--------------------------------------------------------------------------*/
+// (4)
+ half4 lumaSe = h4tex2Dlod(tex, half4(fxaaConsolePosPos.zw, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ dir.x += lumaSe.w;
+ dir.z -= lumaSe.w;
+ #else
+ dir.x += lumaSe.y;
+ dir.z -= lumaSe.y;
+ #endif
+/*--------------------------------------------------------------------------*/
+// (5)
+ half4 dir1_pos;
+ dir1_pos.xy = normalize(dir.xyz).xz;
+ half dirAbsMinTimesC = min(abs(dir1_pos.x), abs(dir1_pos.y)) * half(FXAA_CONSOLE__PS3_EDGE_SHARPNESS);
+/*--------------------------------------------------------------------------*/
+// (6)
+ half4 dir2_pos;
+ dir2_pos.xy = clamp(dir1_pos.xy / dirAbsMinTimesC, half(-2.0), half(2.0));
+ dir1_pos.zw = pos.xy;
+ dir2_pos.zw = pos.xy;
+ half4 temp1N;
+ temp1N.xy = dir1_pos.zw - dir1_pos.xy * fxaaConsoleRcpFrameOpt.zw;
+/*--------------------------------------------------------------------------*/
+// (7)
+ temp1N = h4tex2Dlod(tex, half4(temp1N.xy, 0.0, 0.0));
+ half4 rgby1;
+ rgby1.xy = dir1_pos.zw + dir1_pos.xy * fxaaConsoleRcpFrameOpt.zw;
+/*--------------------------------------------------------------------------*/
+// (8)
+ rgby1 = h4tex2Dlod(tex, half4(rgby1.xy, 0.0, 0.0));
+ rgby1 = (temp1N + rgby1) * 0.5;
+/*--------------------------------------------------------------------------*/
+// (9)
+ half4 temp2N;
+ temp2N.xy = dir2_pos.zw - dir2_pos.xy * fxaaConsoleRcpFrameOpt2.zw;
+ temp2N = h4tex2Dlod(tex, half4(temp2N.xy, 0.0, 0.0));
+/*--------------------------------------------------------------------------*/
+// (10)
+ half4 rgby2;
+ rgby2.xy = dir2_pos.zw + dir2_pos.xy * fxaaConsoleRcpFrameOpt2.zw;
+ rgby2 = h4tex2Dlod(tex, half4(rgby2.xy, 0.0, 0.0));
+ rgby2 = (temp2N + rgby2) * 0.5;
+/*--------------------------------------------------------------------------*/
+// (11)
+ // compilier moves these scalar ops up to other cycles
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ half lumaMin = min(min(lumaNw.w, lumaSw.w), min(lumaNe.w, lumaSe.w));
+ half lumaMax = max(max(lumaNw.w, lumaSw.w), max(lumaNe.w, lumaSe.w));
+ #else
+ half lumaMin = min(min(lumaNw.y, lumaSw.y), min(lumaNe.y, lumaSe.y));
+ half lumaMax = max(max(lumaNw.y, lumaSw.y), max(lumaNe.y, lumaSe.y));
+ #endif
+ rgby2 = (rgby2 + rgby1) * 0.5;
+/*--------------------------------------------------------------------------*/
+// (12)
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ bool twoTapLt = rgby2.w < lumaMin;
+ bool twoTapGt = rgby2.w > lumaMax;
+ #else
+ bool twoTapLt = rgby2.y < lumaMin;
+ bool twoTapGt = rgby2.y > lumaMax;
+ #endif
+/*--------------------------------------------------------------------------*/
+// (13)
+ if(twoTapLt || twoTapGt) rgby2 = rgby1;
+/*--------------------------------------------------------------------------*/
+ return rgby2; }
+/*==========================================================================*/
+#endif
+
+
+
+/*============================================================================
+
+ FXAA3 CONSOLE - OPTIMIZED PS3 PIXEL SHADER (WITH EARLY EXIT)
+
+==============================================================================
+The code mostly matches the assembly.
+I have a feeling that 14 cycles is possible, but was not able to get there.
+Might have to increase register count to get full performance.
+Note this shader does not use perspective interpolation.
+
+Use the following cgc options,
+
+ --fenable-bx2 --fastmath --fastprecision --nofloatbindings
+
+Use of FXAA_GREEN_AS_LUMA currently adds a cycle (16 clks).
+Will look at fixing this for FXAA 3.12.
+------------------------------------------------------------------------------
+ NVSHADERPERF OUTPUT
+------------------------------------------------------------------------------
+For reference and to aid in debug, output of NVShaderPerf should match this,
+
+Shader to schedule:
+ 0: texpkb h0.w(TRUE), v5.zyxx, #0
+ 2: addh h2.y(TRUE), h0.w, constant(0.001953, 0.000000, 0.000000, 0.000000).x
+ 4: texpkb h1.w(TRUE), v5.xwxx, #0
+ 6: addh h0.x(TRUE), h1.w, -h2.y
+ 7: texpkb h2.w(TRUE), v5.zwzz, #0
+ 9: minh h4.w(TRUE), h2.y, h2
+ 10: maxh h5.x(TRUE), h2.y, h2.w
+ 11: texpkb h0.w(TRUE), v5, #0
+ 13: addh h3.w(TRUE), -h0, h0.x
+ 14: addh h0.x(TRUE), h0.w, h0
+ 15: addh h0.z(TRUE), -h2.w, h0.x
+ 16: addh h0.x(TRUE), h2.w, h3.w
+ 17: minh h5.y(TRUE), h0.w, h1.w
+ 18: nrmh h2.xz(TRUE), h0_n
+ 19: minh_m8 h2.w(TRUE), |h2.x|, |h2.z|
+ 20: divx h4.xy(TRUE), h2_n.xzzw, h2_n.w
+ 21: movr r1.zw(TRUE), v4.xxxy
+ 22: maxh h2.w(TRUE), h0, h1
+ 23: fenct TRUE
+ 24: madr r0.xy(TRUE), -h2.xzzw, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w).zwzz, r1.zwzz
+ 26: texpkb h0(TRUE), r0, #0
+ 28: maxh h5.x(TRUE), h2.w, h5
+ 29: minh h5.w(TRUE), h5.y, h4
+ 30: madr r1.xy(TRUE), h2.xzzw, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w).zwzz, r1.zwzz
+ 32: texpkb h2(TRUE), r1, #0
+ 34: addh_d2 h2(TRUE), h0, h2
+ 35: texpkb h1(TRUE), v4, #0
+ 37: maxh h5.y(TRUE), h5.x, h1.w
+ 38: minh h4.w(TRUE), h1, h5
+ 39: madr r0.xy(TRUE), -h4, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w).xyxx, r1.zwzz
+ 41: texpkb h0(TRUE), r0, #0
+ 43: addh_m8 h5.z(TRUE), h5.y, -h4.w
+ 44: madr r2.xy(TRUE), h4, constant(cConst5.x, cConst5.y, cConst5.z, cConst5.w).xyxx, r1.zwzz
+ 46: texpkb h3(TRUE), r2, #0
+ 48: addh_d2 h0(TRUE), h0, h3
+ 49: addh_d2 h3(TRUE), h0, h2
+ 50: movh h0(TRUE), h3
+ 51: slth h3.x(TRUE), h3.w, h5.w
+ 52: sgth h3.w(TRUE), h3, h5.x
+ 53: addx.c0 rc(TRUE), h3.x, h3
+ 54: slth.c0 rc(TRUE), h5.z, h5
+ 55: movh h0(c0.NE.w), h2
+ 56: movh h0(c0.NE.x), h1
+
+IPU0 ------ Simplified schedule: --------
+Pass | Unit | uOp | PC: Op
+-----+--------+------+-------------------------
+ 1 | SCT0/1 | mov | 0: TXLr h0.w, g[TEX1].zyxx, const.xxxx, TEX0;
+ | TEX | txl | 0: TXLr h0.w, g[TEX1].zyxx, const.xxxx, TEX0;
+ | SCB0 | add | 2: ADDh h2.y, h0.-w--, const.-x--;
+ | | |
+ 2 | SCT0/1 | mov | 4: TXLr h1.w, g[TEX1].xwxx, const.xxxx, TEX0;
+ | TEX | txl | 4: TXLr h1.w, g[TEX1].xwxx, const.xxxx, TEX0;
+ | SCB0 | add | 6: ADDh h0.x, h1.w---,-h2.y---;
+ | | |
+ 3 | SCT0/1 | mov | 7: TXLr h2.w, g[TEX1].zwzz, const.xxxx, TEX0;
+ | TEX | txl | 7: TXLr h2.w, g[TEX1].zwzz, const.xxxx, TEX0;
+ | SCB0 | max | 10: MAXh h5.x, h2.y---, h2.w---;
+ | SCB1 | min | 9: MINh h4.w, h2.---y, h2;
+ | | |
+ 4 | SCT0/1 | mov | 11: TXLr h0.w, g[TEX1], const.xxxx, TEX0;
+ | TEX | txl | 11: TXLr h0.w, g[TEX1], const.xxxx, TEX0;
+ | SCB0 | add | 14: ADDh h0.x, h0.w---, h0;
+ | SCB1 | add | 13: ADDh h3.w,-h0, h0.---x;
+ | | |
+ 5 | SCT0 | mad | 16: ADDh h0.x, h2.w---, h3.w---;
+ | SCT1 | mad | 15: ADDh h0.z,-h2.--w-, h0.--x-;
+ | SCB0 | min | 17: MINh h5.y, h0.-w--, h1.-w--;
+ | | |
+ 6 | SCT1 | mov | 18: NRMh h2.xz, h0;
+ | SRB | nrm | 18: NRMh h2.xz, h0;
+ | SCB1 | min | 19: MINh*8 h2.w, |h2.---x|, |h2.---z|;
+ | | |
+ 7 | SCT0 | div | 20: DIVx h4.xy, h2.xz--, h2.ww--;
+ | SCT1 | mov | 21: MOVr r1.zw, g[TEX0].--xy;
+ | SCB1 | max | 22: MAXh h2.w, h0, h1;
+ | | |
+ 8 | SCT0 | mad | 24: MADr r0.xy,-h2.xz--, const.zw--, r1.zw--;
+ | SCT1 | mov | 26: TXLr h0, r0, const.xxxx, TEX0;
+ | TEX | txl | 26: TXLr h0, r0, const.xxxx, TEX0;
+ | SCB0 | max | 28: MAXh h5.x, h2.w---, h5;
+ | SCB1 | min | 29: MINh h5.w, h5.---y, h4;
+ | | |
+ 9 | SCT0 | mad | 30: MADr r1.xy, h2.xz--, const.zw--, r1.zw--;
+ | SCT1 | mov | 32: TXLr h2, r1, const.xxxx, TEX0;
+ | TEX | txl | 32: TXLr h2, r1, const.xxxx, TEX0;
+ | SCB0/1 | add | 34: ADDh/2 h2, h0, h2;
+ | | |
+ 10 | SCT0/1 | mov | 35: TXLr h1, g[TEX0], const.xxxx, TEX0;
+ | TEX | txl | 35: TXLr h1, g[TEX0], const.xxxx, TEX0;
+ | SCB0 | max | 37: MAXh h5.y, h5.-x--, h1.-w--;
+ | SCB1 | min | 38: MINh h4.w, h1, h5;
+ | | |
+ 11 | SCT0 | mad | 39: MADr r0.xy,-h4, const.xy--, r1.zw--;
+ | SCT1 | mov | 41: TXLr h0, r0, const.zzzz, TEX0;
+ | TEX | txl | 41: TXLr h0, r0, const.zzzz, TEX0;
+ | SCB0 | mad | 44: MADr r2.xy, h4, const.xy--, r1.zw--;
+ | SCB1 | add | 43: ADDh*8 h5.z, h5.--y-,-h4.--w-;
+ | | |
+ 12 | SCT0/1 | mov | 46: TXLr h3, r2, const.xxxx, TEX0;
+ | TEX | txl | 46: TXLr h3, r2, const.xxxx, TEX0;
+ | SCB0/1 | add | 48: ADDh/2 h0, h0, h3;
+ | | |
+ 13 | SCT0/1 | mad | 49: ADDh/2 h3, h0, h2;
+ | SCB0/1 | mul | 50: MOVh h0, h3;
+ | | |
+ 14 | SCT0 | set | 51: SLTh h3.x, h3.w---, h5.w---;
+ | SCT1 | set | 52: SGTh h3.w, h3, h5.---x;
+ | SCB0 | set | 54: SLThc0 rc, h5.z---, h5;
+ | SCB1 | add | 53: ADDxc0_s rc, h3.---x, h3;
+ | | |
+ 15 | SCT0/1 | mul | 55: MOVh h0(NE0.wwww), h2;
+ | SCB0/1 | mul | 56: MOVh h0(NE0.xxxx), h1;
+
+Pass SCT TEX SCB
+ 1: 0% 100% 25%
+ 2: 0% 100% 25%
+ 3: 0% 100% 50%
+ 4: 0% 100% 50%
+ 5: 50% 0% 25%
+ 6: 0% 0% 25%
+ 7: 100% 0% 25%
+ 8: 0% 100% 50%
+ 9: 0% 100% 100%
+ 10: 0% 100% 50%
+ 11: 0% 100% 75%
+ 12: 0% 100% 100%
+ 13: 100% 0% 100%
+ 14: 50% 0% 50%
+ 15: 100% 0% 100%
+
+MEAN: 26% 60% 56%
+
+Pass SCT0 SCT1 TEX SCB0 SCB1
+ 1: 0% 0% 100% 100% 0%
+ 2: 0% 0% 100% 100% 0%
+ 3: 0% 0% 100% 100% 100%
+ 4: 0% 0% 100% 100% 100%
+ 5: 100% 100% 0% 100% 0%
+ 6: 0% 0% 0% 0% 100%
+ 7: 100% 100% 0% 0% 100%
+ 8: 0% 0% 100% 100% 100%
+ 9: 0% 0% 100% 100% 100%
+ 10: 0% 0% 100% 100% 100%
+ 11: 0% 0% 100% 100% 100%
+ 12: 0% 0% 100% 100% 100%
+ 13: 100% 100% 0% 100% 100%
+ 14: 100% 100% 0% 100% 100%
+ 15: 100% 100% 0% 100% 100%
+
+MEAN: 33% 33% 60% 86% 80%
+Fragment Performance Setup: Driver RSX Compiler, GPU RSX, Flags 0x5
+Results 15 cycles, 3 r regs, 800,000,000 pixels/s
+============================================================================*/
+#if (FXAA_PS3 == 1) && (FXAA_EARLY_EXIT == 1)
+/*--------------------------------------------------------------------------*/
+#pragma regcount 7
+#pragma disablepc all
+#pragma option O2
+#pragma option OutColorPrec=fp16
+#pragma texformat default RGBA8
+/*==========================================================================*/
+half4 FxaaPixelShader(
+ // See FXAA Quality FxaaPixelShader() source for docs on Inputs!
+ FxaaFloat2 pos,
+ FxaaFloat4 fxaaConsolePosPos,
+ FxaaTex tex,
+ FxaaTex fxaaConsole360TexExpBiasNegOne,
+ FxaaTex fxaaConsole360TexExpBiasNegTwo,
+ FxaaFloat2 fxaaQualityRcpFrame,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt,
+ FxaaFloat4 fxaaConsoleRcpFrameOpt2,
+ FxaaFloat4 fxaaConsole360RcpFrameOpt2,
+ FxaaFloat fxaaQualitySubpix,
+ FxaaFloat fxaaQualityEdgeThreshold,
+ FxaaFloat fxaaQualityEdgeThresholdMin,
+ FxaaFloat fxaaConsoleEdgeSharpness,
+ FxaaFloat fxaaConsoleEdgeThreshold,
+ FxaaFloat fxaaConsoleEdgeThresholdMin,
+ FxaaFloat4 fxaaConsole360ConstDir
+) {
+/*--------------------------------------------------------------------------*/
+// (1)
+ half4 rgbyNe = h4tex2Dlod(tex, half4(fxaaConsolePosPos.zy, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ half lumaNe = rgbyNe.w + half(1.0/512.0);
+ #else
+ half lumaNe = rgbyNe.y + half(1.0/512.0);
+ #endif
+/*--------------------------------------------------------------------------*/
+// (2)
+ half4 lumaSw = h4tex2Dlod(tex, half4(fxaaConsolePosPos.xw, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ half lumaSwNegNe = lumaSw.w - lumaNe;
+ #else
+ half lumaSwNegNe = lumaSw.y - lumaNe;
+ #endif
+/*--------------------------------------------------------------------------*/
+// (3)
+ half4 lumaNw = h4tex2Dlod(tex, half4(fxaaConsolePosPos.xy, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ half lumaMaxNwSw = max(lumaNw.w, lumaSw.w);
+ half lumaMinNwSw = min(lumaNw.w, lumaSw.w);
+ #else
+ half lumaMaxNwSw = max(lumaNw.y, lumaSw.y);
+ half lumaMinNwSw = min(lumaNw.y, lumaSw.y);
+ #endif
+/*--------------------------------------------------------------------------*/
+// (4)
+ half4 lumaSe = h4tex2Dlod(tex, half4(fxaaConsolePosPos.zw, 0, 0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ half dirZ = lumaNw.w + lumaSwNegNe;
+ half dirX = -lumaNw.w + lumaSwNegNe;
+ #else
+ half dirZ = lumaNw.y + lumaSwNegNe;
+ half dirX = -lumaNw.y + lumaSwNegNe;
+ #endif
+/*--------------------------------------------------------------------------*/
+// (5)
+ half3 dir;
+ dir.y = 0.0;
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ dir.x = lumaSe.w + dirX;
+ dir.z = -lumaSe.w + dirZ;
+ half lumaMinNeSe = min(lumaNe, lumaSe.w);
+ #else
+ dir.x = lumaSe.y + dirX;
+ dir.z = -lumaSe.y + dirZ;
+ half lumaMinNeSe = min(lumaNe, lumaSe.y);
+ #endif
+/*--------------------------------------------------------------------------*/
+// (6)
+ half4 dir1_pos;
+ dir1_pos.xy = normalize(dir).xz;
+ half dirAbsMinTimes8 = min(abs(dir1_pos.x), abs(dir1_pos.y)) * half(FXAA_CONSOLE__PS3_EDGE_SHARPNESS);
+/*--------------------------------------------------------------------------*/
+// (7)
+ half4 dir2_pos;
+ dir2_pos.xy = clamp(dir1_pos.xy / dirAbsMinTimes8, half(-2.0), half(2.0));
+ dir1_pos.zw = pos.xy;
+ dir2_pos.zw = pos.xy;
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ half lumaMaxNeSe = max(lumaNe, lumaSe.w);
+ #else
+ half lumaMaxNeSe = max(lumaNe, lumaSe.y);
+ #endif
+/*--------------------------------------------------------------------------*/
+// (8)
+ half4 temp1N;
+ temp1N.xy = dir1_pos.zw - dir1_pos.xy * fxaaConsoleRcpFrameOpt.zw;
+ temp1N = h4tex2Dlod(tex, half4(temp1N.xy, 0.0, 0.0));
+ half lumaMax = max(lumaMaxNwSw, lumaMaxNeSe);
+ half lumaMin = min(lumaMinNwSw, lumaMinNeSe);
+/*--------------------------------------------------------------------------*/
+// (9)
+ half4 rgby1;
+ rgby1.xy = dir1_pos.zw + dir1_pos.xy * fxaaConsoleRcpFrameOpt.zw;
+ rgby1 = h4tex2Dlod(tex, half4(rgby1.xy, 0.0, 0.0));
+ rgby1 = (temp1N + rgby1) * 0.5;
+/*--------------------------------------------------------------------------*/
+// (10)
+ half4 rgbyM = h4tex2Dlod(tex, half4(pos.xy, 0.0, 0.0));
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ half lumaMaxM = max(lumaMax, rgbyM.w);
+ half lumaMinM = min(lumaMin, rgbyM.w);
+ #else
+ half lumaMaxM = max(lumaMax, rgbyM.y);
+ half lumaMinM = min(lumaMin, rgbyM.y);
+ #endif
+/*--------------------------------------------------------------------------*/
+// (11)
+ half4 temp2N;
+ temp2N.xy = dir2_pos.zw - dir2_pos.xy * fxaaConsoleRcpFrameOpt2.zw;
+ temp2N = h4tex2Dlod(tex, half4(temp2N.xy, 0.0, 0.0));
+ half4 rgby2;
+ rgby2.xy = dir2_pos.zw + dir2_pos.xy * fxaaConsoleRcpFrameOpt2.zw;
+ half lumaRangeM = (lumaMaxM - lumaMinM) / FXAA_CONSOLE__PS3_EDGE_THRESHOLD;
+/*--------------------------------------------------------------------------*/
+// (12)
+ rgby2 = h4tex2Dlod(tex, half4(rgby2.xy, 0.0, 0.0));
+ rgby2 = (temp2N + rgby2) * 0.5;
+/*--------------------------------------------------------------------------*/
+// (13)
+ rgby2 = (rgby2 + rgby1) * 0.5;
+/*--------------------------------------------------------------------------*/
+// (14)
+ #if (FXAA_GREEN_AS_LUMA == 0)
+ bool twoTapLt = rgby2.w < lumaMin;
+ bool twoTapGt = rgby2.w > lumaMax;
+ #else
+ bool twoTapLt = rgby2.y < lumaMin;
+ bool twoTapGt = rgby2.y > lumaMax;
+ #endif
+ bool earlyExit = lumaRangeM < lumaMax;
+ bool twoTap = twoTapLt || twoTapGt;
+/*--------------------------------------------------------------------------*/
+// (15)
+ if(twoTap) rgby2 = rgby1;
+ if(earlyExit) rgby2 = rgbyM;
+/*--------------------------------------------------------------------------*/
+ return rgby2; }
+/*==========================================================================*/
+#endif
diff --git a/mp/game/momentum/shadereditorui/shader_src/basetexture_accum_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/basetexture_accum_ps30.fxc
new file mode 100644
index 0000000000..7226c1ec57
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/basetexture_accum_ps30.fxc
@@ -0,0 +1,44 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _texLookup_3 = tex2D( _Sampler_00, In.vTexCoord_0 );
+ float3 _var0 = _texLookup_3.rgb;
+ float _var1 = _texLookup_3.a;
+ float4 _texLookup_5 = tex2D( _Sampler_01, In.vTexCoord_0 );
+ float3 _var2 = _texLookup_5.rgb;
+ float _var3 = _texLookup_5.a;
+ _var0 = lerp( _var0, _var2, float( 0.800000 ) );
+ _var1 = lerp( _var1, _var3, float( 0.400000 ) );
+ float4 _var4 = float4( _var0, _var1 );
+ Out.vColor_0 = _var4;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/basetexture_accum_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/basetexture_accum_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/basetexture_accum_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/basetexture_blend_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/basetexture_blend_ps30.fxc
new file mode 100644
index 0000000000..9eb6539a61
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/basetexture_blend_ps30.fxc
@@ -0,0 +1,40 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = tex2D( _Sampler_00, In.vTexCoord_0 ).rgba;
+ float4 _var1 = tex2D( _Sampler_01, In.vTexCoord_0 ).rgba;
+ float _var2 = distance( In.vTexCoord_0, float2( 0.500000, 0.500000 ) );
+ _var2 = smoothstep( float( 0.000000 ), float( 0.600000 ), _var2 );
+ _var0 = lerp( _var0, _var1, _var2 );
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/basetexture_blend_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/basetexture_blend_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/basetexture_blend_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/bin/dx_proxy.dll b/mp/game/momentum/shadereditorui/shader_src/bin/dx_proxy.dll
new file mode 100644
index 0000000000..7640fd8639
Binary files /dev/null and b/mp/game/momentum/shadereditorui/shader_src/bin/dx_proxy.dll differ
diff --git a/mp/game/momentum/shadereditorui/shader_src/bin/fxc.exe b/mp/game/momentum/shadereditorui/shader_src/bin/fxc.exe
new file mode 100644
index 0000000000..9d5e3e7359
Binary files /dev/null and b/mp/game/momentum/shadereditorui/shader_src/bin/fxc.exe differ
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_flashlight_fxc.h b/mp/game/momentum/shadereditorui/shader_src/common_flashlight_fxc.h
new file mode 100644
index 0000000000..9e8c049a92
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_flashlight_fxc.h
@@ -0,0 +1,821 @@
+//====== Copyright © 1996-2007, Valve Corporation, All rights reserved. =======//
+//
+// Purpose: Common pixel shader code specific to flashlights
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+#ifndef COMMON_FLASHLIGHT_FXC_H_
+#define COMMON_FLASHLIGHT_FXC_H_
+
+#include "common_ps_fxc.h"
+
+
+// JasonM - TODO: remove this simpleton version
+float DoShadow( sampler DepthSampler, float4 texCoord )
+{
+ const float g_flShadowBias = 0.0005f;
+ float2 uoffset = float2( 0.5f/512.f, 0.0f );
+ float2 voffset = float2( 0.0f, 0.5f/512.f );
+ float3 projTexCoord = texCoord.xyz / texCoord.w;
+ float4 flashlightDepth = float4( tex2D( DepthSampler, projTexCoord + uoffset + voffset ).x,
+ tex2D( DepthSampler, projTexCoord + uoffset - voffset ).x,
+ tex2D( DepthSampler, projTexCoord - uoffset + voffset ).x,
+ tex2D( DepthSampler, projTexCoord - uoffset - voffset ).x );
+
+# if ( defined( REVERSE_DEPTH_ON_X360 ) )
+ {
+ flashlightDepth = 1.0f - flashlightDepth;
+ }
+# endif
+
+ float shadowed = 0.0f;
+ float z = texCoord.z/texCoord.w;
+ float4 dz = float4(z,z,z,z) - (flashlightDepth + float4( g_flShadowBias, g_flShadowBias, g_flShadowBias, g_flShadowBias));
+ float4 shadow = float4(0.25f,0.25f,0.25f,0.25f);
+
+ if( dz.x <= 0.0f )
+ shadowed += shadow.x;
+ if( dz.y <= 0.0f )
+ shadowed += shadow.y;
+ if( dz.z <= 0.0f )
+ shadowed += shadow.z;
+ if( dz.w <= 0.0f )
+ shadowed += shadow.w;
+
+ return shadowed;
+}
+
+
+float DoShadowNvidiaRAWZOneTap( sampler DepthSampler, const float4 shadowMapPos )
+{
+ float ooW = 1.0f / shadowMapPos.w; // 1 / w
+ float3 shadowMapCenter_objDepth = shadowMapPos.xyz * ooW; // Do both projections at once
+
+ float2 shadowMapCenter = shadowMapCenter_objDepth.xy; // Center of shadow filter
+ float objDepth = shadowMapCenter_objDepth.z; // Object depth in shadow space
+
+ float fDepth = dot(tex2D(DepthSampler, shadowMapCenter).arg, float3(0.996093809371817670572857294849, 0.0038909914428586627756752238080039, 1.5199185323666651467481343000015e-5));
+
+ return fDepth > objDepth;
+}
+
+
+float DoShadowNvidiaRAWZ( sampler DepthSampler, const float4 shadowMapPos )
+{
+ float fE = 1.0f / 512.0f; // Epsilon
+
+ float ooW = 1.0f / shadowMapPos.w; // 1 / w
+ float3 shadowMapCenter_objDepth = shadowMapPos.xyz * ooW; // Do both projections at once
+
+ float2 shadowMapCenter = shadowMapCenter_objDepth.xy; // Center of shadow filter
+ float objDepth = shadowMapCenter_objDepth.z; // Object depth in shadow space
+
+ float4 vDepths;
+ vDepths.x = dot(tex2D(DepthSampler, shadowMapCenter + float2( fE, fE )).arg, float3(0.996093809371817670572857294849, 0.0038909914428586627756752238080039, 1.5199185323666651467481343000015e-5));
+ vDepths.y = dot(tex2D(DepthSampler, shadowMapCenter + float2( -fE, fE )).arg, float3(0.996093809371817670572857294849, 0.0038909914428586627756752238080039, 1.5199185323666651467481343000015e-5));
+ vDepths.z = dot(tex2D(DepthSampler, shadowMapCenter + float2( fE, -fE )).arg, float3(0.996093809371817670572857294849, 0.0038909914428586627756752238080039, 1.5199185323666651467481343000015e-5));
+ vDepths.w = dot(tex2D(DepthSampler, shadowMapCenter + float2( -fE, -fE )).arg, float3(0.996093809371817670572857294849, 0.0038909914428586627756752238080039, 1.5199185323666651467481343000015e-5));
+
+ return dot(vDepths > objDepth.xxxx, float4(0.25, 0.25, 0.25, 0.25));
+}
+
+
+float DoShadowNvidiaCheap( sampler DepthSampler, const float4 shadowMapPos )
+{
+ float fTexelEpsilon = 1.0f / 1024.0f;
+
+ float ooW = 1.0f / shadowMapPos.w; // 1 / w
+ float3 shadowMapCenter_objDepth = shadowMapPos.xyz * ooW; // Do both projections at once
+
+ float2 shadowMapCenter = shadowMapCenter_objDepth.xy; // Center of shadow filter
+ float objDepth = shadowMapCenter_objDepth.z; // Object depth in shadow space
+
+ float4 vTaps;
+ vTaps.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTexelEpsilon, fTexelEpsilon), objDepth, 1 ) ).x;
+ vTaps.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTexelEpsilon, fTexelEpsilon), objDepth, 1 ) ).x;
+ vTaps.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTexelEpsilon, -fTexelEpsilon), objDepth, 1 ) ).x;
+ vTaps.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTexelEpsilon, -fTexelEpsilon), objDepth, 1 ) ).x;
+
+ return dot(vTaps, float4(0.25, 0.25, 0.25, 0.25));
+}
+
+float DoShadowNvidiaPCF3x3Box( sampler DepthSampler, const float4 shadowMapPos )
+{
+ float fTexelEpsilon = 1.0f / 1024.0f;
+
+ float ooW = 1.0f / shadowMapPos.w; // 1 / w
+ float3 shadowMapCenter_objDepth = shadowMapPos.xyz * ooW; // Do both projections at once
+
+ float2 shadowMapCenter = shadowMapCenter_objDepth.xy; // Center of shadow filter
+ float objDepth = shadowMapCenter_objDepth.z; // Object depth in shadow space
+
+ float4 vOneTaps;
+ vOneTaps.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTexelEpsilon, fTexelEpsilon ), objDepth, 1 ) ).x;
+ vOneTaps.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTexelEpsilon, fTexelEpsilon ), objDepth, 1 ) ).x;
+ vOneTaps.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTexelEpsilon, -fTexelEpsilon ), objDepth, 1 ) ).x;
+ vOneTaps.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTexelEpsilon, -fTexelEpsilon ), objDepth, 1 ) ).x;
+ float flOneTaps = dot( vOneTaps, float4(1.0f / 9.0f, 1.0f / 9.0f, 1.0f / 9.0f, 1.0f / 9.0f));
+
+ float4 vTwoTaps;
+ vTwoTaps.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTexelEpsilon, 0 ), objDepth, 1 ) ).x;
+ vTwoTaps.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTexelEpsilon, 0 ), objDepth, 1 ) ).x;
+ vTwoTaps.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( 0, -fTexelEpsilon ), objDepth, 1 ) ).x;
+ vTwoTaps.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( 0, -fTexelEpsilon ), objDepth, 1 ) ).x;
+ float flTwoTaps = dot( vTwoTaps, float4(1.0f / 9.0f, 1.0f / 9.0f, 1.0f / 9.0f, 1.0f / 9.0f));
+
+ float flCenterTap = tex2Dproj( DepthSampler, float4( shadowMapCenter, objDepth, 1 ) ).x * (1.0f / 9.0f);
+
+ // Sum all 9 Taps
+ return flOneTaps + flTwoTaps + flCenterTap;
+}
+
+
+//
+// 1 4 7 4 1
+// 4 20 33 20 4
+// 7 33 55 33 7
+// 4 20 33 20 4
+// 1 4 7 4 1
+//
+float DoShadowNvidiaPCF5x5Gaussian( sampler DepthSampler, const float4 shadowMapPos )
+{
+ float fEpsilon = 1.0f / 512.0f;
+ float fTwoEpsilon = 2.0f * fEpsilon;
+
+ float ooW = 1.0f / shadowMapPos.w; // 1 / w
+ float3 shadowMapCenter_objDepth = shadowMapPos.xyz * ooW; // Do both projections at once
+
+ float2 shadowMapCenter = shadowMapCenter_objDepth.xy; // Center of shadow filter
+ float objDepth = shadowMapCenter_objDepth.z; // Object depth in shadow space
+
+ float4 vOneTaps;
+ vOneTaps.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTwoEpsilon, fTwoEpsilon ), objDepth, 1 ) ).x;
+ vOneTaps.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTwoEpsilon, fTwoEpsilon ), objDepth, 1 ) ).x;
+ vOneTaps.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTwoEpsilon, -fTwoEpsilon ), objDepth, 1 ) ).x;
+ vOneTaps.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTwoEpsilon, -fTwoEpsilon ), objDepth, 1 ) ).x;
+ float flOneTaps = dot( vOneTaps, float4(1.0f / 331.0f, 1.0f / 331.0f, 1.0f / 331.0f, 1.0f / 331.0f));
+
+ float4 vSevenTaps;
+ vSevenTaps.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTwoEpsilon, 0 ), objDepth, 1 ) ).x;
+ vSevenTaps.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTwoEpsilon, 0 ), objDepth, 1 ) ).x;
+ vSevenTaps.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( 0, -fTwoEpsilon ), objDepth, 1 ) ).x;
+ vSevenTaps.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( 0, -fTwoEpsilon ), objDepth, 1 ) ).x;
+ float flSevenTaps = dot( vSevenTaps, float4( 7.0f / 331.0f, 7.0f / 331.0f, 7.0f / 331.0f, 7.0f / 331.0f ) );
+
+ float4 vFourTapsA, vFourTapsB;
+ vFourTapsA.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTwoEpsilon, fEpsilon ), objDepth, 1 ) ).x;
+ vFourTapsA.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fEpsilon, fTwoEpsilon ), objDepth, 1 ) ).x;
+ vFourTapsA.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fEpsilon, fTwoEpsilon ), objDepth, 1 ) ).x;
+ vFourTapsA.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTwoEpsilon, fEpsilon ), objDepth, 1 ) ).x;
+ vFourTapsB.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fTwoEpsilon, -fEpsilon ), objDepth, 1 ) ).x;
+ vFourTapsB.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fEpsilon, -fTwoEpsilon ), objDepth, 1 ) ).x;
+ vFourTapsB.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fEpsilon, -fTwoEpsilon ), objDepth, 1 ) ).x;
+ vFourTapsB.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fTwoEpsilon, -fEpsilon ), objDepth, 1 ) ).x;
+ float flFourTapsA = dot( vFourTapsA, float4( 4.0f / 331.0f, 4.0f / 331.0f, 4.0f / 331.0f, 4.0f / 331.0f ) );
+ float flFourTapsB = dot( vFourTapsB, float4( 4.0f / 331.0f, 4.0f / 331.0f, 4.0f / 331.0f, 4.0f / 331.0f ) );
+
+ float4 v20Taps;
+ v20Taps.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fEpsilon, fEpsilon ), objDepth, 1 ) ).x;
+ v20Taps.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fEpsilon, fEpsilon ), objDepth, 1 ) ).x;
+ v20Taps.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fEpsilon, -fEpsilon ), objDepth, 1 ) ).x;
+ v20Taps.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fEpsilon, -fEpsilon ), objDepth, 1 ) ).x;
+ float fl20Taps = dot( v20Taps, float4(20.0f / 331.0f, 20.0f / 331.0f, 20.0f / 331.0f, 20.0f / 331.0f));
+
+ float4 v33Taps;
+ v33Taps.x = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( fEpsilon, 0 ), objDepth, 1 ) ).x;
+ v33Taps.y = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( -fEpsilon, 0 ), objDepth, 1 ) ).x;
+ v33Taps.z = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( 0, -fEpsilon ), objDepth, 1 ) ).x;
+ v33Taps.w = tex2Dproj( DepthSampler, float4( shadowMapCenter + float2( 0, -fEpsilon ), objDepth, 1 ) ).x;
+ float fl33Taps = dot( v33Taps, float4(33.0f / 331.0f, 33.0f / 331.0f, 33.0f / 331.0f, 33.0f / 331.0f));
+
+ float flCenterTap = tex2Dproj( DepthSampler, float4( shadowMapCenter, objDepth, 1 ) ).x * (55.0f / 331.0f);
+
+ // Sum all 25 Taps
+ return flOneTaps + flSevenTaps + +flFourTapsA + flFourTapsB + fl20Taps + fl33Taps + flCenterTap;
+}
+
+
+float DoShadowATICheap( sampler DepthSampler, const float4 shadowMapPos )
+{
+ float2 shadowMapCenter = shadowMapPos.xy/shadowMapPos.w;
+ float objDepth = shadowMapPos.z / shadowMapPos.w;
+ float fSampleDepth = tex2D( DepthSampler, shadowMapCenter ).x;
+
+ objDepth = min( objDepth, 0.99999 ); //HACKHACK: On 360, surfaces at or past the far flashlight plane have an abrupt cutoff. This is temp until a smooth falloff is implemented
+
+ return fSampleDepth > objDepth;
+}
+
+
+// Poisson disc, randomly rotated at different UVs
+float DoShadowPoisson16Sample( sampler DepthSampler, sampler RandomRotationSampler, const float3 vProjCoords, const float2 vScreenPos, const float4 vShadowTweaks, bool bNvidiaHardwarePCF, bool bFetch4 )
+{
+ float2 vPoissonOffset[8] = { float2( 0.3475f, 0.0042f ),
+ float2( 0.8806f, 0.3430f ),
+ float2( -0.0041f, -0.6197f ),
+ float2( 0.0472f, 0.4964f ),
+ float2( -0.3730f, 0.0874f ),
+ float2( -0.9217f, -0.3177f ),
+ float2( -0.6289f, 0.7388f ),
+ float2( 0.5744f, -0.7741f ) };
+
+ float flScaleOverMapSize = vShadowTweaks.x * 2; // Tweak parameters to shader
+ float2 vNoiseOffset = vShadowTweaks.zw;
+ float4 vLightDepths = 0, accum = 0.0f;
+ float2 rotOffset = 0;
+
+ float2 shadowMapCenter = vProjCoords.xy; // Center of shadow filter
+ float objDepth = min( vProjCoords.z, 0.99999 ); // Object depth in shadow space
+
+ // 2D Rotation Matrix setup
+ float3 RMatTop = 0, RMatBottom = 0;
+#if defined(SHADER_MODEL_PS_2_0) || defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)
+ RMatTop.xy = tex2D( RandomRotationSampler, cFlashlightScreenScale.xy * (vScreenPos * 0.5 + 0.5) + vNoiseOffset) * 2.0 - 1.0;
+ RMatBottom.xy = float2(-1.0, 1.0) * RMatTop.yx; // 2x2 rotation matrix in 4-tuple
+#endif
+
+ RMatTop *= flScaleOverMapSize; // Scale up kernel while accounting for texture resolution
+ RMatBottom *= flScaleOverMapSize;
+
+ RMatTop.z = shadowMapCenter.x; // To be added in d2adds generated below
+ RMatBottom.z = shadowMapCenter.y;
+
+ float fResult = 0.0f;
+
+ if ( bNvidiaHardwarePCF )
+ {
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[0].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[0].xy) + RMatBottom.z;
+ vLightDepths.x += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[1].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[1].xy) + RMatBottom.z;
+ vLightDepths.y += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[2].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[2].xy) + RMatBottom.z;
+ vLightDepths.z += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[3].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[3].xy) + RMatBottom.z;
+ vLightDepths.w += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[4].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[4].xy) + RMatBottom.z;
+ vLightDepths.x += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[5].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[5].xy) + RMatBottom.z;
+ vLightDepths.y += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[6].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[6].xy) + RMatBottom.z;
+ vLightDepths.z += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[7].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[7].xy) + RMatBottom.z;
+ vLightDepths.w += tex2Dproj( DepthSampler, float4(rotOffset, objDepth, 1) ).x;
+
+ fResult = dot( vLightDepths, float4( 0.25, 0.25, 0.25, 0.25) );
+ }
+ else if ( bFetch4 )
+ {
+/*
+
+TODO: Fix this contact hardening stuff
+
+ float flNumCloserSamples = 1;
+ float flAccumulatedCloserSamples = objDepth;
+ float4 vBlockerDepths;
+
+ // First, search for blockers
+ for( int j=0; j<8; j++ )
+ {
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[j].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[j].xy) + RMatBottom.z;
+ vBlockerDepths = tex2D( DepthSampler, rotOffset.xy );
+
+ // Which samples are closer than the pixel we're rendering?
+ float4 vCloserSamples = (vBlockerDepths < objDepth.xxxx ); // Binary comparison results
+ flNumCloserSamples += dot( vCloserSamples, float4(1, 1, 1, 1) ); // How many samples are closer than receiver?
+ flAccumulatedCloserSamples += dot (vCloserSamples, vBlockerDepths ); // Total depths from samples closer than receiver
+ }
+
+ float flBlockerDepth = flAccumulatedCloserSamples / flNumCloserSamples;
+ float flContactHardeningScale = (objDepth - flBlockerDepth) / flBlockerDepth;
+
+ // Scale the kernel
+ RMatTop.xy *= flContactHardeningScale;
+ RMatBottom.xy *= flContactHardeningScale;
+*/
+
+ for( int i=0; i<8; i++ )
+ {
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[i].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[i].xy) + RMatBottom.z;
+ vLightDepths = tex2D( DepthSampler, rotOffset.xy );
+ accum += (vLightDepths > objDepth.xxxx);
+ }
+
+ fResult = dot( accum, float4( 1.0f/32.0f, 1.0f/32.0f, 1.0f/32.0f, 1.0f/32.0f) );
+ }
+ else // ATI vanilla hardware shadow mapping
+ {
+ for( int i=0; i<2; i++ )
+ {
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[4*i+0].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[4*i+0].xy) + RMatBottom.z;
+ vLightDepths.x = tex2D( DepthSampler, rotOffset.xy ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[4*i+1].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[4*i+1].xy) + RMatBottom.z;
+ vLightDepths.y = tex2D( DepthSampler, rotOffset.xy ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[4*i+2].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[4*i+2].xy) + RMatBottom.z;
+ vLightDepths.z = tex2D( DepthSampler, rotOffset.xy ).x;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[4*i+3].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[4*i+3].xy) + RMatBottom.z;
+ vLightDepths.w = tex2D( DepthSampler, rotOffset.xy ).x;
+
+ accum += (vLightDepths > objDepth.xxxx);
+ }
+
+ fResult = dot( accum, float4( 0.125, 0.125, 0.125, 0.125) );
+ }
+
+ return fResult;
+}
+
+#if defined( _X360 )
+
+// Poisson disc, randomly rotated at different UVs
+float DoShadow360Simple( sampler DepthSampler, const float3 vProjCoords )
+{
+ float fLOD;
+ float2 shadowMapCenter = vProjCoords.xy; // Center of shadow filter
+ float objDepth = min( vProjCoords.z, 0.99999 ); // Object depth in shadow space
+
+#if defined( REVERSE_DEPTH_ON_X360 )
+ objDepth = 1.0f - objDepth;
+#endif
+
+ float4 vSampledDepths, vWeights;
+
+ asm {
+ getCompTexLOD2D fLOD.x, shadowMapCenter.xy, DepthSampler, AnisoFilter=max16to1
+ setTexLOD fLOD.x
+
+ tfetch2D vSampledDepths.x___, shadowMapCenter, DepthSampler, OffsetX = -0.5, OffsetY = -0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths._x__, shadowMapCenter, DepthSampler, OffsetX = 0.5, OffsetY = -0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths.__x_, shadowMapCenter, DepthSampler, OffsetX = -0.5, OffsetY = 0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths.___x, shadowMapCenter, DepthSampler, OffsetX = 0.5, OffsetY = 0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+
+ getWeights2D vWeights, shadowMapCenter.xy, DepthSampler, MagFilter=linear, MinFilter=linear, UseComputedLOD=false, UseRegisterLOD=true
+ };
+
+ vWeights = float4( (1-vWeights.x)*(1-vWeights.y), vWeights.x*(1-vWeights.y), (1-vWeights.x)*vWeights.y, vWeights.x*vWeights.y );
+
+#if defined( REVERSE_DEPTH_ON_X360 )
+ float4 vCompare = (vSampledDepths < objDepth.xxxx);
+#else
+ float4 vCompare = (vSampledDepths > objDepth.xxxx);
+#endif
+
+ return dot( vCompare, vWeights );
+}
+
+
+float Do360PCFFetch( sampler DepthSampler, float2 tc, float objDepth )
+{
+ float fLOD;
+ float4 vSampledDepths, vWeights;
+
+ asm {
+ getCompTexLOD2D fLOD.x, tc.xy, DepthSampler, AnisoFilter=max16to1
+ setTexLOD fLOD.x
+
+ tfetch2D vSampledDepths.x___, tc, DepthSampler, OffsetX = -0.5, OffsetY = -0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths._x__, tc, DepthSampler, OffsetX = 0.5, OffsetY = -0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths.__x_, tc, DepthSampler, OffsetX = -0.5, OffsetY = 0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths.___x, tc, DepthSampler, OffsetX = 0.5, OffsetY = 0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+
+ getWeights2D vWeights, tc.xy, DepthSampler, MagFilter=linear, MinFilter=linear, UseComputedLOD=false, UseRegisterLOD=true
+ };
+
+ vWeights = float4( (1-vWeights.x)*(1-vWeights.y), vWeights.x*(1-vWeights.y), (1-vWeights.x)*vWeights.y, vWeights.x*vWeights.y );
+
+#if defined( REVERSE_DEPTH_ON_X360 )
+ float4 vCompare = (vSampledDepths < objDepth.xxxx);
+#else
+ float4 vCompare = (vSampledDepths > objDepth.xxxx);
+#endif
+
+ return dot( vCompare, vWeights );
+}
+
+
+
+float Do360NearestFetch( sampler DepthSampler, float2 tc, float objDepth )
+{
+ float fLOD;
+ float4 vSampledDepth;
+
+ asm {
+ getCompTexLOD2D fLOD.x, tc.xy, DepthSampler, AnisoFilter=max16to1
+ setTexLOD fLOD.x
+
+ tfetch2D vSampledDepth.x___, tc, DepthSampler, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ };
+
+#if defined( REVERSE_DEPTH_ON_X360 )
+ return (vSampledDepth.x < objDepth.x);
+#else
+ return (vSampledDepth.x > objDepth.x);
+#endif
+
+}
+
+
+float AmountShadowed_8Tap_360( sampler DepthSampler, float2 tc, float objDepth )
+{
+ float fLOD;
+ float4 vSampledDepthsA, vSampledDepthsB;
+
+ // Optimal 8 rooks pattern to get an idea about whether we're at a penumbra or not
+ // From [Kallio07] "Scanline Edge-Flag Algorithm for Antialiasing"
+ //
+ // +---+---+---+---+---+---+---+---+
+ // | | | | | | o | | |
+ // +---+---+---+---+---+---+---+---+
+ // | o | | | | | | | |
+ // +---+---+---+---+---+---+---+---+
+ // | | | | o | | | | |
+ // +---+---+---+---+---+---+---+---+
+ // | | | | | | | o | |
+ // +---+---+---+---+---+---+---+---+
+ // | | o | | | | | | |
+ // +---+---+---+---+---+---+---+---+
+ // | | | | | o | | | |
+ // +---+---+---+---+---+---+---+---+
+ // | | | | | | | | o |
+ // +---+---+---+---+---+---+---+---+
+ // | | | o | | | | | |
+ // +---+---+---+---+---+---+---+---+
+ //
+ asm {
+ getCompTexLOD2D fLOD.x, tc.xy, DepthSampler, AnisoFilter=max16to1
+ setTexLOD fLOD.x
+
+ tfetch2D vSampledDepthsA.x___, tc, DepthSampler, OffsetX = -2.0, OffsetY = -1.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepthsA._x__, tc, DepthSampler, OffsetX = -1.5, OffsetY = 0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepthsA.__x_, tc, DepthSampler, OffsetX = -1.0, OffsetY = 2.0, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepthsA.___x, tc, DepthSampler, OffsetX = -0.5, OffsetY = -1.0, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+
+ tfetch2D vSampledDepthsB.x___, tc, DepthSampler, OffsetX = 0.5, OffsetY = 1.0, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepthsB._x__, tc, DepthSampler, OffsetX = 1.0, OffsetY = -2.0, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepthsB.__x_, tc, DepthSampler, OffsetX = 1.5, OffsetY = -0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepthsB.___x, tc, DepthSampler, OffsetX = 2.0, OffsetY = 1.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ };
+
+#if defined( REVERSE_DEPTH_ON_X360 )
+ float4 vCompareA = (vSampledDepthsA < objDepth.xxxx);
+ float4 vCompareB = (vSampledDepthsB < objDepth.xxxx);
+#else
+ float4 vCompareA = (vSampledDepthsA > objDepth.xxxx);
+ float4 vCompareB = (vSampledDepthsB > objDepth.xxxx);
+#endif
+
+ return dot( vCompareA, float4(0.125,0.125,0.125,0.125) ) + dot( vCompareB, float4(0.125,0.125,0.125,0.125) );
+}
+
+
+float AmountShadowed_4Tap_360( sampler DepthSampler, float2 tc, float objDepth )
+{
+ float fLOD;
+ float4 vSampledDepths;
+
+ // Rotated grid pattern to get an idea about whether we're at a penumbra or not
+ asm {
+ getCompTexLOD2D fLOD.x, tc.xy, DepthSampler, AnisoFilter=max16to1
+ setTexLOD fLOD.x
+
+ tfetch2D vSampledDepths.x___, tc, DepthSampler, OffsetX = -1.0, OffsetY = 0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths._x__, tc, DepthSampler, OffsetX = -0.5, OffsetY = -1.0, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths.__x_, tc, DepthSampler, OffsetX = 0.5, OffsetY = 1.0, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ tfetch2D vSampledDepths.___x, tc, DepthSampler, OffsetX = 1.0, OffsetY = -0.5, UseComputedLOD=false, UseRegisterLOD=true, MagFilter = point, MinFilter = point
+ };
+
+#if defined( REVERSE_DEPTH_ON_X360 )
+ float4 vCompare = (vSampledDepths < objDepth.xxxx);
+#else
+ float4 vCompare = (vSampledDepths > objDepth.xxxx);
+#endif
+
+ return dot( vCompare, float4(0.25,0.25,0.25,0.25) );
+}
+
+// Poisson disc, randomly rotated at different UVs
+float DoShadowPoisson360( sampler DepthSampler, sampler RandomRotationSampler, const float3 vProjCoords, const float2 vScreenPos, const float4 vShadowTweaks )
+{
+ float2 vPoissonOffset[8] = { float2( 0.3475f, 0.0042f ), float2( 0.8806f, 0.3430f ),
+ float2( -0.0041f, -0.6197f ), float2( 0.0472f, 0.4964f ),
+ float2( -0.3730f, 0.0874f ), float2( -0.9217f, -0.3177f ),
+ float2( -0.6289f, 0.7388f ), float2( 0.5744f, -0.7741f ) };
+
+ float2 shadowMapCenter = vProjCoords.xy; // Center of shadow filter
+ float objDepth = min( vProjCoords.z, 0.99999 ); // Object depth in shadow space
+
+#if defined( REVERSE_DEPTH_ON_X360 )
+ objDepth = 1.0f - objDepth;
+#endif
+
+ float fAmountShadowed = AmountShadowed_4Tap_360( DepthSampler, shadowMapCenter, objDepth );
+
+ if ( fAmountShadowed >= 1.0f ) // Fully in light
+ {
+ return 1.0f;
+ }
+ else // Do the expensive filtering since we're at least partially shadowed
+ {
+ float flScaleOverMapSize = 1.7f / 512.0f; // Tweak parameters to shader
+
+ // 2D Rotation Matrix setup
+ float3 RMatTop = 0, RMatBottom = 0;
+#if defined(SHADER_MODEL_PS_2_0) || defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)
+ RMatTop.xy = tex2D( RandomRotationSampler, cFlashlightScreenScale.xy * (vScreenPos * 0.5 + 0.5)) * 2.0 - 1.0;
+ RMatBottom.xy = float2(-1.0, 1.0) * RMatTop.yx; // 2x2 rotation matrix in 4-tuple
+#endif
+
+ RMatTop *= flScaleOverMapSize; // Scale up kernel while accounting for texture resolution
+ RMatBottom *= flScaleOverMapSize;
+ RMatTop.z = shadowMapCenter.x; // To be added in d2adds generated below
+ RMatBottom.z = shadowMapCenter.y;
+ float2 rotOffset = float2(0,0);
+ float4 vAccum = 0;
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[0].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[0].xy) + RMatBottom.z;
+ vAccum.x = Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[1].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[1].xy) + RMatBottom.z;
+ vAccum.y = Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[2].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[2].xy) + RMatBottom.z;
+ vAccum.z = Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[3].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[3].xy) + RMatBottom.z;
+ vAccum.w = Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[4].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[4].xy) + RMatBottom.z;
+ vAccum.x += Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[5].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[5].xy) + RMatBottom.z;
+ vAccum.y += Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[6].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[6].xy) + RMatBottom.z;
+ vAccum.z += Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ rotOffset.x = dot (RMatTop.xy, vPoissonOffset[7].xy) + RMatTop.z;
+ rotOffset.y = dot (RMatBottom.xy, vPoissonOffset[7].xy) + RMatBottom.z;
+ vAccum.w += Do360NearestFetch( DepthSampler, rotOffset, objDepth );
+
+ return dot( vAccum, float4( 0.25, 0.25, 0.25, 0.25) );
+ }
+}
+
+#endif // _X360
+
+
+float DoFlashlightShadow( sampler DepthSampler, sampler RandomRotationSampler, float3 vProjCoords, float2 vScreenPos, int nShadowLevel, float4 vShadowTweaks, bool bAllowHighQuality )
+{
+ float flShadow = 1.0f;
+
+#if !defined( _X360 ) //PC
+ if( nShadowLevel == NVIDIA_PCF_POISSON )
+ flShadow = DoShadowPoisson16Sample( DepthSampler, RandomRotationSampler, vProjCoords, vScreenPos, vShadowTweaks, true, false );
+ else if( nShadowLevel == ATI_NOPCF )
+ flShadow = DoShadowPoisson16Sample( DepthSampler, RandomRotationSampler, vProjCoords, vScreenPos, vShadowTweaks, false, false );
+ else if( nShadowLevel == ATI_NO_PCF_FETCH4 )
+ flShadow = DoShadowPoisson16Sample( DepthSampler, RandomRotationSampler, vProjCoords, vScreenPos, vShadowTweaks, false, true );
+
+ return flShadow;
+#else
+
+ // Compile-time switch for shaders which allow high quality modes on 360
+ if ( bAllowHighQuality )
+ {
+ // Static control flow switch for shadow quality. Some non-interactive sequences use the high quality path
+ if ( g_bHighQualityShadows )
+ {
+ flShadow = DoShadowPoisson360( DepthSampler, RandomRotationSampler, vProjCoords, vScreenPos, vShadowTweaks );
+ }
+ else
+ {
+ flShadow = DoShadow360Simple( DepthSampler, vProjCoords );
+ }
+ }
+ else
+ {
+ flShadow = DoShadow360Simple( DepthSampler, vProjCoords );
+ }
+
+ return flShadow;
+
+#endif
+}
+
+float3 SpecularLight( const float3 vWorldNormal, const float3 vLightDir, const float fSpecularExponent,
+ const float3 vEyeDir, /*const bool bDoSpecularWarp, in sampler specularWarpSampler,*/ float fFresnel )
+{
+ float3 result = float3(0.0f, 0.0f, 0.0f);
+
+ float3 vReflect = reflect( -vEyeDir, vWorldNormal ); // Reflect view through normal
+ float3 vSpecular = saturate(dot( vReflect, vLightDir )); // L.R (use half-angle instead?)
+ vSpecular = pow( vSpecular.x, fSpecularExponent ); // Raise to specular power
+
+ // Optionally warp as function of scalar specular and fresnel
+ //if ( bDoSpecularWarp )
+ // vSpecular *= tex2D( specularWarpSampler, float2(vSpecular.x, fFresnel) ); // Sample at { (L.R)^k, fresnel }
+ vSpecular *= fFresnel;
+
+ return vSpecular;
+}
+
+void DoSpecularFlashlight( float3 flashlightPos, float3 worldPos, float4 flashlightSpacePosition, float3 worldNormal,
+ float3 attenuationFactors, float farZ, sampler FlashlightSampler, sampler FlashlightDepthSampler, sampler RandomRotationSampler,
+ int nShadowLevel, bool bDoShadows, bool bAllowHighQuality, const float2 vScreenPos, const float fSpecularExponent, const float3 vEyeDir,
+ /*const bool bDoSpecularWarp, sampler specularWarpSampler,*/ float fFresnel, float4 vShadowTweaks,
+
+ // Outputs of this shader...separate shadowed diffuse and specular from the flashlight
+ out float3 diffuseLighting, out float3 specularLighting )
+{
+ float3 vProjCoords = flashlightSpacePosition.xyz / flashlightSpacePosition.w;
+ float3 flashlightColor = float3(1,1,1);
+
+#if ( defined( _X360 ) )
+
+ float3 ltz = vProjCoords.xyz < float3( 0.0f, 0.0f, 0.0f );
+ float3 gto = vProjCoords.xyz > float3( 1.0f, 1.0f, 1.0f );
+
+ [branch]
+ if ( dot(ltz + gto, float3(1,1,1)) > 0 )
+ {
+ clip(-1);
+ diffuseLighting = specularLighting = float3(0,0,0);
+ return;
+ }
+ else
+ {
+ flashlightColor = tex2D( FlashlightSampler, vProjCoords );
+
+ [branch]
+ if ( dot(flashlightColor.xyz, float3(1,1,1)) <= 0 )
+ {
+ clip(-1);
+ diffuseLighting = specularLighting = float3(0,0,0);
+ return;
+ }
+ }
+#else
+ flashlightColor = tex2D( FlashlightSampler, vProjCoords );
+#endif
+
+
+#if defined(SHADER_MODEL_PS_2_0) || defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)
+ flashlightColor *= cFlashlightColor.xyz; // Flashlight color
+#endif
+
+ float3 delta = flashlightPos - worldPos;
+ float3 L = normalize( delta );
+ float distSquared = dot( delta, delta );
+ float dist = sqrt( distSquared );
+
+ float endFalloffFactor = RemapValClamped( dist, farZ, 0.6f * farZ, 0.0f, 1.0f );
+
+ // Attenuation for light and to fade out shadow over distance
+ float fAtten = saturate( dot( attenuationFactors, float3( 1.0f, 1.0f/dist, 1.0f/distSquared ) ) );
+
+ // Shadowing and coloring terms
+#if (defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0))
+ if ( bDoShadows )
+ {
+ float flShadow = DoFlashlightShadow( FlashlightDepthSampler, RandomRotationSampler, vProjCoords, vScreenPos, nShadowLevel, vShadowTweaks, bAllowHighQuality );
+ float flAttenuated = lerp( flShadow, 1.0f, vShadowTweaks.y ); // Blend between fully attenuated and not attenuated
+ flShadow = saturate( lerp( flAttenuated, flShadow, fAtten ) ); // Blend between shadow and above, according to light attenuation
+ flashlightColor *= flShadow; // Shadow term
+ }
+#endif
+
+ diffuseLighting = fAtten;
+#if defined(SHADER_MODEL_PS_2_0) || defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)
+ diffuseLighting *= saturate( dot( L.xyz, worldNormal.xyz ) + flFlashlightNoLambertValue ); // Lambertian term
+#else
+ diffuseLighting *= saturate( dot( L.xyz, worldNormal.xyz ) ); // Lambertian (not Half-Lambert) term
+#endif
+ diffuseLighting *= flashlightColor;
+ diffuseLighting *= endFalloffFactor;
+
+ // Specular term (masked by diffuse)
+ specularLighting = diffuseLighting * SpecularLight ( worldNormal, L, fSpecularExponent, vEyeDir, /*bDoSpecularWarp, specularWarpSampler,*/ fFresnel );
+}
+
+// Diffuse only version
+float3 DoFlashlight( float3 flashlightPos, float3 worldPos, float4 flashlightSpacePosition, float3 worldNormal,
+ float3 attenuationFactors, float farZ, sampler FlashlightSampler, sampler FlashlightDepthSampler,
+ sampler RandomRotationSampler, int nShadowLevel, bool bDoShadows, bool bAllowHighQuality,
+ const float2 vScreenPos, bool bClip, float4 vShadowTweaks = float4(3/1024.0f, 0.0005f, 0.0f, 0.0f), bool bHasNormal = true )
+{
+ float3 vProjCoords = flashlightSpacePosition.xyz / flashlightSpacePosition.w;
+ float3 flashlightColor = float3(1,1,1);
+
+#if ( defined( _X360 ) )
+
+ float3 ltz = vProjCoords.xyz < float3( 0.0f, 0.0f, 0.0f );
+ float3 gto = vProjCoords.xyz > float3( 1.0f, 1.0f, 1.0f );
+
+ [branch]
+ if ( dot(ltz + gto, float3(1,1,1)) > 0 )
+ {
+ if ( bClip )
+ {
+ clip(-1);
+ }
+ return float3(0,0,0);
+ }
+ else
+ {
+ flashlightColor = tex2D( FlashlightSampler, vProjCoords );
+
+ [branch]
+ if ( dot(flashlightColor.xyz, float3(1,1,1)) <= 0 )
+ {
+ if ( bClip )
+ {
+ clip(-1);
+ }
+ return float3(0,0,0);
+ }
+ }
+#else
+ flashlightColor = tex2D( FlashlightSampler, vProjCoords );
+#endif
+
+#if defined(SHADER_MODEL_PS_2_0) || defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)
+ flashlightColor *= cFlashlightColor.xyz; // Flashlight color
+#endif
+
+ float3 delta = flashlightPos - worldPos;
+ float3 L = normalize( delta );
+ float distSquared = dot( delta, delta );
+ float dist = sqrt( distSquared );
+
+ float endFalloffFactor = RemapValClamped( dist, farZ, 0.6f * farZ, 0.0f, 1.0f );
+
+ // Attenuation for light and to fade out shadow over distance
+ float fAtten = saturate( dot( attenuationFactors, float3( 1.0f, 1.0f/dist, 1.0f/distSquared ) ) );
+
+ // Shadowing and coloring terms
+#if (defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0))
+ if ( bDoShadows )
+ {
+ float flShadow = DoFlashlightShadow( FlashlightDepthSampler, RandomRotationSampler, vProjCoords, vScreenPos, nShadowLevel, vShadowTweaks, bAllowHighQuality );
+ float flAttenuated = lerp( flShadow, 1.0f, vShadowTweaks.y ); // Blend between fully attenuated and not attenuated
+ flShadow = saturate( lerp( flAttenuated, flShadow, fAtten ) ); // Blend between shadow and above, according to light attenuation
+ flashlightColor *= flShadow; // Shadow term
+ }
+#endif
+
+ float3 diffuseLighting = fAtten;
+
+ float flLDotWorldNormal;
+ if ( bHasNormal )
+ {
+ flLDotWorldNormal = dot( L.xyz, worldNormal.xyz );
+ }
+ else
+ {
+ flLDotWorldNormal = 1.0f;
+ }
+
+#if defined(SHADER_MODEL_PS_2_0) || defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)
+ diffuseLighting *= saturate( flLDotWorldNormal + flFlashlightNoLambertValue ); // Lambertian term
+#else
+ diffuseLighting *= saturate( flLDotWorldNormal ); // Lambertian (not Half-Lambert) term
+#endif
+
+ diffuseLighting *= flashlightColor;
+ diffuseLighting *= endFalloffFactor;
+
+ return diffuseLighting;
+}
+
+#endif //#ifndef COMMON_FLASHLIGHT_FXC_H_
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_fxc.h b/mp/game/momentum/shadereditorui/shader_src/common_fxc.h
new file mode 100644
index 0000000000..72a1d5d4b0
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_fxc.h
@@ -0,0 +1,326 @@
+//========= Copyright © 1996-2007, Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+#ifndef COMMON_FXC_H_
+#define COMMON_FXC_H_
+
+#include "common_pragmas.h"
+#include "common_hlsl_cpp_consts.h"
+
+#ifdef NV3X
+# define HALF half
+# define HALF2 half2
+# define HALF3 half3
+# define HALF4 half4
+# define HALF3x3 half3x3
+# define HALF3x4 half3x4
+# define HALF4x3 half4x3
+# define HALF_CONSTANT( _constant ) ((HALF)_constant)
+#else
+# define HALF float
+# define HALF2 float2
+# define HALF3 float3
+# define HALF4 float4
+# define HALF3x3 float3x3
+# define HALF3x4 float3x4
+# define HALF4x3 float4x3
+# define HALF_CONSTANT( _constant ) _constant
+#endif
+
+// This is where all common code for both vertex and pixel shaders.
+#define OO_SQRT_3 0.57735025882720947f
+static const HALF3 bumpBasis[3] = {
+ HALF3( 0.81649661064147949f, 0.0f, OO_SQRT_3 ),
+ HALF3( -0.40824833512306213f, 0.70710676908493042f, OO_SQRT_3 ),
+ HALF3( -0.40824821591377258f, -0.7071068286895752f, OO_SQRT_3 )
+};
+static const HALF3 bumpBasisTranspose[3] = {
+ HALF3( 0.81649661064147949f, -0.40824833512306213f, -0.40824833512306213f ),
+ HALF3( 0.0f, 0.70710676908493042f, -0.7071068286895752f ),
+ HALF3( OO_SQRT_3, OO_SQRT_3, OO_SQRT_3 )
+};
+
+#if defined( _X360 )
+#define REVERSE_DEPTH_ON_X360 //uncomment to use D3DFMT_D24FS8 with an inverted depth viewport for better performance. Keep this in sync with the same named #define in public/shaderapi/shareddefs.h
+//Note that the reversal happens in the viewport. So ONLY reading back from a depth texture should be affected. Projected math is unaffected.
+#endif
+
+HALF3 CalcReflectionVectorNormalized( HALF3 normal, HALF3 eyeVector )
+{
+ // FIXME: might be better of normalizing with a normalizing cube map and
+ // get rid of the dot( normal, normal )
+ // compute reflection vector r = 2 * ((n dot v)/(n dot n)) n - v
+ return 2.0 * ( dot( normal, eyeVector ) / dot( normal, normal ) ) * normal - eyeVector;
+}
+
+HALF3 CalcReflectionVectorUnnormalized( HALF3 normal, HALF3 eyeVector )
+{
+ // FIXME: might be better of normalizing with a normalizing cube map and
+ // get rid of the dot( normal, normal )
+ // compute reflection vector r = 2 * ((n dot v)/(n dot n)) n - v
+ // multiply all values through by N.N. uniformly scaling reflection vector won't affect result
+ // since it is used in a cubemap lookup
+ return (2.0*(dot( normal, eyeVector ))*normal) - (dot( normal, normal )*eyeVector);
+}
+
+float3 HuePreservingColorClamp( float3 c )
+{
+ // Get the max of all of the color components and a specified maximum amount
+ float maximum = max( max( c.x, c.y ), max( c.z, 1.0f ) );
+
+ return (c / maximum);
+}
+
+HALF3 HuePreservingColorClamp( HALF3 c, HALF maxVal )
+{
+ // Get the max of all of the color components and a specified maximum amount
+ float maximum = max( max( c.x, c.y ), max( c.z, maxVal ) );
+ return (c * ( maxVal / maximum ) );
+}
+
+#if (AA_CLAMP==1)
+HALF2 ComputeLightmapCoordinates( HALF4 Lightmap1and2Coord, HALF2 Lightmap3Coord )
+{
+ HALF2 result = saturate(Lightmap1and2Coord.xy) * Lightmap1and2Coord.wz * 0.99;
+ result += Lightmap3Coord;
+ return result;
+}
+
+void ComputeBumpedLightmapCoordinates( HALF4 Lightmap1and2Coord, HALF2 Lightmap3Coord,
+ out HALF2 bumpCoord1,
+ out HALF2 bumpCoord2,
+ out HALF2 bumpCoord3 )
+{
+ HALF2 result = saturate(Lightmap1and2Coord.xy) * Lightmap1and2Coord.wz * 0.99;
+ result += Lightmap3Coord;
+ bumpCoord1 = result + HALF2(Lightmap1and2Coord.z, 0);
+ bumpCoord2 = result + 2*HALF2(Lightmap1and2Coord.z, 0);
+ bumpCoord3 = result + 3*HALF2(Lightmap1and2Coord.z, 0);
+}
+#else
+HALF2 ComputeLightmapCoordinates( HALF4 Lightmap1and2Coord, HALF2 Lightmap3Coord )
+{
+ return Lightmap1and2Coord.xy;
+}
+
+void ComputeBumpedLightmapCoordinates( HALF4 Lightmap1and2Coord, HALF2 Lightmap3Coord,
+ out HALF2 bumpCoord1,
+ out HALF2 bumpCoord2,
+ out HALF2 bumpCoord3 )
+{
+ bumpCoord1 = Lightmap1and2Coord.xy;
+ bumpCoord2 = Lightmap1and2Coord.wz; // reversed order!!!
+ bumpCoord3 = Lightmap3Coord.xy;
+}
+#endif
+
+// Versions of matrix multiply functions which force HLSL compiler to explictly use DOTs,
+// not giving it the option of using MAD expansion. In a perfect world, the compiler would
+// always pick the best strategy, and these shouldn't be needed.. but.. well.. umm..
+//
+// lorenmcq
+
+float3 mul3x3(float3 v, float3x3 m)
+{
+#if !defined( _X360 )
+ return float3(dot(v, transpose(m)[0]), dot(v, transpose(m)[1]), dot(v, transpose(m)[2]));
+#else
+ // xbox360 fxc.exe (new back end) borks with transposes, generates bad code
+ return mul( v, m );
+#endif
+}
+
+float3 mul4x3(float4 v, float4x3 m)
+{
+#if !defined( _X360 )
+ return float3(dot(v, transpose(m)[0]), dot(v, transpose(m)[1]), dot(v, transpose(m)[2]));
+#else
+ // xbox360 fxc.exe (new back end) borks with transposes, generates bad code
+ return mul( v, m );
+#endif
+}
+
+float3 DecompressHDR( float4 input )
+{
+ return input.rgb * input.a * MAX_HDR_OVERBRIGHT;
+}
+
+float4 CompressHDR( float3 input )
+{
+ // FIXME: want to use min so that we clamp to white, but what happens if we
+ // have an albedo component that's less than 1/MAX_HDR_OVERBRIGHT?
+ // float fMax = max( max( color.r, color.g ), color.b );
+ float4 output;
+ float fMax = min( min( input.r, input.g ), input.b );
+ if( fMax > 1.0f )
+ {
+ float oofMax = 1.0f / fMax;
+ output.rgb = oofMax * input.rgb;
+ output.a = min( fMax / MAX_HDR_OVERBRIGHT, 1.0f );
+ }
+ else
+ {
+ output.rgb = input.rgb;
+ output.a = 0.0f;
+ }
+ return output;
+}
+
+
+float3 LinearToGamma( const float3 f3linear )
+{
+ return pow( f3linear, 1.0f / 2.2f );
+}
+
+float4 LinearToGamma( const float4 f4linear )
+{
+ return float4( pow( f4linear.xyz, 1.0f / 2.2f ), f4linear.w );
+}
+
+float LinearToGamma( const float f1linear )
+{
+ return pow( f1linear, 1.0f / 2.2f );
+}
+
+float3 GammaToLinear( const float3 gamma )
+{
+ return pow( gamma, 2.2f );
+}
+
+float4 GammaToLinear( const float4 gamma )
+{
+ return float4( pow( gamma.xyz, 2.2f ), gamma.w );
+}
+
+float GammaToLinear( const float gamma )
+{
+ return pow( gamma, 2.2f );
+}
+
+// These two functions use the actual sRGB math
+float SrgbGammaToLinear( float flSrgbGammaValue )
+{
+ float x = saturate( flSrgbGammaValue );
+ return ( x <= 0.04045f ) ? ( x / 12.92f ) : ( pow( ( x + 0.055f ) / 1.055f, 2.4f ) );
+}
+
+float SrgbLinearToGamma( float flLinearValue )
+{
+ float x = saturate( flLinearValue );
+ return ( x <= 0.0031308f ) ? ( x * 12.92f ) : ( 1.055f * pow( x, ( 1.0f / 2.4f ) ) ) - 0.055f;
+}
+
+// These twofunctions use the XBox 360's exact piecewise linear algorithm
+float X360GammaToLinear( float fl360GammaValue )
+{
+ float flLinearValue;
+
+ fl360GammaValue = saturate( fl360GammaValue );
+ if ( fl360GammaValue < ( 96.0f / 255.0f ) )
+ {
+ if ( fl360GammaValue < ( 64.0f / 255.0f ) )
+ {
+ flLinearValue = fl360GammaValue * 255.0f;
+ }
+ else
+ {
+ flLinearValue = fl360GammaValue * ( 255.0f * 2.0f ) - 64.0f;
+ flLinearValue += floor( flLinearValue * ( 1.0f / 512.0f ) );
+ }
+ }
+ else
+ {
+ if( fl360GammaValue < ( 192.0f / 255.0f ) )
+ {
+ flLinearValue = fl360GammaValue * ( 255.0f * 4.0f ) - 256.0f;
+ flLinearValue += floor( flLinearValue * ( 1.0f / 256.0f ) );
+ }
+ else
+ {
+ flLinearValue = fl360GammaValue * ( 255.0f * 8.0f ) - 1024.0f;
+ flLinearValue += floor( flLinearValue * ( 1.0f / 128.0f ) );
+ }
+ }
+
+ flLinearValue *= 1.0f / 1023.0f;
+
+ flLinearValue = saturate( flLinearValue );
+ return flLinearValue;
+}
+
+float X360LinearToGamma( float flLinearValue )
+{
+ float fl360GammaValue;
+
+ flLinearValue = saturate( flLinearValue );
+ if ( flLinearValue < ( 128.0f / 1023.0f ) )
+ {
+ if ( flLinearValue < ( 64.0f / 1023.0f ) )
+ {
+ fl360GammaValue = flLinearValue * ( 1023.0f * ( 1.0f / 255.0f ) );
+ }
+ else
+ {
+ fl360GammaValue = flLinearValue * ( ( 1023.0f / 2.0f ) * ( 1.0f / 255.0f ) ) + ( 32.0f / 255.0f );
+ }
+ }
+ else
+ {
+ if ( flLinearValue < ( 512.0f / 1023.0f ) )
+ {
+ fl360GammaValue = flLinearValue * ( ( 1023.0f / 4.0f ) * ( 1.0f / 255.0f ) ) + ( 64.0f / 255.0f );
+ }
+ else
+ {
+ fl360GammaValue = flLinearValue * ( ( 1023.0f /8.0f ) * ( 1.0f / 255.0f ) ) + ( 128.0f /255.0f ); // 1.0 -> 1.0034313725490196078431372549016
+ if ( fl360GammaValue > 1.0f )
+ {
+ fl360GammaValue = 1.0f;
+ }
+ }
+ }
+
+ fl360GammaValue = saturate( fl360GammaValue );
+ return fl360GammaValue;
+}
+
+float SrgbGammaTo360Gamma( float flSrgbGammaValue )
+{
+ float flLinearValue = SrgbGammaToLinear( flSrgbGammaValue );
+ float fl360GammaValue = X360LinearToGamma( flLinearValue );
+ return fl360GammaValue;
+}
+
+float3 Vec3WorldToTangent( float3 iWorldVector, float3 iWorldNormal, float3 iWorldTangent, float3 iWorldBinormal )
+{
+ float3 vTangentVector;
+ vTangentVector.x = dot( iWorldVector.xyz, iWorldTangent.xyz );
+ vTangentVector.y = dot( iWorldVector.xyz, iWorldBinormal.xyz );
+ vTangentVector.z = dot( iWorldVector.xyz, iWorldNormal.xyz );
+ return vTangentVector.xyz; // Return without normalizing
+}
+
+float3 Vec3WorldToTangentNormalized( float3 iWorldVector, float3 iWorldNormal, float3 iWorldTangent, float3 iWorldBinormal )
+{
+ return normalize( Vec3WorldToTangent( iWorldVector, iWorldNormal, iWorldTangent, iWorldBinormal ) );
+}
+
+float3 Vec3TangentToWorld( float3 iTangentVector, float3 iWorldNormal, float3 iWorldTangent, float3 iWorldBinormal )
+{
+ float3 vWorldVector;
+ vWorldVector.xyz = iTangentVector.x * iWorldTangent.xyz;
+ vWorldVector.xyz += iTangentVector.y * iWorldBinormal.xyz;
+ vWorldVector.xyz += iTangentVector.z * iWorldNormal.xyz;
+ return vWorldVector.xyz; // Return without normalizing
+}
+
+float3 Vec3TangentToWorldNormalized( float3 iTangentVector, float3 iWorldNormal, float3 iWorldTangent, float3 iWorldBinormal )
+{
+ return normalize( Vec3TangentToWorld( iTangentVector, iWorldNormal, iWorldTangent, iWorldBinormal ) );
+}
+
+#endif //#ifndef COMMON_FXC_H_
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_hlsl_cpp_consts.h b/mp/game/momentum/shadereditorui/shader_src/common_hlsl_cpp_consts.h
new file mode 100644
index 0000000000..5989e2b088
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_hlsl_cpp_consts.h
@@ -0,0 +1,27 @@
+//========= Copyright © 1996-2005, Valve Corporation, All rights reserved. ============//
+//
+// Purpose:
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+#ifndef COMMON_HLSL_CONSTS_H_
+#define COMMON_HLSL_CONSTS_H_
+
+#ifdef NV3X
+ #define PSHADER_VECT_SCALE 20.0
+ #define VSHADER_VECT_SCALE (1.0 / (PSHADER_VECT_SCALE) )
+#else
+ #define PSHADER_VECT_SCALE 1.0
+ #define VSHADER_VECT_SCALE 1.0
+#endif
+
+// GR - HDR luminance maps to 0..n range
+// IMPORTANT: Keep the same value as in materialsystem_global.h
+// HDRFIXME: Make this a pixel shader constant?
+#define MAX_HDR_OVERBRIGHT 16.0f
+
+#define LINEAR_FOG_COLOR 29
+#define TONE_MAPPING_SCALE_PSH_CONSTANT 30
+
+#endif //#ifndef COMMON_HLSL_CONSTS_H_
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_lightmappedgeneric_fxc.h b/mp/game/momentum/shadereditorui/shader_src/common_lightmappedgeneric_fxc.h
new file mode 100644
index 0000000000..a1354d1a16
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_lightmappedgeneric_fxc.h
@@ -0,0 +1,201 @@
+
+
+#if defined( _X360 )
+
+void GetBaseTextureAndNormal( sampler base, sampler base2, sampler bump, bool bBase2, bool bBump, float3 coords, float3 vWeights,
+ out float4 vResultBase, out float4 vResultBase2, out float4 vResultBump )
+{
+ vResultBase = 0;
+ vResultBase2 = 0;
+ vResultBump = 0;
+
+ if ( !bBump )
+ {
+ vResultBump = float4(0, 0, 1, 1);
+ }
+
+#if SEAMLESS
+
+ vWeights = max( vWeights - 0.3, 0 );
+
+ vWeights *= 1.0f / dot( vWeights, float3(1,1,1) );
+
+ [branch]
+ if (vWeights.x > 0)
+ {
+ vResultBase += vWeights.x * tex2D( base, coords.zy );
+
+ if ( bBase2 )
+ {
+ vResultBase2 += vWeights.x * tex2D( base2, coords.zy );
+ }
+
+ if ( bBump )
+ {
+ vResultBump += vWeights.x * tex2D( bump, coords.zy );
+ }
+ }
+
+ [branch]
+ if (vWeights.y > 0)
+ {
+ vResultBase += vWeights.y * tex2D( base, coords.xz );
+
+ if ( bBase2 )
+ {
+ vResultBase2 += vWeights.y * tex2D( base2, coords.xz );
+ }
+ if ( bBump )
+ {
+ vResultBump += vWeights.y * tex2D( bump, coords.xz );
+ }
+ }
+
+ [branch]
+ if (vWeights.z > 0)
+ {
+ vResultBase += vWeights.z * tex2D( base, coords.xy );
+ if ( bBase2 )
+ {
+ vResultBase2 += vWeights.z * tex2D( base2, coords.xy );
+ }
+
+ if ( bBump )
+ {
+ vResultBump += vWeights.z * tex2D( bump, coords.xy );
+ }
+ }
+
+#else // not seamless
+
+ vResultBase = tex2D( base, coords.xy );
+
+ if ( bBase2 )
+ {
+ vResultBase2 = tex2D( base2, coords.xy );
+ }
+
+ if ( bBump )
+ {
+ vResultBump = tex2D( bump, coords.xy );
+ }
+
+#endif
+
+
+}
+
+#else // PC
+
+void GetBaseTextureAndNormal( sampler base, sampler base2, sampler bump, bool bBase2, bool bBump, float3 coords, float3 vWeights,
+ out float4 vResultBase, out float4 vResultBase2, out float4 vResultBump )
+{
+ vResultBase = 0;
+ vResultBase2 = 0;
+ vResultBump = 0;
+
+ if ( !bBump )
+ {
+ vResultBump = float4(0, 0, 1, 1);
+ }
+
+#if SEAMLESS
+
+ vResultBase += vWeights.x * tex2D( base, coords.zy );
+ if ( bBase2 )
+ {
+ vResultBase2 += vWeights.x * tex2D( base2, coords.zy );
+ }
+ if ( bBump )
+ {
+ vResultBump += vWeights.x * tex2D( bump, coords.zy );
+ }
+
+ vResultBase += vWeights.y * tex2D( base, coords.xz );
+ if ( bBase2 )
+ {
+ vResultBase2 += vWeights.y * tex2D( base2, coords.xz );
+ }
+ if ( bBump )
+ {
+ vResultBump += vWeights.y * tex2D( bump, coords.xz );
+ }
+
+ vResultBase += vWeights.z * tex2D( base, coords.xy );
+ if ( bBase2 )
+ {
+ vResultBase2 += vWeights.z * tex2D( base2, coords.xy );
+ }
+ if ( bBump )
+ {
+ vResultBump += vWeights.z * tex2D( bump, coords.xy );
+ }
+
+#else // not seamless
+
+ vResultBase = tex2D( base, coords.xy );
+ if ( bBase2 )
+ {
+ vResultBase2 = tex2D( base2, coords.xy );
+ }
+ if ( bBump )
+ {
+ vResultBump = tex2D( bump, coords.xy );
+ }
+#endif
+
+}
+
+#endif
+
+
+
+
+float3 LightMapSample( sampler LightmapSampler, float2 vTexCoord )
+{
+# if ( !defined( _X360 ) || !defined( USE_32BIT_LIGHTMAPS_ON_360 ) )
+ {
+ float3 sample = tex2D( LightmapSampler, vTexCoord );
+
+ return sample;
+ }
+# else
+ {
+# if 0 //1 for cheap sampling, 0 for accurate scaling from the individual samples
+ {
+ float4 sample = tex2D( LightmapSampler, vTexCoord );
+
+ return sample.rgb * sample.a;
+ }
+# else
+ {
+ float4 Weights;
+ float4 samples_0; //no arrays allowed in inline assembly
+ float4 samples_1;
+ float4 samples_2;
+ float4 samples_3;
+
+ asm {
+ tfetch2D samples_0, vTexCoord.xy, LightmapSampler, OffsetX = -0.5, OffsetY = -0.5, MinFilter=point, MagFilter=point, MipFilter=keep, UseComputedLOD=false
+ tfetch2D samples_1, vTexCoord.xy, LightmapSampler, OffsetX = 0.5, OffsetY = -0.5, MinFilter=point, MagFilter=point, MipFilter=keep, UseComputedLOD=false
+ tfetch2D samples_2, vTexCoord.xy, LightmapSampler, OffsetX = -0.5, OffsetY = 0.5, MinFilter=point, MagFilter=point, MipFilter=keep, UseComputedLOD=false
+ tfetch2D samples_3, vTexCoord.xy, LightmapSampler, OffsetX = 0.5, OffsetY = 0.5, MinFilter=point, MagFilter=point, MipFilter=keep, UseComputedLOD=false
+
+ getWeights2D Weights, vTexCoord.xy, LightmapSampler
+ };
+
+ Weights = float4( (1-Weights.x)*(1-Weights.y), Weights.x*(1-Weights.y), (1-Weights.x)*Weights.y, Weights.x*Weights.y );
+
+ float3 result;
+ result.rgb = samples_0.rgb * (samples_0.a * Weights.x);
+ result.rgb += samples_1.rgb * (samples_1.a * Weights.y);
+ result.rgb += samples_2.rgb * (samples_2.a * Weights.z);
+ result.rgb += samples_3.rgb * (samples_3.a * Weights.w);
+
+ return result;
+ }
+# endif
+ }
+# endif
+}
+
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_parallax.h b/mp/game/momentum/shadereditorui/shader_src/common_parallax.h
new file mode 100644
index 0000000000..85361a7f16
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_parallax.h
@@ -0,0 +1,247 @@
+#ifndef COMMON_PARALLAX_H
+#define COMMON_PARALLAX_H
+
+#include "common_ps_fxc.h"
+
+void GetWorldSpaceOffset( const bool bDoCalc, float3 wpos, float2 uvdelta,
+ float prlxamt, float scale, out float3 worldSpaceOffset )
+{
+ if ( bDoCalc )
+ {
+ worldSpaceOffset.xy = uvdelta * scale;
+ worldSpaceOffset.z = prlxamt; // * 0.7f;
+ }
+ else
+ worldSpaceOffset = float3( 0, 0, 0 );
+}
+
+float CalcDerivativeScale( const bool bDoCalc, float2 uvddx, float2 uvddy, float3 wpos )
+{
+ float scale = 1;
+ if ( bDoCalc )
+ scale = max( length( ddx( wpos ) ) / length(uvddx), length( ddy( wpos ) ) / length(uvddy) );
+ return scale;
+}
+
+float2 CalcParallaxUV_Relief( float2 inTexCoord, float3 vViewTS, float flParallaxAmt, float3 vNormal,
+ float3 vViewW, sampler HeightMapSampler,
+ const int samples_min, const int samples_max, const int binary_max,
+ float3 WPos, out float3 worldSpaceOffset,
+ const bool bDoGradient, const bool bGetOffset )
+{
+ float3 p = float3(inTexCoord,1);
+ float3 v = normalize(vViewTS);
+ v.z = abs(v.z);
+
+ float2 dx = ddx( inTexCoord );
+ float2 dy = ddy( inTexCoord );
+ float scale = CalcDerivativeScale( true, dx, dy, WPos );
+
+ flParallaxAmt /= scale;
+
+ float depthBias = 1.0 - v.z;
+ depthBias = 1.0f - pow( depthBias, 10 );
+
+ v.xy *= depthBias * flParallaxAmt;
+
+ int linearSearchSteps = samples_max;
+ if ( bDoGradient )
+ {
+ vViewW = normalize( vViewW );
+ linearSearchSteps = (int) lerp( samples_max, samples_min, dot( vViewW, vNormal ) );
+ }
+ int binarySearchSteps = binary_max;
+
+ v /= v.z * linearSearchSteps;
+ int i;
+ float curh = 0;
+ v.z *= -1.0f;
+
+ if ( !bDoGradient )
+ {
+ for ( i = 0; i < linearSearchSteps; i++ )
+ {
+ curh = tex2D( HeightMapSampler, p.xy ).r;
+ if ( curh < p.z )
+ p += v;
+ }
+ }
+ else
+ {
+ bool bCondition = true;
+ int nStepIndex = 0;
+ while ( bCondition == true && nStepIndex < linearSearchSteps )
+ {
+ curh = tex2Dgrad( HeightMapSampler, p.xy, dx, dy ).r;
+ if ( curh > p.z )
+ bCondition = false;
+ else
+ {
+ p += v;
+ nStepIndex++;
+ }
+ }
+ }
+
+ for( i = 0; i < binarySearchSteps; i++ )
+ {
+ v *= 0.5f;
+ float tex = tex2D(HeightMapSampler, p.xy).r;
+ if (p.z > tex)
+ p += v;
+ else
+ p -= v;
+ }
+
+ GetWorldSpaceOffset( bGetOffset, WPos, (inTexCoord-p.xy),
+ (1.0f-p.z), scale, worldSpaceOffset );
+ return p.xy;
+}
+
+
+//===================================================================================//
+// This is based on Natasha Tatarchuk's Parallax Occlusion Mapping (ATI)
+//===================================================================================//
+// INPUT:
+// inTexCoord:
+// the texcoord for the height/displacement map before parallaxing
+//
+// vParallax:
+// Compute initial parallax displacement direction:
+// float2 vParallaxDirection = normalize( vViewTS.xy );
+// float fLength = length( vViewTS );
+// float fParallaxLength = sqrt( fLength * fLength - vViewTS.z * vViewTS.z ) / vViewTS.z;
+// Out.vParallax = vParallaxDirection * fParallaxLength * fProjectedBumpHeight;
+//
+// vNormal:
+// tangent space normal
+//
+// vViewW:
+// float3 vViewW = /*normalize*/(mul( matViewInverse, float4( 0, 0, 0, 1)) - inPosition );
+//
+// OUTPUT:
+// the new texcoord after parallaxing
+
+float2 CalcParallaxUV_POM( float2 inTexCoord, float3 vViewTS, float flParallaxAmt, float3 vNormal,
+ float3 vViewW, sampler HeightMapSampler,
+ const int samples_min, const int samples_max, const int binary_max,
+ float3 WPos, out float3 worldSpaceOffset,
+ const bool bDoGradient, const bool bGetOffset )
+{
+ float2 dx = ddx( inTexCoord );
+ float2 dy = ddy( inTexCoord );
+
+ float scale = CalcDerivativeScale( true, dx, dy, WPos );
+ flParallaxAmt /= scale;
+
+ float2 vParallax = normalize( vViewTS.xy );
+ float fLength = length( vViewTS );
+ float fParallaxLength = sqrt( fLength * fLength - vViewTS.z * vViewTS.z ) / vViewTS.z;
+ vParallax *= fParallaxLength * flParallaxAmt;
+
+ vViewW = normalize( vViewW );
+
+ //===============================================//
+ // Parallax occlusion mapping offset computation //
+ //===============================================//
+ int nNumSteps = (int) lerp( samples_max, samples_min, dot( vViewW, vNormal ) );
+
+ float fCurrHeight = 0.0;
+ float fStepSize = 1.0 / (float) nNumSteps;
+ float fPrevHeight = 1.0;
+ float fNextHeight = 0.0;
+
+ int nStepIndex = 0;
+
+ float2 vTexOffsetPerStep = fStepSize * vParallax;
+
+ float2 vTexCurrentOffset = inTexCoord;
+ float fCurrentBound = 1.0;
+
+ float x = 0;
+ float y = 0;
+ float xh = 0;
+ float yh = 0;
+
+ float2 texOffset2 = 0;
+
+ bool bCondition = true;
+ while ( bCondition == true && nStepIndex < nNumSteps )
+ {
+ vTexCurrentOffset -= vTexOffsetPerStep;
+
+ fCurrHeight = tex2Dgrad( HeightMapSampler, vTexCurrentOffset, dx, dy ).r;
+
+ fCurrentBound -= fStepSize;
+
+ if ( fCurrHeight > fCurrentBound )
+ {
+ x = fCurrentBound;
+ y = fCurrentBound + fStepSize;
+ xh = fCurrHeight;
+ yh = fPrevHeight;
+
+ texOffset2 = vTexCurrentOffset - vTexOffsetPerStep;
+
+ bCondition = false;
+ }
+ else
+ {
+ nStepIndex++;
+ fPrevHeight = fCurrHeight;
+ }
+
+ } // End of while ( bCondition == true && nStepIndex > -1 )#else
+ //fCurrentBound -= fStepSize;
+
+ float fParallaxAmount;
+ float numerator = (x * (y - yh) - y * (x - xh));
+ float denomenator = ((y - yh) - (x - xh));
+ // avoid NaN generation
+ if( ( numerator == 0.0f ) && ( denomenator == 0.0f ) )
+ {
+ fParallaxAmount = 0.0f;
+ }
+ else
+ {
+ fParallaxAmount = numerator / denomenator;
+ }
+
+ fParallaxAmount = 1.0f - fParallaxAmount;
+ float2 vParallaxOffset = vParallax * fParallaxAmount;
+ float2 texSampleBase = inTexCoord - vParallaxOffset;
+
+ vParallaxOffset = clamp( vParallaxOffset, -1, 1 );
+
+ GetWorldSpaceOffset( bGetOffset, WPos, vParallaxOffset,
+ fParallaxAmount, scale, worldSpaceOffset );
+
+ return texSampleBase;
+}
+float CalcParallaxedShadows_OneLight( float2 UV, float2 UV_prlx, float3 vecLightTS, float3 WPos, float flParallaxAmt, float flSoftening, sampler Heightmap )
+{
+ float scale = CalcDerivativeScale( true, ddx( UV ), ddy( UV ), WPos );
+ flParallaxAmt /= scale;
+
+ float2 inXY = vecLightTS.xy * flParallaxAmt;
+
+ float sh0 = tex2D( Heightmap, UV_prlx).r;
+ float shA = (tex2D( Heightmap, UV_prlx + inXY * 0.88 ).r - sh0 - 0.88 ) * 1 * flSoftening;
+ float sh9 = (tex2D( Heightmap, UV_prlx + inXY * 0.77 ).r - sh0 - 0.77 ) * 2 * flSoftening;
+ float sh8 = (tex2D( Heightmap, UV_prlx + inXY * 0.66 ).r - sh0 - 0.66 ) * 4 * flSoftening;
+ float sh7 = (tex2D( Heightmap, UV_prlx + inXY * 0.55 ).r - sh0 - 0.55 ) * 6 * flSoftening;
+ float sh6 = (tex2D( Heightmap, UV_prlx + inXY * 0.44 ).r - sh0 - 0.44 ) * 8 * flSoftening;
+ float sh5 = (tex2D( Heightmap, UV_prlx + inXY * 0.33 ).r - sh0 - 0.33 ) * 10 * flSoftening;
+ float sh4 = (tex2D( Heightmap, UV_prlx + inXY * 0.22 ).r - sh0 - 0.22 ) * 12 * flSoftening;
+
+ float fShadow = 1.0f - max( max( max( max( max( max( shA, sh9 ), sh8 ), sh7 ), sh6 ), sh5 ), sh4 );
+ return saturate( fShadow );
+}
+float CalcParallaxedShadows( float2 UV, float3 WPos, float flParallaxAmt, float flSoftening, sampler Heightmap )
+{
+ return 1;
+ //float3 vecLightTS = float3( 0, 0.7f, 0 );
+ //return CalcParallaxedShadows_OneLight( UV, vecLightTS, WPos, flParallaxAmt, flSoftening, Heightmap );
+}
+
+#endif
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_pragmas.h b/mp/game/momentum/shadereditorui/shader_src/common_pragmas.h
new file mode 100644
index 0000000000..d2cf3e140a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_pragmas.h
@@ -0,0 +1,38 @@
+//========= Copyright © 1996-2007, Valve Corporation, All rights reserved. ============//
+//
+// Purpose: Common shader compiler pragmas
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+#ifndef COMMON_PRAGMAS_H_
+#define COMMON_PRAGMAS_H_
+
+//
+// Validated shader models:
+//
+// SHADER_MODEL_VS_1_1
+// SHADER_MODEL_VS_2_0
+// SHADER_MODEL_VS_3_0
+//
+// SHADER_MODEL_PS_1_1
+// SHADER_MODEL_PS_1_4
+// SHADER_MODEL_PS_2_0
+// SHADER_MODEL_PS_2_B
+// SHADER_MODEL_PS_3_0
+//
+//
+//
+// Platforms:
+//
+// PC
+// _X360
+//
+
+// Special pragmas silencing common warnings
+#pragma warning ( disable : 3557 ) // warning X3557: Loop only executes for N iteration(s), forcing loop to unroll
+#pragma warning ( disable : 3595 ) // warning X3595: Microcode Compiler possible performance issue: pixel shader input semantic ___ is unused
+#pragma warning ( disable : 3596 ) // warning X3596: Microcode Compiler possible performance issue: pixel shader input semantic ___ is unused
+#pragma warning ( disable : 4702 ) // warning X4702: complement opportunity missed because input result WAS clamped from 0 to 1
+
+#endif //#ifndef COMMON_PRAGMAS_H_
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_ps_fxc.h b/mp/game/momentum/shadereditorui/shader_src/common_ps_fxc.h
new file mode 100644
index 0000000000..b634a5409a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_ps_fxc.h
@@ -0,0 +1,664 @@
+//====== Copyright © 1996-2007, Valve Corporation, All rights reserved. =======//
+//
+// Purpose: Common pixel shader code
+//
+// $NoKeywords: $
+//
+//=============================================================================//
+#ifndef COMMON_PS_FXC_H_
+#define COMMON_PS_FXC_H_
+
+#include "common_fxc.h"
+
+// Put global skip commands here. . make sure and check that the appropriate vars are defined
+// so these aren't used on the wrong shaders!
+
+// --------------------------------------------------------------------------------
+// HDR should never be enabled if we don't aren't running in float or integer HDR mode.
+// SKIP: defined $HDRTYPE && defined $HDRENABLED && !$HDRTYPE && $HDRENABLED
+// --------------------------------------------------------------------------------
+// We don't ever write water fog to dest alpha if we aren't doing water fog.
+// SKIP: defined $PIXELFOGTYPE && defined $WRITEWATERFOGTODESTALPHA && ( $PIXELFOGTYPE != 1 ) && $WRITEWATERFOGTODESTALPHA
+// --------------------------------------------------------------------------------
+// We don't need fog in the pixel shader if we aren't in float fog mode2
+// NOSKIP: defined $HDRTYPE && defined $HDRENABLED && defined $PIXELFOGTYPE && $HDRTYPE != HDR_TYPE_FLOAT && $FOGTYPE != 0
+// --------------------------------------------------------------------------------
+// We don't do HDR and LIGHTING_PREVIEW at the same time since it's running LDR in hammer.
+// SKIP: defined $LIGHTING_PREVIEW && defined $HDRTYPE && $LIGHTING_PREVIEW && $HDRTYPE != 0
+// --------------------------------------------------------------------------------
+// Ditch all fastpath attempts if we are doing LIGHTING_PREVIEW.
+// SKIP: defined $LIGHTING_PREVIEW && defined $FASTPATHENVMAPTINT && $LIGHTING_PREVIEW && $FASTPATHENVMAPTINT
+// SKIP: defined $LIGHTING_PREVIEW && defined $FASTPATHENVMAPCONTRAST && $LIGHTING_PREVIEW && $FASTPATHENVMAPCONTRAST
+// SKIP: defined $LIGHTING_PREVIEW && defined $FASTPATH && $LIGHTING_PREVIEW && $FASTPATH
+// --------------------------------------------------------------------------------
+// Ditch flashlight depth when flashlight is disabled
+// SKIP: ($FLASHLIGHT || $FLASHLIGHTSHADOWS) && $LIGHTING_PREVIEW
+// --------------------------------------------------------------------------------
+
+// System defined pixel shader constants
+
+#if defined( _X360 )
+const bool g_bHighQualityShadows : register( b0 );
+#endif
+
+// NOTE: w == 1.0f / (Dest alpha compressed depth range).
+const float4 g_LinearFogColor : register( c29 );
+
+#define OO_DESTALPHA_DEPTH_RANGE (g_LinearFogColor.w)
+
+// Linear and gamma light scale values
+const float4 cLightScale : register( c30 );
+#define LINEAR_LIGHT_SCALE (cLightScale.x)
+#define LIGHT_MAP_SCALE (cLightScale.y)
+#define ENV_MAP_SCALE (cLightScale.z)
+#define GAMMA_LIGHT_SCALE (cLightScale.w)
+
+// Flashlight constants
+#if defined(SHADER_MODEL_PS_2_0) || defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)
+ const float4 cFlashlightColor : register( c10 ); //register( c28 );
+ const float4 cFlashlightScreenScale : register( c11 ); //register( c31 ); // .zw are currently unused
+ #define flFlashlightNoLambertValue cFlashlightColor.w // This is either 0.0 or 2.0
+#endif
+
+#define HDR_INPUT_MAP_SCALE 16.0f
+
+#define TONEMAP_SCALE_NONE 0
+#define TONEMAP_SCALE_LINEAR 1
+#define TONEMAP_SCALE_GAMMA 2
+
+#define PIXEL_FOG_TYPE_NONE -1 //MATERIAL_FOG_NONE is handled by PIXEL_FOG_TYPE_RANGE, this is for explicitly disabling fog in the shader
+#define PIXEL_FOG_TYPE_RANGE 0 //range+none packed together in ps2b. Simply none in ps20 (instruction limits)
+#define PIXEL_FOG_TYPE_HEIGHT 1
+
+// If you change these, make the corresponding change in hardwareconfig.cpp
+#define NVIDIA_PCF_POISSON 0
+#define ATI_NOPCF 1
+#define ATI_NO_PCF_FETCH4 2
+
+struct LPREVIEW_PS_OUT
+{
+ float4 color : COLOR0;
+ float4 normal : COLOR1;
+ float4 position : COLOR2;
+ float4 flags : COLOR3;
+};
+
+/*
+// unused
+HALF Luminance( HALF3 color )
+{
+ return dot( color, HALF3( HALF_CONSTANT(0.30f), HALF_CONSTANT(0.59f), HALF_CONSTANT(0.11f) ) );
+}
+*/
+
+/*
+// unused
+HALF LuminanceScaled( HALF3 color )
+{
+ return dot( color, HALF3( HALF_CONSTANT(0.30f) / MAX_HDR_OVERBRIGHT, HALF_CONSTANT(0.59f) / MAX_HDR_OVERBRIGHT, HALF_CONSTANT(0.11f) / MAX_HDR_OVERBRIGHT ) );
+}
+*/
+
+/*
+// unused
+HALF AvgColor( HALF3 color )
+{
+ return dot( color, HALF3( HALF_CONSTANT(0.33333f), HALF_CONSTANT(0.33333f), HALF_CONSTANT(0.33333f) ) );
+}
+*/
+
+/*
+// unused
+HALF4 DiffuseBump( sampler lightmapSampler,
+ float2 lightmapTexCoord1,
+ float2 lightmapTexCoord2,
+ float2 lightmapTexCoord3,
+ HALF3 normal )
+{
+ HALF3 lightmapColor1 = tex2D( lightmapSampler, lightmapTexCoord1 );
+ HALF3 lightmapColor2 = tex2D( lightmapSampler, lightmapTexCoord2 );
+ HALF3 lightmapColor3 = tex2D( lightmapSampler, lightmapTexCoord3 );
+
+ HALF3 diffuseLighting;
+ diffuseLighting = saturate( dot( normal, bumpBasis[0] ) ) * lightmapColor1 +
+ saturate( dot( normal, bumpBasis[1] ) ) * lightmapColor2 +
+ saturate( dot( normal, bumpBasis[2] ) ) * lightmapColor3;
+
+ return HALF4( diffuseLighting, LuminanceScaled( diffuseLighting ) );
+}
+*/
+
+
+/*
+// unused
+HALF Fresnel( HALF3 normal,
+ HALF3 eye,
+ HALF2 scaleBias )
+{
+ HALF fresnel = HALF_CONSTANT(1.0f) - dot( normal, eye );
+ fresnel = pow( fresnel, HALF_CONSTANT(5.0f) );
+
+ return fresnel * scaleBias.x + scaleBias.y;
+}
+*/
+
+/*
+// unused
+HALF4 GetNormal( sampler normalSampler,
+ float2 normalTexCoord )
+{
+ HALF4 normal = tex2D( normalSampler, normalTexCoord );
+ normal.rgb = HALF_CONSTANT(2.0f) * normal.rgb - HALF_CONSTANT(1.0f);
+
+ return normal;
+}
+*/
+
+// Needs to match NormalDecodeMode_t enum in imaterialsystem.h
+#define NORM_DECODE_NONE 0
+#define NORM_DECODE_ATI2N 1
+#define NORM_DECODE_ATI2N_ALPHA 2
+
+float4 DecompressNormal( sampler NormalSampler, float2 tc, int nDecompressionMode, sampler AlphaSampler )
+{
+ float4 normalTexel = tex2D( NormalSampler, tc );
+ float4 result;
+
+ if ( nDecompressionMode == NORM_DECODE_NONE )
+ {
+ result = float4(normalTexel.xyz * 2.0f - 1.0f, normalTexel.a );
+ }
+ else if ( nDecompressionMode == NORM_DECODE_ATI2N )
+ {
+ result.xy = normalTexel.xy * 2.0f - 1.0f;
+ result.z = sqrt( 1.0f - dot(result.xy, result.xy) );
+ result.a = 1.0f;
+ }
+ else // ATI2N plus ATI1N for alpha
+ {
+ result.xy = normalTexel.xy * 2.0f - 1.0f;
+ result.z = sqrt( 1.0f - dot(result.xy, result.xy) );
+ result.a = tex2D( AlphaSampler, tc ).x; // Note that this comes in on the X channel
+ }
+
+ return result;
+}
+
+float4 DecompressNormal( sampler NormalSampler, float2 tc, int nDecompressionMode )
+{
+ return DecompressNormal( NormalSampler, tc, nDecompressionMode, NormalSampler );
+}
+
+
+HALF3 NormalizeWithCubemap( sampler normalizeSampler, HALF3 input )
+{
+// return texCUBE( normalizeSampler, input ) * 2.0f - 1.0f;
+ return texCUBE( normalizeSampler, input );
+}
+
+/*
+HALF4 EnvReflect( sampler envmapSampler,
+ sampler normalizeSampler,
+ HALF3 normal,
+ float3 eye,
+ HALF2 fresnelScaleBias )
+{
+ HALF3 normEye = NormalizeWithCubemap( normalizeSampler, eye );
+ HALF fresnel = Fresnel( normal, normEye, fresnelScaleBias );
+ HALF3 reflect = CalcReflectionVectorUnnormalized( normal, eye );
+ return texCUBE( envmapSampler, reflect );
+}
+*/
+
+float CalcWaterFogAlpha( const float flWaterZ, const float flEyePosZ, const float flWorldPosZ, const float flProjPosZ, const float flFogOORange )
+{
+// float flDepthFromWater = flWaterZ - flWorldPosZ + 2.0f; // hackity hack . .this is for the DF_FUDGE_UP in view_scene.cpp
+ float flDepthFromWater = flWaterZ - flWorldPosZ;
+
+ // if flDepthFromWater < 0, then set it to 0
+ // This is the equivalent of moving the vert to the water surface if it's above the water surface
+ // We'll do this with the saturate at the end instead.
+// flDepthFromWater = max( 0.0f, flDepthFromWater );
+
+ // Calculate the ratio of water fog to regular fog (ie. how much of the distance from the viewer
+ // to the vert is actually underwater.
+ float flDepthFromEye = flEyePosZ - flWorldPosZ;
+ float f = (flDepthFromWater / flDepthFromEye) * flProjPosZ;
+
+ // $tmp.w is now the distance that we see through water.
+ return saturate( f * flFogOORange );
+}
+
+#if defined(SHADER_EDITOR_SWARM_COMPILE)
+float CalcRangeFog( const float3 flEyePos, const float3 flWorldPos, const float flFogEndOverRange, const float flFogMaxDensity, const float flFogOORange )
+#else
+float CalcRangeFog( const float flProjPosZ, const float flFogEndOverRange, const float flFogMaxDensity, const float flFogOORange )
+#endif // SHADER_EDITOR_SWARM_COMPILE
+{
+#if defined(SHADER_EDITOR_SWARM_COMPILE)
+ return min( flFogMaxDensity, saturate( flFogEndOverRange + ( distance( flEyePos, flWorldPos ) * flFogOORange ) ) );
+#elif defined(SHADER_EDITOR_2013_COMPILE)
+ return min( flFogMaxDensity, ( saturate( flProjPosZ * flFogOORange - flFogEndOverRange ) ) );
+#else
+#if !(defined(SHADER_MODEL_PS_1_1) || defined(SHADER_MODEL_PS_1_4) || defined(SHADER_MODEL_PS_2_0)) //Minimum requirement of ps2b
+ return min( flFogMaxDensity, ( saturate( 1.0 - (flFogEndOverRange - (flProjPosZ * flFogOORange)) ) ) );
+#else
+ return 0.0f; //ps20 shaders will never have range fog enabled because too many ran out of slots.
+#endif
+#endif // SHADER_EDITOR_SWARM_COMPILE
+}
+
+#if defined(SHADER_EDITOR_SWARM_COMPILE)
+float CalcPixelFogFactor( int iPIXELFOGTYPE, const float4 fogParams, const float3 flEyePos, const float3 flWorldPos )
+#else
+float CalcPixelFogFactor( int iPIXELFOGTYPE, const float4 fogParams, const float flEyePosZ, const float flWorldPosZ, const float flProjPosZ )
+#endif // SHADER_EDITOR_SWARM_COMPILE
+{
+ float retVal;
+ if ( iPIXELFOGTYPE == PIXEL_FOG_TYPE_NONE )
+ {
+ retVal = 0.0f;
+ }
+ if ( iPIXELFOGTYPE == PIXEL_FOG_TYPE_RANGE ) //range fog, or no fog depending on fog parameters
+ {
+#if defined(SHADER_EDITOR_SWARM_COMPILE)
+ retVal = CalcRangeFog( flEyePos, flWorldPos, fogParams.x, fogParams.z, fogParams.w );
+#else
+ retVal = CalcRangeFog( flProjPosZ, fogParams.x, fogParams.z, fogParams.w );
+#endif // SHADER_EDITOR_SWARM_COMPILE
+ }
+ else if ( iPIXELFOGTYPE == PIXEL_FOG_TYPE_HEIGHT ) //height fog
+ {
+#if defined(SHADER_EDITOR_SWARM_COMPILE)
+ retVal = 0.0f;
+#else
+ retVal = CalcWaterFogAlpha( fogParams.y, flEyePosZ, flWorldPosZ, flProjPosZ, fogParams.w );
+#endif // SHADER_EDITOR_SWARM_COMPILE
+ }
+
+ return retVal;
+}
+
+//g_FogParams not defined by default, but this is the same layout for every shader that does define it
+#define g_FogEndOverRange g_FogParams.x
+#define g_WaterZ g_FogParams.y
+#define g_FogMaxDensity g_FogParams.z
+#define g_FogOORange g_FogParams.w
+
+float3 BlendPixelFog( const float3 vShaderColor, float pixelFogFactor, const float3 vFogColor, const int iPIXELFOGTYPE )
+{
+ if( iPIXELFOGTYPE == PIXEL_FOG_TYPE_RANGE ) //either range fog or no fog depending on fog parameters and whether this is ps20 or ps2b
+ {
+# if !(defined(SHADER_MODEL_PS_1_1) || defined(SHADER_MODEL_PS_1_4) || defined(SHADER_MODEL_PS_2_0)) //Minimum requirement of ps2b
+ pixelFogFactor = saturate( pixelFogFactor );
+ return lerp( vShaderColor.rgb, vFogColor.rgb, pixelFogFactor * pixelFogFactor ); //squaring the factor will get the middle range mixing closer to hardware fog
+# else
+ return vShaderColor;
+# endif
+ }
+ else if( iPIXELFOGTYPE == PIXEL_FOG_TYPE_HEIGHT )
+ {
+ return lerp( vShaderColor.rgb, vFogColor.rgb, saturate( pixelFogFactor ) );
+ }
+ else if( iPIXELFOGTYPE == PIXEL_FOG_TYPE_NONE )
+ {
+ return vShaderColor;
+ }
+}
+
+
+#if ((defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0)) && ( CONVERT_TO_SRGB != 0 ) )
+sampler1D GammaTableSampler : register( s15 );
+
+float3 SRGBOutput( const float3 vShaderColor )
+{
+ //On ps2b capable hardware we always have the linear->gamma conversion table texture in sampler s15.
+ float3 result;
+ result.r = tex1D( GammaTableSampler, vShaderColor.r ).r;
+ result.g = tex1D( GammaTableSampler, vShaderColor.g ).r;
+ result.b = tex1D( GammaTableSampler, vShaderColor.b ).r;
+ return result;
+}
+
+#else
+
+float3 SRGBOutput( const float3 vShaderColor )
+{
+ return vShaderColor; //ps 1.1, 1.4, and 2.0 never do srgb conversion in the pixel shader
+}
+
+#endif
+
+
+float SoftParticleDepth( float flDepth )
+{
+ return flDepth * OO_DESTALPHA_DEPTH_RANGE;
+}
+
+
+float DepthToDestAlpha( const float flProjZ )
+{
+#if !(defined(SHADER_MODEL_PS_1_1) || defined(SHADER_MODEL_PS_1_4) || defined(SHADER_MODEL_PS_2_0)) //Minimum requirement of ps2b
+ return SoftParticleDepth( flProjZ );
+#else
+ return 1.0f;
+#endif
+}
+
+
+float4 FinalOutput( const float4 vShaderColor, float pixelFogFactor, const int iPIXELFOGTYPE, const int iTONEMAP_SCALE_TYPE, const bool bWriteDepthToDestAlpha = false, const float flProjZ = 1.0f )
+{
+ float4 result;
+ if( iTONEMAP_SCALE_TYPE == TONEMAP_SCALE_LINEAR )
+ {
+ result.rgb = vShaderColor.rgb * LINEAR_LIGHT_SCALE;
+ }
+ else if( iTONEMAP_SCALE_TYPE == TONEMAP_SCALE_GAMMA )
+ {
+ result.rgb = vShaderColor.rgb * GAMMA_LIGHT_SCALE;
+ }
+ else if( iTONEMAP_SCALE_TYPE == TONEMAP_SCALE_NONE )
+ {
+ result.rgb = vShaderColor.rgb;
+ }
+
+ if( bWriteDepthToDestAlpha )
+#if ( WRITEWATERFOGTODESTALPHA == 1 )
+ result.a = pixelFogFactor;
+#else
+ result.a = DepthToDestAlpha( flProjZ );
+#endif
+ else
+ result.a = vShaderColor.a;
+
+ result.rgb = BlendPixelFog( result.rgb, pixelFogFactor, g_LinearFogColor.rgb, iPIXELFOGTYPE );
+
+#if !(defined(SHADER_EDITOR_SWARM_COMPILE))
+
+#if !(defined(SHADER_MODEL_PS_1_1) || defined(SHADER_MODEL_PS_1_4) || defined(SHADER_MODEL_PS_2_0)) //Minimum requirement of ps2b
+ result.rgb = SRGBOutput( result.rgb ); //SRGB in pixel shader conversion
+#endif
+
+#endif // SHADER_EDITOR_SWARM_COMPILE
+
+ return result;
+}
+
+LPREVIEW_PS_OUT FinalOutput( const LPREVIEW_PS_OUT vShaderColor, float pixelFogFactor, const int iPIXELFOGTYPE, const int iTONEMAP_SCALE_TYPE )
+{
+ LPREVIEW_PS_OUT result;
+ result.color = FinalOutput( vShaderColor.color, pixelFogFactor, iPIXELFOGTYPE, iTONEMAP_SCALE_TYPE );
+ result.normal.rgb = SRGBOutput( vShaderColor.normal.rgb );
+ result.normal.a = vShaderColor.normal.a;
+
+ result.position.rgb = SRGBOutput( vShaderColor.position.rgb );
+ result.position.a = vShaderColor.position.a;
+
+ result.flags.rgb = SRGBOutput( vShaderColor.flags.rgb );
+ result.flags.a = vShaderColor.flags.a;
+
+ return result;
+}
+
+
+
+
+float RemapValClamped( float val, float A, float B, float C, float D)
+{
+ float cVal = (val - A) / (B - A);
+ cVal = saturate( cVal );
+
+ return C + (D - C) * cVal;
+}
+
+//======================================//
+// HSL Color space conversion routines //
+//======================================//
+
+#define HUE 0
+#define SATURATION 1
+#define LIGHTNESS 2
+
+// Convert from RGB to HSL color space
+float4 RGBtoHSL( float4 inColor )
+{
+ float h, s;
+ float flMax = max( inColor.r, max( inColor.g, inColor.b ) );
+ float flMin = min( inColor.r, min( inColor.g, inColor.b ) );
+
+ float l = (flMax + flMin) / 2.0f;
+
+ if (flMax == flMin) // achromatic case
+ {
+ s = h = 0;
+ }
+ else // chromatic case
+ {
+ // Next, calculate the hue
+ float delta = flMax - flMin;
+
+ // First, calculate the saturation
+ if (l < 0.5f) // If we're in the lower hexcone
+ {
+ s = delta/(flMax + flMin);
+ }
+ else
+ {
+ s = delta/(2 - flMax - flMin);
+ }
+
+ if ( inColor.r == flMax )
+ {
+ h = (inColor.g - inColor.b)/delta; // color between yellow and magenta
+ }
+ else if ( inColor.g == flMax )
+ {
+ h = 2 + (inColor.b - inColor.r)/delta; // color between cyan and yellow
+ }
+ else // blue must be max
+ {
+ h = 4 + (inColor.r - inColor.g)/delta; // color between magenta and cyan
+ }
+
+ h *= 60.0f;
+
+ if (h < 0.0f)
+ {
+ h += 360.0f;
+ }
+
+ h /= 360.0f;
+ }
+
+ return float4 (h, s, l, 1.0f);
+}
+
+float HueToRGB( float v1, float v2, float vH )
+{
+ float fResult = v1;
+
+ vH = fmod (vH + 1.0f, 1.0f);
+
+ if ( ( 6.0f * vH ) < 1.0f )
+ {
+ fResult = ( v1 + ( v2 - v1 ) * 6.0f * vH );
+ }
+ else if ( ( 2.0f * vH ) < 1.0f )
+ {
+ fResult = ( v2 );
+ }
+ else if ( ( 3.0f * vH ) < 2.0f )
+ {
+ fResult = ( v1 + ( v2 - v1 ) * ( ( 2.0f / 3.0f ) - vH ) * 6.0f );
+ }
+
+ return fResult;
+}
+
+// Convert from HSL to RGB color space
+float4 HSLtoRGB( float4 hsl )
+{
+ float r, g, b;
+ float h = hsl[HUE];
+ float s = hsl[SATURATION];
+ float l = hsl[LIGHTNESS];
+
+ if ( s == 0 )
+ {
+ r = g = b = l;
+ }
+ else
+ {
+ float v1, v2;
+
+ if ( l < 0.5f )
+ v2 = l * ( 1.0f + s );
+ else
+ v2 = ( l + s ) - ( s * l );
+
+ v1 = 2 * l - v2;
+
+ r = HueToRGB( v1, v2, h + ( 1.0f / 3.0f ) );
+ g = HueToRGB( v1, v2, h );
+ b = HueToRGB( v1, v2, h - ( 1.0f / 3.0f ) );
+ }
+
+ return float4( r, g, b, 1.0f );
+}
+
+
+// texture combining modes for combining base and detail/basetexture2
+#define TCOMBINE_RGB_EQUALS_BASE_x_DETAILx2 0 // original mode
+#define TCOMBINE_RGB_ADDITIVE 1 // base.rgb+detail.rgb*fblend
+#define TCOMBINE_DETAIL_OVER_BASE 2
+#define TCOMBINE_FADE 3 // straight fade between base and detail.
+#define TCOMBINE_BASE_OVER_DETAIL 4 // use base alpha for blend over detail
+#define TCOMBINE_RGB_ADDITIVE_SELFILLUM 5 // add detail color post lighting
+#define TCOMBINE_RGB_ADDITIVE_SELFILLUM_THRESHOLD_FADE 6
+#define TCOMBINE_MOD2X_SELECT_TWO_PATTERNS 7 // use alpha channel of base to select between mod2x channels in r+a of detail
+#define TCOMBINE_MULTIPLY 8
+#define TCOMBINE_MASK_BASE_BY_DETAIL_ALPHA 9 // use alpha channel of detail to mask base
+#define TCOMBINE_SSBUMP_BUMP 10 // use detail to modulate lighting as an ssbump
+#define TCOMBINE_SSBUMP_NOBUMP 11 // detail is an ssbump but use it as an albedo. shader does the magic here - no user needs to specify mode 11
+
+float4 TextureCombine( float4 baseColor, float4 detailColor, int combine_mode,
+ float fBlendFactor )
+{
+ if ( combine_mode == TCOMBINE_MOD2X_SELECT_TWO_PATTERNS)
+ {
+ float3 dc=lerp(detailColor.r,detailColor.a, baseColor.a);
+ baseColor.rgb*=lerp(float3(1,1,1),2.0*dc,fBlendFactor);
+ }
+ if ( combine_mode == TCOMBINE_RGB_EQUALS_BASE_x_DETAILx2)
+ baseColor.rgb*=lerp(float3(1,1,1),2.0*detailColor.rgb,fBlendFactor);
+ if ( combine_mode == TCOMBINE_RGB_ADDITIVE )
+ baseColor.rgb += fBlendFactor * detailColor.rgb;
+ if ( combine_mode == TCOMBINE_DETAIL_OVER_BASE )
+ {
+ float fblend=fBlendFactor * detailColor.a;
+ baseColor.rgb = lerp( baseColor.rgb, detailColor.rgb, fblend);
+ }
+ if ( combine_mode == TCOMBINE_FADE )
+ {
+ baseColor = lerp( baseColor, detailColor, fBlendFactor);
+ }
+ if ( combine_mode == TCOMBINE_BASE_OVER_DETAIL )
+ {
+ float fblend=fBlendFactor * (1-baseColor.a);
+ baseColor.rgb = lerp( baseColor.rgb, detailColor.rgb, fblend );
+ baseColor.a = detailColor.a;
+ }
+ if ( combine_mode == TCOMBINE_MULTIPLY )
+ {
+ baseColor = lerp( baseColor, baseColor*detailColor, fBlendFactor);
+ }
+
+ if (combine_mode == TCOMBINE_MASK_BASE_BY_DETAIL_ALPHA )
+ {
+ baseColor.a = lerp( baseColor.a, baseColor.a*detailColor.a, fBlendFactor );
+ }
+ if ( combine_mode == TCOMBINE_SSBUMP_NOBUMP )
+ {
+ baseColor.rgb = baseColor.rgb * dot( detailColor.rgb, 2.0/3.0 );
+ }
+ return baseColor;
+}
+
+float3 lerp5(float3 f1, float3 f2, float i1, float i2, float x)
+{
+ return f1+(f2-f1)*(x-i1)/(i2-i1);
+}
+
+float3 TextureCombinePostLighting( float3 lit_baseColor, float4 detailColor, int combine_mode,
+ float fBlendFactor )
+{
+ if ( combine_mode == TCOMBINE_RGB_ADDITIVE_SELFILLUM )
+ lit_baseColor += fBlendFactor * detailColor.rgb;
+ if ( combine_mode == TCOMBINE_RGB_ADDITIVE_SELFILLUM_THRESHOLD_FADE )
+ {
+ // fade in an unusual way - instead of fading out color, remap an increasing band of it from
+ // 0..1
+ if ( fBlendFactor > 0.5)
+ lit_baseColor += min(1, (1.0/fBlendFactor)*max(0, detailColor.rgb-(1-fBlendFactor) ) );
+ else
+ lit_baseColor += 2*fBlendFactor*2*max(0, detailColor.rgb-.5);
+ }
+ return lit_baseColor;
+}
+
+//NOTE: On X360. fProjZ is expected to be pre-reversed for cheaper math here in the pixel shader
+float DepthFeathering( sampler DepthSampler, const float2 vScreenPos, float fProjZ, float fProjW, float4 vDepthBlendConstants )
+{
+# if ( !(defined(SHADER_MODEL_PS_1_1) || defined(SHADER_MODEL_PS_1_4) || defined(SHADER_MODEL_PS_2_0)) ) //minimum requirement of ps2b
+ {
+ float flFeatheredAlpha;
+ float2 flDepths;
+#define flSceneDepth flDepths.x
+#define flSpriteDepth flDepths.y
+
+# if ( defined( _X360 ) )
+ {
+ //Get depth from the depth texture. Need to sample with the offset of (0.5, 0.5) to fix rounding errors
+ asm {
+ tfetch2D flDepths.x___, vScreenPos, DepthSampler, OffsetX=0.5, OffsetY=0.5, MinFilter=point, MagFilter=point, MipFilter=point
+ };
+
+# if( !defined( REVERSE_DEPTH_ON_X360 ) )
+ flSceneDepth = 1.0f - flSceneDepth;
+# endif
+
+ //get the sprite depth into the same range as the texture depth
+ flSpriteDepth = fProjZ / fProjW;
+
+ //unproject to get at the pre-projection z. This value is much more linear than depth
+ flDepths = vDepthBlendConstants.z / flDepths;
+ flDepths = vDepthBlendConstants.y - flDepths;
+
+ flFeatheredAlpha = flSceneDepth - flSpriteDepth;
+ flFeatheredAlpha *= vDepthBlendConstants.x;
+ flFeatheredAlpha = saturate( flFeatheredAlpha );
+ }
+# else
+ {
+ flSceneDepth = tex2D( DepthSampler, vScreenPos ).a; // PC uses dest alpha of the frame buffer
+ flSpriteDepth = SoftParticleDepth( fProjZ );
+
+ flFeatheredAlpha = abs(flSceneDepth - flSpriteDepth) * vDepthBlendConstants.x;
+ flFeatheredAlpha = max( smoothstep( 0.75f, 1.0f, flSceneDepth ), flFeatheredAlpha ); //as the sprite approaches the edge of our compressed depth space, the math stops working. So as the sprite approaches the far depth, smoothly remove feathering.
+ flFeatheredAlpha = saturate( flFeatheredAlpha );
+ }
+# endif
+
+#undef flSceneDepth
+#undef flSpriteDepth
+
+ return flFeatheredAlpha;
+ }
+# else
+ {
+ return 1.0f;
+ }
+# endif
+}
+
+#endif //#ifndef COMMON_PS_FXC_H_
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_vertexlitgeneric_dx9.h b/mp/game/momentum/shadereditorui/shader_src/common_vertexlitgeneric_dx9.h
new file mode 100644
index 0000000000..9c2ebfc2b2
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_vertexlitgeneric_dx9.h
@@ -0,0 +1,449 @@
+#ifndef COMMON_VERTEXLITGENERIC_DX9_H_
+#define COMMON_VERTEXLITGENERIC_DX9_H_
+
+#include "common_ps_fxc.h"
+
+// We store four light colors and positions in an
+// array of three of these structures like so:
+//
+// x y z w
+// +------+------+------+------+
+// | L0.rgb | |
+// +------+------+------+ |
+// | L0.pos | L3 |
+// +------+------+------+ rgb |
+// | L1.rgb | |
+// +------+------+------+------+
+// | L1.pos | |
+// +------+------+------+ |
+// | L2.rgb | L3 |
+// +------+------+------+ pos |
+// | L2.pos | |
+// +------+------+------+------+
+//
+struct PixelShaderLightInfo
+{
+ float4 color;
+ float4 pos;
+};
+
+#define cOverbright 2.0f
+#define cOOOverbright 0.5f
+
+#define LIGHTTYPE_NONE 0
+#define LIGHTTYPE_SPOT 1
+#define LIGHTTYPE_POINT 2
+#define LIGHTTYPE_DIRECTIONAL 3
+
+// Better suited to Pixel shader models, 11 instructions in pixel shader
+float3 PixelShaderAmbientLight( const float3 worldNormal, const float3 cAmbientCube[6] )
+{
+ float3 linearColor, nSquared = worldNormal * worldNormal;
+ float3 isNegative = ( worldNormal < 0.0 );
+ float3 isPositive = 1-isNegative;
+
+ isNegative *= nSquared;
+ isPositive *= nSquared;
+
+ linearColor = isPositive.x * cAmbientCube[0] + isNegative.x * cAmbientCube[1] +
+ isPositive.y * cAmbientCube[2] + isNegative.y * cAmbientCube[3] +
+ isPositive.z * cAmbientCube[4] + isNegative.z * cAmbientCube[5];
+
+ return linearColor;
+}
+
+// Better suited to Vertex shader models
+// Six VS instructions due to use of constant indexing (slt, mova, mul, mul, mad, mad)
+float3 VertexShaderAmbientLight( const float3 worldNormal, const float3 cAmbientCube[6] )
+{
+ float3 nSquared = worldNormal * worldNormal;
+ int3 isNegative = ( worldNormal < 0.0 );
+ float3 linearColor;
+ linearColor = nSquared.x * cAmbientCube[isNegative.x] +
+ nSquared.y * cAmbientCube[isNegative.y+2] +
+ nSquared.z * cAmbientCube[isNegative.z+4];
+ return linearColor;
+}
+
+float3 AmbientLight( const float3 worldNormal, const float3 cAmbientCube[6] )
+{
+ // Vertex shader cases
+#ifdef SHADER_MODEL_VS_1_0
+ return VertexShaderAmbientLight( worldNormal, cAmbientCube );
+#elif SHADER_MODEL_VS_1_1
+ return VertexShaderAmbientLight( worldNormal, cAmbientCube );
+#elif SHADER_MODEL_VS_2_0
+ return VertexShaderAmbientLight( worldNormal, cAmbientCube );
+#elif SHADER_MODEL_VS_3_0
+ return VertexShaderAmbientLight( worldNormal, cAmbientCube );
+#else
+ // Pixel shader case
+ return PixelShaderAmbientLight( worldNormal, cAmbientCube );
+#endif
+}
+
+//-----------------------------------------------------------------------------
+// Purpose: Compute scalar diffuse term with various optional tweaks such as
+// Half Lambert and ambient occlusion
+//-----------------------------------------------------------------------------
+float3 DiffuseTerm(const bool bHalfLambert, const float3 worldNormal, const float3 lightDir,
+ const bool bDoAmbientOcclusion, const float fAmbientOcclusion/*,
+ const bool bDoLightingWarp, in sampler lightWarpSampler*/ )
+{
+ float fResult;
+
+ float NDotL = dot( worldNormal, lightDir ); // Unsaturated dot (-1 to 1 range)
+
+ if ( bHalfLambert )
+ {
+ fResult = saturate(NDotL * 0.5 + 0.5); // Scale and bias to 0 to 1 range
+
+ //if ( !bDoLightingWarp )
+ {
+ fResult *= fResult; // Square
+ }
+ }
+ else
+ {
+ fResult = saturate( NDotL ); // Saturate pure Lambertian term
+ }
+
+ if ( bDoAmbientOcclusion )
+ {
+ // Raise to higher powers for darker AO values
+// float fAOPower = lerp( 4.0f, 1.0f, fAmbientOcclusion );
+// result *= pow( NDotL * 0.5 + 0.5, fAOPower );
+ fResult *= fAmbientOcclusion;
+ }
+
+ float3 fOut = float3( fResult, fResult, fResult );
+ //if ( bDoLightingWarp )
+ //{
+ // fOut = 2.0f * tex1D( lightWarpSampler, fResult );
+ //}
+
+ return fOut;
+}
+
+float3 PixelShaderDoGeneralDiffuseLight( const float fAtten, const float3 worldPos, const float3 worldNormal,
+ /* in sampler NormalizeSampler,*/
+ const float3 vPosition, const float3 vColor, const bool bHalfLambert,
+ const bool bDoAmbientOcclusion, const float fAmbientOcclusion/*,
+ const bool bDoLightingWarp, in sampler lightWarpSampler*/ )
+{
+//#if (defined(SHADER_MODEL_PS_2_B) || defined(SHADER_MODEL_PS_3_0))
+ float3 lightDir = normalize( vPosition - worldPos );
+//#else
+// float3 lightDir = NormalizeWithCubemap( NormalizeSampler, vPosition - worldPos );
+//#endif
+ return vColor * fAtten * DiffuseTerm( bHalfLambert, worldNormal, lightDir, bDoAmbientOcclusion, fAmbientOcclusion/*, bDoLightingWarp, lightWarpSampler*/ );
+}
+
+float3 PixelShaderGetLightVector( const float3 worldPos, PixelShaderLightInfo cLightInfo[3], int nLightIndex )
+{
+ if ( nLightIndex == 3 )
+ {
+ // Unpack light 3 from w components...
+ float3 vLight3Pos = float3( cLightInfo[1].pos.w, cLightInfo[2].color.w, cLightInfo[2].pos.w );
+ return normalize( vLight3Pos - worldPos );
+ }
+ else
+ {
+ return normalize( cLightInfo[nLightIndex].pos - worldPos );
+ }
+}
+
+float3 PixelShaderGetLightColor( PixelShaderLightInfo cLightInfo[3], int nLightIndex )
+{
+ if ( nLightIndex == 3 )
+ {
+ // Unpack light 3 from w components...
+ return float3( cLightInfo[0].color.w, cLightInfo[0].pos.w, cLightInfo[1].color.w );
+ }
+ else
+ {
+ return cLightInfo[nLightIndex].color.rgb;
+ }
+}
+
+void GetLightData( PixelShaderLightInfo cLightInfo[3], int index, float3 worldpos,
+ out float3 color, out float3 dir )
+{
+ color = PixelShaderGetLightColor( cLightInfo, index );
+ dir = PixelShaderGetLightVector( worldpos, cLightInfo, index );
+}
+
+
+void SpecularAndRimTerms( const float3 vWorldNormal, const float3 vLightDir, const float fSpecularExponent,
+ const float3 vEyeDir, const bool bDoAmbientOcclusion, const float fAmbientOcclusion,
+ /*const bool bDoSpecularWarp, in sampler specularWarpSampler,*/ const float fFresnel,
+ const float3 color, /*const bool bDoRimLighting, const float fRimExponent,*/
+
+ // Outputs
+ out float3 specularLighting/*, out float3 rimLighting*/ )
+{
+ //rimLighting = float3(0.0f, 0.0f, 0.0f);
+
+ float3 vReflect = reflect( -vEyeDir, vWorldNormal ); // Reflect view through normal
+ float LdotR = saturate(dot( vReflect, vLightDir )); // L.R (use half-angle instead?)
+ specularLighting = pow( LdotR, fSpecularExponent ); // Raise to specular exponent
+
+ // Optionally warp as function of scalar specular and fresnel
+ //if ( bDoSpecularWarp )
+ // specularLighting *= tex2D( specularWarpSampler, float2(specularLighting.x, fFresnel) ); // Sample at { (L.R)^k, fresnel }
+ specularLighting *= fFresnel; // Sample at { (L.R)^k, fresnel }
+
+ specularLighting *= saturate(dot( vWorldNormal, vLightDir )); // Mask with N.L
+ specularLighting *= color; // Modulate with light color
+
+ if ( bDoAmbientOcclusion ) // Optionally modulate with ambient occlusion
+ specularLighting *= fAmbientOcclusion;
+
+ //if ( bDoRimLighting ) // Optionally do rim lighting
+ //{
+ // rimLighting = pow( LdotR, fRimExponent ); // Raise to rim exponent
+ // rimLighting *= saturate(dot( vWorldNormal, vLightDir )); // Mask with N.L
+ // rimLighting *= color; // Modulate with light color
+ //}
+}
+
+// Traditional fresnel term approximation
+float Fresnel( const float3 vNormal, const float3 vEyeDir )
+{
+ float fresnel = 1-saturate( dot( vNormal, vEyeDir ) ); // 1-(N.V) for Fresnel term
+ return fresnel * fresnel; // Square for a more subtle look
+}
+
+// Traditional fresnel term approximation which uses 4th power (square twice)
+float Fresnel4( const float3 vNormal, const float3 vEyeDir )
+{
+ float fresnel = 1-saturate( dot( vNormal, vEyeDir ) ); // 1-(N.V) for Fresnel term
+ fresnel = fresnel * fresnel; // Square
+ return fresnel * fresnel; // Square again for a more subtle look
+}
+
+
+//
+// Custom Fresnel with low, mid and high parameters defining a piecewise continuous function
+// with traditional fresnel (0 to 1 range) as input. The 0 to 0.5 range blends between
+// low and mid while the 0.5 to 1 range blends between mid and high
+//
+// |
+// | . M . . . H
+// | .
+// L
+// |
+// +----------------
+// 0 1
+//
+float Fresnel( const float3 vNormal, const float3 vEyeDir, float3 vRanges )
+{
+ float result, f = Fresnel( vNormal, vEyeDir ); // Traditional Fresnel
+
+ if ( f > 0.5f )
+ result = lerp( vRanges.y, vRanges.z, (2*f)-1 ); // Blend between mid and high values
+ else
+ result = lerp( vRanges.x, vRanges.y, 2*f ); // Blend between low and mid values
+
+ return result;
+}
+
+void PixelShaderDoSpecularLight( const float3 vWorldPos, const float3 vWorldNormal, const float fSpecularExponent, const float3 vEyeDir,
+ const float fAtten, const float3 vLightColor, const float3 vLightDir,
+ const bool bDoAmbientOcclusion, const float fAmbientOcclusion,
+ /*const bool bDoSpecularWarp, in sampler specularWarpSampler,*/ float fFresnel,
+ /*const bool bDoRimLighting, const float fRimExponent,*/
+
+ // Outputs
+ out float3 specularLighting/*, out float3 rimLighting*/ )
+{
+ // Compute Specular and rim terms
+ SpecularAndRimTerms( vWorldNormal, vLightDir, fSpecularExponent,
+ vEyeDir, bDoAmbientOcclusion, fAmbientOcclusion,
+ /*bDoSpecularWarp, specularWarpSampler,*/ fFresnel, vLightColor * fAtten,
+ /*bDoRimLighting, fRimExponent,*/ specularLighting/*, rimLighting*/ );
+}
+
+float3 PixelShaderDoLightingLinear( const float3 worldPos, const float3 worldNormal,
+ const float3 staticLightingColor, const bool bStaticLight,
+ const bool bAmbientLight, const float4 lightAtten, const float3 cAmbientCube[6],
+ /*in sampler NormalizeSampler,*/ const int nNumLights, PixelShaderLightInfo cLightInfo[3],
+ const bool bHalfLambert, const bool bDoAmbientOcclusion, const float fAmbientOcclusion/*,
+ const bool bDoLightingWarp, in sampler lightWarpSampler*/ )
+{
+ float3 linearColor = 0.0f;
+
+ if ( bStaticLight )
+ {
+ // The static lighting comes in in gamma space and has also been premultiplied by $cOOOverbright
+ // need to get it into
+ // linear space so that we can do adds.
+ linearColor += GammaToLinear( staticLightingColor * cOverbright );
+ }
+
+ if ( bAmbientLight )
+ {
+ float3 ambient = AmbientLight( worldNormal, cAmbientCube );
+
+ if ( bDoAmbientOcclusion )
+ ambient *= fAmbientOcclusion * fAmbientOcclusion; // Note squaring...
+
+ linearColor += ambient;
+ }
+
+ if ( nNumLights > 0 )
+ {
+ linearColor += PixelShaderDoGeneralDiffuseLight( lightAtten.x, worldPos, worldNormal, /*NormalizeSampler,*/
+ cLightInfo[0].pos, cLightInfo[0].color, bHalfLambert,
+ bDoAmbientOcclusion, fAmbientOcclusion/*,
+ bDoLightingWarp, lightWarpSampler*/ );
+ if ( nNumLights > 1 )
+ {
+ linearColor += PixelShaderDoGeneralDiffuseLight( lightAtten.y, worldPos, worldNormal, /*NormalizeSampler,*/
+ cLightInfo[1].pos, cLightInfo[1].color, bHalfLambert,
+ bDoAmbientOcclusion, fAmbientOcclusion/*,
+ bDoLightingWarp, lightWarpSampler*/ );
+ if ( nNumLights > 2 )
+ {
+ linearColor += PixelShaderDoGeneralDiffuseLight( lightAtten.z, worldPos, worldNormal, /*NormalizeSampler,*/
+ cLightInfo[2].pos, cLightInfo[2].color, bHalfLambert,
+ bDoAmbientOcclusion, fAmbientOcclusion/*,
+ bDoLightingWarp, lightWarpSampler*/ );
+ if ( nNumLights > 3 )
+ {
+ // Unpack the 4th light's data from tight constant packing
+ float3 vLight3Color = float3( cLightInfo[0].color.w, cLightInfo[0].pos.w, cLightInfo[1].color.w );
+ float3 vLight3Pos = float3( cLightInfo[1].pos.w, cLightInfo[2].color.w, cLightInfo[2].pos.w );
+ linearColor += PixelShaderDoGeneralDiffuseLight( lightAtten.w, worldPos, worldNormal, /*NormalizeSampler,*/
+ vLight3Pos, vLight3Color, bHalfLambert,
+ bDoAmbientOcclusion, fAmbientOcclusion/*,
+ bDoLightingWarp, lightWarpSampler*/ );
+ }
+ }
+ }
+ }
+
+ return linearColor;
+}
+
+void PixelShaderDoSpecularLighting( const float3 worldPos, const float3 worldNormal, const float fSpecularExponent, const float3 vEyeDir,
+ const float4 lightAtten, const int nNumLights, PixelShaderLightInfo cLightInfo[3],
+ const bool bDoAmbientOcclusion, const float fAmbientOcclusion,
+ /*const bool bDoSpecularWarp, in sampler specularWarpSampler,*/ float fFresnel,
+ /*const bool bDoRimLighting, const float fRimExponent,*/
+
+ // Outputs
+ out float3 specularLighting/*, out float3 rimLighting*/ )
+{
+ specularLighting /*= rimLighting*/ = float3( 0.0f, 0.0f, 0.0f );
+ float3 localSpecularTerm/*, localRimTerm*/;
+
+ if( nNumLights > 0 )
+ {
+ PixelShaderDoSpecularLight( worldPos, worldNormal, fSpecularExponent, vEyeDir,
+ lightAtten.x, PixelShaderGetLightColor( cLightInfo, 0 ),
+ PixelShaderGetLightVector( worldPos, cLightInfo, 0 ),
+ bDoAmbientOcclusion, fAmbientOcclusion,
+ /*bDoSpecularWarp, specularWarpSampler,*/ fFresnel,
+ /*bDoRimLighting, fRimExponent,*/
+ localSpecularTerm/*, localRimTerm*/ );
+
+ specularLighting += localSpecularTerm; // Accumulate specular and rim terms
+ /*rimLighting += localRimTerm;*/
+ }
+
+ if( nNumLights > 1 )
+ {
+ PixelShaderDoSpecularLight( worldPos, worldNormal, fSpecularExponent, vEyeDir,
+ lightAtten.y, PixelShaderGetLightColor( cLightInfo, 1 ),
+ PixelShaderGetLightVector( worldPos, cLightInfo, 1 ),
+ bDoAmbientOcclusion, fAmbientOcclusion,
+ /*bDoSpecularWarp, specularWarpSampler,*/ fFresnel,
+ /*bDoRimLighting, fRimExponent,*/
+ localSpecularTerm/*, localRimTerm*/ );
+
+ specularLighting += localSpecularTerm; // Accumulate specular and rim terms
+ /*rimLighting += localRimTerm;*/
+ }
+
+
+ if( nNumLights > 2 )
+ {
+ PixelShaderDoSpecularLight( worldPos, worldNormal, fSpecularExponent, vEyeDir,
+ lightAtten.z, PixelShaderGetLightColor( cLightInfo, 2 ),
+ PixelShaderGetLightVector( worldPos, cLightInfo, 2 ),
+ bDoAmbientOcclusion, fAmbientOcclusion,
+ /*bDoSpecularWarp, specularWarpSampler,*/ fFresnel,
+ /*bDoRimLighting, fRimExponent,*/
+ localSpecularTerm/*, localRimTerm*/ );
+
+ specularLighting += localSpecularTerm; // Accumulate specular and rim terms
+ /*rimLighting += localRimTerm;*/
+ }
+
+ if( nNumLights > 3 )
+ {
+ PixelShaderDoSpecularLight( worldPos, worldNormal, fSpecularExponent, vEyeDir,
+ lightAtten.w, PixelShaderGetLightColor( cLightInfo, 3 ),
+ PixelShaderGetLightVector( worldPos, cLightInfo, 3 ),
+ bDoAmbientOcclusion, fAmbientOcclusion,
+ /*bDoSpecularWarp, specularWarpSampler,*/ fFresnel,
+ /*bDoRimLighting, fRimExponent,*/
+ localSpecularTerm/*, localRimTerm*/ );
+
+ specularLighting += localSpecularTerm; // Accumulate specular and rim terms
+ /*rimLighting += localRimTerm;*/
+ }
+
+}
+
+float3 PixelShaderDoRimLighting( const float3 worldNormal, const float3 vEyeDir, const float3 cAmbientCube[6], float fFresnel )
+{
+ float3 vReflect = reflect( -vEyeDir, worldNormal ); // Reflect view through normal
+
+ return fFresnel * PixelShaderAmbientLight( vEyeDir, cAmbientCube );
+}
+
+// Called directly by newer shaders or through the following wrapper for older shaders
+float3 PixelShaderDoLighting( const float3 worldPos, const float3 worldNormal,
+ const float3 staticLightingColor, const bool bStaticLight,
+ const bool bAmbientLight, const float4 lightAtten, const float3 cAmbientCube[6],
+ /*in sampler NormalizeSampler,*/ const int nNumLights, PixelShaderLightInfo cLightInfo[3],
+ const bool bHalfLambert,
+
+ // New optional/experimental parameters
+ const bool bDoAmbientOcclusion, const float fAmbientOcclusion/*,
+ const bool bDoLightingWarp, in sampler lightWarpSampler*/ )
+{
+ float3 returnColor;
+
+ // special case for no lighting
+ if( !bStaticLight && !bAmbientLight )
+ {
+ returnColor = float3( 0.0f, 0.0f, 0.0f );
+ }
+ else if( bStaticLight && !bAmbientLight )
+ {
+ // special case for static lighting only
+ returnColor = GammaToLinear( staticLightingColor );
+ }
+ else
+ {
+ float3 linearColor;
+
+ linearColor = PixelShaderDoLightingLinear( worldPos, worldNormal, staticLightingColor,
+ bStaticLight, bAmbientLight, lightAtten,
+ cAmbientCube, /*NormalizeSampler,*/ nNumLights, cLightInfo, bHalfLambert,
+ bDoAmbientOcclusion, fAmbientOcclusion/*,
+ bDoLightingWarp, lightWarpSampler*/ );
+
+ // go ahead and clamp to the linear space equivalent of overbright 2 so that we match
+ // everything else.
+// returnColor = HuePreservingColorClamp( linearColor, pow( 2.0f, 2.2 ) );
+ returnColor = linearColor;
+ }
+
+ return returnColor;
+}
+
+#endif //#ifndef COMMON_VERTEXLITGENERIC_DX9_H_
diff --git a/mp/game/momentum/shadereditorui/shader_src/common_vs_fxc.h b/mp/game/momentum/shadereditorui/shader_src/common_vs_fxc.h
new file mode 100644
index 0000000000..2378abc178
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/common_vs_fxc.h
@@ -0,0 +1,959 @@
+//===== Copyright © 1996-2005, Valve Corporation, All rights reserved. ======//
+//
+// Purpose: This is where all common code for vertex shaders go.
+//
+// $NoKeywords: $
+//
+//===========================================================================//
+
+
+
+#ifndef COMMON_VS_FXC_H_
+#define COMMON_VS_FXC_H_
+
+#include "common_fxc.h"
+
+// Put global skip commands here. . make sure and check that the appropriate vars are defined
+// so these aren't used on the wrong shaders!
+// --------------------------------------------------------------------------------
+// Ditch all fastpath attemps if we are doing LIGHTING_PREVIEW.
+// SKIP: defined $LIGHTING_PREVIEW && defined $FASTPATH && $LIGHTING_PREVIEW && $FASTPATH
+// --------------------------------------------------------------------------------
+
+
+#ifndef COMPRESSED_VERTS
+// Default to no vertex compression
+#define COMPRESSED_VERTS 0
+#endif
+
+#if ( !defined( SHADER_MODEL_VS_2_0 ) && !defined( SHADER_MODEL_VS_3_0 ) )
+#if COMPRESSED_VERTS == 1
+#error "Vertex compression is only for DX9 and up!"
+#endif
+#endif
+
+// We're testing 2 normal compression methods
+// One compressed normals+tangents into a SHORT2 each (8 bytes total)
+// The other compresses them together, into a single UBYTE4 (4 bytes total)
+// FIXME: pick one or the other, compare lighting quality in important cases
+#define COMPRESSED_NORMALS_SEPARATETANGENTS_SHORT2 0
+#define COMPRESSED_NORMALS_COMBINEDTANGENTS_UBYTE4 1
+//#define COMPRESSED_NORMALS_TYPE COMPRESSED_NORMALS_SEPARATETANGENTS_SHORT2
+#define COMPRESSED_NORMALS_TYPE COMPRESSED_NORMALS_COMBINEDTANGENTS_UBYTE4
+
+
+#define FOGTYPE_RANGE 0
+#define FOGTYPE_HEIGHT 1
+
+#define COMPILE_ERROR ( 1/0; )
+
+// -------------------------
+// CONSTANTS
+// -------------------------
+
+#pragma def ( vs, c0, 0.0f, 1.0f, 2.0f, 0.5f )
+
+const float4 cConstants1 : register(c1);
+#define cOOGamma cConstants1.x
+#define cOverbright 2.0f
+#define cOneThird cConstants1.z
+#define cOOOverbright ( 1.0f / 2.0f )
+
+
+// The g_bLightEnabled registers and g_nLightCountRegister hold the same information regarding
+// enabling lights, but callers internal to this file tend to use the loops, while external
+// callers will end up using the booleans
+const bool g_bLightEnabled[4] : register(b0);
+ // through b3
+
+const int g_nLightCountRegister : register(i0);
+
+
+#define g_nLightCount g_nLightCountRegister.x
+
+const float4 cEyePosWaterZ : register(c2);
+#define cEyePos cEyePosWaterZ.xyz
+
+// This is still used by asm stuff.
+const float4 cObsoleteLightIndex : register(c3);
+
+const float4x4 cModelViewProj : register(c4);
+const float4x4 cViewProj : register(c8);
+
+// Only cFlexScale.x is used
+// It is a binary value used to switch on/off the addition of the flex delta stream
+const float4 cFlexScale : register(c13);
+
+const float4 cFogParams : register(c16);
+#define cFogEndOverFogRange cFogParams.x
+#define cFogOne cFogParams.y
+#define cFogMaxDensity cFogParams.z
+#define cOOFogRange cFogParams.w
+
+const float4x4 cViewModel : register(c17);
+
+const float3 cAmbientCubeX [ 2 ] : register ( c21 ) ;
+const float3 cAmbientCubeY [ 2 ] : register ( c23 ) ;
+const float3 cAmbientCubeZ [ 2 ] : register ( c25 ) ;
+
+#ifdef SHADER_MODEL_VS_3_0
+const float4 cFlexWeights [ 512 ] : register ( c1024 ) ;
+#endif
+
+struct LightInfo
+{
+ float4 color; // {xyz} is color w is light type code (see comment below)
+ float4 dir; // {xyz} is dir w is light type code
+ float4 pos;
+ float4 spotParams;
+ float4 atten;
+};
+
+// w components of color and dir indicate light type:
+// 1x - directional
+// 01 - spot
+// 00 - point
+
+// Four lights x 5 constants each = 20 constants
+LightInfo cLightInfo[4] : register(c27);
+#define LIGHT_0_POSITION_REG c29
+
+#ifdef SHADER_MODEL_VS_1_1
+
+const float4 cModulationColor : register(c37);
+
+#define SHADER_SPECIFIC_CONST_0 c38
+#define SHADER_SPECIFIC_CONST_1 c39
+#define SHADER_SPECIFIC_CONST_2 c40
+#define SHADER_SPECIFIC_CONST_3 c41
+#define SHADER_SPECIFIC_CONST_4 c42
+#define SHADER_SPECIFIC_CONST_5 c43
+#define SHADER_SPECIFIC_CONST_6 c44
+#define SHADER_SPECIFIC_CONST_7 c45
+#define SHADER_SPECIFIC_CONST_8 c46
+#define SHADER_SPECIFIC_CONST_9 c47
+#define SHADER_SPECIFIC_CONST_10 c14
+#define SHADER_SPECIFIC_CONST_11 c15
+
+static const int cModel0Index = 48;
+const float4x3 cModel[16] : register(c48);
+// last cmodel is c105 for dx80, c214 for dx90
+
+#else // DX9 shaders (vs20 and beyond)
+
+const float4 cModulationColor : register( c47 );
+
+#define SHADER_SPECIFIC_CONST_0 c48
+#define SHADER_SPECIFIC_CONST_1 c49
+#define SHADER_SPECIFIC_CONST_2 c50
+#define SHADER_SPECIFIC_CONST_3 c51
+#define SHADER_SPECIFIC_CONST_4 c52
+#define SHADER_SPECIFIC_CONST_5 c53
+#define SHADER_SPECIFIC_CONST_6 c54
+#define SHADER_SPECIFIC_CONST_7 c55
+#define SHADER_SPECIFIC_CONST_8 c56
+#define SHADER_SPECIFIC_CONST_9 c57
+#define SHADER_SPECIFIC_CONST_10 c14
+#define SHADER_SPECIFIC_CONST_11 c15
+
+static const int cModel0Index = 58;
+const float4x3 cModel[53] : register( c58 );
+// last cmodel is c105 for dx80, c214 for dx90
+
+#define SHADER_SPECIFIC_BOOL_CONST_0 b4
+#define SHADER_SPECIFIC_BOOL_CONST_1 b5
+#define SHADER_SPECIFIC_BOOL_CONST_2 b6
+#define SHADER_SPECIFIC_BOOL_CONST_3 b7
+#define SHADER_SPECIFIC_BOOL_CONST_4 b8
+#define SHADER_SPECIFIC_BOOL_CONST_5 b9
+#define SHADER_SPECIFIC_BOOL_CONST_6 b10
+#define SHADER_SPECIFIC_BOOL_CONST_7 b11
+#endif // vertex shader model constant packing changes
+
+
+//=======================================================================================
+// Methods to decompress vertex normals
+//=======================================================================================
+
+//-----------------------------------------------------------------------------------
+// Decompress a normal from two-component compressed format
+// We expect this data to come from a signed SHORT2 stream in the range of -32768..32767
+//
+// -32678 and 0 are invalid encodings
+// w contains the sign to use in the cross product when generating a binormal
+void _DecompressShort2Tangent( float2 inputTangent, out float4 outputTangent )
+{
+ float2 ztSigns = sign( inputTangent ); // sign bits for z and tangent (+1 or -1)
+ float2 xyAbs = abs( inputTangent ); // 1..32767
+ outputTangent.xy = (xyAbs - 16384.0f) / 16384.0f; // x and y
+ outputTangent.z = ztSigns.x * sqrt( saturate( 1.0f - dot( outputTangent.xy, outputTangent.xy ) ) );
+ outputTangent.w = ztSigns.y;
+}
+
+//-----------------------------------------------------------------------------------
+// Same code as _DecompressShort2Tangent, just one returns a float4, one a float3
+void _DecompressShort2Normal( float2 inputNormal, out float3 outputNormal )
+{
+ float4 result;
+ _DecompressShort2Tangent( inputNormal, result );
+ outputNormal = result.xyz;
+}
+
+//-----------------------------------------------------------------------------------
+// Decompress normal+tangent together
+void _DecompressShort2NormalTangent( float2 inputNormal, float2 inputTangent, out float3 outputNormal, out float4 outputTangent )
+{
+ // FIXME: if we end up sticking with the SHORT2 format, pack the normal and tangent into a single SHORT4 element
+ // (that would make unpacking normal+tangent here together much cheaper than the sum of their parts)
+ _DecompressShort2Normal( inputNormal, outputNormal );
+ _DecompressShort2Tangent( inputTangent, outputTangent );
+}
+
+//=======================================================================================
+// Decompress a normal and tangent from four-component compressed format
+// We expect this data to come from an unsigned UBYTE4 stream in the range of 0..255
+// The final vTangent.w contains the sign to use in the cross product when generating a binormal
+void _DecompressUByte4NormalTangent( float4 inputNormal,
+ out float3 outputNormal, // {nX, nY, nZ}
+ out float4 outputTangent ) // {tX, tY, tZ, sign of binormal}
+{
+ float fOne = 1.0f;
+
+ float4 ztztSignBits = ( inputNormal - 128.0f ) < 0; // sign bits for zs and binormal (1 or 0) set-less-than (slt) asm instruction
+ float4 xyxyAbs = abs( inputNormal - 128.0f ) - ztztSignBits; // 0..127
+ float4 xyxySignBits = ( xyxyAbs - 64.0f ) < 0; // sign bits for xs and ys (1 or 0)
+ float4 normTan = (abs( xyxyAbs - 64.0f ) - xyxySignBits) / 63.0f; // abs({nX, nY, tX, tY})
+ outputNormal.xy = normTan.xy; // abs({nX, nY, __, __})
+ outputTangent.xy = normTan.zw; // abs({tX, tY, __, __})
+
+ float4 xyxySigns = 1 - 2*xyxySignBits; // Convert sign bits to signs
+ float4 ztztSigns = 1 - 2*ztztSignBits; // ( [1,0] -> [-1,+1] )
+
+ outputNormal.z = 1.0f - outputNormal.x - outputNormal.y; // Project onto x+y+z=1
+ outputNormal.xyz = normalize( outputNormal.xyz ); // Normalize onto unit sphere
+ outputNormal.xy *= xyxySigns.xy; // Restore x and y signs
+ outputNormal.z *= ztztSigns.x; // Restore z sign
+
+ outputTangent.z = 1.0f - outputTangent.x - outputTangent.y; // Project onto x+y+z=1
+ outputTangent.xyz = normalize( outputTangent.xyz ); // Normalize onto unit sphere
+ outputTangent.xy *= xyxySigns.zw; // Restore x and y signs
+ outputTangent.z *= ztztSigns.z; // Restore z sign
+ outputTangent.w = ztztSigns.w; // Binormal sign
+}
+
+
+//-----------------------------------------------------------------------------------
+// Decompress just a normal from four-component compressed format (same as above)
+// We expect this data to come from an unsigned UBYTE4 stream in the range of 0..255
+// [ When compiled, this works out to approximately 17 asm instructions ]
+void _DecompressUByte4Normal( float4 inputNormal,
+ out float3 outputNormal) // {nX, nY, nZ}
+{
+ float fOne = 1.0f;
+
+ float2 ztSigns = ( inputNormal.xy - 128.0f ) < 0; // sign bits for zs and binormal (1 or 0) set-less-than (slt) asm instruction
+ float2 xyAbs = abs( inputNormal.xy - 128.0f ) - ztSigns; // 0..127
+ float2 xySigns = ( xyAbs - 64.0f ) < 0; // sign bits for xs and ys (1 or 0)
+ outputNormal.xy = ( abs( xyAbs - 64.0f ) - xySigns ) / 63.0f; // abs({nX, nY})
+
+ outputNormal.z = 1.0f - outputNormal.x - outputNormal.y; // Project onto x+y+z=1
+ outputNormal.xyz = normalize( outputNormal.xyz ); // Normalize onto unit sphere
+
+ outputNormal.xy *= lerp( fOne.xx, -fOne.xx, xySigns ); // Restore x and y signs
+ outputNormal.z *= lerp( fOne.x, -fOne.x, ztSigns.x ); // Restore z sign
+}
+
+
+void DecompressVertex_Normal( float4 inputNormal, out float3 outputNormal )
+{
+ if ( COMPRESSED_VERTS == 1 )
+ {
+ if ( COMPRESSED_NORMALS_TYPE == COMPRESSED_NORMALS_SEPARATETANGENTS_SHORT2 )
+ {
+ _DecompressShort2Normal( inputNormal.xy, outputNormal );
+ }
+ else // ( COMPRESSED_NORMALS_TYPE == COMPRESSED_NORMALS_COMBINEDTANGENTS_UBYTE4 )
+ {
+ _DecompressUByte4Normal( inputNormal, outputNormal );
+ }
+ }
+ else
+ {
+ outputNormal = inputNormal.xyz;
+ }
+}
+
+void DecompressVertex_NormalTangent( float4 inputNormal, float4 inputTangent, out float3 outputNormal, out float4 outputTangent )
+{
+ if ( COMPRESSED_VERTS == 1 )
+ {
+ if ( COMPRESSED_NORMALS_TYPE == COMPRESSED_NORMALS_SEPARATETANGENTS_SHORT2 )
+ {
+ _DecompressShort2NormalTangent( inputNormal.xy, inputTangent.xy, outputNormal, outputTangent );
+ }
+ else // ( COMPRESSED_NORMALS_TYPE == COMPRESSED_NORMALS_COMBINEDTANGENTS_UBYTE4 )
+ {
+ _DecompressUByte4NormalTangent( inputNormal, outputNormal, outputTangent );
+ }
+ }
+ else
+ {
+ outputNormal = inputNormal.xyz;
+ outputTangent = inputTangent;
+ }
+}
+
+
+#ifdef SHADER_MODEL_VS_3_0
+
+//-----------------------------------------------------------------------------
+// Methods to sample morph data from a vertex texture
+// NOTE: vMorphTargetTextureDim.x = width, cVertexTextureDim.y = height, cVertexTextureDim.z = # of float4 fields per vertex
+// For position + normal morph for example, there will be 2 fields.
+//-----------------------------------------------------------------------------
+float4 SampleMorphDelta( sampler2D vt, const float3 vMorphTargetTextureDim, const float4 vMorphSubrect, const float flVertexID, const float flField )
+{
+ float flColumn = floor( flVertexID / vMorphSubrect.w );
+
+ float4 t;
+ t.x = vMorphSubrect.x + vMorphTargetTextureDim.z * flColumn + flField + 0.5f;
+ t.y = vMorphSubrect.y + flVertexID - flColumn * vMorphSubrect.w + 0.5f;
+ t.xy /= vMorphTargetTextureDim.xy;
+ t.z = t.w = 0.f;
+
+ return tex2Dlod( vt, t );
+}
+
+// Optimized version which reads 2 deltas
+void SampleMorphDelta2( sampler2D vt, const float3 vMorphTargetTextureDim, const float4 vMorphSubrect, const float flVertexID, out float4 delta1, out float4 delta2 )
+{
+ float flColumn = floor( flVertexID / vMorphSubrect.w );
+
+ float4 t;
+ t.x = vMorphSubrect.x + vMorphTargetTextureDim.z * flColumn + 0.5f;
+ t.y = vMorphSubrect.y + flVertexID - flColumn * vMorphSubrect.w + 0.5f;
+ t.xy /= vMorphTargetTextureDim.xy;
+ t.z = t.w = 0.f;
+
+ delta1 = tex2Dlod( vt, t );
+ t.x += 1.0f / vMorphTargetTextureDim.x;
+ delta2 = tex2Dlod( vt, t );
+}
+
+#endif // SHADER_MODEL_VS_3_0
+
+//-----------------------------------------------------------------------------
+// Method to apply morphs
+//-----------------------------------------------------------------------------
+bool ApplyMorph( float3 vPosFlex, in float3 vPosition, out float3 vPosition_O )
+{
+ // Flexes coming in from a separate stream
+ float3 vPosDelta = vPosFlex.xyz * cFlexScale.x;
+ vPosition_O.xyz = vPosition + vPosDelta;
+ return true;
+}
+
+bool ApplyMorph( float3 vPosFlex, float3 vNormalFlex,
+ in float3 vPosition, out float3 vPosition_O,
+ in float3 vNormal, out float3 vNormal_O )
+{
+ // Flexes coming in from a separate stream
+ float3 vPosDelta = vPosFlex.xyz * cFlexScale.x;
+ float3 vNormalDelta = vNormalFlex.xyz * cFlexScale.x;
+ vPosition_O.xyz = vPosition + vPosDelta;
+ vNormal_O.xyz = vNormal + vNormalDelta;
+ return true;
+}
+
+bool ApplyMorph( float3 vPosFlex, float3 vNormalFlex,
+ in float3 vPosition, out float3 vPosition_O,
+ in float3 vNormal, out float3 vNormal_O,
+ in float3 vTangent, out float3 vTangent_O )
+{
+ // Flexes coming in from a separate stream
+ float3 vPosDelta = vPosFlex.xyz * cFlexScale.x;
+ float3 vNormalDelta = vNormalFlex.xyz * cFlexScale.x;
+ vPosition_O.xyz = vPosition + vPosDelta;
+ vNormal_O.xyz = vNormal + vNormalDelta;
+ vTangent_O.xyz = vTangent + vNormalDelta;
+ return true;
+}
+
+bool ApplyMorph( float4 vPosFlex, float3 vNormalFlex,
+ inout float3 vPosition, inout float3 vNormal, inout float3 vTangent, out float flWrinkle )
+{
+ // Flexes coming in from a separate stream
+ float3 vPosDelta = vPosFlex.xyz * cFlexScale.x;
+ float3 vNormalDelta = vNormalFlex.xyz * cFlexScale.x;
+ flWrinkle = vPosFlex.w * cFlexScale.y;
+ vPosition.xyz += vPosDelta;
+ vNormal += vNormalDelta;
+ vTangent.xyz += vNormalDelta;
+ return true;
+}
+
+#ifdef SHADER_MODEL_VS_3_0
+
+bool ApplyMorph( sampler2D morphSampler, const float3 vMorphTargetTextureDim, const float4 vMorphSubrect,
+ const float flVertexID, const float3 vMorphTexCoord,
+ in float3 vPosition, out float3 vPosition_O )
+{
+#if MORPHING
+
+#if 1
+ // Flexes coming in from a separate stream
+ float4 vPosDelta = SampleMorphDelta( morphSampler, vMorphTargetTextureDim, vMorphSubrect, flVertexID, 0 );
+ vPosition_O = vPosition + vPosDelta.xyz;
+#else
+ float4 t = float4( vMorphTexCoord.x, vMorphTexCoord.y, 0.0f, 0.0f );
+ float3 vPosDelta = tex2Dlod( morphSampler, t );
+ vPosition += vPosDelta.xyz * vMorphTexCoord.z;
+#endif // DECAL
+
+ return true;
+
+#else // !MORPHING
+ vPosition_O = vPosition;
+ return false;
+#endif
+}
+
+bool ApplyMorph( sampler2D morphSampler, const float3 vMorphTargetTextureDim, const float4 vMorphSubrect,
+ const float flVertexID, const float3 vMorphTexCoord,
+ in float3 vPosition, out float3 vPosition_O,
+ in float3 vNormal, out float3 vNormal_O )
+{
+#if MORPHING
+
+#if 1
+ float4 vPosDelta, vNormalDelta;
+ SampleMorphDelta2( morphSampler, vMorphTargetTextureDim, vMorphSubrect, flVertexID, vPosDelta, vNormalDelta );
+ vPosition_O = vPosition + vPosDelta.xyz;
+ vNormal_O = vNormal + vNormalDelta.xyz;
+#else
+ float4 t = float4( vMorphTexCoord.x, vMorphTexCoord.y, 0.0f, 0.0f );
+ float3 vPosDelta = tex2Dlod( morphSampler, t );
+ t.x += 1.0f / vMorphTargetTextureDim.x;
+ float3 vNormalDelta = tex2Dlod( morphSampler, t );
+ vPosition += vPosDelta.xyz * vMorphTexCoord.z;
+ vNormal += vNormalDelta.xyz * vMorphTexCoord.z;
+#endif // DECAL
+
+ return true;
+
+#else // !MORPHING
+ vPosition_O = vPosition;
+ vNormal_O = vNormal;
+ return false;
+#endif
+}
+
+bool ApplyMorph( sampler2D morphSampler, const float3 vMorphTargetTextureDim, const float4 vMorphSubrect,
+ const float flVertexID, const float3 vMorphTexCoord,
+ in float3 vPosition, out float3 vPosition_O,
+ in float3 vNormal, out float3 vNormal_O,
+ in float3 vTangent, out float3 vTangent_O )
+{
+#if MORPHING
+
+#if 1
+ float4 vPosDelta, vNormalDelta;
+ SampleMorphDelta2( morphSampler, vMorphTargetTextureDim, vMorphSubrect, flVertexID, vPosDelta, vNormalDelta );
+ vPosition_O = vPosition + vPosDelta.xyz;
+ vNormal_O = vNormal + vNormalDelta.xyz;
+ vTangent_O = vTangent + vNormalDelta.xyz;
+#else
+ float4 t = float4( vMorphTexCoord.x, vMorphTexCoord.y, 0.0f, 0.0f );
+ float3 vPosDelta = tex2Dlod( morphSampler, t );
+ t.x += 1.0f / vMorphTargetTextureDim.x;
+ float3 vNormalDelta = tex2Dlod( morphSampler, t );
+ vPosition += vPosDelta.xyz * vMorphTexCoord.z;
+ vNormal += vNormalDelta.xyz * vMorphTexCoord.z;
+ vTangent += vNormalDelta.xyz * vMorphTexCoord.z;
+#endif // DECAL
+
+ return true;
+
+#else // MORPHING
+ vPosition_O = vPosition;
+ vNormal_O = vNormal;
+ vTangent_O = vTangent;
+ return false;
+#endif
+}
+
+bool ApplyMorph( sampler2D morphSampler, const float3 vMorphTargetTextureDim, const float4 vMorphSubrect,
+ const float flVertexID, const float3 vMorphTexCoord,
+ inout float3 vPosition, inout float3 vNormal, inout float3 vTangent, out float flWrinkle )
+{
+#if MORPHING
+
+#if !DECAL
+ float4 vPosDelta, vNormalDelta;
+ SampleMorphDelta2( morphSampler, vMorphTargetTextureDim, vMorphSubrect, flVertexID, vPosDelta, vNormalDelta );
+ vPosition += vPosDelta.xyz;
+ vNormal += vNormalDelta.xyz;
+ vTangent += vNormalDelta.xyz;
+ flWrinkle = vPosDelta.w;
+#else
+ float4 t = float4( vMorphTexCoord.x, vMorphTexCoord.y, 0.0f, 0.0f );
+ float4 vPosDelta = tex2Dlod( morphSampler, t );
+ t.x += 1.0f / vMorphTargetTextureDim.x;
+ float3 vNormalDelta = tex2Dlod( morphSampler, t );
+
+ vPosition += vPosDelta.xyz * vMorphTexCoord.z;
+ vNormal += vNormalDelta.xyz * vMorphTexCoord.z;
+ vTangent += vNormalDelta.xyz * vMorphTexCoord.z;
+ flWrinkle = vPosDelta.w * vMorphTexCoord.z;
+#endif // DECAL
+
+ return true;
+
+#else // MORPHING
+
+ flWrinkle = 0.0f;
+ return false;
+
+#endif
+}
+
+#endif // SHADER_MODEL_VS_3_0
+
+
+float RangeFog( const float3 projPos )
+{
+ return max( cFogMaxDensity, ( -projPos.z * cOOFogRange + cFogEndOverFogRange ) );
+}
+
+float WaterFog( const float3 worldPos, const float3 projPos )
+{
+ float4 tmp;
+
+ tmp.xy = cEyePosWaterZ.wz - worldPos.z;
+
+ // tmp.x is the distance from the water surface to the vert
+ // tmp.y is the distance from the eye position to the vert
+
+ // if $tmp.x < 0, then set it to 0
+ // This is the equivalent of moving the vert to the water surface if it's above the water surface
+
+ tmp.x = max( 0.0f, tmp.x );
+
+ // $tmp.w = $tmp.x / $tmp.y
+ tmp.w = tmp.x / tmp.y;
+
+ tmp.w *= projPos.z;
+
+ // $tmp.w is now the distance that we see through water.
+
+ return max( cFogMaxDensity, ( -tmp.w * cOOFogRange + cFogOne ) );
+}
+
+float CalcFog( const float3 worldPos, const float3 projPos, const int fogType )
+{
+#if defined( _X360 )
+ // 360 only does pixel fog
+ return 1.0f;
+#endif
+
+ if( fogType == FOGTYPE_RANGE )
+ {
+ return RangeFog( projPos );
+ }
+ else
+ {
+#if SHADERMODEL_VS_2_0 == 1
+ // We do this work in the pixel shader in dx9, so don't do any fog here.
+ return 1.0f;
+#else
+ return WaterFog( worldPos, projPos );
+#endif
+ }
+}
+
+float CalcFog( const float3 worldPos, const float3 projPos, const bool bWaterFog )
+{
+#if defined( _X360 )
+ // 360 only does pixel fog
+ return 1.0f;
+#endif
+
+ float flFog;
+ if( !bWaterFog )
+ {
+ flFog = RangeFog( projPos );
+ }
+ else
+ {
+#if SHADERMODEL_VS_2_0 == 1
+ // We do this work in the pixel shader in dx9, so don't do any fog here.
+ flFog = 1.0f;
+#else
+ flFog = WaterFog( worldPos, projPos );
+#endif
+ }
+
+ return flFog;
+}
+
+float4 DecompressBoneWeights( const float4 weights )
+{
+ float4 result = weights;
+
+ if ( COMPRESSED_VERTS )
+ {
+ // Decompress from SHORT2 to float. In our case, [-1, +32767] -> [0, +1]
+ // NOTE: we add 1 here so we can divide by 32768 - which is exact (divide by 32767 is not).
+ // This avoids cracking between meshes with different numbers of bone weights.
+ // We use SHORT2 instead of SHORT2N for a similar reason - the GPU's conversion
+ // from [-32768,+32767] to [-1,+1] is imprecise in the same way.
+ result += 1;
+ result /= 32768;
+ }
+
+ return result;
+}
+
+void SkinPosition( bool bSkinning, const float4 modelPos,
+ const float4 boneWeights, float4 fBoneIndices,
+ out float3 worldPos )
+{
+#if !defined( _X360 )
+ int3 boneIndices = D3DCOLORtoUBYTE4( fBoneIndices );
+#else
+ int3 boneIndices = fBoneIndices;
+#endif
+
+ // Needed for invariance issues caused by multipass rendering
+#if defined( _X360 )
+ [isolate]
+#endif
+ {
+ if ( !bSkinning )
+ {
+ worldPos = mul4x3( modelPos, cModel[0] );
+ }
+ else // skinning - always three bones
+ {
+ float4x3 mat1 = cModel[boneIndices[0]];
+ float4x3 mat2 = cModel[boneIndices[1]];
+ float4x3 mat3 = cModel[boneIndices[2]];
+
+ float3 weights = DecompressBoneWeights( boneWeights ).xyz;
+ weights[2] = 1 - (weights[0] + weights[1]);
+
+ float4x3 blendMatrix = mat1 * weights[0] + mat2 * weights[1] + mat3 * weights[2];
+ worldPos = mul4x3( modelPos, blendMatrix );
+ }
+ }
+}
+
+void SkinPositionAndNormal( bool bSkinning, const float4 modelPos, const float3 modelNormal,
+ const float4 boneWeights, float4 fBoneIndices,
+ out float3 worldPos, out float3 worldNormal )
+{
+ // Needed for invariance issues caused by multipass rendering
+#if defined( _X360 )
+ [isolate]
+#endif
+ {
+
+#if !defined( _X360 )
+ int3 boneIndices = D3DCOLORtoUBYTE4( fBoneIndices );
+#else
+ int3 boneIndices = fBoneIndices;
+#endif
+
+ if ( !bSkinning )
+ {
+ worldPos = mul4x3( modelPos, cModel[0] );
+ worldNormal = mul3x3( modelNormal, ( const float3x3 )cModel[0] );
+ }
+ else // skinning - always three bones
+ {
+ float4x3 mat1 = cModel[boneIndices[0]];
+ float4x3 mat2 = cModel[boneIndices[1]];
+ float4x3 mat3 = cModel[boneIndices[2]];
+
+ float3 weights = DecompressBoneWeights( boneWeights ).xyz;
+ weights[2] = 1 - (weights[0] + weights[1]);
+
+ float4x3 blendMatrix = mat1 * weights[0] + mat2 * weights[1] + mat3 * weights[2];
+ worldPos = mul4x3( modelPos, blendMatrix );
+ worldNormal = mul3x3( modelNormal, ( float3x3 )blendMatrix );
+ }
+
+ } // end [isolate]
+}
+
+// Is it worth keeping SkinPosition and SkinPositionAndNormal around since the optimizer
+// gets rid of anything that isn't used?
+void SkinPositionNormalAndTangentSpace(
+ bool bSkinning,
+ const float4 modelPos, const float3 modelNormal,
+ const float4 modelTangentS,
+ const float4 boneWeights, float4 fBoneIndices,
+ out float3 worldPos, out float3 worldNormal,
+ out float3 worldTangentS, out float3 worldTangentT )
+{
+#if !defined( _X360 )
+ int3 boneIndices = D3DCOLORtoUBYTE4( fBoneIndices );
+#else
+ int3 boneIndices = fBoneIndices;
+#endif
+
+ // Needed for invariance issues caused by multipass rendering
+#if defined( _X360 )
+ [isolate]
+#endif
+ {
+ if ( !bSkinning )
+ {
+ worldPos = mul4x3( modelPos, cModel[0] );
+ worldNormal = mul3x3( modelNormal, ( const float3x3 )cModel[0] );
+ worldTangentS = mul3x3( ( float3 )modelTangentS, ( const float3x3 )cModel[0] );
+ }
+ else // skinning - always three bones
+ {
+ float4x3 mat1 = cModel[boneIndices[0]];
+ float4x3 mat2 = cModel[boneIndices[1]];
+ float4x3 mat3 = cModel[boneIndices[2]];
+
+ float3 weights = DecompressBoneWeights( boneWeights ).xyz;
+ weights[2] = 1 - (weights[0] + weights[1]);
+
+ float4x3 blendMatrix = mat1 * weights[0] + mat2 * weights[1] + mat3 * weights[2];
+ worldPos = mul4x3( modelPos, blendMatrix );
+ worldNormal = mul3x3( modelNormal, ( const float3x3 )blendMatrix );
+ worldTangentS = mul3x3( ( float3 )modelTangentS, ( const float3x3 )blendMatrix );
+ }
+ worldTangentT = cross( worldNormal, worldTangentS ) * -modelTangentS.w;
+ }
+}
+
+
+//-----------------------------------------------------------------------------
+// Lighting helper functions
+//-----------------------------------------------------------------------------
+
+float3 AmbientLight( const float3 worldNormal )
+{
+ float3 nSquared = worldNormal * worldNormal;
+ int3 isNegative = ( worldNormal < 0.0 );
+ float3 linearColor;
+ linearColor = nSquared.x * cAmbientCubeX[isNegative.x] +
+ nSquared.y * cAmbientCubeY[isNegative.y] +
+ nSquared.z * cAmbientCubeZ[isNegative.z];
+ return linearColor;
+}
+
+// The following "internal" routines are called "privately" by other routines in this file which
+// handle the particular flavor of vs20 control flow appropriate to the original caller
+float VertexAttenInternal( const float3 worldPos, int lightNum )
+{
+ float result = 0.0f;
+
+ // Get light direction
+ float3 lightDir = cLightInfo[lightNum].pos - worldPos;
+
+ // Get light distance squared.
+ float lightDistSquared = dot( lightDir, lightDir );
+
+ // Get 1/lightDistance
+ float ooLightDist = rsqrt( lightDistSquared );
+
+ // Normalize light direction
+ lightDir *= ooLightDist;
+
+ float3 vDist;
+# if defined( _X360 )
+ {
+ //X360 dynamic compile hits an internal compiler error using dst(), this is the breakdown of how dst() works from the 360 docs.
+ vDist.x = 1;
+ vDist.y = lightDistSquared * ooLightDist;
+ vDist.z = lightDistSquared;
+ //flDist.w = ooLightDist;
+ }
+# else
+ {
+ vDist = dst( lightDistSquared, ooLightDist );
+ }
+# endif
+
+ float flDistanceAtten = 1.0f / dot( cLightInfo[lightNum].atten.xyz, vDist );
+
+ // Spot attenuation
+ float flCosTheta = dot( cLightInfo[lightNum].dir.xyz, -lightDir );
+ float flSpotAtten = (flCosTheta - cLightInfo[lightNum].spotParams.z) * cLightInfo[lightNum].spotParams.w;
+ flSpotAtten = max( 0.0001f, flSpotAtten );
+ flSpotAtten = pow( flSpotAtten, cLightInfo[lightNum].spotParams.x );
+ flSpotAtten = saturate( flSpotAtten );
+
+ // Select between point and spot
+ float flAtten = lerp( flDistanceAtten, flDistanceAtten * flSpotAtten, cLightInfo[lightNum].dir.w );
+
+ // Select between above and directional (no attenuation)
+ result = lerp( flAtten, 1.0f, cLightInfo[lightNum].color.w );
+
+ return result;
+}
+
+float CosineTermInternal( const float3 worldPos, const float3 worldNormal, int lightNum, bool bHalfLambert )
+{
+ // Calculate light direction assuming this is a point or spot
+ float3 lightDir = normalize( cLightInfo[lightNum].pos - worldPos );
+
+ // Select the above direction or the one in the structure, based upon light type
+ lightDir = lerp( lightDir, -cLightInfo[lightNum].dir, cLightInfo[lightNum].color.w );
+
+ // compute N dot L
+ float NDotL = dot( worldNormal, lightDir );
+
+ if ( !bHalfLambert )
+ {
+ NDotL = max( 0.0f, NDotL );
+ }
+ else // Half-Lambert
+ {
+ NDotL = NDotL * 0.5 + 0.5;
+ NDotL = NDotL * NDotL;
+ }
+ return NDotL;
+}
+
+// This routine uses booleans to do early-outs and is meant to be called by routines OUTSIDE of this file
+float GetVertexAttenForLight( const float3 worldPos, int lightNum )
+{
+ float result = 0.0f;
+ if ( g_bLightEnabled[lightNum] )
+ {
+ result = VertexAttenInternal( worldPos, lightNum );
+ }
+
+ return result;
+}
+
+// This routine uses booleans to do early-outs and is meant to be called by routines OUTSIDE of this file
+float CosineTerm( const float3 worldPos, const float3 worldNormal, int lightNum, bool bHalfLambert )
+{
+ float flResult = 0.0f;
+ if ( g_bLightEnabled[lightNum] )
+ {
+ flResult = CosineTermInternal( worldPos, worldNormal, lightNum, bHalfLambert );
+ }
+
+ return flResult;
+}
+
+float3 DoLightInternal( const float3 worldPos, const float3 worldNormal, int lightNum, bool bHalfLambert )
+{
+ return cLightInfo[lightNum].color *
+ CosineTermInternal( worldPos, worldNormal, lightNum, bHalfLambert ) *
+ VertexAttenInternal( worldPos, lightNum );
+}
+
+// This routine
+float3 DoLighting( const float3 worldPos, const float3 worldNormal,
+ const float3 staticLightingColor, const bool bStaticLight,
+ const bool bDynamicLight, bool bHalfLambert )
+{
+ float3 linearColor = float3( 0.0f, 0.0f, 0.0f );
+
+ if( bStaticLight ) // Static light
+ {
+ float3 col = staticLightingColor * cOverbright;
+#if defined ( _X360 )
+ linearColor += col * col;
+#else
+ linearColor += GammaToLinear( col );
+#endif
+ }
+
+ if( bDynamicLight ) // Dynamic light
+ {
+ for (int i = 0; i < g_nLightCount; i++)
+ {
+ linearColor += DoLightInternal( worldPos, worldNormal, i, bHalfLambert );
+ }
+ }
+
+ if( bDynamicLight )
+ {
+ linearColor += AmbientLight( worldNormal ); //ambient light is already remapped
+ }
+
+ return linearColor;
+}
+
+float3 DoLightingUnrolled( const float3 worldPos, const float3 worldNormal,
+ const float3 staticLightingColor, const bool bStaticLight,
+ const bool bDynamicLight, bool bHalfLambert, const int nNumLights )
+{
+ float3 linearColor = float3( 0.0f, 0.0f, 0.0f );
+
+ if( bStaticLight ) // Static light
+ {
+ linearColor += GammaToLinear( staticLightingColor * cOverbright );
+ }
+
+ if( bDynamicLight ) // Ambient light
+ {
+ if ( nNumLights >= 1 )
+ linearColor += DoLightInternal( worldPos, worldNormal, 0, bHalfLambert );
+ if ( nNumLights >= 2 )
+ linearColor += DoLightInternal( worldPos, worldNormal, 1, bHalfLambert );
+ if ( nNumLights >= 3 )
+ linearColor += DoLightInternal( worldPos, worldNormal, 2, bHalfLambert );
+ if ( nNumLights >= 4 )
+ linearColor += DoLightInternal( worldPos, worldNormal, 3, bHalfLambert );
+ }
+
+ if( bDynamicLight )
+ {
+ linearColor += AmbientLight( worldNormal ); //ambient light is already remapped
+ }
+
+ return linearColor;
+}
+
+int4 FloatToInt( in float4 floats )
+{
+ return D3DCOLORtoUBYTE4( floats.zyxw / 255.001953125 );
+}
+
+float2 ComputeSphereMapTexCoords( in float3 reflectionVector )
+{
+ // transform reflection vector into view space
+ reflectionVector = mul( reflectionVector, ( float3x3 )cViewModel );
+
+ // generate
+ float3 tmp = float3( reflectionVector.x, reflectionVector.y, reflectionVector.z + 1.0f );
+
+ // find 1 / len
+ float ooLen = dot( tmp, tmp );
+ ooLen = 1.0f / sqrt( ooLen );
+
+ // tmp = tmp/|tmp| + 1
+ tmp.xy = ooLen * tmp.xy + 1.0f;
+
+ return tmp.xy * 0.5f;
+}
+
+
+#define DEFORMATION_CLAMP_TO_BOX_IN_WORLDSPACE 1
+ // minxyz.minsoftness / maxxyz.maxsoftness
+float3 ApplyDeformation( float3 worldpos, int deftype, float4 defparms0, float4 defparms1,
+ float4 defparms2, float4 defparms3 )
+{
+ float3 ret = worldpos;
+ if ( deftype == DEFORMATION_CLAMP_TO_BOX_IN_WORLDSPACE )
+ {
+ ret=max( ret, defparms2.xyz );
+ ret=min( ret, defparms3.xyz );
+ }
+
+ return ret;
+}
+
+
+#endif //#ifndef COMMON_VS_FXC_H_
diff --git a/mp/game/momentum/shadereditorui/shader_src/cpp_shader_constant_register_map.h b/mp/game/momentum/shadereditorui/shader_src/cpp_shader_constant_register_map.h
new file mode 100644
index 0000000000..62c9acd19c
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/cpp_shader_constant_register_map.h
@@ -0,0 +1,45 @@
+//========= Copyright © 1996-2006, Valve LLC, All rights reserved. ============
+//
+// Purpose: Provide convenient mapping for shader constants
+//
+// $NoKeywords: $
+//=============================================================================
+
+#define C_CODE_HACK
+#include "shader_constant_register_map.h"
+#undef C_CODE_HACK
+
+// For the C code, map the above file's defines back to integers...
+#define PSREG_CONSTANT_00 0
+#define PSREG_CONSTANT_01 1
+#define PSREG_CONSTANT_02 2
+#define PSREG_CONSTANT_03 3
+#define PSREG_CONSTANT_04 4
+#define PSREG_CONSTANT_05 5
+#define PSREG_CONSTANT_06 6
+#define PSREG_CONSTANT_07 7
+#define PSREG_CONSTANT_08 8
+#define PSREG_CONSTANT_09 9
+#define PSREG_CONSTANT_10 10
+#define PSREG_CONSTANT_11 11
+#define PSREG_CONSTANT_12 12
+#define PSREG_CONSTANT_13 13
+#define PSREG_CONSTANT_14 14
+#define PSREG_CONSTANT_15 15
+#define PSREG_CONSTANT_16 16
+#define PSREG_CONSTANT_17 17
+#define PSREG_CONSTANT_18 18
+#define PSREG_CONSTANT_19 19
+#define PSREG_CONSTANT_20 20
+#define PSREG_CONSTANT_21 21
+#define PSREG_CONSTANT_22 22
+#define PSREG_CONSTANT_23 23
+#define PSREG_CONSTANT_24 24
+#define PSREG_CONSTANT_25 25
+#define PSREG_CONSTANT_26 26
+#define PSREG_CONSTANT_27 27
+#define PSREG_CONSTANT_28 28
+#define PSREG_CONSTANT_29 29
+#define PSREG_CONSTANT_30 30
+#define PSREG_CONSTANT_31 31
+
diff --git a/mp/game/momentum/shadereditorui/shader_src/detail_prop_shader_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/detail_prop_shader_ps30.fxc
new file mode 100644
index 0000000000..6d7cc5f53d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/detail_prop_shader_ps30.fxc
@@ -0,0 +1,92 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Combos
+// STATIC: "FLASHLIGHT" "0..1"
+// DYNAMIC: "FLASHLIGHTDEPTHFILTERMODE" "0..2"
+// DYNAMIC: "FLASHLIGHTSHADOWS" "0..1"
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _gSampler_Flashlight_Cookie : register( s1 );
+sampler _gSampler_Flashlight_Depth : register( s2 );
+sampler _gSampler_Flashlight_Random : register( s3 );
+
+// Constants
+const float3 g_cData_grass_spec_color : register( c16 ); // Static
+const float3 _g_VecForward : register( c17 );
+const float4 _g_FogParams : register( c18 );
+const float3 _g_VecOrig : register( c19 );
+const float4 g_cFlashlightAttenuationFactors : register( c8 );
+const float4 g_cFlashlightPos : register( c9 );
+const float4 g_cShadowTweaks : register( c7 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float4 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float3 vTexCoord_4 : TEXCOORD4;
+ float vColor_0 : COLOR0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _texLookup_16 = tex2D( _Sampler_00, In.vTexCoord_0 );
+ float3 _var0 = _texLookup_16.rgb;
+ float _var1 = _texLookup_16.a;
+ float3 _var2 = float3( 0.000000, 0.000000, 0.000000 );
+ float3 _var3 = float3( 0.000000, 0.000000, 0.000000 );
+ float3 _var4 = float( -1.000000 ) * _g_VecForward;
+ float _var5 = _g_VecOrig.z;
+ float _var6 = In.vTexCoord_4.z;
+ float _var7 = In.vTexCoord_3.z;
+#if ( FLASHLIGHT == 0 )
+ float _var8 = smoothstep( float( 0.290000 ), float( 0.300000 ), _var1 );
+ _var3 = In.vTexCoord_1;
+ _var8 = In.vColor_0 * _var8;
+ float3 _var9 = _var8 * g_cData_grass_spec_color;
+ _var2 = _var9;
+#endif
+#if ( FLASHLIGHT == 1 )
+ float2 _var10 = In.vTexCoord_3.xy;
+ float _var11 = In.vTexCoord_3.w;
+ _var10 = _var10 / _var11;
+ _var4 = DoFlashlight( g_cFlashlightPos.xyz, In.vTexCoord_4, In.vTexCoord_2, _var4,
+ g_cFlashlightAttenuationFactors.xyz, g_cFlashlightAttenuationFactors.w,
+ _gSampler_Flashlight_Cookie, _gSampler_Flashlight_Depth, _gSampler_Flashlight_Random,
+ FLASHLIGHTDEPTHFILTERMODE, FLASHLIGHTSHADOWS, true,
+ _var10, false, g_cShadowTweaks );
+ _var3 = _var4;
+#endif
+ _var0 = _var0 + _var2;
+ _var3 = _var3;
+ float _var12 = _var1 - float( 0.100000 );
+ _var5 = CalcPixelFogFactor( PIXELFOGTYPE, _g_FogParams, _var5, _var6, _var7 );
+ _var0 = _var0 * _var3;
+ clip( _var12 );
+ float4 _var13 = float4( _var0, _var12 );
+ _var13 = FinalOutput( _var13, _var5, PIXELFOGTYPE, TONEMAP_SCALE_GAMMA, true, _var7 );
+ Out.vColor_0 = _var13;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/detail_prop_shader_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/detail_prop_shader_vs30.fxc
new file mode 100644
index 0000000000..165ce5fd3f
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/detail_prop_shader_vs30.fxc
@@ -0,0 +1,136 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+// Combos
+// STATIC: "FLASHLIGHT" "0..1"
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Constants
+const float3 g_cData_Mutable_01 : register( c48 ); // Mutable
+const float g_cData_Mutable_02 : register( c49 ); // Mutable
+const float _g_Time : register( c50 );
+const float4x4 g_cFlashlightWorldToTexture : register( c51 );
+
+// User code - globals
+float3 triangle( float3 a )
+{
+ return abs( frac( a + 0.5f ) * 2.0f - 1.0f );
+}
+
+// User code - function bodies
+void UserFunction_195( in float3 var_00, out float3 var_01 )
+{
+ var_01 = triangle( var_00 );
+
+ var_01 = ( 3.0 - 2.000000000001 * var_01 ) * var_01 * var_01;
+}
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float3 vNormal : NORMAL;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float4 vColor_0 : COLOR0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float4 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float3 vTexCoord_4 : TEXCOORD4;
+ float vColor_0 : COLOR0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float _var0 = dot( In.vTexCoord_2, In.vNormal );
+ float _var1 = In.vTexCoord_1.z;
+ float3 _var2 = In.vNormal * float( -0.900000 );
+ float _var3 = dot( In.vNormal, g_cData_Mutable_01 );
+ float _var4 = In.vTexCoord_1.y;
+ float _var5 = In.vTexCoord_1.x;
+ float _var6 = cos( g_cData_Mutable_02 );
+ float _var7 = In.vPos.x;
+ float _var8 = sin( g_cData_Mutable_02 );
+ float _var9 = In.vPos.y;
+ float _var10 = In.vPos.z;
+ float _var11 = _g_Time * float( 0.700000 );
+ float3 _var12 = In.vColor_0.xyz;
+ float4 _var13 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float3 _var14 = _var0 * In.vNormal;
+ _var2 = _var1 * _var2;
+ float3 _var15 = _var3 * In.vNormal;
+ float _var16 = 1.0f - _var4;
+ float _var17 = _var6 * _var7;
+ float _var18 = _var8 * _var9;
+ float _var19 = _var9 * _var6;
+ float _var20 = _var8 * _var7;
+ float _var21 = _var4 * float( 0.400000 );
+ _var14 = In.vTexCoord_2 - _var14;
+ _var15 = g_cData_Mutable_01 - _var15;
+ float _var22 = _var16 * _var5;
+ _var17 = _var17 - _var18;
+ _var19 = _var19 + _var20;
+ _var12 = _var21 + _var12;
+ float _var23 = _var5 * _var16;
+ _var14 = _var14 * _var1;
+ _var15 = normalize( _var15 );
+ float2 _var24 = float2( _var17, _var19 );
+ _var14 = _var14 + _var2;
+ _var15 = _var15 * float( 2.000000 );
+ float3 _var25 = float3( _var24, _var10 );
+ _var15 = _var15 * _var22;
+ _var25 = _var25 * float( 0.005000 );
+ _var25 = _var25 + _var11;
+ float3 _var26 = (float3)0;
+ UserFunction_195( _var25, _var26 );
+ float3 _var27 = sin( _var25 );
+ float3 _var28 = abs( _var26 );
+ float3 _var29 = sign( _var26 );
+ _var27 = abs( _var27 );
+ _var28 = pow( _var28, float( 3.000000 ) );
+ float _var30 = dot( _var27, float3( 0.333333, 0.333333, 0.333333 ) );
+ _var29 = _var28 * _var29;
+ float3 _var31 = _var12 * _var30;
+ float _var32 = dot( _var28, float3( 0.333333, 0.333333, 0.333333 ) );
+ float _var33 = pow( _var30, float( 2.000000 ) );
+ _var15 = _var15 * _var29;
+ _var31 = lerp( _var12, _var31, float( 0.400000 ) );
+ _var32 = _var32 * _var33;
+ _var15 = In.vPos + _var15;
+ _var23 = _var23 * _var32;
+ _var14 = _var14 + _var15;
+ float4 _var34 = mul( float4(_var14.xyz,1), cModelViewProj );
+ float4 _var35 = _var34;
+#if ( FLASHLIGHT == 1 )
+ float4 _var36 = mul( float4(_var14.xyz,1), g_cFlashlightWorldToTexture );
+ float2 _var37 = _var34.xy;
+ float _var38 = _var34.z;
+ float _var39 = _var34.w;
+ _var13 = _var36;
+ _var38 = _var38 - float( 0.100000 );
+ float3 _var40 = float3( _var37, _var38 );
+ float4 _var41 = float4( _var40, _var39 );
+ _var35 = _var41;
+#endif
+ Out.vProjPos = _var35;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ Out.vTexCoord_1 = _var31;
+ Out.vTexCoord_2 = _var13;
+ Out.vTexCoord_3 = _var35;
+ Out.vTexCoord_4 = _var14;
+ Out.vColor_0 = _var23;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/downsample_4_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/downsample_4_ps30.fxc
new file mode 100644
index 0000000000..df6d0b81ea
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/downsample_4_ps30.fxc
@@ -0,0 +1,58 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// Arrays
+static const float2 g_cArray_202[4] =
+{
+ float2( 0.000000f, 0.000000f ),
+ float2( 2.000000f, 0.000000f ),
+ float2( 0.000000f, 2.000000f ),
+ float2( 2.000000f, 2.000000f ),
+};
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = _g_TexelSize * float( 0.500000 );
+ _var1 = In.vTexCoord_0 + _var1;
+ for ( int _var2 = 0; _var2 < 4; _var2++ )
+ {
+ float2 _var3 = _var1;
+ float2 _var4 = g_cArray_202[_var2] * _g_TexelSize;
+ _var3 = _var3 + _var4;
+ float4 _var5 = tex2D( _Sampler_00, _var3 ).rgba;
+ _var0 = _var0 + _var5;
+ }
+ _var0 = _var0 * float( 0.250000 );
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/downsample_4_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/downsample_4_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/downsample_4_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_x_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_x_ps30.fxc
new file mode 100644
index 0000000000..cf9fe1d4d7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_x_ps30.fxc
@@ -0,0 +1,58 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// Arrays
+static const float g_cArray_231[5] =
+{
+ float( 0.054489f ),
+ float( 0.244201f ),
+ float( 0.402620f ),
+ float( 0.244201f ),
+ float( 0.054489f ),
+};
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = float2( 3.000000, 0.000000 ) * _g_TexelSize;
+ float2 _var2 = float2( 1.000000, 0.000000 ) * _g_TexelSize;
+ _var1 = In.vTexCoord_0 - _var1;
+ for ( int _var3 = 0; _var3 < 5; _var3++ )
+ {
+ _var1 = _var1 + _var2;
+ float4 _var4 = tex2D( _Sampler_00, _var1 ).rgba;
+ _var4 = _var4 * g_cArray_231[_var3];
+ _var0 = _var0 + _var4;
+ }
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_x_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_x_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_x_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_y_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_y_ps30.fxc
new file mode 100644
index 0000000000..d5f98cefd7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_y_ps30.fxc
@@ -0,0 +1,58 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// Arrays
+static const float g_cArray_253[5] =
+{
+ float( 0.054489f ),
+ float( 0.244201f ),
+ float( 0.402620f ),
+ float( 0.244201f ),
+ float( 0.054489f ),
+};
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = float2( 0.000000, 3.000000 ) * _g_TexelSize;
+ float2 _var2 = float2( 0.000000, 1.000000 ) * _g_TexelSize;
+ _var1 = In.vTexCoord_0 - _var1;
+ for ( int _var3 = 0; _var3 < 5; _var3++ )
+ {
+ _var1 = _var1 + _var2;
+ float4 _var4 = tex2D( _Sampler_00, _var1 ).rgba;
+ _var4 = _var4 * g_cArray_253[_var3];
+ _var0 = _var0 + _var4;
+ }
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_y_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_y_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_5_y_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_x_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_x_ps30.fxc
new file mode 100644
index 0000000000..dd26fa72c4
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_x_ps30.fxc
@@ -0,0 +1,71 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// Arrays
+static const float g_cArray_274[7] =
+{
+ float( 0.167839f ),
+ float( 0.684901f ),
+ float( 1.592437f ),
+ float( 2.109639f ),
+ float( 1.592437f ),
+ float( 0.684901f ),
+ float( 0.167839f ),
+};
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = float2( 4.000000, 0.000000 ) * _g_TexelSize;
+ float2 _var2 = float2( 1.000000, 0.000000 ) * _g_TexelSize;
+ float _var3 = float( 0.000000 );
+ _var1 = In.vTexCoord_0 - _var1;
+ for ( int _var4 = 0; _var4 < 7; _var4++ )
+ {
+ _var1 = _var1 + _var2;
+ float4 _texLookup_16 = tex2D( _Sampler_00, _var1 );
+ float3 _var5 = _texLookup_16.rgb;
+ float _var6 = _texLookup_16.a;
+ _var6 = ceil( _var6 );
+ float4 _var7 = float4( _var5, _var6 );
+ _var3 = _var3 + _var6;
+ _var7 = _var7 * g_cArray_274[_var4];
+ _var0 = _var0 + _var7;
+ }
+ float3 _var8 = _var0.xyz;
+ float _var9 = _var0.w;
+ _var8 = _var8 / _var3;
+ _var9 = _var9 / float( 7.000000 );
+ float4 _var10 = float4( _var8, _var9 );
+ Out.vColor_0 = _var10;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_x_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_x_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_x_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_y_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_y_ps30.fxc
new file mode 100644
index 0000000000..37faf10f6a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_y_ps30.fxc
@@ -0,0 +1,70 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// Arrays
+static const float g_cArray_305[7] =
+{
+ float( 0.167839f ),
+ float( 0.684901f ),
+ float( 1.592437f ),
+ float( 2.109639f ),
+ float( 1.592437f ),
+ float( 0.684901f ),
+ float( 0.167839f ),
+};
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = float2( 0.000000, 4.000000 ) * _g_TexelSize;
+ float2 _var2 = float2( 0.000000, 1.000000 ) * _g_TexelSize;
+ float _var3 = float( 0.000000 );
+ _var1 = In.vTexCoord_0 - _var1;
+ for ( int _var4 = 0; _var4 < 7; _var4++ )
+ {
+ _var1 = _var1 + _var2;
+ float4 _texLookup_16 = tex2D( _Sampler_00, _var1 );
+ float4 _var5 = _texLookup_16.rgba;
+ float _var6 = _texLookup_16.a;
+ _var5 = _var5 * g_cArray_305[_var4];
+ _var6 = ceil( _var6 );
+ _var0 = _var0 + _var5;
+ _var3 = _var3 + _var6;
+ }
+ float3 _var7 = _var0.xyz;
+ float _var8 = _var0.w;
+ _var7 = _var7 / _var3;
+ _var8 = _var8 / float( 7.000000 );
+ float4 _var9 = float4( _var7, _var8 );
+ Out.vColor_0 = _var9;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_y_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_y_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_7_half_aceil_y_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_x_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_x_ps30.fxc
new file mode 100644
index 0000000000..4ad623d05e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_x_ps30.fxc
@@ -0,0 +1,56 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// Arrays
+static const float g_cArray_332[3] =
+{
+ float( 0.196842f ),
+ float( 0.606316f ),
+ float( 0.196842f ),
+};
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = float2( 2.000000, 0.000000 ) * _g_TexelSize;
+ float2 _var2 = float2( 1.000000, 0.000000 ) * _g_TexelSize;
+ _var1 = In.vTexCoord_0 - _var1;
+ for ( int _var3 = 0; _var3 < 3; _var3++ )
+ {
+ _var1 = _var1 + _var2;
+ float4 _var4 = tex2D( _Sampler_00, _var1 ).rgba;
+ _var4 = _var4 * g_cArray_332[_var3];
+ _var0 = _var0 + _var4;
+ }
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_x_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_x_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_x_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_y_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_y_ps30.fxc
new file mode 100644
index 0000000000..8536cb69e9
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_y_ps30.fxc
@@ -0,0 +1,56 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// Arrays
+static const float g_cArray_351[3] =
+{
+ float( 0.196842f ),
+ float( 0.606316f ),
+ float( 0.196842f ),
+};
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = float2( 0.000000, 2.000000 ) * _g_TexelSize;
+ float2 _var2 = float2( 0.000000, 1.000000 ) * _g_TexelSize;
+ _var1 = In.vTexCoord_0 - _var1;
+ for ( int _var3 = 0; _var3 < 3; _var3++ )
+ {
+ _var1 = _var1 + _var2;
+ float4 _var4 = tex2D( _Sampler_00, _var1 ).rgba;
+ _var4 = _var4 * g_cArray_351[_var3];
+ _var0 = _var0 + _var4;
+ }
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_y_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_y_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/gauss_blur_half_3_y_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/intrinsic.h b/mp/game/momentum/shadereditorui/shader_src/intrinsic.h
new file mode 100644
index 0000000000..bb9ad3069e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/intrinsic.h
@@ -0,0 +1,260 @@
+// Absolute value (per component).
+auto abs( multi x );
+
+// Returns the arccosine of each component of x.
+auto acos( multi x );
+
+// Test if all components of x are nonzero.
+auto all( multi x );
+
+// Test if any component of x is nonzero.
+auto any( multi x );
+
+// Returns the arcsine of each component of x.
+auto asin( multi x );
+
+// Returns the arctangent of x.
+auto atan( multi x );
+
+// Returns the arctangent of of two values (x,y).
+auto atan2( multi x, auto y );
+
+// Returns the smallest integer which is greater than or equal to x.
+auto ceil( multi x );
+
+// Clamps x to the range [min, max].
+auto clamp( multi x, auto min, auto max );
+
+// Discards the current pixel, if any component of x is less than zero.
+auto clip( multi x );
+
+// Returns the cosine of x.
+auto cos( multi x );
+
+// Returns the hyperbolic cosine of x.
+auto cosh( multi x );
+
+// Returns the cross product of two 3D vectors.
+float3 cross( float3 x, float3 y );
+
+// Swizzles and scales components of the 4D vector xto compensate for the lack of UBYTE4 support in some hardware.
+int4 D3DCOLORtoUBYTE4( float4 x );
+
+// Returns the partial derivative of x with respect to the screen-space x-coordinate.
+auto ddx( multi x );
+
+// Returns the partial derivative of x with respect to the screen-space y-coordinate.
+auto ddy( multi x );
+
+// Converts x from radians to degrees.
+auto degrees( multi x );
+
+// Returns the determinant of the square matrix m.
+float determinant( matrix m );
+
+// Returns the distance between two points.
+float distance( vector x, vector y );
+
+// Returns the dot product of two vectors.
+float dot( vector x, vector y );
+
+// Returns the base-e exponent.
+auto exp( multi x );
+
+// Base 2 exponent (per component).
+auto exp2( multi x );
+
+// Returns -n * sign(dot(i, ng)).
+auto faceforward( vector n, auto i, auto ng );
+
+// Returns the greatest integer which is less than or equal to x.
+auto floor( multi x );
+
+// Returns the floating point remainder of x/y.
+auto fmod( multi x, auto y );
+
+// Returns the fractional part of x.
+auto frac( multi x );
+
+// Returns the mantissa and exponent of x.
+auto frexp( multi x, auto exp );
+
+// Returns abs(ddx(x)) + abs(ddy(x))
+auto fwidth( multi x );
+
+// Returns true if x is finite, false otherwise.
+bool isfinite( multi x );
+
+// Returns true if x is +INF or -INF, false otherwise.
+bool isinf( multi x );
+
+// Returns true if x is NAN or QNAN, false otherwise.
+bool isnan( multi x );
+
+// Returns x * 2exp
+auto ldexp( multi x, auto exp );
+
+// Returns the length of the vector v.
+float length( vector x );
+
+// Returns x + s(y - x).
+auto lerp( multi x, auto y, auto s );
+
+// Returns a lighting vector (ambient, diffuse, specular, 1)
+float4 lit( float n_dot_l, float n_dot_h, float m );
+
+// Returns the base-e logarithm of x.
+auto log( multi x );
+
+// Returns the base-10 logarithm of x.
+auto log10( multi x );
+
+// Returns the base-2 logarithm of x.
+auto log2( multi x );
+
+// Selects the greater of x and y.
+auto max( multi x, auto y );
+
+// Selects the lesser of x and y.
+auto min( multi x, auto y );
+
+// Splits the value x into fractional and integer parts.
+auto modf( multi x, out auto ip );
+
+// Performs matrix multiplication using x and y.
+multi mul( multi x, multi y );
+
+// Generates a random value using the Perlin-noise algorithm.
+float noise( vector x );
+
+// Returns a normalized vector.
+auto normalize( vector x );
+
+// Returns x^y
+auto pow( multi x, auto y );
+
+// Converts x from degrees to radians.
+auto radians( multi x );
+
+// Returns a reflection vector.
+auto reflect( vector i, auto n );
+
+// Returns the refraction vector.
+auto refract( vector i, auto n, float index );
+
+// Rounds x to the nearest integer.
+auto round( multi x );
+
+// Returns 1 / sqrt(x)
+auto rsqrt( multi x );
+
+// Clamps x to the range [0, 1]
+auto saturate( multi x );
+
+// Computes the sign of x.
+auto sign( multi x );
+
+// Returns the sine of x
+auto sin( multi x );
+
+// Returns the sine and cosine of x.
+void sincos( multi x, out auto s, out auto c );
+
+// Returns the hyperbolic sine of x
+auto sinh( multi x );
+
+// Returns a smooth Hermite interpolation between 0 and 1.
+auto smoothstep( auto min, auto max, multi x );
+
+// Square root (per component)
+auto sqrt( multi x );
+
+// Returns (x >= y) ? 1 : 0
+auto step( multi y, auto x );
+
+// Returns the tangent of x
+auto tan( multi x );
+
+// Returns the hyperbolic tangent of x
+auto tanh( multi x );
+
+// Returns the transpose of the matrix m.
+matrix transpose( matrix x );
+
+// Truncates floating-point value(s) to integer value(s)
+auto trunc( multi x );
+
+// 1D texture lookup.
+float4 tex1D( sampler s, float t );
+
+// 1D texture lookup.
+float4 tex1D( sampler s, float t, float ddx, float ddy );
+
+// 1D texture lookup with bias.
+float4 tex1Dbias( sampler s, float4 t );
+
+// 1D texture lookup with a gradient.
+float4 tex1Dgrad( sampler s, float t, float ddx, float ddy );
+
+// 1D texture lookup with LOD.
+float4 tex1Dlod( sampler s, float4 t );
+
+// 1D texture lookup with projective divide.
+float4 tex1Dproj( sampler s, float4 t );
+
+
+// 2D texture lookup.
+float4 tex2D( sampler s, float2 t );
+
+// 2D texture lookup.
+float4 tex2D( sampler s, float2 t, float2 ddx, float2 ddy );
+
+// 2D texture lookup with bias.
+float4 tex2Dbias( sampler s, float4 t );
+
+// 2D texture lookup with a gradient.
+float4 tex2Dgrad( sampler s, float2 t, float2 ddx, float2 ddy );
+
+// 2D texture lookup with LOD.
+float4 tex2Dlod( sampler s, float4 t );
+
+// 2D texture lookup with projective divide.
+float4 tex2Dproj( sampler s, float4 t );
+
+
+// 3D texture lookup.
+float4 tex3D( sampler s, float3 t );
+
+// 3D texture lookup.
+float4 tex3D( sampler s, float3 t, float3 ddx, float3 ddy );
+
+// 3D texture lookup with bias.
+float4 tex3Dbias( sampler s, float4 t );
+
+// 3D texture lookup with a gradient.
+float4 tex3Dgrad( sampler s, float3 t, float3 ddx, float3 ddy );
+
+// 3D texture lookup with LOD.
+float4 tex3Dlod( sampler s, float4 t );
+
+// 3D texture lookup with projective divide.
+float4 tex3Dproj( sampler s, float4 t );
+
+
+// Cube texture lookup.
+float4 texCUBE( sampler s, float3 t );
+
+// Cube texture lookup.
+float4 texCUBE( sampler s, float3 t, float3 ddx, float3 ddy );
+
+// Cube texture lookup with bias.
+float4 texCUBEbias( sampler s, float4 t );
+
+// Cube texture lookup with a gradient.
+float4 texCUBEgrad( sampler s, float3 t, float3 ddx, float3 ddy );
+
+// Cube texture lookup with LOD.
+float4 texCUBElod( sampler s, float4 t );
+
+// Cube texture lookup with projective divide.
+float4 texCUBEproj( sampler s, float4 t );
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/lightmap_blend_bump_detail_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/lightmap_blend_bump_detail_ps30.fxc
new file mode 100644
index 0000000000..668eecbde9
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/lightmap_blend_bump_detail_ps30.fxc
@@ -0,0 +1,188 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Combos
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// DYNAMIC: "FLASHLIGHT" "0..1"
+// DYNAMIC: "FLASHLIGHTDEPTHFILTERMODE" "0..2"
+// DYNAMIC: "FLASHLIGHTSHADOWS" "0..1"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+sampler _Sampler_02 : register( s2 );
+sampler _Sampler_03 : register( s3 );
+sampler _Sampler_04 : register( s4 );
+sampler _Sampler_05 : register( s5 );
+sampler _Sampler_06 : register( s6 );
+sampler _Sampler_07 : register( s7 );
+sampler _Sampler_08 : register( s8 );
+sampler _Sampler_09 : register( s9 );
+sampler _Sampler_10 : register( s10 );
+sampler _gSampler_Flashlight_Cookie : register( s11 );
+sampler _gSampler_Flashlight_Depth : register( s12 );
+sampler _gSampler_Flashlight_Random : register( s13 );
+
+// Constants
+const float4x4 g_cFlashlightWorldToTexture : register( c12 );
+const float2 g_cData_base_detail_0_smoothing : register( c16 ); // Static
+const float2 g_cData_base_detail_1_smoothing : register( c17 ); // Static
+const float3 _g_VecOrig : register( c18 );
+const float4 _g_FogParams : register( c19 );
+const float4 g_cFlashlightAttenuationFactors : register( c8 );
+const float4 g_cFlashlightPos : register( c9 );
+const float4 g_cShadowTweaks : register( c7 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float4 vTexCoord_0 : TEXCOORD0;
+ float4 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float3 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+ float3 vTexCoord_6 : TEXCOORD6;
+ float2 vTexCoord_7 : TEXCOORD7;
+ float4 vColor_0 : COLOR0;
+ float4 vColor_1 : COLOR1;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float3 _var0 = float3( 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = In.vTexCoord_0.xy;
+ float2 _var2 = In.vTexCoord_4.zw;
+ float _var3 = In.vColor_1.w;
+ float2 _var4 = In.vTexCoord_0.zw;
+ float2 _var5 = In.vTexCoord_4.xy;
+ float _var6 = g_cData_base_detail_0_smoothing.x;
+ float _var7 = g_cData_base_detail_0_smoothing.y;
+ float2 _var8 = In.vTexCoord_7.xy;
+ float _var9 = g_cData_base_detail_1_smoothing.x;
+ float _var10 = g_cData_base_detail_1_smoothing.y;
+ float3 _var11 = float3( 0.000000, 0.000000, 0.000000 );
+ float _var12 = _g_VecOrig.z;
+ float _var13 = In.vTexCoord_3.z;
+ float _var14 = In.vColor_0.z;
+ float4 _texLookup_48 = tex2D( _Sampler_00, _var1 );
+ float3 _var15 = _texLookup_48.rgb;
+ float _var16 = _texLookup_48.b;
+ float3 _var17 = tex2D( _Sampler_01, _var2 ).rgb;
+ float4 _texLookup_51 = tex2D( _Sampler_02, _var1 );
+ float3 _var18 = _texLookup_51.rgb;
+ float _var19 = _texLookup_51.b;
+ float3 _var20 = tex2D( _Sampler_03, _var2 ).rgb;
+ float4 _texLookup_54 = tex2D( _Sampler_04, _var4 );
+ float _var21 = _texLookup_54.r;
+ float _var22 = _texLookup_54.g;
+ float3 _var23 = tex2D( _Sampler_05, _var1 ).rgb;
+ float3 _var24 = tex2D( _Sampler_06, _var8 ).rgb;
+ float4 _texLookup_58 = tex2D( _Sampler_07, _var1 );
+ float3 _var25 = _texLookup_58.rgb;
+ float _var26 = _texLookup_58.g;
+ float3 _var27 = tex2D( _Sampler_08, _var8 ).rgb;
+ _var12 = CalcPixelFogFactor( PIXELFOGTYPE, _g_FogParams, _var12, _var13, _var14 );
+ float2 _var28 = _var15.xy;
+ float2 _var29 = _var17.xy;
+ float2 _var30 = _var18.xy;
+ float2 _var31 = _var20.xy;
+ _var21 = min( _var3, _var21 );
+ _var22 = max( _var3, _var22 );
+ _var24 = smoothstep( _var6, _var7, _var24 );
+ _var27 = smoothstep( _var9, _var10, _var27 );
+ _var29 = _var29 - float( 0.500000 );
+ _var31 = _var31 - float( 0.500000 );
+ _var21 = lerp( _var21, _var22, _var3 );
+ _var23 = _var23 * _var24;
+ _var25 = _var25 * _var27;
+ _var28 = _var28 + _var29;
+ _var30 = _var30 + _var31;
+ _var21 = smoothstep( float( 0.400000 ), float( 0.600000 ), _var21 );
+ _var28 = saturate( _var28 );
+ _var30 = saturate( _var30 );
+ _var23 = lerp( _var23, _var25, _var21 );
+ _var26 = _var26 * _var21;
+ float3 _var32 = float3( _var28, _var16 );
+ float3 _var33 = float3( _var30, _var19 );
+ _var32 = lerp( _var32, _var33, _var21 );
+ _var32 = _var32 * float( 2.000000 );
+ _var32 = _var32 - float( 1.000000 );
+#if ( FLASHLIGHT == 0 )
+ float2 _var34 = In.vTexCoord_1.xy;
+ float _var35 = dot( _var32, bumpBasis[0] );
+ float _var36 = dot( _var32, bumpBasis[1] );
+ float _var37 = dot( _var32, bumpBasis[2] );
+ float2 _var38 = In.vTexCoord_1.zw;
+ float3 _var39 = tex2D( _Sampler_09, _var5 ).rgb;
+ float3 _var40 = In.vTexCoord_3 - _g_VecOrig;
+ float3 _var41 = lerp( _var32, In.vTexCoord_2, float( 0.900000 ) );
+ float3 _var42 = tex2D( _Sampler_09, _var34 ).rgb;
+ float2 _var43 = float2( _var35, _var36 );
+ float3 _var44 = tex2D( _Sampler_09, _var38 ).rgb;
+ _var40 = reflect( _var40, _var41 );
+ float3 _var45 = float3( _var43, _var37 );
+ float3 _var46 = texCUBE( _Sampler_10, _var40 ).rgb;
+ _var45 = saturate( _var45 );
+ _var46 = _var46 * float( 0.040000 );
+ _var45 = _var45 * _var45;
+ _var46 = _var46 * ENV_MAP_SCALE;
+ float _var47 = _var45.x;
+ float _var48 = _var45.y;
+ float _var49 = _var45.z;
+ float _var50 = dot( float3( float( 1.000000 ), float( 1.000000 ), float( 1.000000 ) ), _var45 );
+ _var11 = _var46;
+ _var42 = _var42 * _var47;
+ _var44 = _var44 * _var48;
+ _var39 = _var39 * _var49;
+ _var50 = LIGHT_MAP_SCALE / _var50;
+ _var42 = _var42 + _var44;
+ _var42 = _var42 + _var39;
+ _var42 = _var42 * _var50;
+ _var0 = _var42;
+#endif
+#if ( FLASHLIGHT == 1 )
+ float3x3 _var51 = { In.vTexCoord_5,
+ In.vTexCoord_6,
+ In.vTexCoord_2 };
+ float4 _var52 = mul( float4(In.vTexCoord_3.xyz,1), g_cFlashlightWorldToTexture );
+ float2 _var53 = In.vColor_0.xy;
+ float _var54 = In.vColor_0.w;
+ float3 _var55 = mul( _var32, _var51 );
+ _var53 = _var53 / _var54;
+ _var55 = normalize( _var55 );
+ _var53 = _var53 * float( 0.500000 );
+ _var53 = _var53 + float( 0.500000 );
+ _var55 = DoFlashlight( g_cFlashlightPos.xyz, In.vTexCoord_3, _var52, _var55,
+ g_cFlashlightAttenuationFactors.xyz, g_cFlashlightAttenuationFactors.w,
+ _gSampler_Flashlight_Cookie, _gSampler_Flashlight_Depth, _gSampler_Flashlight_Random,
+ FLASHLIGHTDEPTHFILTERMODE, FLASHLIGHTSHADOWS, true,
+ _var53, false, g_cShadowTweaks );
+ _var0 = _var55;
+#endif
+ _var0 = _var0;
+ _var11 = _var11 * _var26;
+ _var0 = _var0 * _var23;
+ _var0 = _var0 + _var11;
+ float4 _var56 = float4( _var0.x, _var0.y, _var0.z, 1.000000 );
+ _var56 = FinalOutput( _var56, _var12, PIXELFOGTYPE, TONEMAP_SCALE_LINEAR, true, _var14 );
+ Out.vColor_0 = _var56;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/lightmap_blend_bump_detail_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/lightmap_blend_bump_detail_vs30.fxc
new file mode 100644
index 0000000000..692e25f5e9
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/lightmap_blend_bump_detail_vs30.fxc
@@ -0,0 +1,82 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float3 vNormal : NORMAL;
+ float3 vTangent_S : TANGENT;
+ float3 vTangent_T : BINORMAL;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float2 vTexCoord_1 : TEXCOORD1;
+ float2 vTexCoord_2 : TEXCOORD2;
+ float4 vColor_0 : COLOR0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float4 vTexCoord_0 : TEXCOORD0;
+ float4 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float3 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+ float3 vTexCoord_6 : TEXCOORD6;
+ float2 vTexCoord_7 : TEXCOORD7;
+ float4 vColor_0 : COLOR0;
+ float4 vColor_1 : COLOR1;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float3 _var0 = mul( float4(In.vPos.xyz,1), cModel[0] );
+ float2 _var1 = In.vTexCoord_0 * float( 1.000000 );
+ float2 _var2 = In.vTexCoord_0 * float( 0.120000 );
+ float2 _var3 = In.vTexCoord_1 + In.vTexCoord_2;
+ float3 _var4 = mul( float4(In.vNormal.xyz,1), cModel[0] );
+ float2 _var5 = In.vTexCoord_0 * float2( 5.000000, 5.000000 );
+ float3 _var6 = mul( float4(In.vTangent_S.xyz,1), cModel[0] );
+ float3 _var7 = mul( float4(In.vTangent_T.xyz,1), cModel[0] );
+ float2 _var8;
+ {
+ float2 center_def = float2( 0.5f, 0.5f );
+ float2 trans_def = float2( 0.0f, 0.0f );
+ float fs = sin( float( 45.000000 ) );
+ float fc = cos( float( 45.000000 ) );
+ float4 row_0 = float4( fc * float2( 4.000000, 4.000000 ).x, -fs * float2( 4.000000, 4.000000 ).x, 0, ( -center_def.x * fc + center_def.y * fs ) * float2( 4.000000, 4.000000 ).x + center_def.x + trans_def.x );
+ float4 row_1 = float4( fs * float2( 4.000000, 4.000000 ).y, fc * float2( 4.000000, 4.000000 ).y, 0, ( -center_def.x * fs - center_def.y * fc ) * float2( 4.000000, 4.000000 ).y + center_def.y + trans_def.y );
+ _var8.x = dot( float4( In.vTexCoord_0, 0, 1 ), row_0 );
+ _var8.y = dot( float4( In.vTexCoord_0, 0, 1 ), row_1 );
+ }
+ float4 _var9 = mul( float4(_var0.xyz,1), cViewProj );
+ float4 _var10 = float4( _var1, _var2 );
+ float2 _var11 = _var3 + In.vTexCoord_2;
+ _var4 = normalize( _var4 );
+ _var6 = normalize( _var6 );
+ _var7 = normalize( _var7 );
+ float4 _var12 = float4( _var3, _var11 );
+ float2 _var13 = _var11 + In.vTexCoord_2;
+ float4 _var14 = float4( _var13, _var5 );
+ Out.vProjPos = _var9;
+ Out.vTexCoord_0 = _var10;
+ Out.vTexCoord_1 = _var12;
+ Out.vTexCoord_2 = _var4;
+ Out.vTexCoord_3 = _var0;
+ Out.vTexCoord_4 = _var14;
+ Out.vTexCoord_5 = _var6;
+ Out.vTexCoord_6 = _var7;
+ Out.vTexCoord_7 = _var8;
+ Out.vColor_0 = _var9;
+ Out.vColor_1 = In.vColor_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/lightmap_parallax_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/lightmap_parallax_ps30.fxc
new file mode 100644
index 0000000000..e750404ab7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/lightmap_parallax_ps30.fxc
@@ -0,0 +1,179 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Combos
+// DYNAMIC: "FLASHLIGHT" "0..1"
+// DYNAMIC: "FLASHLIGHTSHADOWS" "0..1"
+// DYNAMIC: "FLASHLIGHTDEPTHFILTERMODE" "0..2"
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+sampler _Sampler_02 : register( s2 );
+sampler _Sampler_03 : register( s3 );
+sampler _gSampler_Flashlight_Cookie : register( s4 );
+sampler _gSampler_Flashlight_Depth : register( s5 );
+sampler _gSampler_Flashlight_Random : register( s6 );
+
+// Constants
+const float3 _g_VecOrig : register( c16 );
+const float g_cData_parallax_geo_height : register( c17 ); // Static
+const float4x4 g_cFlashlightWorldToTexture : register( c12 );
+const float4x4 g_cCMatrix_ViewProj : register( c18 );
+const float4 g_cFlashlightAttenuationFactors : register( c8 );
+const float4 g_cFlashlightPos : register( c9 );
+const float4 g_cShadowTweaks : register( c7 );
+const float4 _g_FogParams : register( c22 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+ float4 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float3 vTexCoord_3 : TEXCOORD3;
+ float2 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+ float3 vTexCoord_6 : TEXCOORD6;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+ float vDepth : DEPTH;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float3 _var0 = float3( 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = float2( 0.000000, 0.000000 );
+ float3x3 _var2 = { In.vTexCoord_5,
+ In.vTexCoord_6,
+ In.vTexCoord_2 };
+ float3 _var3 = In.vTexCoord_3 - _g_VecOrig;
+ float3 _var4 = _g_VecOrig - In.vTexCoord_3;
+ float3 _var5 = float3( 0.000000, 0.000000, 0.000000 );
+ float _var6 = _g_VecOrig.z;
+ _var3 = mul( _var2, _var3 );
+#if ( FLASHLIGHT == 0 )
+ float3 _var8 = (float3)0;
+ float2 _var7 = CalcParallaxUV_Relief( In.vTexCoord_0, _var3, g_cData_parallax_geo_height, In.vTexCoord_2, _var4,
+ _Sampler_00, 10, 30, 5, In.vTexCoord_3,
+ _var8, true, true );
+ _var5 = _var8;
+ _var1 = _var7;
+#endif
+#if ( FLASHLIGHT == 1 )
+ float3 _var10 = (float3)0;
+ float2 _var9 = CalcParallaxUV_Relief( In.vTexCoord_0, _var3, g_cData_parallax_geo_height, In.vTexCoord_2, _var4,
+ _Sampler_00, 8, 15, 5, In.vTexCoord_3,
+ _var10, false, true );
+ _var10 = _var10 * float( 0.900000 );
+ _var1 = _var9;
+ _var5 = _var10;
+#endif
+ _var1 = _var1;
+ _var5 = _var5;
+ float3 _var11 = tex2D( _Sampler_01, _var1 ).rgb;
+ float _var12 = _var5.x;
+ float _var13 = _var5.y;
+ float _var14 = _var5.z;
+ float3 _var15 = tex2D( _Sampler_02, _var1 ).rgb;
+ _var11 = _var11 * float( 2.000000 );
+ float3 _var16 = _var12 * In.vTexCoord_5;
+ float3 _var17 = _var13 * In.vTexCoord_6;
+ float _var18 = _var14 * g_cData_parallax_geo_height;
+ float _var19 = 1.0f - _var14;
+ _var11 = _var11 - float( 1.000000 );
+ _var16 = _var16 + _var17;
+ float3 _var20 = _var18 * In.vTexCoord_2;
+ _var19 = _var19 * _var19;
+#if ( FLASHLIGHT == 0 )
+ float2 _var21 = In.vTexCoord_1.xy;
+ float _var22 = dot( _var11, bumpBasis[0] );
+ float _var23 = dot( _var11, bumpBasis[1] );
+ float _var24 = dot( _var11, bumpBasis[2] );
+ float2 _var25 = In.vTexCoord_1.zw;
+ float3 _var26 = tex2D( _Sampler_03, In.vTexCoord_4 ).rgb;
+ float3 _var27 = tex2D( _Sampler_03, _var21 ).rgb;
+ _var22 = saturate( _var22 );
+ _var23 = saturate( _var23 );
+ _var24 = saturate( _var24 );
+ float3 _var28 = tex2D( _Sampler_03, _var25 ).rgb;
+ float2 _var29 = float2( _var22, _var23 );
+ float3 _var30 = float3( _var29, _var24 );
+ _var30 = _var30 * _var30;
+ float _var31 = _var30.x;
+ float _var32 = _var30.y;
+ float _var33 = _var30.z;
+ float _var34 = dot( float3( float( 1.000000 ), float( 1.000000 ), float( 1.000000 ) ), _var30 );
+ _var27 = _var27 * _var31;
+ _var28 = _var28 * _var32;
+ _var26 = _var26 * _var33;
+ _var34 = LIGHT_MAP_SCALE / _var34;
+ _var27 = _var27 + _var28;
+ _var27 = _var27 + _var26;
+ _var27 = _var27 * _var34;
+ _var0 = _var27;
+#endif
+ _var16 = _var16 + _var20;
+ _var15 = _var15 * _var19;
+ _var16 = In.vTexCoord_3 - _var16;
+ float4 _var35 = mul( float4(_var16.xyz,1), g_cCMatrix_ViewProj );
+ float _var36 = _var16.z;
+#if ( FLASHLIGHT == 1 )
+ float3 _var37 = mul( _var11, _var2 );
+ float4 _var38 = mul( float4(_var16.xyz,1), g_cFlashlightWorldToTexture );
+ float2 _var39 = _var35.xy;
+ float _var40 = _var35.w;
+ _var37 = normalize( _var37 );
+ _var39 = _var39 / _var40;
+ _var39 = _var39 * float( 0.500000 );
+ _var39 = _var39 + float( 0.500000 );
+ _var37 = DoFlashlight( g_cFlashlightPos.xyz, _var16, _var38, _var37,
+ g_cFlashlightAttenuationFactors.xyz, g_cFlashlightAttenuationFactors.w,
+ _gSampler_Flashlight_Cookie, _gSampler_Flashlight_Depth, _gSampler_Flashlight_Random,
+ FLASHLIGHTDEPTHFILTERMODE, FLASHLIGHTSHADOWS, true,
+ _var39, false, g_cShadowTweaks );
+ float3 _var41 = _var37;
+#if ( FLASHLIGHTSHADOWS == 1 )
+ float _var42 = dot( float3( float( 1.000000 ), float( 1.000000 ), float( 1.000000 ) ), _var37 );
+ if ( _var42 > float( 0.010000 ) )
+ {
+ float3 _var43 = _var16 - float3( g_cFlashlightPos.xyz );
+ _var43 = mul( _var2, _var43 );
+ _var43 = normalize( _var43 );
+ float _var44 = CalcParallaxedShadows_OneLight( In.vTexCoord_0, _var1, _var43,
+ In.vTexCoord_3, g_cData_parallax_geo_height, float( 1.000000 ), _Sampler_00 );
+ _var41 = _var41 * _var44;
+ }
+#endif
+ _var0 = _var41;
+#endif
+ _var0 = _var0;
+ float _var45 = _var35.z;
+ float _var46 = _var35.z;
+ float _var47 = _var35.w;
+ _var0 = _var0 * _var15;
+ _var6 = CalcPixelFogFactor( PIXELFOGTYPE, _g_FogParams, _var6, _var36, _var45 );
+ _var46 = _var46 / _var47;
+ float4 _var48 = float4( _var0.x, _var0.y, _var0.z, 1.000000 );
+ _var46 = saturate( _var46 );
+ _var48 = FinalOutput( _var48, _var6, PIXELFOGTYPE, TONEMAP_SCALE_LINEAR, true, _var45 );
+ Out.vColor_0 = _var48;
+ Out.vDepth = _var46;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/lightmap_parallax_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/lightmap_parallax_vs30.fxc
new file mode 100644
index 0000000000..8bff40552d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/lightmap_parallax_vs30.fxc
@@ -0,0 +1,64 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Constants
+const float g_cData_parallax_geo_height : register( c48 ); // Static
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float3 vNormal : NORMAL;
+ float3 vTangent_S : TANGENT;
+ float3 vTangent_T : BINORMAL;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float2 vTexCoord_1 : TEXCOORD1;
+ float2 vTexCoord_2 : TEXCOORD2;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float4 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float3 vTexCoord_3 : TEXCOORD3;
+ float2 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+ float3 vTexCoord_6 : TEXCOORD6;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float3 _var0 = mul( float4(In.vPos.xyz,1), cModel[0] );
+ float3 _var1 = mul( float4(In.vNormal.xyz,1), cModel[0] );
+ float2 _var2 = In.vTexCoord_1 + In.vTexCoord_2;
+ float3 _var3 = mul( float4(In.vTangent_S.xyz,1), cModel[0] );
+ float3 _var4 = mul( float4(In.vTangent_T.xyz,1), cModel[0] );
+ _var1 = normalize( _var1 );
+ float2 _var5 = _var2 + In.vTexCoord_2;
+ _var3 = normalize( _var3 );
+ _var4 = normalize( _var4 );
+ float3 _var6 = _var1 * g_cData_parallax_geo_height;
+ float4 _var7 = float4( _var2, _var5 );
+ float2 _var8 = _var5 + In.vTexCoord_2;
+ _var0 = _var0 + _var6;
+ float4 _var9 = mul( float4(_var0.xyz,1), cViewProj );
+ Out.vProjPos = _var9;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ Out.vTexCoord_1 = _var7;
+ Out.vTexCoord_2 = _var1;
+ Out.vTexCoord_3 = _var0;
+ Out.vTexCoord_4 = _var8;
+ Out.vTexCoord_5 = _var3;
+ Out.vTexCoord_6 = _var4;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_chromatic_aberration_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_chromatic_aberration_ps30.fxc
new file mode 100644
index 0000000000..ab3789b9d1
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_chromatic_aberration_ps30.fxc
@@ -0,0 +1,101 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+sampler _Sampler_02 : register( s2 );
+
+// Constants
+const float4x4 g_cCMatrix_ViewProj : register( c16 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float3 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float2 _var0 = In.vTexCoord_3.xy;
+ float _var1 = In.vTexCoord_3.w;
+ float3 _var2 = tex2D( _Sampler_00, In.vTexCoord_0 ).rgb;
+ float3x3 _var3 = { In.vTexCoord_4,
+ In.vTexCoord_5,
+ In.vTexCoord_1 };
+ float3 _var4 = normalize( In.vTexCoord_2 );
+ float _var5 = In.vTexCoord_3.z;
+ _var0 = _var0 / _var1;
+ _var2 = lerp( _var2, float3( 0.500000, 0.500000, 1.000000 ), float( 0.500000 ) );
+ _var5 = smoothstep( float( 1.000000 ), float( 2.500000 ), _var5 );
+ _var0 = _var0 * float2( 0.500000, -0.500000 );
+ _var2 = _var2 * float( 2.000000 );
+ _var5 = float( 0.800000 ) * _var5;
+ _var0 = _var0 + float( 0.500000 );
+ _var2 = _var2 - float( 1.000000 );
+ _var2 = mul( _var2, _var3 );
+ _var2 = normalize( _var2 );
+ float3 _var6 = mul( float4(_var2.xyz,1), (float3x3)g_cCMatrix_ViewProj );
+ float _var7 = dot( _var2, _var4 );
+ float3 _var8 = reflect( _var4, _var2 );
+ float2 _var9 = _var6.xy;
+ float _var10 = smoothstep( float( -0.050000 ), float( -0.100000 ), _var7 );
+ float _var11 = abs( _var7 );
+ float _var12 = smoothstep( float( -1.000000 ), float( 0.000000 ), _var7 );
+ float3 _var13 = texCUBE( _Sampler_01, _var8 ).rgb;
+ float _var14 = smoothstep( float( -1.000000 ), float( -0.500000 ), _var7 );
+ float _var15 = smoothstep( float( 0.100000 ), float( -0.500000 ), _var7 );
+ _var9 = _var9 * _var10;
+ _var11 = 1.0f - _var11;
+ float _var16 = pow( _var12, float( 2.000000 ) );
+ _var13 = _var13 * ENV_MAP_SCALE;
+ _var14 = min( _var14, _var15 );
+ float _var17 = pow( _var12, float( 20.000000 ) );
+ _var9 = _var9 * float2( 1.000000, -1.000000 );
+ _var11 = _var11 * float( 0.100000 );
+ float3 _var18 = lerp( float( 1.000000 ), float3( 0.830000, 0.867400, 1.000000 ), _var16 );
+ _var14 = _var14 * float( 0.500000 );
+ _var17 = _var17 * float( 0.300000 );
+ float _var19 = float( 0.005000 ) + _var11;
+ float _var20 = float( 0.010000 ) + _var11;
+ float _var21 = float( 0.015000 ) + _var11;
+ float2 _var22 = _var9 * _var19;
+ float2 _var23 = _var9 * _var20;
+ float2 _var24 = _var9 * _var21;
+ _var22 = _var0 - _var22;
+ _var23 = _var0 - _var23;
+ _var24 = _var0 - _var24;
+ float _var25 = tex2D( _Sampler_02, _var22 ).r;
+ float _var26 = tex2D( _Sampler_02, _var23 ).g;
+ float _var27 = tex2D( _Sampler_02, _var24 ).b;
+ float2 _var28 = float2( _var25, _var26 );
+ float3 _var29 = float3( _var28, _var27 );
+ _var29 = _var29 * _var18;
+ _var29 = lerp( _var29, _var13, _var14 );
+ _var29 = lerp( _var29, float( 1.000000 ), _var17 );
+ float4 _var30 = float4( _var29, _var5 );
+ Out.vColor_0 = _var30;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_chromatic_aberration_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_chromatic_aberration_vs30.fxc
new file mode 100644
index 0000000000..46ce7c9e06
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_chromatic_aberration_vs30.fxc
@@ -0,0 +1,65 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+// Combos
+// DYNAMIC: "COMPRESSED_VERTS" "0..1"
+// DYNAMIC: "SKINNING" "0..1"
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Constants
+const float3 _g_VecOrig : register( c48 );
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float4 vBoneWeights : BLENDWEIGHT;
+ float4 vBoneIndices : BLENDINDICES;
+ float4 vNormal : NORMAL;
+ float4 vTangent_S : TANGENT;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float3 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float3 _var0 = (float3)0;
+ float4 _var1 = (float4)0;
+ DecompressVertex_NormalTangent( In.vNormal, In.vTangent_S, _var0, _var1 );
+ float3 _var2 = (float3)0;
+ float3 _var3 = (float3)0;
+ float3 _var4 = (float3)0;
+ float3 _var5 = (float3)0;
+ SkinPositionNormalAndTangentSpace( SKINNING, float4( In.vPos, 1 ), _var0, _var1,
+ In.vBoneWeights, In.vBoneIndices,
+ _var2, _var3, _var4, _var5 );
+ float4 _var6 = mul( float4(_var2.xyz,1), cViewProj );
+ _var3 = normalize( _var3 );
+ float3 _var7 = _var2 - _g_VecOrig;
+ _var4 = normalize( _var4 );
+ _var5 = normalize( _var5 );
+ Out.vProjPos = _var6;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ Out.vTexCoord_1 = _var3;
+ Out.vTexCoord_2 = _var7;
+ Out.vTexCoord_3 = _var6;
+ Out.vTexCoord_4 = _var4;
+ Out.vTexCoord_5 = _var5;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_cubemap_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_cubemap_ps30.fxc
new file mode 100644
index 0000000000..1e89098d8a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_cubemap_ps30.fxc
@@ -0,0 +1,41 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Combos
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float3 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float3 _var0 = reflect( In.vTexCoord_0, In.vTexCoord_1 );
+ float4 _var1 = texCUBE( _Sampler_00, _var0 ).rgba;
+ _var1 = FinalOutput( _var1, float( 0.000000 ), PIXELFOGTYPE, TONEMAP_SCALE_LINEAR, true, float( 0.000000 ) );
+ Out.vColor_0 = _var1;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_cubemap_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_cubemap_vs30.fxc
new file mode 100644
index 0000000000..ba65e96cdf
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_cubemap_vs30.fxc
@@ -0,0 +1,50 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+// Combos
+// DYNAMIC: "COMPRESSED_VERTS" "0..1"
+// DYNAMIC: "SKINNING" "0..1"
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Constants
+const float3 _g_VecOrig : register( c48 );
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float4 vBoneWeights : BLENDWEIGHT;
+ float4 vBoneIndices : BLENDINDICES;
+ float4 vNormal : NORMAL;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float3 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float3 _var0 = (float3)0;
+ DecompressVertex_Normal( In.vNormal, _var0 );
+ float3 _var1 = (float3)0;
+ float3 _var2 = (float3)0;
+ SkinPositionAndNormal( SKINNING, float4( In.vPos, 1 ), _var0,
+ In.vBoneWeights, In.vBoneIndices,
+ _var1, _var2 );
+ float4 _var3 = mul( float4(_var1.xyz,1), cViewProj );
+ float3 _var4 = _var1 - _g_VecOrig;
+ _var4 = normalize( _var4 );
+ Out.vProjPos = _var3;
+ Out.vTexCoord_0 = _var4;
+ Out.vTexCoord_1 = _var2;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_litsphere_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_litsphere_ps30.fxc
new file mode 100644
index 0000000000..6f7aa0ab0a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_litsphere_ps30.fxc
@@ -0,0 +1,99 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Combos
+// STATIC: "FLASHLIGHT" "0..1"
+// DYNAMIC: "FLASHLIGHTDEPTHFILTERMODE" "0..2"
+// DYNAMIC: "FLASHLIGHTSHADOWS" "0..1"
+// DYNAMIC: "NUM_LIGHTS" "0..4"
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _gSampler_Flashlight_Cookie : register( s1 );
+sampler _gSampler_Flashlight_Depth : register( s2 );
+sampler _gSampler_Flashlight_Random : register( s3 );
+sampler _Sampler_04 : register( s4 );
+
+// Constants
+const float4x3 g_cCMatrix_View : register( c16 );
+const float4 _g_FogParams : register( c19 );
+const float3 _g_VecOrig : register( c20 );
+const float4 g_cFlashlightAttenuationFactors : register( c8 );
+const float4 g_cFlashlightPos : register( c9 );
+const float4 g_cShadowTweaks : register( c7 );
+const float3 g_cAmbientCube[6] : register( c0 );
+PixelShaderLightInfo g_cLightInfo[3] : register( c6 );
+
+// Arrays
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float4 vColor_0 : COLOR0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _texLookup_12 = tex2D( _Sampler_00, In.vTexCoord_0 );
+ float3 _var0 = _texLookup_12.rgb;
+ float _var1 = _texLookup_12.a;
+ float3 _var2 = float3( 0.000000, 0.000000, 0.000000 );
+ float3 _var3 = mul( float4(In.vTexCoord_2.xyz,1), (float3x3)g_cCMatrix_View );
+ float _var4 = _g_VecOrig.z;
+ float _var5 = In.vTexCoord_1.z;
+ float _var6 = In.vTexCoord_3.z;
+#if ( FLASHLIGHT == 1 )
+ float2 _var7 = In.vTexCoord_3.xy;
+ float _var8 = In.vTexCoord_3.w;
+ _var7 = _var7 / _var8;
+ float3 _var9 = DoFlashlight( g_cFlashlightPos.xyz, In.vTexCoord_1, In.vTexCoord_4, In.vTexCoord_2,
+ g_cFlashlightAttenuationFactors.xyz, g_cFlashlightAttenuationFactors.w,
+ _gSampler_Flashlight_Cookie, _gSampler_Flashlight_Depth, _gSampler_Flashlight_Random,
+ FLASHLIGHTDEPTHFILTERMODE, FLASHLIGHTSHADOWS, true,
+ _var7, false, g_cShadowTweaks );
+ _var2 = _var9;
+#endif
+#if ( FLASHLIGHT == 0 )
+ float3 _var10 = PixelShaderDoLighting( In.vTexCoord_1, In.vTexCoord_2, float3(0,0,0),
+ false, true, In.vColor_0,
+ g_cAmbientCube, NUM_LIGHTS, g_cLightInfo,
+ false, false, 1.0f );
+ _var2 = _var10;
+#endif
+ _var2 = _var2;
+ float2 _var11 = _var3.xy;
+ _var4 = CalcPixelFogFactor( PIXELFOGTYPE, _g_FogParams, _var4, _var5, _var6 );
+ _var11 = _var11 * float2( 1.000000, -1.000000 );
+ _var11 = _var11 * float( 0.500000 );
+ _var11 = _var11 + float( 0.500000 );
+ float3 _var12 = tex2D( _Sampler_04, _var11 ).rgb;
+ _var2 = _var2 + _var12;
+ _var0 = _var0 * _var2;
+ float4 _var13 = float4( _var0, _var1 );
+ _var13 = FinalOutput( _var13, _var4, PIXELFOGTYPE, TONEMAP_SCALE_LINEAR, true, _var6 );
+ Out.vColor_0 = _var13;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_litsphere_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_litsphere_vs30.fxc
new file mode 100644
index 0000000000..d4166e5ec5
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_litsphere_vs30.fxc
@@ -0,0 +1,71 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Combos
+// DYNAMIC: "SKINNING" "0..1"
+// STATIC: "FLASHLIGHT" "0..1"
+
+// Samplers
+
+// Constants
+const float4x4 g_cFlashlightWorldToTexture : register( c48 );
+
+// Arrays
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float4 vBoneWeights : BLENDWEIGHT;
+ float4 vBoneIndices : BLENDINDICES;
+ float3 vNormal : NORMAL;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float4 vTexCoord_5 : TEXCOORD5;
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float3 _var0 = (float3)0;
+ float3 _var1 = (float3)0;
+ SkinPositionAndNormal( SKINNING, float4( In.vPos, 1 ), In.vNormal,
+ In.vBoneWeights, In.vBoneIndices,
+ _var0, _var1 );
+ float4 _var2 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float4 _var3 = mul( float4(_var0.xyz,1), cViewProj );
+#if ( FLASHLIGHT == 1 )
+ float4 _var4 = mul( float4(_var0.xyz,1), g_cFlashlightWorldToTexture );
+ _var2 = _var4;
+#endif
+ float4 _var5 = mul( float4(_var1.xyz,1), cViewProj );
+ float4 _var6 = float4( GetVertexAttenForLight( _var0, 0 ),
+ GetVertexAttenForLight( _var0, 1 ),
+ GetVertexAttenForLight( _var0, 2 ),
+ GetVertexAttenForLight( _var0, 3 ) );
+ Out.vProjPos = _var3;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ Out.vTexCoord_1 = _var0;
+ Out.vTexCoord_2 = _var1;
+ Out.vTexCoord_3 = _var3;
+ Out.vTexCoord_4 = _var2;
+ Out.vTexCoord_5 = _var5;
+ Out.vColor_0 = _var6;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_snowy_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_snowy_ps30.fxc
new file mode 100644
index 0000000000..deb7ecffda
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_snowy_ps30.fxc
@@ -0,0 +1,209 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Combos
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// STATIC: "FLASHLIGHT" "0..1"
+// DYNAMIC: "FLASHLIGHTDEPTHFILTERMODE" "0..2"
+// DYNAMIC: "FLASHLIGHTSHADOWS" "0..1"
+// DYNAMIC: "NUM_LIGHTS" "0..4"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+sampler _Sampler_02 : register( s2 );
+sampler _Sampler_03 : register( s3 );
+sampler _Sampler_04 : register( s4 );
+sampler _Sampler_05 : register( s5 );
+sampler _gSampler_Flashlight_Cookie : register( s6 );
+sampler _gSampler_Flashlight_Depth : register( s7 );
+sampler _gSampler_Flashlight_Random : register( s8 );
+sampler _Sampler_09 : register( s9 );
+
+// Constants
+const float4 _g_FogParams : register( c16 );
+const float3 _g_VecOrig : register( c17 );
+const float4 g_cFlashlightAttenuationFactors : register( c8 );
+const float4 g_cFlashlightPos : register( c9 );
+const float4 g_cShadowTweaks : register( c7 );
+const float3 g_cAmbientCube[6] : register( c0 );
+PixelShaderLightInfo g_cLightInfo[3] : register( c6 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float4 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+ float3 vTexCoord_6 : TEXCOORD6;
+ float3 vTexCoord_7 : TEXCOORD7;
+ float4 vColor_0 : COLOR0;
+ float4 vColor_1 : COLOR1;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float3 _var0 = float3( 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = In.vTexCoord_0.xy;
+ float2 _var2 = In.vTexCoord_0.zw;
+ float _var3 = In.vColor_1.w;
+ float _var4 = In.vColor_1.x;
+ float _var5 = In.vColor_1.y;
+ float _var6 = In.vColor_1.z;
+ float _var7 = dot( In.vTexCoord_1, float3( 0.000000, 0.000000, 1.000000 ) );
+ float3x3 _var8 = { In.vTexCoord_5,
+ In.vTexCoord_6,
+ In.vTexCoord_1 };
+ float2 _var9 = In.vTexCoord_4.xy;
+ float _var10 = In.vTexCoord_4.w;
+ float3 _var11 = normalize( In.vTexCoord_7 );
+ float3 _var12 = float3( 0.000000, 0.000000, 0.000000 );
+ float _var13 = In.vTexCoord_4.z;
+ float _var14 = _g_VecOrig.z;
+ float _var15 = In.vTexCoord_2.z;
+ float _var16 = In.vTexCoord_4.z;
+ float4 _texLookup_56 = tex2D( _Sampler_00, _var1 );
+ float3 _var17 = _texLookup_56.rgb;
+ float _var18 = _texLookup_56.a;
+ float3 _var19 = float3( _var2, _var3 );
+ _var9 = _var9 / _var10;
+ float3 _var20 = _var11 * float( -1.000000 );
+ float _var21 = tex2D( _Sampler_01, _var1 ).r;
+ float4 _texLookup_62 = tex2D( _Sampler_02, _var1 );
+ float3 _var22 = _texLookup_62.rgb;
+ float _var23 = _texLookup_62.a;
+ _var13 = smoothstep( float( 50.000000 ), float( 0.000000 ), _var13 );
+ _var14 = CalcPixelFogFactor( PIXELFOGTYPE, _g_FogParams, _var14, _var15, _var16 );
+ float3 _var24 = _var19 * float( 0.015000 );
+ float _var25 = 1.0f - _var21;
+ float _var26 = _var21 * float( 150.000000 );
+ _var13 = _var13 * float( 0.500000 );
+ float2 _var27 = _var24.zy;
+ float2 _var28 = _var24.xz;
+ float2 _var29 = _var24.xy;
+ _var25 = _var25 + _var26;
+ _var13 = _var13 + float( 0.100000 );
+ float3 _var30 = tex2D( _Sampler_03, _var27 ).rgb;
+ float3 _var31 = tex2D( _Sampler_03, _var28 ).rgb;
+ float3 _var32 = tex2D( _Sampler_03, _var29 ).rgb;
+ float4 _var33 = tex2D( _Sampler_04, _var27 ).rgba;
+ float4 _var34 = tex2D( _Sampler_04, _var28 ).rgba;
+ float4 _var35 = tex2D( _Sampler_04, _var29 ).rgba;
+ float3 _var36 = _var19 * _var13;
+ _var30 = _var30 * _var4;
+ _var31 = _var31 * _var5;
+ _var32 = _var32 * _var6;
+ _var33 = _var33 * _var4;
+ _var34 = _var34 * _var5;
+ _var35 = _var35 * _var6;
+ float2 _var37 = _var36.zy;
+ float2 _var38 = _var36.xz;
+ float2 _var39 = _var36.xy;
+ _var30 = _var30 + _var31;
+ _var33 = _var33 + _var34;
+ float3 _var40 = tex2D( _Sampler_05, _var37 ).rgb;
+ float3 _var41 = tex2D( _Sampler_05, _var38 ).rgb;
+ float3 _var42 = tex2D( _Sampler_05, _var39 ).rgb;
+ _var30 = _var30 + _var32;
+ _var33 = _var33 + _var35;
+ _var40 = _var40 * _var4;
+ _var41 = _var41 * _var5;
+ _var42 = _var42 * _var6;
+ float _var43 = _var33.w;
+ float3 _var44 = _var33.xyz;
+ _var40 = _var40 + _var41;
+ float _var45 = pow( _var43, float( 10.000000 ) );
+ float _var46 = _var43 * float( 0.500000 );
+ _var44 = _var44 * float3( 0.540000, 0.570000, 0.600000 );
+ _var40 = _var40 + _var42;
+ float _var47 = min( _var7, _var45 );
+ float _var48 = max( _var7, _var45 );
+ _var46 = _var46 + float( 0.500000 );
+ float _var49 = _var40.x;
+ float3 _var50 = _var40 * float( 2.000000 );
+ _var47 = lerp( _var47, _var48, _var7 );
+ float3 _var51 = lerp( float3( 0.900000, 0.950000, 1.000000 ), float3( 0.500000, 0.700000, 1.000000 ), _var49 );
+ _var50 = _var50 - float( 1.000000 );
+ _var47 = smoothstep( float( 0.100000 ), float( 0.600000 ), _var47 );
+ _var50 = normalize( _var50 );
+ _var46 = min( _var47, _var46 );
+ _var17 = lerp( _var17, _var30, _var46 );
+ _var22 = lerp( _var22, _var44, _var46 );
+ _var17 = _var17 * float( 2.000000 );
+ _var17 = _var17 - float( 1.000000 );
+ _var17 = mul( _var17, _var8 );
+ _var17 = normalize( _var17 );
+ float _var52 = dot( _var17, _var20 );
+ float _var53 = dot( _var17, _var50 );
+ _var52 = abs( _var52 );
+ _var53 = smoothstep( float( 0.995000 ), float( 0.996000 ), _var53 );
+ _var52 = 1.0f - _var52;
+ _var51 = _var51 * _var53;
+ _var52 = pow( _var52, float( 3.000000 ) );
+ _var51 = _var51 * float( 0.400000 );
+ float _var54 = max( _var52, _var18 );
+ _var51 = _var51 * _var47;
+#if ( FLASHLIGHT == 1 )
+ float3 _var55 = (float3)0;
+ float3 _var56 = (float3)0;
+ DoSpecularFlashlight( g_cFlashlightPos.xyz, In.vTexCoord_2, In.vColor_0, _var17,
+ g_cFlashlightAttenuationFactors.xyz, g_cFlashlightAttenuationFactors.w,
+ _gSampler_Flashlight_Cookie, _gSampler_Flashlight_Depth, _gSampler_Flashlight_Random,
+ FLASHLIGHTDEPTHFILTERMODE, FLASHLIGHTSHADOWS, true,
+ _var9, _var25, _var20, _var54, g_cShadowTweaks,
+ _var55, _var56 );
+ _var0 = _var55;
+ _var12 = _var56;
+#endif
+#if ( FLASHLIGHT == 0 )
+ float3 _var57 = (float3)0;
+ PixelShaderDoSpecularLighting( In.vTexCoord_2, _var17, _var25, _var20,
+ In.vTexCoord_3, NUM_LIGHTS, g_cLightInfo,
+ false, 1.0f, _var54, _var57 );
+ float3 _var58 = PixelShaderDoLighting( In.vTexCoord_2, _var17, float3(0,0,0),
+ false, true, In.vTexCoord_3,
+ g_cAmbientCube, NUM_LIGHTS, g_cLightInfo,
+ false, false, 1.0f );
+ _var12 = _var57;
+ _var0 = _var58;
+#endif
+ _var0 = _var0;
+ _var12 = _var12;
+ _var0 = _var0 * _var22;
+ _var0 = _var0 + _var12;
+#if ( FLASHLIGHT == 0 )
+ float3 _var59 = reflect( _var11, _var17 );
+ float3 _var60 = texCUBE( _Sampler_09, _var59 ).rgb;
+ _var60 = _var60 * ENV_MAP_SCALE;
+ float3 _var61 = _var60 * _var18;
+ _var61 = lerp( _var61, _var60, _var47 );
+ _var61 = _var52 * _var61;
+ _var61 = _var61 * float( 0.100000 );
+ _var0 = _var0 + _var61;
+#endif
+ _var0 = _var0 + _var51;
+ float4 _var62 = float4( _var0, _var23 );
+ _var62 = FinalOutput( _var62, _var14, PIXELFOGTYPE, TONEMAP_SCALE_LINEAR, true, _var16 );
+ Out.vColor_0 = _var62;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/model_snowy_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/model_snowy_vs30.fxc
new file mode 100644
index 0000000000..9424faea7b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/model_snowy_vs30.fxc
@@ -0,0 +1,118 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+// Combos
+// DYNAMIC: "COMPRESSED_VERTS" "0..1"
+// DYNAMIC: "MORPHING" "0..1"
+// DYNAMIC: "SKINNING" "0..1"
+// STATIC: "FLASHLIGHT" "0..1"
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Samplers
+sampler2D morphSampler : register( D3DVERTEXTEXTURESAMPLER0, s0 );
+
+// Constants
+const float3 _g_VecOrig : register( c48 );
+const float4x4 g_cFlashlightWorldToTexture : register( c49 );
+#ifdef SHADER_MODEL_VS_3_0
+const float3 g_cMorphTargetTextureDim : register( SHADER_SPECIFIC_CONST_10 );
+const float4 g_cMorphSubrect : register( SHADER_SPECIFIC_CONST_11 );
+#endif
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float3 vFlexDelta : POSITION1;
+ float3 vFlexDelta_Normal : NORMAL1;
+ float4 vBoneWeights : BLENDWEIGHT;
+ float4 vBoneIndices : BLENDINDICES;
+ float4 vNormal : NORMAL;
+ float4 vTangent_S : TANGENT;
+ float2 vTexCoord_0 : TEXCOORD0;
+#ifdef SHADER_MODEL_VS_3_0
+ float vVertexID : POSITION2;
+#endif
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float4 vTexCoord_0 : TEXCOORD0;
+ float3 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float4 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float3 vTexCoord_5 : TEXCOORD5;
+ float3 vTexCoord_6 : TEXCOORD6;
+ float3 vTexCoord_7 : TEXCOORD7;
+ float4 vColor_0 : COLOR0;
+ float4 vColor_1 : COLOR1;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float3 _var0 = (float3)0;
+ float4 _var1 = (float4)0;
+ DecompressVertex_NormalTangent( In.vNormal, In.vTangent_S, _var0, _var1 );
+ float2 _var2 = In.vPos.xy;
+ float4 _var3 = float4( 0.000000, 0.000000, 0.000000, 0.000000 );
+ float _var4 = In.vPos.z;
+ float3 _var5 = _var1.xyz;
+ float _var6 = _var1.w;
+ float4 _var7 = float4( In.vTexCoord_0, _var2 );
+ float3 _var8 = _var0 * _var0;
+ float3 _var9 = (float3)0;
+#if !defined( SHADER_MODEL_VS_3_0 ) || !MORPHING
+ ApplyMorph( In.vFlexDelta, In.vFlexDelta_Normal,
+ In.vPos, _var9,
+ _var0, _var0,
+ _var5, _var5 );
+#else
+ ApplyMorph( morphSampler, g_cMorphTargetTextureDim, g_cMorphSubrect,
+ In.vVertexID, float3( 0, 0, 0 ),
+ In.vPos, _var9,
+ _var0, _var0,
+ _var5, _var5 );
+#endif
+ float4 _var10 = float4( _var8, _var4 );
+ float4 _var11 = float4( _var5, _var6 );
+ float3 _var12 = (float3)0;
+ float3 _var13 = (float3)0;
+ float3 _var14 = (float3)0;
+ float3 _var15 = (float3)0;
+ SkinPositionNormalAndTangentSpace( SKINNING, float4( _var9, 1 ), _var0, _var11,
+ In.vBoneWeights, In.vBoneIndices,
+ _var12, _var13, _var14, _var15 );
+ float4 _var16 = mul( float4(_var12.xyz,1), cViewProj );
+ _var13 = normalize( _var13 );
+ float4 _var17 = float4( GetVertexAttenForLight( _var12, 0 ),
+ GetVertexAttenForLight( _var12, 1 ),
+ GetVertexAttenForLight( _var12, 2 ),
+ GetVertexAttenForLight( _var12, 3 ) );
+ _var14 = normalize( _var14 );
+ _var15 = normalize( _var15 );
+ float3 _var18 = _var12 - _g_VecOrig;
+#if ( FLASHLIGHT == 1 )
+ float4 _var19 = mul( float4(_var12.xyz,1), g_cFlashlightWorldToTexture );
+ _var3 = _var19;
+#endif
+ Out.vProjPos = _var16;
+ Out.vTexCoord_0 = _var7;
+ Out.vTexCoord_1 = _var13;
+ Out.vTexCoord_2 = _var12;
+ Out.vTexCoord_3 = _var17;
+ Out.vTexCoord_4 = _var16;
+ Out.vTexCoord_5 = _var14;
+ Out.vTexCoord_6 = _var15;
+ Out.vTexCoord_7 = _var18;
+ Out.vColor_0 = _var3;
+ Out.vColor_1 = _var10;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/postproc_sunrays_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/postproc_sunrays_ps30.fxc
new file mode 100644
index 0000000000..bcf60e78e5
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/postproc_sunrays_ps30.fxc
@@ -0,0 +1,69 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+
+
+// Combos
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+
+// Constants
+const float4 g_cData_sun_data : register( c0 ); // Callback
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _texLookup_9 = tex2D( _Sampler_00, In.vTexCoord_0 );
+ float3 _var0 = _texLookup_9.rgb;
+ float _var1 = _texLookup_9.a;
+ float3 _var2 = float3( 0.000000, 0.000000, 0.000000 );
+ float2 _var3 = In.vTexCoord_0;
+ float2 _var4 = g_cData_sun_data.xy;
+ float _var5 = float( 1.000000 );
+ float _var6 = g_cData_sun_data.z;
+ _var4 = In.vTexCoord_0 - _var4;
+ _var6 = saturate( _var6 );
+ float _var7 = length( _var4 );
+ float2 _var8 = _var4 / _var7;
+ float _var9 = smoothstep( float( 0.000000 ), float( 0.700000 ), _var7 );
+ _var8 = _var8 * _var9;
+ _var8 = _var8 * float( 0.010000 );
+ for ( int _var10 = 0; _var10 < 35; _var10++ )
+ {
+ float2 _var11 = _var8;
+ _var5 = _var5 * float( 0.960000 );
+ _var3 = _var3 - _var11;
+ float4 _texLookup_28 = tex2D( _Sampler_01, _var3 );
+ float3 _var12 = _texLookup_28.rgb;
+ float _var13 = _texLookup_28.a;
+ _var12 = _var12 * _var13;
+ _var12 = _var12 * _var5;
+ _var2 = _var2 + _var12;
+ }
+ _var2 = _var2 * float( 0.050000 );
+ _var2 = _var2 * _var6;
+ _var0 = _var0 + _var2;
+ float4 _var14 = float4( _var0, _var1 );
+ Out.vColor_0 = _var14;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/postproc_sunrays_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/postproc_sunrays_vs30.fxc
new file mode 100644
index 0000000000..1bc4fd7520
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/postproc_sunrays_vs30.fxc
@@ -0,0 +1,36 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Combos
+
+// Samplers
+
+// Constants
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/sprite_sun_nodepth_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/sprite_sun_nodepth_ps30.fxc
new file mode 100644
index 0000000000..c1a736d16c
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/sprite_sun_nodepth_ps30.fxc
@@ -0,0 +1,41 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Combos
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+ float4 vColor_0 : COLOR0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = tex2D( _Sampler_00, In.vTexCoord_0 ).rgba;
+ _var0 = _var0 * In.vColor_0;
+ _var0 = FinalOutput( _var0, float( 0.000000 ), PIXELFOGTYPE, TONEMAP_SCALE_LINEAR, false, 1.0f );
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/sprite_sun_nodepth_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/sprite_sun_nodepth_vs30.fxc
new file mode 100644
index 0000000000..f5c86cd6cf
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/sprite_sun_nodepth_vs30.fxc
@@ -0,0 +1,34 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float4 vColor_0 : COLOR0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = mul( float4(In.vPos.xyz,1), cModelViewProj );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ Out.vColor_0 = In.vColor_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/ssao_calc_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/ssao_calc_ps30.fxc
new file mode 100644
index 0000000000..3a7bda5743
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/ssao_calc_ps30.fxc
@@ -0,0 +1,228 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// User code - globals
+#define PI 3.14159265
+
+//--------------------------------------------------------
+//a list of user parameters
+
+#define METHOD 0
+
+static float near = 7; //Z-near
+static float far = 192.0; //Z-far
+static float zScaleLinear = near / far;
+static float zScaleLinearRev = far / near;
+
+#if ( METHOD == 0 )
+static int samples = 3; //samples on the first ring (3 - 5)
+static int rings = 3; //ring count (3 - 5)
+static float radius_close = 6.0; //ao radius
+static float radius_far = 0.5; //ao radius
+#else
+static int samples = 24; //samples on the first ring (3 - 5)
+static float radius_close = 7.0; //ao radius
+static float radius_far = 1.5; //ao radius
+#endif
+
+static float dist_exp = 6.0f;
+
+static float diffarea = 0.45; //self-shadowing reduction
+static float gdisplace = 0.4; //gauss bell center
+
+static float lumInfluence = 0.4; //how much luminance affects occlusion
+static float aoBoost_far = 2.5f;
+static float aoBoost_close = 6.0f;
+
+static bool noise = true; //use noise instead of pattern for sample dithering?
+static bool onlyAO = true; //use only ambient occlusion pass?
+static bool fadeout = true;
+
+//--------------------------------------------------------
+
+float2 rand(float2 coord, float2 size) //generating noise/pattern texture for dithering
+{
+ float noiseX = ((frac(1.0-coord.x*(size.x/2.0))*0.25)+(frac(coord.y*(size.y/2.0))*0.75))*2.0-1.0;
+ float noiseY = ((frac(1.0-coord.x*(size.x/2.0))*0.75)+(frac(coord.y*(size.y/2.0))*0.25))*2.0-1.0;
+
+ if (noise)
+ {
+ noiseX = frac(sin(dot(coord ,float2(12.9898,78.233))) * 43758.5453) * 2.0-1.0;
+ noiseY = frac(sin(dot(coord ,float2(12.9898,78.233)*2.0)) * 43758.5453) * 2.0-1.0;
+ }
+ return float2(noiseX,noiseY)*0.001;
+}
+
+float readDepth(in float2 coord, sampler tex)
+{
+ return tex2D(tex, coord ).a * zScaleLinear;
+ //return (2.0 * near) / (far + near - tex2D(tex, coord ).a * (far-near));
+}
+
+float readDepth(float linDepth)
+{
+ return linDepth * zScaleLinear;
+}
+
+float compareDepths(in float depth1, in float depth2,inout int far)
+{
+ float garea = 2.0; //gauss bell width
+ float diff = (depth1 - depth2)*100.0; //depth difference (0-100)
+ //reduce left bell width to avoid self-shadowing
+
+
+ if ( diff < gdisplace )
+ {
+ garea = diffarea;
+ }else{
+ far = 1;
+ }
+
+ float gauss = pow(2.7182,-2.0*(diff-gdisplace)*(diff-gdisplace)/(garea*garea));
+ return gauss;
+}
+
+float calAO(float2 uv,float localDepth, float depth, float dw, float dh, sampler tex)
+{
+ float dd = (1.0-depth)*lerp( radius_far, radius_close, localDepth );
+
+ float temp = 0.0;
+ float temp2 = 0.0;
+ float coordw = uv.x + dw*dd;
+ float coordh = uv.y + dh*dd;
+ float coordw2 = uv.x - dw*dd;
+ float coordh2 = uv.y - dh*dd;
+
+ float2 coord = float2(coordw , coordh);
+ float2 coord2 = float2(coordw2, coordh2);
+
+ int far = 0;
+ temp = compareDepths(depth, readDepth(coord,tex),far);
+ //DEPTH EXTRAPOLATION:
+ if (far > 0)
+ {
+ temp2 = compareDepths(readDepth(coord2,tex),depth,far);
+ temp += (1.0-temp)*temp2;
+ }
+
+ return temp;
+}
+
+// User code - function bodies
+void DoSSAO( in float2 uv, in float2 texelSize, in sampler color_depth, out float ao_out )
+{
+ float2 size = 1.0f / texelSize;
+
+ float2 noise = rand(uv,size);
+ float depthSample = tex2D(color_depth, uv ).a;
+ float depth = readDepth(depthSample);
+ depthSample = pow( (1.0f - depthSample), dist_exp );
+ float d;
+
+ float w = texelSize.x/clamp(depth,0.25,1.0)+(noise.x*(1.0-noise.x));
+ float h = texelSize.y/clamp(depth,0.25,1.0)+(noise.y*(1.0-noise.y));
+
+ float pw;
+ float ph;
+
+ float ao;
+ float s;
+
+ int ringsamples;
+
+#if (METHOD == 0)
+ for (int i = 1; i <= rings; i++)
+ {
+ ringsamples = i * samples;
+ for (int j = 0 ; j < ringsamples ; j += 1)
+ {
+ float step = PI*2.0 / float(ringsamples);
+ pw = (cos(float(j)*step)*float(i));
+ ph = (sin(float(j)*step)*float(i));
+ ao += calAO( uv, depthSample, depth, pw*w, ph*h, color_depth );
+ s += 1.0;
+ }
+ }
+ ao /= s;
+ ao = 1.0-ao;
+#else
+ float dl = PI*(3.0-sqrt(5.0));
+ float dz = 1.0/float(samples);
+ float l = 0.0;
+ float z = 1.0 - dz/2.0;
+
+ for (int i = 0; i <= samples; i ++)
+ {
+ float r = sqrt(1.0-z);
+
+ pw = cos(l)*r;
+ ph = sin(l)*r;
+ ao += calAO(uv,depthSample,depth,pw*w,ph*h,color_depth);
+ z = z - dz;
+ l = l + dl;
+ }
+
+ ao /= float(samples);
+ ao = 1.0-ao;
+#endif
+
+ float3 color = tex2D(color_depth,uv).rgb;
+
+ float3 lumcoeff = float3(0.299,0.587,0.114);
+ float lum = dot(color.rgb, lumcoeff);
+ float3 luminance = float3(lum, lum, lum);
+
+ ao = pow( ao, lerp( aoBoost_far, aoBoost_close, depthSample ) );
+
+ //lum = lerp(ao,1.0,luminance*lumInfluence);
+ ao_out = lerp(ao,1.0,luminance*lumInfluence);
+
+ if ( fadeout )
+ {
+ float fade = depth * zScaleLinearRev;
+ ao_out = lerp( ao_out, 0.65, pow( fade, 3 ) );
+ }
+
+ //if(onlyAO)
+ // ao = lum; //ambient occlusion only
+ //else
+ // col = color * lum;
+}
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float _var0 = (float)0;
+ DoSSAO( In.vTexCoord_0, _g_TexelSize, _Sampler_00, _var0 );
+ float4 _var1 = float4( _var0.x, _var0.x, _var0.x, 1.000000 );
+ Out.vColor_0 = _var1;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/ssao_calc_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/ssao_calc_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/ssao_calc_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/ssao_combine_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/ssao_combine_ps30.fxc
new file mode 100644
index 0000000000..5ffbad2719
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/ssao_combine_ps30.fxc
@@ -0,0 +1,43 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _texLookup_3 = tex2D( _Sampler_00, In.vTexCoord_0 );
+ float3 _var0 = _texLookup_3.rgb;
+ float _var1 = _texLookup_3.a;
+ float _var2 = tex2D( _Sampler_01, In.vTexCoord_0 ).r;
+ _var2 = _var2 * float( 2.000000 );
+ _var0 = _var0 * _var2;
+ _var0 = _var0 * float( 0.850000 );
+ float4 _var3 = float4( _var0, _var1 );
+ Out.vColor_0 = _var3;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/ssao_combine_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/ssao_combine_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/ssao_combine_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/ssao_fxaa_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/ssao_fxaa_ps30.fxc
new file mode 100644
index 0000000000..06ce553f1f
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/ssao_fxaa_ps30.fxc
@@ -0,0 +1,97 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float2 _g_TexelSize : register( c16 );
+
+// User code - globals
+#define FXAA_PC 1
+#define FXAA_HLSL_3 1
+#define FXAA_GREEN_AS_LUMA 1
+#define FXAA_DISCARD 1
+#define FXAA_QUALITY__PRESET 10
+
+#include "fxaa3_11.h"
+
+// User code - function bodies
+void DoFXAA( in sampler tex, in float2 uv, in float2 texelsize, out float4 col )
+{
+ col = FxaaPixelShader( uv,
+ (float4)0,
+ tex,
+ tex,
+ tex,
+ texelsize,
+ (float4)0,
+ (float4)0,
+ (float4)0,
+ // fxaaQualitySubpix
+ // This used to be the FXAA_QUALITY__SUBPIX define.
+ // It is here now to allow easier tuning.
+ // Choose the amount of sub-pixel aliasing removal.
+ // This can effect sharpness.
+ // 1.00 - upper limit (softer)
+ // 0.75 - default amount of filtering
+ // 0.50 - lower limit (sharper, less sub-pixel aliasing removal)
+ // 0.25 - almost off
+ // 0.00 - completely off
+ 0.5,
+ // This used to be the FXAA_QUALITY__EDGE_THRESHOLD define.
+ // It is here now to allow easier tuning.
+ // The minimum amount of local contrast required to apply algorithm.
+ // 0.333 - too little (faster)
+ // 0.250 - low quality
+ // 0.166 - default
+ // 0.125 - high quality
+ // 0.063 - overkill (slower)
+ // fxaaQualityEdgeThreshold
+ 0.2,
+ // This used to be the FXAA_QUALITY__EDGE_THRESHOLD_MIN define.
+ // It is here now to allow easier tuning.
+ // Trims the algorithm from processing darks.
+ // 0.0833 - upper limit (default, the start of visible unfiltered edges)
+ // 0.0625 - high quality (faster)
+ // 0.0312 - visible limit (slower)
+ // Special notes when using FXAA_GREEN_AS_LUMA,
+ // Likely want to set this to zero.
+ // As colors that are mostly not-green
+ // will appear very dark in the green channel!
+ // Tune by looking at mostly non-green content,
+ // then start at zero and increase until aliasing is a problem.
+ 0.0833,
+ 0, 0, 0, (float4)0 );
+}
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float4 _var0 = (float4)0;
+ DoFXAA( _Sampler_00, In.vTexCoord_0, _g_TexelSize, _var0 );
+ Out.vColor_0 = _var0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/ssao_fxaa_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/ssao_fxaa_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/ssao_fxaa_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/sunrays_calc_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/sunrays_calc_ps30.fxc
new file mode 100644
index 0000000000..e15e593a93
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/sunrays_calc_ps30.fxc
@@ -0,0 +1,64 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+
+// Constants
+const float4 g_cData_sun_data : register( c16 ); // Callback
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float3 _var0 = float3( 0.000000, 0.000000, 0.000000 );
+ float2 _var1 = In.vTexCoord_0;
+ float2 _var2 = g_cData_sun_data.xy;
+ float _var3 = float( 1.000000 );
+ float _var4 = g_cData_sun_data.z;
+ _var2 = In.vTexCoord_0 - _var2;
+ _var4 = saturate( _var4 );
+ float _var5 = length( _var2 );
+ float2 _var6 = _var2 / _var5;
+ float _var7 = smoothstep( float( 0.000000 ), float( 0.700000 ), _var5 );
+ _var6 = _var6 * _var7;
+ _var6 = _var6 * float( 0.011000 );
+ for ( int _var8 = 0; _var8 < 35; _var8++ )
+ {
+ float2 _var9 = _var6;
+ _var3 = _var3 * float( 0.950000 );
+ _var1 = _var1 - _var9;
+ float4 _texLookup_26 = tex2D( _Sampler_00, _var1 );
+ float3 _var10 = _texLookup_26.rgb;
+ float _var11 = _texLookup_26.a;
+ _var10 = _var10 * _var11;
+ _var10 = _var10 * _var3;
+ _var0 = _var0 + _var10;
+ }
+ _var0 = _var0 * float( 0.060000 );
+ _var0 = _var0 * _var4;
+ float4 _var12 = float4( _var0.x, _var0.y, _var0.z, 1.000000 );
+ Out.vColor_0 = _var12;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/sunrays_calc_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/sunrays_calc_vs30.fxc
new file mode 100644
index 0000000000..9c0734a8f7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/sunrays_calc_vs30.fxc
@@ -0,0 +1,31 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/swarm_test_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/swarm_test_ps30.fxc
new file mode 100644
index 0000000000..8bf67b8000
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/swarm_test_ps30.fxc
@@ -0,0 +1,59 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float3 _var0 = float3( 0.000000, 0.000000, 0.000000 );
+ float4 _texLookup_12 = tex2D( _Sampler_00, In.vTexCoord_0 );
+ float3 _var1 = _texLookup_12.rgb;
+ float _var2 = _texLookup_12.a;
+ for ( int _var3 = -40; _var3 <= 40; _var3++ )
+ {
+ float2 _var4 = float2( 0.005000, 0.000000 ) * _var3;
+ float _var5 = abs( _var3 );
+ _var4 = _var4 + In.vTexCoord_0;
+ _var5 = _var5 / float( 25.000000 );
+ float3 _var6 = tex2D( _Sampler_01, _var4 ).rgb;
+ float _var7 = _var4.x;
+ _var5 = 1.0f - _var5;
+ _var6 = smoothstep( float( 0.250000 ), float( 0.350000 ), _var6 );
+ _var7 = _var7 - float( 0.500000 );
+ _var5 = pow( _var5, float( 2.000000 ) );
+ _var7 = abs( _var7 );
+ _var7 = smoothstep( float( 0.500000 ), float( 0.400000 ), _var7 );
+ _var7 = _var7 * _var5;
+ _var6 = _var6 * _var7;
+ _var0 = _var0 + _var6;
+ }
+ _var0 = _var0 * float3( 0.030000, 0.040000, 0.050000 );
+ _var0 = _var0 + _var1;
+ float4 _var8 = float4( _var0, _var2 );
+ Out.vColor_0 = _var8;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/swarm_test_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/swarm_test_vs30.fxc
new file mode 100644
index 0000000000..1063824bdd
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/swarm_test_vs30.fxc
@@ -0,0 +1,30 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float4 _var0 = float4( In.vPos.x, In.vPos.y, In.vPos.z, 1.000000 );
+ Out.vProjPos = _var0;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/unnamedshader_ps30.fxc b/mp/game/momentum/shadereditorui/shader_src/unnamedshader_ps30.fxc
new file mode 100644
index 0000000000..b3ced5707f
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/unnamedshader_ps30.fxc
@@ -0,0 +1,90 @@
+// ********************************
+// ** auto generated pixelshader **
+// ********************************
+
+// Combos
+// DYNAMIC: "FLASHLIGHT" "0..1"
+// DYNAMIC: "FLASHLIGHTDEPTHFILTERMODE" "0..2"
+// DYNAMIC: "FLASHLIGHTSHADOWS" "0..1"
+// DYNAMIC: "PIXELFOGTYPE" "0..1"
+// DYNAMIC: "WRITEWATERFOGTODESTALPHA" "0..1"
+
+// Includes
+#include "common_ps_fxc.h"
+#include "common_vertexlitgeneric_dx9.h"
+#include "common_lightmappedgeneric_fxc.h"
+#include "common_flashlight_fxc.h"
+#include "common_parallax.h"
+
+
+// Samplers
+sampler _Sampler_00 : register( s0 );
+sampler _Sampler_01 : register( s1 );
+sampler _Sampler_02 : register( s2 );
+sampler _gSampler_Flashlight_Cookie : register( s3 );
+sampler _gSampler_Flashlight_Depth : register( s4 );
+sampler _gSampler_Flashlight_Random : register( s5 );
+
+// Constants
+const float4x4 g_cFlashlightWorldToTexture : register( c12 );
+const float4 _g_FogParams : register( c16 );
+const float3 _g_VecOrig : register( c17 );
+const float4 g_cFlashlightAttenuationFactors : register( c8 );
+const float4 g_cFlashlightPos : register( c9 );
+const float4 g_cShadowTweaks : register( c7 );
+
+// Semantic structures
+struct PS_INPUT
+{
+ float2 vTexCoord_0 : TEXCOORD0;
+ float2 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float3 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float4 vColor_0 : COLOR0;
+};
+
+struct PS_OUTPUT
+{
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+PS_OUTPUT main( const PS_INPUT In )
+{
+ PS_OUTPUT Out;
+ float3 _var0 = float3( 0.000000, 0.000000, 0.000000 );
+ float3 _var1 = tex2D( _Sampler_00, In.vTexCoord_0 ).rgb;
+ float3 _var2 = tex2D( _Sampler_01, In.vTexCoord_0 ).rgb;
+ float _var3 = In.vColor_0.w;
+ float _var4 = _g_VecOrig.z;
+ float _var5 = In.vTexCoord_3.z;
+ float _var6 = In.vTexCoord_4.z;
+#if ( FLASHLIGHT == 0 )
+ float3 _var7 = tex2D( _Sampler_02, In.vTexCoord_1 ).rgb;
+ _var7 = _var7 * LIGHT_MAP_SCALE;
+ _var0 = _var7;
+#endif
+#if ( FLASHLIGHT == 1 )
+ float4 _var8 = mul( float4(In.vTexCoord_3.xyz,1), g_cFlashlightWorldToTexture );
+ float2 _var9 = In.vTexCoord_4.xy;
+ float _var10 = In.vTexCoord_4.w;
+ _var9 = _var9 / _var10;
+ _var9 = _var9 * float( 0.500000 );
+ _var9 = _var9 + float( 0.500000 );
+ float3 _var11 = DoFlashlight( g_cFlashlightPos.xyz, In.vTexCoord_3, _var8, In.vTexCoord_2,
+ g_cFlashlightAttenuationFactors.xyz, g_cFlashlightAttenuationFactors.w,
+ _gSampler_Flashlight_Cookie, _gSampler_Flashlight_Depth, _gSampler_Flashlight_Random,
+ FLASHLIGHTDEPTHFILTERMODE, FLASHLIGHTSHADOWS, true,
+ _var9, false, g_cShadowTweaks );
+ _var0 = _var11;
+#endif
+ _var0 = _var0;
+ _var1 = lerp( _var1, _var2, _var3 );
+ _var4 = CalcPixelFogFactor( PIXELFOGTYPE, _g_FogParams, _var4, _var5, _var6 );
+ _var0 = _var0 * _var1;
+ float4 _var12 = float4( _var0.x, _var0.y, _var0.z, 1.000000 );
+ _var12 = FinalOutput( _var12, _var4, PIXELFOGTYPE, TONEMAP_SCALE_LINEAR, true, _var6 );
+ Out.vColor_0 = _var12;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/shader_src/unnamedshader_vs30.fxc b/mp/game/momentum/shadereditorui/shader_src/unnamedshader_vs30.fxc
new file mode 100644
index 0000000000..49e60abdc4
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/shader_src/unnamedshader_vs30.fxc
@@ -0,0 +1,46 @@
+// *********************************
+// ** auto generated vertexshader **
+// *********************************
+
+
+// Includes
+#include "common_vs_fxc.h"
+
+
+// Semantic structures
+struct VS_INPUT
+{
+ float3 vPos : POSITION;
+ float3 vNormal : NORMAL;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float2 vTexCoord_1 : TEXCOORD1;
+ float4 vColor_0 : COLOR0;
+};
+
+struct VS_OUTPUT
+{
+ float4 vProjPos : POSITION;
+ float2 vTexCoord_0 : TEXCOORD0;
+ float2 vTexCoord_1 : TEXCOORD1;
+ float3 vTexCoord_2 : TEXCOORD2;
+ float3 vTexCoord_3 : TEXCOORD3;
+ float4 vTexCoord_4 : TEXCOORD4;
+ float4 vColor_0 : COLOR0;
+};
+
+// Entry point
+VS_OUTPUT main( const VS_INPUT In )
+{
+ VS_OUTPUT Out;
+ float3 _var0 = mul( float4(In.vPos.xyz,1), cModel[0] );
+ float3 _var1 = mul( float4(In.vNormal.xyz,1), cModel[0] );
+ float4 _var2 = mul( float4(_var0.xyz,1), cViewProj );
+ Out.vProjPos = _var2;
+ Out.vTexCoord_0 = In.vTexCoord_0;
+ Out.vTexCoord_1 = In.vTexCoord_1;
+ Out.vTexCoord_2 = _var1;
+ Out.vTexCoord_3 = _var0;
+ Out.vTexCoord_4 = _var2;
+ Out.vColor_0 = In.vColor_0;
+ return Out;
+}
\ No newline at end of file
diff --git a/mp/game/momentum/shadereditorui/user_functions/call_fxaa.ufunc b/mp/game/momentum/shadereditorui/user_functions/call_fxaa.ufunc
new file mode 100644
index 0000000000..88cd0c61a7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/user_functions/call_fxaa.ufunc
@@ -0,0 +1,20 @@
+"user_func"
+{
+ "szFunctionName" "DoFXAA"
+ "szFilePath" "shadereditorui\user_functions\call_fxaa.ufunc"
+ "iInline" "0"
+ "szcode_global_num_strings" "1"
+ "szcode_global_partial_00" "#define FXAA_PC 1\r\n#define FXAA_HLSL_3 1\r\n#define FXAA_GREEN_AS_LUMA 1\r\n#define FXAA_DISCARD 1\r\n#define FXAA_QUALITY__PRESET 12\r\n\r\n#include \'fxaa3_11.h\'\n"
+ "szcode_body_num_strings" "2"
+ "szcode_body_partial_00" " col = FxaaPixelShader( uv,\r\n (float4)0,\r\n tex,\r\n tex,\r\n tex,\r\n texelsize,\r\n (float4)0,\r\n (float4)0,\r\n (float4)0,\r\n // fxaaQualitySubpix\r\n // This used to be the FXAA_QUALITY__SUBPIX define.\r\n // It is here now to allow easier tuning.\r\n // Choose the amount of sub-pixel aliasing removal.\r\n // This can effect sharpness.\r\n // 1.00 - upper limit (softer)\r\n // 0.75 - default amount of filtering\r\n // 0.50 - lower limit (sharper, less sub-pixel aliasing removal)\r\n // 0.25 - almost off\r\n // 0.00 - completely off\r\n 0.5,\r\n // This used to be the FXAA_QUALITY__EDGE_THRESHOLD define.\r\n // It is here now to allow easier tuning.\r\n // The minimum amount of local contrast required to apply algorithm.\r\n // 0.333 - too little (faster)\r\n // 0.250 - low quality\r\n // 0.166 - default\r\n // 0.125 - high quality \r\n // 0.063 - overkill (slower)\r\n // fxaaQualityEdgeThreshold\r\n 0.2,\r\n // This used to be the"
+ "szcode_body_partial_01" " FXAA_QUALITY__EDGE_THRESHOLD_MIN define.\r\n // It is here now to allow easier tuning.\r\n // Trims the algorithm from processing darks.\r\n // 0.0833 - upper limit (default, the start of visible unfiltered edges)\r\n // 0.0625 - high quality (faster)\r\n // 0.0312 - visible limit (slower)\r\n // Special notes when using FXAA_GREEN_AS_LUMA,\r\n // Likely want to set this to zero.\r\n // As colors that are mostly not-green\r\n // will appear very dark in the green channel!\r\n // Tune by looking at mostly non-green content,\r\n // then start at zero and increase until aliasing is a problem.\r\n 0.0833,\r\n 0, 0, 0, (float4)0 );"
+ "iEnvFlags" "0"
+ "varName_In_0" "tex"
+ "varType_In_0" "128"
+ "varName_In_1" "uv"
+ "varType_In_1" "2"
+ "varName_In_2" "texelsize"
+ "varType_In_2" "2"
+ "varName_Out_0" "col"
+ "varType_Out_0" "8"
+}
diff --git a/mp/game/momentum/shadereditorui/user_functions/lighting_example.ufunc b/mp/game/momentum/shadereditorui/user_functions/lighting_example.ufunc
new file mode 100644
index 0000000000..4239ec9fa5
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/user_functions/lighting_example.ufunc
@@ -0,0 +1,18 @@
+"user_func"
+{
+ "szFunctionName" "DoUserLighting"
+ "szFilePath" "shadereditorui\user_functions\lighting_example.ufunc"
+ "iInline" "0"
+ "szcode_global_num_strings" "0"
+ "szcode_body_num_strings" "1"
+ "szcode_body_partial_00" " light = (float3)0;\r\n \r\n float3 ambient = PixelShaderAmbientLight( normal, g_cAmbientCube );\r\n float3 color;\r\n float3 dir;\r\n\r\n for ( int i = 0; i < NUM_LIGHTS; i++ )\r\n {\r\n GetLightData( g_cLightInfo, i, wpos, color, dir );\r\n\r\n color *= attn[i] * saturate( dot( normal, dir ) * 0.5 + 0.5 );\r\n \r\n light += pow( color, 2 );\r\n }\r\n\r\n light = max( light, ambient );"
+ "iEnvFlags" "1"
+ "varName_In_0" "attn"
+ "varType_In_0" "8"
+ "varName_In_1" "wpos"
+ "varType_In_1" "4"
+ "varName_In_2" "normal"
+ "varType_In_2" "4"
+ "varName_Out_0" "light"
+ "varType_Out_0" "4"
+}
diff --git a/mp/game/momentum/shadereditorui/user_functions/mandelbrot.ufunc b/mp/game/momentum/shadereditorui/user_functions/mandelbrot.ufunc
new file mode 100644
index 0000000000..9fcb72368f
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/user_functions/mandelbrot.ufunc
@@ -0,0 +1,15 @@
+"user_func"
+{
+ "szFunctionName" "MandelBrot"
+ "szFilePath" "shadereditorui\user_functions\mandelbrot.ufunc"
+ "iInline" "0"
+ "szcode_global_num_strings" "1"
+ "szcode_global_partial_00" "static const int Iterations = 128;\r\nstatic const float2 Pan = float2(1, 0);\r\nstatic const float Zoom = 1;\r\nstatic const float Aspect = 1;\r\nstatic const float2 JuliaSeed = float2(0.39, -0.2);\r\nstatic const float3 ColorScale = float3(4, 5, 6);\r\n\r\nfloat ComputeValue(float2 v, float2 offset)\r\n{\r\n float vxsquare = 0;\r\n float vysquare = 0;\r\n\r\n int iteration = 0;\r\n int lastIteration = Iterations;\r\n\r\n do\r\n {\r\n vxsquare = v.x*v.x;\r\n vysquare = v.y*v.y;\r\n \r\n v = float2(vxsquare - vysquare, v.x * v.y * 2) + offset;\r\n \r\n iteration++;\r\n \r\n if ((lastIteration == Iterations) && (vxsquare + vysquare) > 4.0)\r\n {\r\n lastIteration = iteration + 1;\r\n }\r\n }\r\n while (iteration < lastIteration);\r\n \r\n return (float(iteration) - (log(log(sqrt(v.x * v.x + v.y * v.y))) / log(2.0))) / float(Iterations);\r\n}\n"
+ "szcode_body_num_strings" "1"
+ "szcode_body_partial_00" " float2 v = (uv - 0.5) * Zoom * float2(1, Aspect) - Pan;\r\n\r\n float val = ComputeValue(v, v);\r\n\r\n col = float4(sin(val * ColorScale.x), sin(val * ColorScale.y), sin(val * ColorScale.z), 1);"
+ "iEnvFlags" "0"
+ "varName_In_0" "uv"
+ "varType_In_0" "2"
+ "varName_Out_0" "col"
+ "varType_Out_0" "8"
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/code_editor_window.res b/mp/game/momentum/shadereditorui/vgui/code_editor_window.res
new file mode 100644
index 0000000000..de70a8d8b4
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/code_editor_window.res
@@ -0,0 +1,402 @@
+"shadereditorui/vgui/code_editor_Window.res"
+{
+ "ceditinstance"
+ {
+ "ControlName" "CCode_Editor"
+ "fieldName" "ceditinstance"
+ "xpos" "200"
+ "ypos" "112"
+ "wide" "1200"
+ "tall" "675"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "1184"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "670"
+ "wide" "1174"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "659"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "1195"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "649"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "1192"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "667"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "1182"
+ "ypos" "657"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "1190"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "610"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "codewindow"
+ {
+ "ControlName" "CSmartText"
+ "fieldName" "codewindow"
+ "xpos" "15"
+ "ypos" "15"
+ "wide" "1170"
+ "tall" "615"
+ "autoResize" "3"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "32 32 32 255"
+ "allowColorOverrides" "1"
+ }
+ "button_save"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_save"
+ "xpos" "969"
+ "ypos" "640"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "3"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Save"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "save_code"
+ "Default" "0"
+ }
+ "button_cancel"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_cancel"
+ "xpos" "1124"
+ "ypos" "640"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "3"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cancel"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "0"
+ }
+ "button_apply"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_apply"
+ "xpos" "1046"
+ "ypos" "640"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "3"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Apply"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "apply_code"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "653"
+ "ypos" "144"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/colorpicker.res b/mp/game/momentum/shadereditorui/vgui/colorpicker.res
new file mode 100644
index 0000000000..04adca163f
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/colorpicker.res
@@ -0,0 +1,616 @@
+"shadereditorui/vgui/colorpicker.res"
+{
+ "cpicker"
+ {
+ "ControlName" "ColorPicker"
+ "fieldName" "cpicker"
+ "xpos" "580"
+ "ypos" "300"
+ "wide" "440"
+ "tall" "300"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "64 64 64 160"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "424"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "295"
+ "wide" "414"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "284"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "435"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "274"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "432"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "292"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "422"
+ "ypos" "282"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "430"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "415"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "pick_hue"
+ {
+ "ControlName" "HSV_Select_Hue"
+ "fieldName" "pick_hue"
+ "xpos" "250"
+ "ypos" "40"
+ "wide" "32"
+ "tall" "200"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "pick_sv"
+ {
+ "ControlName" "HSV_Select_SV"
+ "fieldName" "pick_sv"
+ "xpos" "25"
+ "ypos" "40"
+ "wide" "200"
+ "tall" "200"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "col_0"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "col_0"
+ "xpos" "380"
+ "ypos" "40"
+ "wide" "40"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "3"
+ "NumericInputOnly" "1"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "col_1"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "col_1"
+ "xpos" "380"
+ "ypos" "70"
+ "wide" "40"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "3"
+ "NumericInputOnly" "1"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "col_2"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "col_2"
+ "xpos" "380"
+ "ypos" "100"
+ "wide" "40"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "3"
+ "NumericInputOnly" "1"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "col_hex"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "col_hex"
+ "xpos" "355"
+ "ypos" "140"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "6"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "colorpreview"
+ {
+ "ControlName" "Panel"
+ "fieldName" "colorpreview"
+ "xpos" "370"
+ "ypos" "192"
+ "wide" "48"
+ "tall" "48"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "360"
+ "ypos" "260"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "3"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cancel"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "310"
+ "ypos" "40"
+ "wide" "32"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "R"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "310"
+ "ypos" "140"
+ "wide" "40"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Hex#"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "310"
+ "ypos" "70"
+ "wide" "32"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "G"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "310"
+ "ypos" "100"
+ "wide" "32"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "B"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "280"
+ "ypos" "260"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "160 160 160 255"
+ "allowColorOverrides" "0"
+ "labelText" "Ok"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "save"
+ "Default" "1"
+ }
+ "Label5"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label5"
+ "xpos" "310"
+ "ypos" "192"
+ "wide" "48"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Result:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "42"
+ "ypos" "75"
+ "wide" "489"
+ "tall" "799"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/dialog_config.res b/mp/game/momentum/shadereditorui/vgui/dialog_config.res
new file mode 100644
index 0000000000..4e3d7c4e0d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/dialog_config.res
@@ -0,0 +1,627 @@
+"shadereditorui/dialog_config.res"
+{
+ "_config"
+ {
+ "ControlName" "CDialog_GeneralConfig"
+ "fieldName" "_config"
+ "xpos" "600"
+ "ypos" "300"
+ "wide" "400"
+ "tall" "300"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "384"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "295"
+ "wide" "374"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "284"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "395"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "274"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "392"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "292"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "382"
+ "ypos" "282"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "390"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "375"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "rad_1"
+ {
+ "ControlName" "RadioButton"
+ "fieldName" "rad_1"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "SM 2.0b"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ "SubTabPosition" "1"
+ }
+ "rad_2"
+ {
+ "ControlName" "RadioButton"
+ "fieldName" "rad_2"
+ "xpos" "140"
+ "ypos" "60"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "SM 3.0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ "SubTabPosition" "1"
+ }
+ "depthtest"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "depthtest"
+ "xpos" "168"
+ "ypos" "125"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Depth testing"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "DepthWrite"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "depthwrite"
+ "xpos" "25"
+ "ypos" "125"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Depth writing"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "srgbwrite"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "srgbwrite"
+ "xpos" "25"
+ "ypos" "225"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "write sRGB"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "alphablend"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "alphablend"
+ "xpos" "25"
+ "ypos" "190"
+ "wide" "148"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cullmode"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cullmode"
+ "xpos" "230"
+ "ypos" "190"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "35"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Target shader model:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "25"
+ "ypos" "100"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Depth buffering:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "25"
+ "ypos" "165"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Alpha blending:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "230"
+ "ypos" "165"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cullmode:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "275"
+ "ypos" "255"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cancel"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "1"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "160"
+ "ypos" "255"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Save"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "save"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "876"
+ "ypos" "124"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/dialog_editor_config.res b/mp/game/momentum/shadereditorui/vgui/dialog_editor_config.res
new file mode 100644
index 0000000000..d2f57cc484
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/dialog_editor_config.res
@@ -0,0 +1,608 @@
+"shadereditorui/vgui/dialog_editor_config.res"
+{
+ "_editor_config"
+ {
+ "ControlName" "CDialog_EditorConfig"
+ "fieldName" "_editor_config"
+ "xpos" "600"
+ "ypos" "287"
+ "wide" "400"
+ "tall" "325"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "384"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "320"
+ "wide" "374"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "309"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "395"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "299"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "392"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "317"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "382"
+ "ypos" "307"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "390"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "draw_datatypes"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "draw_datatypes"
+ "xpos" "25"
+ "ypos" "65"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Datatypes"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "draw_shadows"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "draw_shadows"
+ "xpos" "25"
+ "ypos" "90"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Shadows"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "draw_info"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "draw_info"
+ "xpos" "175"
+ "ypos" "65"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Additional info"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "draw_tooltip"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "draw_tooltip"
+ "xpos" "175"
+ "ypos" "90"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Show tooltips on graph"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "compile_preview"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "compile_preview"
+ "xpos" "25"
+ "ypos" "160"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Auto compile enabled"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "compile_always_full"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "compile_always_full"
+ "xpos" "25"
+ "ypos" "185"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Always compile preview + full"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "compile_auto_publish"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "compile_auto_publish"
+ "xpos" "25"
+ "ypos" "210"
+ "wide" "350"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Auto publish shaders to materials (full compile)"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "warn_on_close_tab"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "warn_on_close_tab"
+ "xpos" "25"
+ "ypos" "235"
+ "wide" "350"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Warn when closing a tab with unsaved changes"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "20"
+ "ypos" "35"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Draw:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "20"
+ "ypos" "130"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Compiler:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "320"
+ "ypos" "285"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cancel"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "0"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "240"
+ "ypos" "285"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Save"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "save"
+ "Default" "1"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/dialog_newcanvas.res b/mp/game/momentum/shadereditorui/vgui/dialog_newcanvas.res
new file mode 100644
index 0000000000..f1e29ebbe1
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/dialog_newcanvas.res
@@ -0,0 +1,776 @@
+"shadereditorui/dialog_newcanvas.res"
+{
+ "newshader"
+ {
+ "ControlName" "CDialog_NewCanvas"
+ "fieldName" "newshader"
+ "xpos" "600"
+ "ypos" "250"
+ "wide" "400"
+ "tall" "400"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "384"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "395"
+ "wide" "374"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "384"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "395"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "374"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "392"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "392"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "382"
+ "ypos" "382"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "390"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "375"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "rad_1"
+ {
+ "ControlName" "RadioButton"
+ "fieldName" "rad_1"
+ "xpos" "25"
+ "ypos" "230"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "SM 2.0b"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ "SubTabPosition" "1"
+ }
+ "rad_2"
+ {
+ "ControlName" "RadioButton"
+ "fieldName" "rad_2"
+ "xpos" "145"
+ "ypos" "230"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "SM 3.0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ "SubTabPosition" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "40"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Create a new shader"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "25"
+ "ypos" "75"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "empty canvas:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "230"
+ "ypos" "75"
+ "wide" "148"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Scratch"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "scratch"
+ "Default" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "25"
+ "ypos" "105"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Basic post processing shader:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "230"
+ "ypos" "105"
+ "wide" "148"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Post process"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "postprocess"
+ "Default" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "25"
+ "ypos" "135"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Basic lightmapped shader:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button3"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button3"
+ "xpos" "230"
+ "ypos" "135"
+ "wide" "70"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Blend"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "lightmapped_simple"
+ "Default" "0"
+ }
+ "Label5"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label5"
+ "xpos" "25"
+ "ypos" "165"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Basic model shader:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button4"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button4"
+ "xpos" "230"
+ "ypos" "165"
+ "wide" "70"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Generic"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "model_simple"
+ "Default" "0"
+ }
+ "Button5"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button5"
+ "xpos" "315"
+ "ypos" "360"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cancel"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "0"
+ }
+ "Label6"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label6"
+ "xpos" "25"
+ "ypos" "205"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Target shadermodel:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button6"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button6"
+ "xpos" "308"
+ "ypos" "165"
+ "wide" "70"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Complex"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "model_complex"
+ "Default" "0"
+ }
+ "Button7"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button7"
+ "xpos" "308"
+ "ypos" "135"
+ "wide" "70"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Bump"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "lightmapped_bump"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1081"
+ "ypos" "157"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Divider1"
+ {
+ "ControlName" "Divider"
+ "fieldName" "Divider1"
+ "xpos" "22"
+ "ypos" "270"
+ "wide" "350"
+ "tall" "2"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "Button8"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button8"
+ "xpos" "230"
+ "ypos" "320"
+ "wide" "148"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Scratch"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "ppeffect"
+ "Default" "1"
+ }
+ "Label7"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label7"
+ "xpos" "25"
+ "ypos" "285"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Create a new post processing effect"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label8"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label8"
+ "xpos" "25"
+ "ypos" "320"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "empty canvas:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/dialog_ppe_config.res b/mp/game/momentum/shadereditorui/vgui/dialog_ppe_config.res
new file mode 100644
index 0000000000..6f36fe4fc3
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/dialog_ppe_config.res
@@ -0,0 +1,385 @@
+"shadereditorui/vgui/dialog_ppe_config.res"
+{
+ "ppe_config"
+ {
+ "ControlName" "CDialog_PPEConfig"
+ "fieldName" "ppe_config"
+ "xpos" "660"
+ "ypos" "340"
+ "wide" "280"
+ "tall" "220"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "264"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "215"
+ "wide" "254"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "204"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "275"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "194"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "272"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "212"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "262"
+ "ypos" "202"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "270"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "255"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "autoupdatefb"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "autoupdatefb"
+ "xpos" "30"
+ "ypos" "40"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Auto update FB copy tex"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1000"
+ "ypos" "49"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "200"
+ "ypos" "180"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cancel"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "1"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "120"
+ "ypos" "180"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Save"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "save"
+ "Default" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/dialog_ppe_precache_list.res b/mp/game/momentum/shadereditorui/vgui/dialog_ppe_precache_list.res
new file mode 100644
index 0000000000..cf4b117c39
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/dialog_ppe_precache_list.res
@@ -0,0 +1,399 @@
+"shadereditorui/vgui/dialog_ppe_precache_list.res"
+{
+ "dialog_precache_ppeffect"
+ {
+ "ControlName" "CDialog_PPEPrecache"
+ "fieldName" "dialog_precache_ppeffect"
+ "xpos" "550"
+ "ypos" "200"
+ "wide" "500"
+ "tall" "500"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "484"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "495"
+ "wide" "474"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "484"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "495"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "474"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "492"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "492"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "482"
+ "ypos" "482"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "490"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "475"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "effect_list"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "effect_list"
+ "xpos" "20"
+ "ypos" "80"
+ "wide" "460"
+ "tall" "400"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "157"
+ "ypos" "14"
+ "wide" "300"
+ "tall" "32"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "The order in this list does also define the rendering order"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "1"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "20"
+ "ypos" "35"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Add effect"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "add_effect"
+ "Default" "1"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "191"
+ "ypos" "56"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Start enabled"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "defaultverysmall"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1128"
+ "ypos" "112"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/dialog_rendertarget_list.res b/mp/game/momentum/shadereditorui/vgui/dialog_rendertarget_list.res
new file mode 100644
index 0000000000..eabf484763
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/dialog_rendertarget_list.res
@@ -0,0 +1,350 @@
+"shadereditorui/vgui/dialog_rendertarget_list.res"
+{
+ "_rt_list"
+ {
+ "ControlName" "CDialog_RendertargetList"
+ "fieldName" "_rt_list"
+ "xpos" "600"
+ "ypos" "200"
+ "wide" "400"
+ "tall" "500"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "384"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "495"
+ "wide" "374"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "484"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "395"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "474"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "392"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "492"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "382"
+ "ypos" "482"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "390"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "375"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "rtlist"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "rtlist"
+ "xpos" "20"
+ "ypos" "60"
+ "wide" "360"
+ "tall" "420"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "20"
+ "ypos" "26"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Add RT"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "new_rt"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1084"
+ "ypos" "63"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/dialog_rendertarget_settings.res b/mp/game/momentum/shadereditorui/vgui/dialog_rendertarget_settings.res
new file mode 100644
index 0000000000..fd948dd09d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/dialog_rendertarget_settings.res
@@ -0,0 +1,700 @@
+"shadereditorui/vgui/dialog_rendertarget_settings.res"
+{
+ "rtsettings"
+ {
+ "ControlName" "CDialog_RendertargetSettings"
+ "fieldName" "rtsettings"
+ "xpos" "600"
+ "ypos" "225"
+ "wide" "400"
+ "tall" "450"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "384"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "445"
+ "wide" "374"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "434"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "395"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "424"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "392"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "442"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "382"
+ "ypos" "432"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "390"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "rt_name"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "rt_name"
+ "xpos" "22"
+ "ypos" "45"
+ "wide" "356"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "32"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "rt_size_x"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "rt_size_x"
+ "xpos" "40"
+ "ypos" "156"
+ "wide" "48"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "4"
+ "NumericInputOnly" "1"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "rt_size_y"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "rt_size_y"
+ "xpos" "122"
+ "ypos" "156"
+ "wide" "48"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "4"
+ "NumericInputOnly" "1"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "rtlist"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "rtlist"
+ "xpos" "50"
+ "ypos" "210"
+ "wide" "300"
+ "tall" "180"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ }
+ "cbox_format"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_format"
+ "xpos" "216"
+ "ypos" "156"
+ "wide" "164"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_sizemode"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_sizemode"
+ "xpos" "22"
+ "ypos" "100"
+ "wide" "260"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_depthmode"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_depthmode"
+ "xpos" "290"
+ "ypos" "100"
+ "wide" "90"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "317"
+ "ypos" "410"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Cancel"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "22"
+ "ypos" "22"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "RT name:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "22"
+ "ypos" "77"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Auto sizing:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "22"
+ "ypos" "133"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Fixed size:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "216"
+ "ypos" "133"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Image format:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label5"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label5"
+ "xpos" "290"
+ "ypos" "77"
+ "wide" "90"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Depth mode:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label6"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label6"
+ "xpos" "22"
+ "ypos" "156"
+ "wide" "16"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "X:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label7"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label7"
+ "xpos" "104"
+ "ypos" "156"
+ "wide" "16"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Y:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label8"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label8"
+ "xpos" "50"
+ "ypos" "186"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Flags:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1049"
+ "ypos" "76"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "239"
+ "ypos" "410"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Ok"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "Ok"
+ "Default" "1"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/shadereditor_diag_recompileall.res b/mp/game/momentum/shadereditorui/vgui/shadereditor_diag_recompileall.res
new file mode 100644
index 0000000000..788393384a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/shadereditor_diag_recompileall.res
@@ -0,0 +1,368 @@
+"shadereditorui/vgui/shadereditor_diag_recompileall.res"
+{
+ "diag_recompileall"
+ {
+ "ControlName" "CDialogRecompileAll"
+ "fieldName" "diag_recompileall"
+ "xpos" "520"
+ "ypos" "135"
+ "wide" "560"
+ "tall" "629"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "64 64 64 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "544"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "624"
+ "wide" "534"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "613"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "555"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "603"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "552"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "621"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "542"
+ "ypos" "611"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "550"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "535"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "rtext_log"
+ {
+ "ControlName" "RichText"
+ "fieldName" "rtext_log"
+ "xpos" "20"
+ "ypos" "80"
+ "wide" "520"
+ "tall" "509"
+ "autoResize" "3"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "maxchars" "-1"
+ "scrollbar" "1"
+ }
+ "button_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_close"
+ "xpos" "426"
+ "ypos" "596"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "3"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "255 64 64 255"
+ "allowColorOverrides" "0"
+ "labelText" "Terminate"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "close"
+ "Default" "1"
+ }
+ "progress_pos"
+ {
+ "ControlName" "Panel"
+ "fieldName" "progress_pos"
+ "xpos" "25"
+ "ypos" "40"
+ "wide" "510"
+ "tall" "24"
+ "autoResize" "1"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/shadereditor_preview.res b/mp/game/momentum/shadereditorui/vgui/shadereditor_preview.res
new file mode 100644
index 0000000000..d36b4cbcb5
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/shadereditor_preview.res
@@ -0,0 +1,523 @@
+"shadereditorui/vgui/shadereditor_preview.res"
+{
+ "preview"
+ {
+ "ControlName" "CPreview"
+ "fieldName" "preview"
+ "xpos" "1069"
+ "ypos" "375"
+ "wide" "478"
+ "tall" "503"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "64 64 64 196"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "462"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "498"
+ "wide" "452"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "487"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "473"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "477"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "470"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "495"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "460"
+ "ypos" "485"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "468"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "453"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "close"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "renderpanel"
+ {
+ "ControlName" "CRenderPanel"
+ "fieldName" "renderpanel"
+ "xpos" "15"
+ "ypos" "70"
+ "wide" "448"
+ "tall" "418"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "cbox_rendermode"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_rendermode"
+ "xpos" "15"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_modelseq"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_modelseq"
+ "xpos" "105"
+ "ypos" "70"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "check_moverride"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_moverride"
+ "xpos" "315"
+ "ypos" "70"
+ "wide" "110"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Mat override"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_ppe"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_ppe"
+ "xpos" "30"
+ "ypos" "29"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "160 160 160 255"
+ "allowColorOverrides" "0"
+ "labelText" " Enable rendering"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "button_modelload"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_modelload"
+ "xpos" "15"
+ "ypos" "70"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Load Mdl"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "loadmodel"
+ "Default" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "371"
+ "ypos" "30"
+ "wide" "90"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "View reset"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "reset_view"
+ "Default" "1"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "150"
+ "ypos" "30"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Load BG"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "loadbg"
+ "Default" "0"
+ }
+ "Button3"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button3"
+ "xpos" "240"
+ "ypos" "30"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "BG Color"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "bgcolor"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "551"
+ "ypos" "26"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/shadereditor_root.res b/mp/game/momentum/shadereditorui/vgui/shadereditor_root.res
new file mode 100644
index 0000000000..094e56d89b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/shadereditor_root.res
@@ -0,0 +1,666 @@
+"shadereditorui/vgui/shadereditor_root.res"
+{
+ "editor"
+ {
+ "ControlName" "CEditorRoot"
+ "fieldName" "editor"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "800"
+ "tall" "900"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "0"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "784"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "895"
+ "wide" "774"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "884"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "795"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "874"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "792"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "892"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "782"
+ "ypos" "882"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "790"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "title_label"
+ {
+ "ControlName" "Label"
+ "fieldName" "title_label"
+ "xpos" "380"
+ "ypos" "2"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Source Shader Editor v0.3"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "flowgraphsheets"
+ {
+ "ControlName" "CFlowGraphSheet"
+ "fieldName" "flowgraphsheets"
+ "xpos" "22"
+ "ypos" "45"
+ "wide" "756"
+ "tall" "833"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "1"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ }
+ "mouse_node_coords"
+ {
+ "ControlName" "Label"
+ "fieldName" "mouse_node_coords"
+ "xpos" "21"
+ "ypos" "877"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "2"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "position: 531.5 / -176.0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "framespeed"
+ {
+ "ControlName" "Label"
+ "fieldName" "framespeed"
+ "xpos" "521"
+ "ypos" "877"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "3"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "fps: 149.0, ms: 0.0067113"
+ "textAlignment" "east"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "menu_bar"
+ {
+ "ControlName" "MenuBar"
+ "fieldName" "menu_bar"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "240"
+ "tall" "28"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ }
+ "mbut_file"
+ {
+ "ControlName" "MenuButton"
+ "fieldName" "mbut_file"
+ "xpos" "4"
+ "ypos" "4"
+ "wide" "54"
+ "tall" "20"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "File"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "mbut_shader"
+ {
+ "ControlName" "MenuButton"
+ "fieldName" "mbut_shader"
+ "xpos" "58"
+ "ypos" "4"
+ "wide" "60"
+ "tall" "20"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Shader"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "mbut_postproc"
+ {
+ "ControlName" "MenuButton"
+ "fieldName" "mbut_postproc"
+ "xpos" "118"
+ "ypos" "4"
+ "wide" "118"
+ "tall" "20"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Post processing"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "736"
+ "ypos" "0"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Quit"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "quit"
+ "Default" "0"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "672"
+ "ypos" "0"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Options"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "options"
+ "Default" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "523"
+ "ypos" "25"
+ "wide" "100"
+ "tall" "14"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "F1 - toggle fullscreen"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "defaultverysmall"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "627"
+ "ypos" "25"
+ "wide" "80"
+ "tall" "14"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "F2 - toggle input"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "defaultverysmall"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "714"
+ "ypos" "25"
+ "wide" "100"
+ "tall" "14"
+ "autoResize" "0"
+ "pinCorner" "1"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "F3 - toggle visibility"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "defaultverysmall"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button3"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button3"
+ "xpos" "245"
+ "ypos" "0"
+ "wide" "118"
+ "tall" "28"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Toggle preview"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "preview"
+ "Default" "1"
+ }
+ "button_viewreset"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_viewreset"
+ "xpos" "22"
+ "ypos" "854"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "2"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "127 127 127 127"
+ "allowColorOverrides" "0"
+ "labelText" "View reset"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "resetview"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/shadereditor_shaderprecache.res b/mp/game/momentum/shadereditorui/vgui/shadereditor_shaderprecache.res
new file mode 100644
index 0000000000..315f60a48c
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/shadereditor_shaderprecache.res
@@ -0,0 +1,375 @@
+"shadereditorui/vgui/shadereditor_shaderprecache.res"
+{
+ "shaderpreview"
+ {
+ "ControlName" "CShaderPrecache"
+ "fieldName" "shaderpreview"
+ "xpos" "560"
+ "ypos" "90"
+ "wide" "480"
+ "tall" "720"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "64 64 64 196"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "frame_topGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_topGrip"
+ "xpos" "8"
+ "ypos" "0"
+ "wide" "464"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_bottomGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_bottomGrip"
+ "xpos" "8"
+ "ypos" "715"
+ "wide" "454"
+ "tall" "5"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_leftGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_leftGrip"
+ "xpos" "0"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "704"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_rightGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_rightGrip"
+ "xpos" "475"
+ "ypos" "8"
+ "wide" "5"
+ "tall" "694"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_tlGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_tlGrip"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_trGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_trGrip"
+ "xpos" "472"
+ "ypos" "0"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_blGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_blGrip"
+ "xpos" "0"
+ "ypos" "712"
+ "wide" "8"
+ "tall" "8"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_brGrip"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_brGrip"
+ "xpos" "462"
+ "ypos" "702"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_caption"
+ {
+ "ControlName" "Panel"
+ "fieldName" "frame_caption"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "470"
+ "tall" "23"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 196"
+ "allowColorOverrides" "0"
+ }
+ "frame_minimize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_minimize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_maximize"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_maximize"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_mintosystray"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_mintosystray"
+ "xpos" "0"
+ "ypos" "0"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "0"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "o"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "command" "MinimizeToSysTray"
+ "Default" "0"
+ }
+ "frame_close"
+ {
+ "ControlName" "Button"
+ "fieldName" "frame_close"
+ "xpos" "455"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "r"
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "2"
+ "textinsety" "1"
+ "Default" "0"
+ }
+ "frame_menu"
+ {
+ "ControlName" "FrameSystemButton"
+ "fieldName" "frame_menu"
+ "xpos" "7"
+ "ypos" "8"
+ "wide" "18"
+ "tall" "18"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "shaderlist"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "shaderlist"
+ "xpos" "10"
+ "ypos" "51"
+ "wide" "460"
+ "tall" "660"
+ "autoResize" "3"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ }
+ "check_reloadcache"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_reloadcache"
+ "xpos" "150"
+ "ypos" "24"
+ "wide" "180"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Reload cache on close"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "10"
+ "ypos" "24"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Add shader"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "addshader"
+ "Default" "1"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "894"
+ "ypos" "42"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_array.res b/mp/game/momentum/shadereditorui/vgui/sheet_array.res
new file mode 100644
index 0000000000..d57939923a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_array.res
@@ -0,0 +1,367 @@
+"shadereditorui/vgui/sheet_array.res"
+{
+ "asize_x"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "asize_x"
+ "xpos" "30"
+ "ypos" "15"
+ "wide" "32"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "asize_y"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "asize_y"
+ "xpos" "30"
+ "ypos" "50"
+ "wide" "32"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "gauss_bias"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "gauss_bias"
+ "xpos" "327"
+ "ypos" "15"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "ran_min"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "ran_min"
+ "xpos" "258"
+ "ypos" "50"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "ran_max"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "ran_max"
+ "xpos" "327"
+ "ypos" "50"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_datatype"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_datatype"
+ "xpos" "131"
+ "ypos" "50"
+ "wide" "70"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "array_panel"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "array_panel"
+ "xpos" "10"
+ "ypos" "80"
+ "wide" "440"
+ "tall" "220"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "1"
+ "ypos" "15"
+ "wide" "28"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "SX:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "1"
+ "ypos" "50"
+ "wide" "28"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "SY:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "65"
+ "ypos" "50"
+ "wide" "66"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Datatype:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "82"
+ "ypos" "15"
+ "wide" "120"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Update bounds"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "update_array"
+ "Default" "0"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "395"
+ "ypos" "15"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "160 160 160 255"
+ "allowColorOverrides" "0"
+ "labelText" "Gaussian"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "fill_gauss"
+ "Default" "0"
+ }
+ "Button3"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button3"
+ "xpos" "395"
+ "ypos" "50"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Random"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "fill_random"
+ "Default" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "258"
+ "ypos" "15"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Bias:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label5"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label5"
+ "xpos" "211"
+ "ypos" "32"
+ "wide" "40"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Fill:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "97"
+ "ypos" "195"
+ "wide" "421"
+ "tall" "604"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_callback.res b/mp/game/momentum/shadereditorui/vgui/sheet_callback.res
new file mode 100644
index 0000000000..8b3d49b996
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_callback.res
@@ -0,0 +1,60 @@
+"shadereditorui/sheet_callback.res"
+{
+ "cbox_callbacks"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_callbacks"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "196"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "41"
+ "ypos" "102"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "196"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Callback name:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_cmatrix.res b/mp/game/momentum/shadereditorui/vgui/sheet_cmatrix.res
new file mode 100644
index 0000000000..10bb7d9c69
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_cmatrix.res
@@ -0,0 +1,67 @@
+"shadereditorui/vgui/sheet_cmatrix.res"
+{
+ "cbox_mtype"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_mtype"
+ "xpos" "25"
+ "ypos" "70"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "42"
+ "ypos" "75"
+ "wide" "489"
+ "tall" "799"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Matrix type:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_combo.res b/mp/game/momentum/shadereditorui/vgui/sheet_combo.res
new file mode 100644
index 0000000000..38bd63276e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_combo.res
@@ -0,0 +1,165 @@
+"shadereditorui/sheet_combo.res"
+{
+ "cbox_condition"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_condition"
+ "xpos" "222"
+ "ypos" "60"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "text_cname"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "text_cname"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "20"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "text_cvar"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "text_cvar"
+ "xpos" "375"
+ "ypos" "60"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "check_static"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_static"
+ "xpos" "25"
+ "ypos" "100"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Is static"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "41"
+ "ypos" "102"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Combo name"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "222"
+ "ypos" "30"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Condition"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "375"
+ "ypos" "30"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Value"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_comment.res b/mp/game/momentum/shadereditorui/vgui/sheet_comment.res
new file mode 100644
index 0000000000..349978512a
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_comment.res
@@ -0,0 +1,67 @@
+"shadereditorui/vgui/sheet_comment.res"
+{
+ "constantvalues"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "constantvalues"
+ "xpos" "30"
+ "ypos" "60"
+ "wide" "400"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 0 128"
+ "allowColorOverrides" "1"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "1"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "30"
+ "ypos" "30"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Border color"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_condition.res b/mp/game/momentum/shadereditorui/vgui/sheet_condition.res
new file mode 100644
index 0000000000..3cbc61b3e5
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_condition.res
@@ -0,0 +1,115 @@
+"shadereditorui/vgui/sheet_condition.res"
+{
+ "cbox_condition"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_condition"
+ "xpos" "65"
+ "ypos" "60"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "30"
+ "ypos" "60"
+ "wide" "20"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "A"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "190"
+ "ypos" "60"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "B"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "65"
+ "ypos" "30"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Condition"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "97"
+ "ypos" "195"
+ "wide" "421"
+ "tall" "604"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "68 68 68 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_constant.res b/mp/game/momentum/shadereditorui/vgui/sheet_constant.res
new file mode 100644
index 0000000000..27a5943855
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_constant.res
@@ -0,0 +1,67 @@
+"shadereditorui/vgui/sheet_constant.res"
+{
+ "constantvalues"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "constantvalues"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "410"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 0 128"
+ "allowColorOverrides" "1"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Values:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1004"
+ "ypos" "184"
+ "wide" "476"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "67 67 67 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_custom_code.res b/mp/game/momentum/shadereditorui/vgui/sheet_custom_code.res
new file mode 100644
index 0000000000..52a3100e47
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_custom_code.res
@@ -0,0 +1,260 @@
+"shadereditorui/vgui/sheet_custom_code.res"
+{
+ "function_name"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "function_name"
+ "xpos" "146"
+ "ypos" "116"
+ "wide" "296"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "32"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "file_path"
+ {
+ "ControlName" "Label"
+ "fieldName" "file_path"
+ "xpos" "22"
+ "ypos" "20"
+ "wide" "420"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "-"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "check_inline"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_inline"
+ "xpos" "284"
+ "ypos" "50"
+ "wide" "164"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Save in canvas"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_lighting_ps"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_lighting_ps"
+ "xpos" "22"
+ "ypos" "215"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "160 160 160 255"
+ "allowColorOverrides" "0"
+ "labelText" "Add pixel shader lighting"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_lighting_vs"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_lighting_vs"
+ "xpos" "22"
+ "ypos" "245"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Add vertex shader lighting"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "but_editcode"
+ {
+ "ControlName" "Button"
+ "fieldName" "but_editcode"
+ "xpos" "22"
+ "ypos" "156"
+ "wide" "420"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Edit code"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "editcode"
+ "Default" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "22"
+ "ypos" "116"
+ "wide" "110"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Function name:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "button_load"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_load"
+ "xpos" "22"
+ "ypos" "50"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Load function"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "load_code"
+ "Default" "0"
+ }
+ "button_save"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_save"
+ "xpos" "132"
+ "ypos" "50"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Save function"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "save_code"
+ "Default" "0"
+ }
+ "Divider1"
+ {
+ "ControlName" "Divider"
+ "fieldName" "Divider1"
+ "xpos" "22"
+ "ypos" "94"
+ "wide" "420"
+ "tall" "2"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1081"
+ "ypos" "157"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "70 70 70 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_custom_code_io.res b/mp/game/momentum/shadereditorui/vgui/sheet_custom_code_io.res
new file mode 100644
index 0000000000..9911017acf
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_custom_code_io.res
@@ -0,0 +1,115 @@
+"shadereditorui/vgui/sheet_custom_code_io.res"
+{
+ "list_data_parent"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "list_data_parent"
+ "xpos" "22"
+ "ypos" "60"
+ "wide" "420"
+ "tall" "230"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ }
+ "but_addoutput"
+ {
+ "ControlName" "Button"
+ "fieldName" "but_addoutput"
+ "xpos" "130"
+ "ypos" "18"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Add output"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "addoutput"
+ "Default" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "22"
+ "ypos" "18"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Add input"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "addinput"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1039"
+ "ypos" "79"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Button2"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button2"
+ "xpos" "345"
+ "ypos" "18"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Reset"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "resetio"
+ "Default" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_fbtexelsize.res b/mp/game/momentum/shadereditorui/vgui/sheet_fbtexelsize.res
new file mode 100644
index 0000000000..27b1aaee62
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_fbtexelsize.res
@@ -0,0 +1,67 @@
+"shadereditorui/vgui/sheet_fbtexelsize.res"
+{
+ "fbscaling"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "fbscaling"
+ "xpos" "30"
+ "ypos" "60"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1091"
+ "ypos" "82"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "30"
+ "ypos" "20"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Texel pre-scale"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_final.res b/mp/game/momentum/shadereditorui/vgui/sheet_final.res
new file mode 100644
index 0000000000..510b4b8cdf
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_final.res
@@ -0,0 +1,83 @@
+"shadereditorui/sheet_final.res"
+{
+ "cbox_tonemap"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_tonemap"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "slight"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "slight"
+ "xpos" "25"
+ "ypos" "100"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Write depth to alpha"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "41"
+ "ypos" "102"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Tonemapping scale"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_flashlight.res b/mp/game/momentum/shadereditorui/vgui/sheet_flashlight.res
new file mode 100644
index 0000000000..3e794ca610
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_flashlight.res
@@ -0,0 +1,42 @@
+"shadereditorui/sheet_flashlight.res"
+{
+ "check_spec"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_spec"
+ "xpos" "25"
+ "ypos" "25"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Do specular"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "41"
+ "ypos" "102"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_general.res b/mp/game/momentum/shadereditorui/vgui/sheet_general.res
new file mode 100644
index 0000000000..0a8dfc662d
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_general.res
@@ -0,0 +1,183 @@
+"shadereditorui/vgui/sheet_general.res"
+{
+ "name"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "name"
+ "xpos" "30"
+ "ypos" "45"
+ "wide" "400"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "32"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "preview"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "preview"
+ "xpos" "30"
+ "ypos" "80"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Show Preview"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "label_name"
+ {
+ "ControlName" "Label"
+ "fieldName" "label_name"
+ "xpos" "30"
+ "ypos" "120"
+ "wide" "400"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Divide"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "label_info"
+ {
+ "ControlName" "Label"
+ "fieldName" "label_info"
+ "xpos" "30"
+ "ypos" "150"
+ "wide" "400"
+ "tall" "80"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "This node is used to divide two inputs.
+
+Output: The division of the two inputs. The datatype is determined by said inputs."
+ "textAlignment" "north-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "DefaultVerySmall"
+ "wrap" "1"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "label_example"
+ {
+ "ControlName" "Label"
+ "fieldName" "label_example"
+ "xpos" "30"
+ "ypos" "232"
+ "wide" "400"
+ "tall" "54"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Example: A / B"
+ "textAlignment" "south-west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "1"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "30"
+ "ypos" "21"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Node name:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "info_bg"
+ {
+ "ControlName" "Panel"
+ "fieldName" "info_bg"
+ "xpos" "18"
+ "ypos" "119"
+ "wide" "430"
+ "tall" "175"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "32 32 32 128"
+ "allowColorOverrides" "1"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_lightscale.res b/mp/game/momentum/shadereditorui/vgui/sheet_lightscale.res
new file mode 100644
index 0000000000..decdc2dbc9
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_lightscale.res
@@ -0,0 +1,60 @@
+"shadereditorui/sheet_lightscale.res"
+{
+ "cbox_lightscale"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_lightscale"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Lightscale type:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "41"
+ "ypos" "102"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_loop.res b/mp/game/momentum/shadereditorui/vgui/sheet_loop.res
new file mode 100644
index 0000000000..7616cbe149
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_loop.res
@@ -0,0 +1,142 @@
+"shadereditorui/sheet_loop.res"
+{
+ "cbox_condition"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_condition"
+ "xpos" "182"
+ "ypos" "70"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "3"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "text_start"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "text_start"
+ "xpos" "50"
+ "ypos" "70"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "text_end"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "text_end"
+ "xpos" "345"
+ "ypos" "70"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "50"
+ "ypos" "30"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Start value"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "182"
+ "ypos" "30"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Condition"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "300"
+ "ypos" "30"
+ "wide" "110"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Compare value"
+ "textAlignment" "east"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "78"
+ "ypos" "145"
+ "wide" "495"
+ "tall" "658"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_mcompose.res b/mp/game/momentum/shadereditorui/vgui/sheet_mcompose.res
new file mode 100644
index 0000000000..0d519c5b88
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_mcompose.res
@@ -0,0 +1,61 @@
+"shadereditorui/sheet_mcompose.res"
+{
+ "cbox_mtype"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_mtype"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "check_columns"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_columns"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Write columns first"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "41"
+ "ypos" "102"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_multiply.res b/mp/game/momentum/shadereditorui/vgui/sheet_multiply.res
new file mode 100644
index 0000000000..92f78bafac
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_multiply.res
@@ -0,0 +1,46 @@
+"shadereditorui/vgui/sheet_multiply.res"
+{
+ "rotationmatrix"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "rotationmatrix"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Matrix rotation only"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "42"
+ "ypos" "75"
+ "wide" "489"
+ "tall" "799"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_parallax.res b/mp/game/momentum/shadereditorui/vgui/sheet_parallax.res
new file mode 100644
index 0000000000..bd6d2b35ff
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_parallax.res
@@ -0,0 +1,255 @@
+"shadereditorui/vgui/sheet_parallax.res"
+{
+ "samp_min"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "samp_min"
+ "xpos" "25"
+ "ypos" "115"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "samp_max"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "samp_max"
+ "xpos" "130"
+ "ypos" "115"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "samp_binary"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "samp_binary"
+ "xpos" "235"
+ "ypos" "115"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "check_deptht"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_deptht"
+ "xpos" "25"
+ "ypos" "165"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Calc Geometry offset"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_grad"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_grad"
+ "xpos" "25"
+ "ypos" "195"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Use gradient lookup"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "cbox_mode"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_mode"
+ "xpos" "25"
+ "ypos" "25"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Heightmap samples:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "25"
+ "ypos" "90"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Min"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "130"
+ "ypos" "90"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Max"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "235"
+ "ypos" "90"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Binary"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "84"
+ "ypos" "151"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_pp_clear_buffers.res b/mp/game/momentum/shadereditorui/vgui/sheet_pp_clear_buffers.res
new file mode 100644
index 0000000000..d1a6959b7e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_pp_clear_buffers.res
@@ -0,0 +1,117 @@
+"shadereditorui/vgui/sheet_pp_clear_buffers.res"
+{
+ "check_do_col"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_do_col"
+ "xpos" "30"
+ "ypos" "120"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Clear color"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_do_depth"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_do_depth"
+ "xpos" "30"
+ "ypos" "150"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Clear depth"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "constantvalues"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "constantvalues"
+ "xpos" "30"
+ "ypos" "75"
+ "wide" "400"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 0 128"
+ "allowColorOverrides" "1"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "30"
+ "ypos" "30"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Clear color (normalized values)"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1091"
+ "ypos" "82"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_pp_drawmat.res b/mp/game/momentum/shadereditorui/vgui/sheet_pp_drawmat.res
new file mode 100644
index 0000000000..edd8dbb229
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_pp_drawmat.res
@@ -0,0 +1,526 @@
+"shadereditorui/vgui/sheet_pp_drawmat.res"
+{
+ "cbox_sizingrt"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_sizingrt"
+ "xpos" "40"
+ "ypos" "50"
+ "wide" "160"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_sizingsrc"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_sizingsrc"
+ "xpos" "40"
+ "ypos" "120"
+ "wide" "160"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "checkpushtg"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "checkpushtg"
+ "xpos" "230"
+ "ypos" "50"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Push target for rendering"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "default" "0"
+ }
+ "compensate_dest_x"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_dest_x"
+ "xpos" "25"
+ "ypos" "225"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_dest_y"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_dest_y"
+ "xpos" "125"
+ "ypos" "225"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_dest_w"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_dest_w"
+ "xpos" "25"
+ "ypos" "275"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_dest_h"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_dest_h"
+ "xpos" "125"
+ "ypos" "275"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_src_x0"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_src_x0"
+ "xpos" "235"
+ "ypos" "175"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_src_y0"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_src_y0"
+ "xpos" "335"
+ "ypos" "175"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_sourceuv_x"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_sourceuv_x"
+ "xpos" "235"
+ "ypos" "225"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_sourceuv_y"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_sourceuv_y"
+ "xpos" "335"
+ "ypos" "225"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_src_w"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_src_w"
+ "xpos" "235"
+ "ypos" "275"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "compensate_src_h"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "compensate_src_h"
+ "xpos" "335"
+ "ypos" "275"
+ "wide" "96"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "40"
+ "ypos" "20"
+ "wide" "160"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Reference target RT"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "40"
+ "ypos" "90"
+ "wide" "160"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Reference source RT"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "25"
+ "ypos" "170"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Destination offset (absolute)"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "25"
+ "ypos" "250"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "width/height"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label5"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label5"
+ "xpos" "25"
+ "ypos" "200"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "position x/y"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label6"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label6"
+ "xpos" "235"
+ "ypos" "120"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Source offset"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label7"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label7"
+ "xpos" "235"
+ "ypos" "150"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "UV x0/y0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label8"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label8"
+ "xpos" "235"
+ "ypos" "200"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "UV x1/y1"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label9"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label9"
+ "xpos" "235"
+ "ypos" "250"
+ "wide" "200"
+ "tall" "24"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "width/height"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1066"
+ "ypos" "61"
+ "wide" "341"
+ "tall" "583"
+ "AutoResize" "0"
+ "PinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "bgcolor" "48 48 48 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_pp_mat.res b/mp/game/momentum/shadereditorui/vgui/sheet_pp_mat.res
new file mode 100644
index 0000000000..4b68a2e721
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_pp_mat.res
@@ -0,0 +1,148 @@
+"shadereditorui/vgui/sheet_pp_mat.res"
+{
+ "check_inline"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_inline"
+ "xpos" "180"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Inline material"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "button_load"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_load"
+ "xpos" "22"
+ "ypos" "90"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Load material"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "mat_load"
+ "Default" "0"
+ }
+ "button_save"
+ {
+ "ControlName" "Button"
+ "fieldName" "button_save"
+ "xpos" "140"
+ "ypos" "90"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Save material"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "mat_save"
+ "Default" "0"
+ }
+ "label_matpath"
+ {
+ "ControlName" "Label"
+ "fieldName" "label_matpath"
+ "xpos" "22"
+ "ypos" "130"
+ "wide" "420"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "-"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Button1"
+ {
+ "ControlName" "Button"
+ "fieldName" "Button1"
+ "xpos" "22"
+ "ypos" "31"
+ "wide" "100"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Edit vmt"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "edit_vmt"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1128"
+ "ypos" "112"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_pp_rt.res b/mp/game/momentum/shadereditorui/vgui/sheet_pp_rt.res
new file mode 100644
index 0000000000..a2fee9c1c7
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_pp_rt.res
@@ -0,0 +1,83 @@
+"shadereditorui/vgui/sheet_pp_rt.res"
+{
+ "textentry_rtname"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "textentry_rtname"
+ "xpos" "22"
+ "ypos" "40"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "48"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "img_ref"
+ {
+ "ControlName" "Panel"
+ "fieldName" "img_ref"
+ "xpos" "50"
+ "ypos" "80"
+ "wide" "200"
+ "tall" "200"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "22"
+ "ypos" "10"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Search RT by name or select from list"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_pp_viewrender.res b/mp/game/momentum/shadereditorui/vgui/sheet_pp_viewrender.res
new file mode 100644
index 0000000000..080a0a203e
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_pp_viewrender.res
@@ -0,0 +1,132 @@
+"shadereditorui/vgui/sheet_pp_viewrender.res"
+{
+ "list_options"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "list_options"
+ "xpos" "20"
+ "ypos" "85"
+ "wide" "420"
+ "tall" "205"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ }
+ "cbox_vrnames"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_vrnames"
+ "xpos" "130"
+ "ypos" "20"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "check_scenedraw"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_scenedraw"
+ "xpos" "130"
+ "ypos" "55"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Render during main scene"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "20"
+ "ypos" "20"
+ "wide" "110"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Function name:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "20"
+ "ypos" "55"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Options:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_psoutput.res b/mp/game/momentum/shadereditorui/vgui/sheet_psoutput.res
new file mode 100644
index 0000000000..8432c8bdd1
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_psoutput.res
@@ -0,0 +1,100 @@
+"resource/sheet_psoutput.res"
+{
+ "col"
+ {
+ "ControlName" "Slider"
+ "fieldName" "col"
+ "xpos" "170"
+ "ypos" "50"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ }
+ "depth"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "depth"
+ "xpos" "22"
+ "ypos" "90"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Enable depth"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "info_col"
+ {
+ "ControlName" "Label"
+ "fieldName" "info_col"
+ "xpos" "300"
+ "ypos" "50"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "1"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "22"
+ "ypos" "50"
+ "wide" "140"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Num color out:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1021"
+ "ypos" "34"
+ "wide" "498"
+ "tall" "476"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_random.res b/mp/game/momentum/shadereditorui/vgui/sheet_random.res
new file mode 100644
index 0000000000..2c061a4dfb
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_random.res
@@ -0,0 +1,142 @@
+"shadereditorui/vgui/sheet_random.res"
+{
+ "vartype"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "vartype"
+ "xpos" "25"
+ "ypos" "130"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "value_min"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "value_min"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "value_max"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "value_max"
+ "xpos" "200"
+ "ypos" "60"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "35"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Value min:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "200"
+ "ypos" "35"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Value max:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "25"
+ "ypos" "105"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Type:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "34"
+ "ypos" "163"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_std_plight.res b/mp/game/momentum/shadereditorui/vgui/sheet_std_plight.res
new file mode 100644
index 0000000000..50b8491992
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_std_plight.res
@@ -0,0 +1,88 @@
+"shadereditorui/sheet_std_plight.res"
+{
+ "slight"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "slight"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Has static lighting"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "AO"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "AO"
+ "xpos" "25"
+ "ypos" "90"
+ "wide" "258"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "AO term"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "halfl"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "halfl"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "258"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Half lambert"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "755"
+ "ypos" "33"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_std_pspeclight.res b/mp/game/momentum/shadereditorui/vgui/sheet_std_pspeclight.res
new file mode 100644
index 0000000000..1af7fa9580
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_std_pspeclight.res
@@ -0,0 +1,46 @@
+"shadereditorui/vgui/sheet_std_pspeclight.res"
+{
+ "AO"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "AO"
+ "xpos" "25"
+ "ypos" "25"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "AO term"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1096"
+ "ypos" "231"
+ "wide" "476"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_std_skinning.res b/mp/game/momentum/shadereditorui/vgui/sheet_std_skinning.res
new file mode 100644
index 0000000000..a862b7c7d0
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_std_skinning.res
@@ -0,0 +1,60 @@
+"shadereditorui/sheet_std_skinning.res"
+{
+ "cbox_mode"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_mode"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "92"
+ "ypos" "100"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "256"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Skinning mode:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_std_vlight.res b/mp/game/momentum/shadereditorui/vgui/sheet_std_vlight.res
new file mode 100644
index 0000000000..f3747047a9
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_std_vlight.res
@@ -0,0 +1,65 @@
+"shadereditorui/sheet_std_vlight.res"
+{
+ "slight"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "slight"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "258"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Support static lighting"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "halfl"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "halfl"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "labelText" "Half lambert"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1105"
+ "ypos" "81"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_swizzle.res b/mp/game/momentum/shadereditorui/vgui/sheet_swizzle.res
new file mode 100644
index 0000000000..0105860bc9
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_swizzle.res
@@ -0,0 +1,67 @@
+"shadereditorui/vgui/sheet_swizzle.res"
+{
+ "name"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "name"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "410"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 0 128"
+ "allowColorOverrides" "1"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Arbitrary swizzle:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1004"
+ "ypos" "184"
+ "wide" "476"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "72 72 72 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_texsample.res b/mp/game/momentum/shadereditorui/vgui/sheet_texsample.res
new file mode 100644
index 0000000000..e8fdbe70fa
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_texsample.res
@@ -0,0 +1,321 @@
+"shadereditorui/vgui/sheet_texsample.res"
+{
+ "parameter"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "parameter"
+ "xpos" "270"
+ "ypos" "45"
+ "wide" "180"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "srgb"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "srgb"
+ "xpos" "25"
+ "ypos" "70"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "sRGB read"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "textype"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "textype"
+ "xpos" "25"
+ "ypos" "45"
+ "wide" "180"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "demotexname"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "demotexname"
+ "xpos" "270"
+ "ypos" "131"
+ "wide" "180"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "loadtexture"
+ {
+ "ControlName" "Button"
+ "fieldName" "loadtexture"
+ "xpos" "270"
+ "ypos" "106"
+ "wide" "140"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Load demo texture"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "openvtf"
+ "Default" "0"
+ }
+ "fallbacktexname"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "fallbacktexname"
+ "xpos" "25"
+ "ypos" "156"
+ "wide" "180"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "fallbacktype"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "fallbacktype"
+ "xpos" "25"
+ "ypos" "131"
+ "wide" "90"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "lookupoverride"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "lookupoverride"
+ "xpos" "25"
+ "ypos" "262"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "20"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Texture type:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "270"
+ "ypos" "20"
+ "wide" "140"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Material parameter:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "imagepos"
+ {
+ "ControlName" "ImagePanel"
+ "fieldName" "imagepos"
+ "xpos" "322"
+ "ypos" "156"
+ "wide" "128"
+ "tall" "128"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "scaleImage" "0"
+ "scaleAmount" "0.000000"
+ "tileImage" "0"
+ "tileHorizontally" "0"
+ "tileVertically" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "25"
+ "ypos" "106"
+ "wide" "180"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "VMT fallback texture:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label_lookup"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label_lookup"
+ "xpos" "25"
+ "ypos" "237"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Lookup override:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1128"
+ "ypos" "112"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_textransform.res b/mp/game/momentum/shadereditorui/vgui/sheet_textransform.res
new file mode 100644
index 0000000000..919119b513
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_textransform.res
@@ -0,0 +1,133 @@
+"shadereditorui/sheet_textransform.res"
+{
+ "check_center"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_center"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "196"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Custom center"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_rot"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_rot"
+ "xpos" "25"
+ "ypos" "90"
+ "wide" "196"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Rotation"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_scale"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_scale"
+ "xpos" "25"
+ "ypos" "120"
+ "wide" "196"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Scale"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "check_translation"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "check_translation"
+ "xpos" "25"
+ "ypos" "150"
+ "wide" "196"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Translation"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "993"
+ "ypos" "38"
+ "wide" "495"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "25"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Active transforms:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_vcompression.res b/mp/game/momentum/shadereditorui/vgui/sheet_vcompression.res
new file mode 100644
index 0000000000..7e4e176fd1
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_vcompression.res
@@ -0,0 +1,67 @@
+"shadereditorui/vgui/sheet_vcompression.res"
+{
+ "cbox_modes"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_modes"
+ "xpos" "30"
+ "ypos" "60"
+ "wide" "260"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "30"
+ "ypos" "30"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Decompression mode"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_vparam_mutable.res b/mp/game/momentum/shadereditorui/vgui/sheet_vparam_mutable.res
new file mode 100644
index 0000000000..dc6d1167ed
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_vparam_mutable.res
@@ -0,0 +1,135 @@
+"shadereditorui/vgui/sheet_vparam_mutable.res"
+{
+ "cbox_params"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_params"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_types"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_types"
+ "xpos" "260"
+ "ypos" "60"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "constantvalues"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "constantvalues"
+ "xpos" "25"
+ "ypos" "140"
+ "wide" "410"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 0 128"
+ "allowColorOverrides" "1"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Param name:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "260"
+ "ypos" "30"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Type:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1081"
+ "ypos" "157"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_vparam_static.res b/mp/game/momentum/shadereditorui/vgui/sheet_vparam_static.res
new file mode 100644
index 0000000000..584df93d1b
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_vparam_static.res
@@ -0,0 +1,159 @@
+"shadereditorui/vgui/sheet_vparam_static.res"
+{
+ "cbox_types"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_types"
+ "xpos" "260"
+ "ypos" "60"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "tentry_name"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "tentry_name"
+ "xpos" "25"
+ "ypos" "60"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "32"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "constantvalues"
+ {
+ "ControlName" "TextEntry"
+ "fieldName" "constantvalues"
+ "xpos" "25"
+ "ypos" "130"
+ "wide" "410"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 0 128"
+ "allowColorOverrides" "1"
+ "textHidden" "0"
+ "editable" "1"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "1"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "260"
+ "ypos" "30"
+ "wide" "96"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Type:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "25"
+ "ypos" "30"
+ "wide" "200"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Vmt parameter name:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "25"
+ "ypos" "100"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Default values:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1004"
+ "ypos" "184"
+ "wide" "476"
+ "tall" "657"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "70 70 70 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_vsinput.res b/mp/game/momentum/shadereditorui/vgui/sheet_vsinput.res
new file mode 100644
index 0000000000..7a5466cdcd
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_vsinput.res
@@ -0,0 +1,557 @@
+"shadereditorui/vgui/sheet_vsinput.res"
+{
+ "flex"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "flex"
+ "xpos" "22"
+ "ypos" "20"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "160 160 160 255"
+ "allowColorOverrides" "0"
+ "labelText" "Flex delta"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "Normal"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "normal"
+ "xpos" "22"
+ "ypos" "50"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Normal"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "normal_compression"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "normal_compression"
+ "xpos" "164"
+ "ypos" "50"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Compressed"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "tangent"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "tangent"
+ "xpos" "22"
+ "ypos" "80"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Tangentspace"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "blend"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "blend"
+ "xpos" "22"
+ "ypos" "110"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Skinning"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "command" "Skinning"
+ "Default" "0"
+ }
+ "tangent_skinable"
+ {
+ "ControlName" "CheckButton"
+ "fieldName" "tangent_skinable"
+ "xpos" "164"
+ "ypos" "80"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "For skinning"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "6"
+ "textinsety" "0"
+ "Default" "0"
+ }
+ "tex"
+ {
+ "ControlName" "Slider"
+ "fieldName" "tex"
+ "xpos" "170"
+ "ypos" "150"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "col"
+ {
+ "ControlName" "Slider"
+ "fieldName" "col"
+ "xpos" "170"
+ "ypos" "175"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ }
+ "info_tex"
+ {
+ "ControlName" "Label"
+ "fieldName" "info_tex"
+ "xpos" "300"
+ "ypos" "150"
+ "wide" "20"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "1"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "info_col"
+ {
+ "ControlName" "Label"
+ "fieldName" "info_col"
+ "xpos" "300"
+ "ypos" "180"
+ "wide" "20"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "cbox_dtypes_texcoords_0"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_dtypes_texcoords_0"
+ "xpos" "120"
+ "ypos" "240"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_dtypes_texcoords_1"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_dtypes_texcoords_1"
+ "xpos" "215"
+ "ypos" "240"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_dtypes_texcoords_2"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_dtypes_texcoords_2"
+ "xpos" "310"
+ "ypos" "240"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_dtypes_color_0"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_dtypes_color_0"
+ "xpos" "120"
+ "ypos" "270"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "cbox_dtypes_color_1"
+ {
+ "ControlName" "ComboBox"
+ "fieldName" "cbox_dtypes_color_1"
+ "xpos" "215"
+ "ypos" "270"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "0"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 128"
+ "allowColorOverrides" "0"
+ "textHidden" "0"
+ "editable" "0"
+ "maxchars" "-1"
+ "NumericInputOnly" "0"
+ "unicode" "0"
+ "TokenChannels" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "22"
+ "ypos" "150"
+ "wide" "140"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Num texture coords:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "22"
+ "ypos" "175"
+ "wide" "140"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Num vertex colors:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label3"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label3"
+ "xpos" "22"
+ "ypos" "210"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Datatype:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label4"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label4"
+ "xpos" "22"
+ "ypos" "240"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Texcoord:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label5"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label5"
+ "xpos" "22"
+ "ypos" "270"
+ "wide" "80"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Color:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label6"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label6"
+ "xpos" "120"
+ "ypos" "220"
+ "wide" "80"
+ "tall" "16"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Slot 0"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "defaultverysmall"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label7"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label7"
+ "xpos" "215"
+ "ypos" "220"
+ "wide" "80"
+ "tall" "16"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Slot 1"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "defaultverysmall"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label8"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label8"
+ "xpos" "310"
+ "ypos" "220"
+ "wide" "80"
+ "tall" "16"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "0 0 0 0"
+ "allowColorOverrides" "0"
+ "labelText" "Slot 2"
+ "textAlignment" "center"
+ "dulltext" "0"
+ "brighttext" "0"
+ "Font" "defaultverysmall"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1092"
+ "ypos" "60"
+ "wide" "437"
+ "tall" "708"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "BgColor" "96 96 96 255"
+ "allowColorOverrides" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shadereditorui/vgui/sheet_vsoutput_psinput.res b/mp/game/momentum/shadereditorui/vgui/sheet_vsoutput_psinput.res
new file mode 100644
index 0000000000..b612d07b45
--- /dev/null
+++ b/mp/game/momentum/shadereditorui/vgui/sheet_vsoutput_psinput.res
@@ -0,0 +1,149 @@
+"resource/sheet_vsoutput_psinput.res"
+{
+ "tex"
+ {
+ "ControlName" "Slider"
+ "fieldName" "tex"
+ "xpos" "170"
+ "ypos" "30"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ }
+ "col"
+ {
+ "ControlName" "Slider"
+ "fieldName" "col"
+ "xpos" "170"
+ "ypos" "60"
+ "wide" "128"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ }
+ "list_data"
+ {
+ "ControlName" "PanelListPanel"
+ "fieldName" "list_data"
+ "xpos" "31"
+ "ypos" "110"
+ "wide" "400"
+ "tall" "165"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ }
+ "info_tex"
+ {
+ "ControlName" "Label"
+ "fieldName" "info_tex"
+ "xpos" "300"
+ "ypos" "30"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "info_col"
+ {
+ "ControlName" "Label"
+ "fieldName" "info_col"
+ "xpos" "300"
+ "ypos" "60"
+ "wide" "64"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "0"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label1"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label1"
+ "xpos" "22"
+ "ypos" "30"
+ "wide" "140"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Num texture coords:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "Label2"
+ {
+ "ControlName" "Label"
+ "fieldName" "Label2"
+ "xpos" "22"
+ "ypos" "60"
+ "wide" "140"
+ "tall" "24"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "labelText" "Num vertex colors:"
+ "textAlignment" "west"
+ "dulltext" "0"
+ "brighttext" "0"
+ "wrap" "0"
+ "centerwrap" "0"
+ "textinsetx" "0"
+ "textinsety" "0"
+ }
+ "BuildModeDialog"
+ {
+ "ControlName" "BuildModeDialog"
+ "fieldName" "BuildModeDialog"
+ "xpos" "1021"
+ "ypos" "34"
+ "wide" "498"
+ "tall" "476"
+ "autoResize" "0"
+ "pinCorner" "0"
+ "visible" "1"
+ "enabled" "1"
+ "tabPosition" "0"
+ "settitlebarvisible" "1"
+ "title" "#Frame_Untitled"
+ }
+}
diff --git a/mp/game/momentum/shaders/fxc/basetexture_accum_ps30.vcs b/mp/game/momentum/shaders/fxc/basetexture_accum_ps30.vcs
new file mode 100644
index 0000000000..3524a7f678
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/basetexture_accum_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/basetexture_accum_vs30.vcs b/mp/game/momentum/shaders/fxc/basetexture_accum_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/basetexture_accum_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/basetexture_blend_ps30.vcs b/mp/game/momentum/shaders/fxc/basetexture_blend_ps30.vcs
new file mode 100644
index 0000000000..899f05d744
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/basetexture_blend_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/basetexture_blend_vs30.vcs b/mp/game/momentum/shaders/fxc/basetexture_blend_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/basetexture_blend_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/colorpicker_blend_ps20.vcs b/mp/game/momentum/shaders/fxc/colorpicker_blend_ps20.vcs
new file mode 100644
index 0000000000..66649b0c39
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/colorpicker_blend_ps20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/colorpicker_blend_vs20.vcs b/mp/game/momentum/shaders/fxc/colorpicker_blend_vs20.vcs
new file mode 100644
index 0000000000..18a639a98d
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/colorpicker_blend_vs20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/detail_prop_shader_ps30.vcs b/mp/game/momentum/shaders/fxc/detail_prop_shader_ps30.vcs
new file mode 100644
index 0000000000..f950d9ee7a
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/detail_prop_shader_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/detail_prop_shader_vs30.vcs b/mp/game/momentum/shaders/fxc/detail_prop_shader_vs30.vcs
new file mode 100644
index 0000000000..83247707e6
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/detail_prop_shader_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/downsample_4_ps30.vcs b/mp/game/momentum/shaders/fxc/downsample_4_ps30.vcs
new file mode 100644
index 0000000000..503c04fdca
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/downsample_4_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/downsample_4_vs30.vcs b/mp/game/momentum/shaders/fxc/downsample_4_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/downsample_4_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/fallback_ps20.vcs b/mp/game/momentum/shaders/fxc/fallback_ps20.vcs
new file mode 100644
index 0000000000..0cebacceea
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/fallback_ps20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/fallback_vs20.vcs b/mp/game/momentum/shaders/fxc/fallback_vs20.vcs
new file mode 100644
index 0000000000..0f8b44a168
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/fallback_vs20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/fbquad_ps20.vcs b/mp/game/momentum/shaders/fxc/fbquad_ps20.vcs
new file mode 100644
index 0000000000..70e2b72a89
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/fbquad_ps20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/fbquad_vs20.vcs b/mp/game/momentum/shaders/fxc/fbquad_vs20.vcs
new file mode 100644
index 0000000000..75b7ea66c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/fbquad_vs20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_5_x_ps30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_5_x_ps30.vcs
new file mode 100644
index 0000000000..589b255982
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_5_x_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_5_x_vs30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_5_x_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_5_x_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_5_y_ps30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_5_y_ps30.vcs
new file mode 100644
index 0000000000..6e1e972d6d
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_5_y_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_5_y_vs30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_5_y_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_5_y_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_x_ps30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_x_ps30.vcs
new file mode 100644
index 0000000000..37531288fe
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_x_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_x_vs30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_x_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_x_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_y_ps30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_y_ps30.vcs
new file mode 100644
index 0000000000..ffc981000d
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_y_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_y_vs30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_y_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_7_half_aceil_y_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_half_3_x_ps30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_x_ps30.vcs
new file mode 100644
index 0000000000..24ebc125ef
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_x_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_half_3_x_vs30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_x_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_x_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_half_3_y_ps30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_y_ps30.vcs
new file mode 100644
index 0000000000..7a50e0006d
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_y_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/gauss_blur_half_3_y_vs30.vcs b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_y_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/gauss_blur_half_3_y_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/lightmap_blend_bump_detail_ps30.vcs b/mp/game/momentum/shaders/fxc/lightmap_blend_bump_detail_ps30.vcs
new file mode 100644
index 0000000000..4f7fc3dbbb
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/lightmap_blend_bump_detail_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/lightmap_blend_bump_detail_vs30.vcs b/mp/game/momentum/shaders/fxc/lightmap_blend_bump_detail_vs30.vcs
new file mode 100644
index 0000000000..263359ca9e
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/lightmap_blend_bump_detail_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/lightmap_parallax_ps30.vcs b/mp/game/momentum/shaders/fxc/lightmap_parallax_ps30.vcs
new file mode 100644
index 0000000000..27f96a8bcd
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/lightmap_parallax_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/lightmap_parallax_vs30.vcs b/mp/game/momentum/shaders/fxc/lightmap_parallax_vs30.vcs
new file mode 100644
index 0000000000..6dcee2062e
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/lightmap_parallax_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_chromatic_aberration_ps30.vcs b/mp/game/momentum/shaders/fxc/model_chromatic_aberration_ps30.vcs
new file mode 100644
index 0000000000..9fca806a0b
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_chromatic_aberration_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_chromatic_aberration_vs30.vcs b/mp/game/momentum/shaders/fxc/model_chromatic_aberration_vs30.vcs
new file mode 100644
index 0000000000..40e852ffe6
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_chromatic_aberration_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_cubemap_ps30.vcs b/mp/game/momentum/shaders/fxc/model_cubemap_ps30.vcs
new file mode 100644
index 0000000000..2cdab8221b
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_cubemap_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_cubemap_vs30.vcs b/mp/game/momentum/shaders/fxc/model_cubemap_vs30.vcs
new file mode 100644
index 0000000000..ff7e19469a
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_cubemap_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_litsphere_ps30.vcs b/mp/game/momentum/shaders/fxc/model_litsphere_ps30.vcs
new file mode 100644
index 0000000000..94950de4ae
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_litsphere_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_litsphere_vs30.vcs b/mp/game/momentum/shaders/fxc/model_litsphere_vs30.vcs
new file mode 100644
index 0000000000..56163b2417
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_litsphere_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_snowy_ps30.vcs b/mp/game/momentum/shaders/fxc/model_snowy_ps30.vcs
new file mode 100644
index 0000000000..e393e99425
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_snowy_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_snowy_vs30.vcs b/mp/game/momentum/shaders/fxc/model_snowy_vs30.vcs
new file mode 100644
index 0000000000..dc91579906
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_snowy_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_solid_ps30.vcs b/mp/game/momentum/shaders/fxc/model_solid_ps30.vcs
new file mode 100644
index 0000000000..589f8372c8
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_solid_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/model_solid_vs30.vcs b/mp/game/momentum/shaders/fxc/model_solid_vs30.vcs
new file mode 100644
index 0000000000..7bf81c4374
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/model_solid_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/node_ps20.vcs b/mp/game/momentum/shaders/fxc/node_ps20.vcs
new file mode 100644
index 0000000000..5ef9e2dab6
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/node_ps20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/node_vs20.vcs b/mp/game/momentum/shaders/fxc/node_vs20.vcs
new file mode 100644
index 0000000000..6b220d68c0
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/node_vs20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/prev_ps20.vcs b/mp/game/momentum/shaders/fxc/prev_ps20.vcs
new file mode 100644
index 0000000000..3aa0e9c27d
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/prev_ps20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/prev_vs20.vcs b/mp/game/momentum/shaders/fxc/prev_vs20.vcs
new file mode 100644
index 0000000000..2a316a6a33
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/prev_vs20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/psin_ps20.vcs b/mp/game/momentum/shaders/fxc/psin_ps20.vcs
new file mode 100644
index 0000000000..a0ba9931b6
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/psin_ps20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/psin_ps30.vcs b/mp/game/momentum/shaders/fxc/psin_ps30.vcs
new file mode 100644
index 0000000000..bf916ceac8
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/psin_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/psin_vs20.vcs b/mp/game/momentum/shaders/fxc/psin_vs20.vcs
new file mode 100644
index 0000000000..e8ea346ed1
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/psin_vs20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/skymask_ps20.vcs b/mp/game/momentum/shaders/fxc/skymask_ps20.vcs
new file mode 100644
index 0000000000..0c974d8f20
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/skymask_ps20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/skymask_vs20.vcs b/mp/game/momentum/shaders/fxc/skymask_vs20.vcs
new file mode 100644
index 0000000000..a9c458cce6
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/skymask_vs20.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/sprite_sun_nodepth_ps30.vcs b/mp/game/momentum/shaders/fxc/sprite_sun_nodepth_ps30.vcs
new file mode 100644
index 0000000000..3b046a3fc2
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/sprite_sun_nodepth_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/sprite_sun_nodepth_vs30.vcs b/mp/game/momentum/shaders/fxc/sprite_sun_nodepth_vs30.vcs
new file mode 100644
index 0000000000..7e80e95010
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/sprite_sun_nodepth_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/ssao_calc_ps30.vcs b/mp/game/momentum/shaders/fxc/ssao_calc_ps30.vcs
new file mode 100644
index 0000000000..6009a5e09a
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/ssao_calc_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/ssao_calc_vs30.vcs b/mp/game/momentum/shaders/fxc/ssao_calc_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/ssao_calc_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/ssao_combine_ps30.vcs b/mp/game/momentum/shaders/fxc/ssao_combine_ps30.vcs
new file mode 100644
index 0000000000..b0076a6afc
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/ssao_combine_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/ssao_combine_vs30.vcs b/mp/game/momentum/shaders/fxc/ssao_combine_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/ssao_combine_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/ssao_fxaa_ps30.vcs b/mp/game/momentum/shaders/fxc/ssao_fxaa_ps30.vcs
new file mode 100644
index 0000000000..18baf7ca1b
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/ssao_fxaa_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/ssao_fxaa_vs30.vcs b/mp/game/momentum/shaders/fxc/ssao_fxaa_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/ssao_fxaa_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/sunrays_calc_ps30.vcs b/mp/game/momentum/shaders/fxc/sunrays_calc_ps30.vcs
new file mode 100644
index 0000000000..dafa3931b3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/sunrays_calc_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/sunrays_calc_vs30.vcs b/mp/game/momentum/shaders/fxc/sunrays_calc_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/sunrays_calc_vs30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/swarm_test_ps30.vcs b/mp/game/momentum/shaders/fxc/swarm_test_ps30.vcs
new file mode 100644
index 0000000000..3a465d6b70
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/swarm_test_ps30.vcs differ
diff --git a/mp/game/momentum/shaders/fxc/swarm_test_vs30.vcs b/mp/game/momentum/shaders/fxc/swarm_test_vs30.vcs
new file mode 100644
index 0000000000..fd1687a9c3
Binary files /dev/null and b/mp/game/momentum/shaders/fxc/swarm_test_vs30.vcs differ
diff --git a/mp/src/creategameprojects.ps1 b/mp/src/creategameprojects.ps1
index 9b73bcc202..81c2ce3337 100644
--- a/mp/src/creategameprojects.ps1
+++ b/mp/src/creategameprojects.ps1
@@ -9,16 +9,24 @@ $path = (Get-ItemProperty "HKLM:\SOFTWARE\Wow6432Node\Microsoft\Windows\CurrentV
if (!$path)
{
- Write-Warning "You should install Source SDK Base 2013 Multiplayer.`nRequesting Steam to install the app..."
- try {
- $cmd ="cmd.exe"
- &$cmd "/c start steam://install/243750/"
+ $path2 = (Get-ItemProperty "HKLM:\SOFTWARE\Microsoft\Windows\CurrentVersion\Uninstall\Steam App 243750" -Name InstallLocation).InstallLocation
+ if (!$path2)
+ {
+ Write-Warning "You should install Source SDK Base 2013 Multiplayer.`nRequesting Steam to install the app..."
+ try {
+ $cmd ="cmd.exe"
+ &$cmd "/c start steam://install/243750/"
+ }
+ catch {
+ Write-Warning "Steam is not running. Can not launch installation pop-up"
+ }
+ pause
+ exit
}
- catch {
- Write-Warning "Steam is not running. Can not launch installation pop-up"
+ else
+ {
+ ($path = $path2)
}
- pause
- exit
}
$hl2exe = Join-Path $path hl2.exe
diff --git a/mp/src/game/client/ShaderEditor/ISEdit_ModelRender.h b/mp/src/game/client/ShaderEditor/ISEdit_ModelRender.h
new file mode 100644
index 0000000000..6db545e926
--- /dev/null
+++ b/mp/src/game/client/ShaderEditor/ISEdit_ModelRender.h
@@ -0,0 +1,41 @@
+#ifndef IV_SHADEREDITOR_MRENDER
+#define IV_SHADEREDITOR_MRENDER
+
+#ifdef _WIN32
+#pragma once
+#endif // _WIN32
+
+#ifdef SHADER_EDITOR_DLL
+#include "../public/tier1/interface.h"
+#else
+#include "interface.h"
+#include "ShaderEditor/ShaderEditorSystem.h"
+#endif // NOT SHADER_EDITOR_DLL
+
+
+class ISEditModelRender
+{
+public:
+ virtual bool LoadModel( const char *localPath ) = 0;
+ virtual void DestroyModel() = 0;
+ virtual void GetModelCenter( float *pFl3_ViewOffset ) = 0;
+
+ virtual int QuerySequences( char ***list ) = 0;
+ virtual void SetSequence( const char *name ) = 0;
+
+ virtual void ExecRender() = 0;
+ virtual void DoPostProc( int x, int y, int w, int h ) = 0;
+ virtual int MaterialPicker( char ***szMat ) = 0;
+
+ virtual void DestroyCharPtrList( char ***szList ) = 0;
+};
+
+
+#ifdef SHADER_EDITOR_DLL
+extern ISEditModelRender *sEditMRender;
+#else
+class SEditModelRender;
+extern SEditModelRender *sEditMRender;
+#endif
+
+#endif
\ No newline at end of file
diff --git a/mp/src/game/client/ShaderEditor/IVShaderEditor.h b/mp/src/game/client/ShaderEditor/IVShaderEditor.h
new file mode 100644
index 0000000000..160aafbd75
--- /dev/null
+++ b/mp/src/game/client/ShaderEditor/IVShaderEditor.h
@@ -0,0 +1,128 @@
+#ifndef IV_SHADEREDITOR
+#define IV_SHADEREDITOR
+
+#ifdef _WIN32
+#pragma once
+#endif // _WIN32
+
+#define pFnClCallback( x ) void(* x )( float *pfl4 )
+#define pFnClCallback_Declare( x ) void x( float *pfl4 )
+
+#define pFnVrCallback( x ) void(* x )( bool * const pbOptions, int * const piOptions,\
+ float * const pflOptions, char ** const pszOptions )
+#define pFnVrCallback_Declare( x ) void x( bool * const pbOptions, int * const piOptions,\
+ float * const pflOptions, char ** const pszOptions )
+
+#ifndef PROCSHADER_DLL
+
+#ifdef SHADER_EDITOR_DLL
+#include "../public/tier1/interface.h"
+#include "view_shared.h"
+#else
+#include "interface.h"
+#include "ShaderEditor/ShaderEditorSystem.h"
+#endif // NOT SHADER_EDITOR_DLL
+
+enum SEDIT_SKYMASK_MODE
+{
+ SKYMASK_OFF = 0,
+ SKYMASK_QUARTER, // render at 1/4 fb size where possible
+ SKYMASK_FULL, // render at full fb size
+};
+
+class CViewSetup_SEdit_Shared
+{
+public:
+ CViewSetup_SEdit_Shared()
+ {
+ Q_memset( this, 0, sizeof( CViewSetup_SEdit_Shared ) );
+ };
+ CViewSetup_SEdit_Shared( const CViewSetup &o )
+ {
+ x = o.x;
+ y = o.y;
+ width = o.width;
+ height = o.height;
+ fov = o.fov;
+ fovViewmodel = o.fovViewmodel;
+ origin = o.origin;
+ angles = o.angles;
+ zNear = o.zNear;
+ zFar = o.zFar;
+ zNearViewmodel = o.zNearViewmodel;
+ zFarViewmodel = o.zFarViewmodel;
+ m_flAspectRatio = o.m_flAspectRatio;
+ };
+ int x,y,width,height;
+ float fov,fovViewmodel;
+ Vector origin;
+ QAngle angles;
+ float zNear,zFar,zNearViewmodel,zFarViewmodel;
+ float m_flAspectRatio;
+};
+
+
+class IVShaderEditor : public IBaseInterface
+{
+public:
+ virtual bool Init( CreateInterfaceFn appSystemFactory, CGlobalVarsBase *pGlobals,
+ void *pSEditMRender,
+ bool bCreateEditor, bool bEnablePrimaryDebug, int iSkymaskMode ) = 0;
+ virtual void Shutdown() = 0;
+ virtual void PrecacheData() = 0;
+
+ // call before Init() to overwrite any paths, pass in NULL for the ones that shouldn't be overwritten
+ virtual void OverridePaths( const char *pszWorkingDirectory,
+ const char *pszCompilePath = NULL, // abs path to compiler binaries
+ const char *pszLocalCompilePath = NULL, // local path to compiler binaries, relative to shader source directory
+ const char *pszGamePath = NULL,
+ const char *pszCanvas = NULL, // path to canvas files
+ const char *pszShaderSource = NULL, // path to shader source files
+ const char *pszDumps = NULL, // path to shader configuration files
+ const char *pszUserFunctions = NULL, // path to custom function bodies
+ const char *pszEditorRoot = NULL ) = 0; // path to 'shadereditorui' home directory
+
+ // update the lib
+ virtual void OnFrame( float frametime ) = 0;
+ virtual void OnPreRender( void *viewsetup ) = 0;
+ virtual void OnSceneRender() = 0;
+ virtual void OnUpdateSkymask( bool bCombineMode ) = 0;
+ virtual void OnPostRender( bool bUpdateFB ) = 0;
+
+ // data callbacks for hlsl constants
+ virtual void RegisterClientCallback( const char *name, pFnClCallback(callback), int numComponents ) = 0;
+ virtual void LockClientCallbacks() = 0;
+
+ // view render callbacks for post processing graphs
+ virtual void RegisterViewRenderCallback( const char *pszVrCName, pFnVrCallback(callback),
+ const char **pszBoolNames = NULL, const bool *pBoolDefaults = NULL, const int numBoolParams = 0,
+ const char **pszIntNames = NULL, const int *pIntDefaults = NULL, const int numIntParams = 0,
+ const char **pszFloatNames = NULL, const float *pFloatDefaults = NULL, const int numFloatParams = 0,
+ const char **pszStringNames = NULL, const char **pStringDefaults = NULL, const int numStringParams = 0 ) = 0;
+ virtual void LockViewRenderCallbacks() = 0;
+
+ // post processing effect manipulation (precached effects accessible)
+ // the index becomes invalid when editing the precache list
+ virtual int GetPPEIndex( const char *pszName ) = 0; // returns -1 when not found, case insensitive
+ virtual bool IsPPEEnabled( const int &index ) = 0;
+ virtual void SetPPEEnabled( const int &index, const bool &bEnabled ) = 0;
+ virtual IMaterial *GetPPEMaterial( const int &index, const char *pszNodeName ) = 0;
+
+ // Draws a PPE graph right now or adds it to the render queue (r_queued_post_processing!)
+ // Does not push a new RT but uses the current one
+ // If you have 'during scene' nodes, make sure to call it twice in the appropriate places
+ virtual void DrawPPEOnDemand( const int &index, const bool bInScene = false ) = 0;
+};
+
+#define SHADEREDIT_INTERFACE_VERSION "ShaderEditor005"
+
+#ifdef SHADER_EDITOR_DLL
+class ShaderEditorInterface;
+extern ShaderEditorInterface *shaderEdit;
+#else
+extern IVShaderEditor *shaderEdit;
+#endif // NOT SHADER_EDITOR_DLL
+
+#endif // NOT PROCSHADER_DLL
+
+#endif // NOT IV_SHADEREDITOR
\ No newline at end of file
diff --git a/mp/src/game/client/ShaderEditor/SEdit_ModelRender.cpp b/mp/src/game/client/ShaderEditor/SEdit_ModelRender.cpp
new file mode 100644
index 0000000000..ec2a36b98e
--- /dev/null
+++ b/mp/src/game/client/ShaderEditor/SEdit_ModelRender.cpp
@@ -0,0 +1,424 @@
+// ******************************************************
+//
+// Purpose:
+// - Handles model rendering requests from the
+// shader editor library
+//
+// ******************************************************
+
+#include "cbase.h"
+
+#include "vgui/iinput.h"
+#include "vgui_controls/controls.h"
+
+#include "ShaderEditor/SEdit_ModelRender.h"
+#include "model_types.h"
+
+#ifndef SOURCE_2006
+#include "viewpostprocess.h"
+#endif
+
+#include "view.h"
+#include "input.h"
+
+#include "beamdraw.h"
+
+#ifdef SOURCE_2006
+void ScreenToWorld( int mousex, int mousey, float fov,
+ const Vector& vecRenderOrigin,
+ const QAngle& vecRenderAngles,
+ Vector& vecPickingRay )
+{
+ float dx, dy;
+ float c_x, c_y;
+ float dist;
+ Vector vpn, vup, vright;
+
+ float scaled_fov = ScaleFOVByWidthRatio( fov, engine->GetScreenAspectRatio() * 0.75f );
+
+ c_x = ScreenWidth() / 2;
+ c_y = ScreenHeight() / 2;
+
+ dx = (float)mousex - c_x;
+ dy = c_y - (float)mousey;
+
+ float dist_denom = tan(M_PI * scaled_fov / 360.0f);
+ dist = c_x / dist_denom;
+ AngleVectors( vecRenderAngles, &vpn, &vright, &vup );
+ vecPickingRay = vpn * dist + vright * ( dx ) + vup * ( dy );
+ VectorNormalize( vecPickingRay );
+}
+#else
+extern void ScreenToWorld( int mousex, int mousey, float fov,
+ const Vector& vecRenderOrigin,
+ const QAngle& vecRenderAngles,
+ Vector& vecPickingRay );
+#endif
+
+SEditModelRender __g_ShaderEditorMReder( "ShEditMRender" );
+SEditModelRender *sEditMRender = &__g_ShaderEditorMReder;
+
+SEditModelRender::SEditModelRender( char const *name ) : CAutoGameSystemPerFrame( name )
+{
+ pModelInstance = nullptr;
+ m_iNumPoseParams = 0;
+ DestroyModel();
+}
+SEditModelRender::~SEditModelRender()
+{
+ DestroyModel();
+}
+
+bool SEditModelRender::Init()
+{
+ return true;
+}
+void SEditModelRender::Shutdown()
+{
+}
+void SEditModelRender::Update( float frametime )
+{
+ if ( !IsModelReady() )
+ return;
+
+ pModelInstance->StudioFrameAdvance();
+ if ( pModelInstance->GetCycle() >= 1.0f )
+ pModelInstance->SetCycle( pModelInstance->GetCycle() - 1.0f );
+}
+void SEditModelRender::LevelInitPostEntity()
+{
+ ResetModel();
+}
+void SEditModelRender::LevelShutdownPostEntity()
+{
+ ResetModel();
+}
+void SEditModelRender::ResetModel()
+{
+ if ( !IsModelReady() )
+ return;
+ pModelInstance->m_flAnimTime = gpGlobals->curtime;
+ pModelInstance->m_flOldAnimTime = gpGlobals->curtime;
+}
+bool SEditModelRender::IsModelReady()
+{
+ if ( !pModelInstance )
+ return false;
+
+ bool bValid = !!pModelInstance->GetModel();
+
+ if ( bValid && Q_strlen( m_szModelPath ) )
+ {
+ const model_t *pMdl = modelinfo ? modelinfo->FindOrLoadModel( m_szModelPath ) : NULL;
+ if ( pMdl )
+ pModelInstance->SetModelPointer( pMdl );
+ bValid = !!pMdl;
+ }
+
+ if ( !bValid )
+ DestroyModel();
+
+ return bValid;
+}
+bool SEditModelRender::LoadModel( const char *localPath )
+{
+ DestroyModel();
+
+ const model_t *mdl = modelinfo->FindOrLoadModel( localPath );
+ if ( !mdl )
+ return false;
+
+ Q_strcpy( m_szModelPath, localPath );
+
+ C_BaseFlex *pEnt = new C_BaseFlex();
+ pEnt->InitializeAsClientEntity(nullptr,
+#if SWARM_DLL
+ false
+#else
+ RENDER_GROUP_OPAQUE_ENTITY
+#endif
+ );
+ MDLCACHE_CRITICAL_SECTION();
+ pEnt->SetModelPointer( mdl );
+ pEnt->Spawn();
+
+ pEnt->SetAbsAngles( vec3_angle );
+ pEnt->SetAbsOrigin( vec3_origin );
+
+ pEnt->AddEffects( EF_NODRAW | EF_NOINTERP );
+ pEnt->m_EntClientFlags |= ENTCLIENTFLAG_DONTUSEIK;
+
+ // leave it alone.
+ pEnt->RemoveFromLeafSystem();
+ cl_entitylist->RemoveEntity( pEnt->GetRefEHandle() );
+ pEnt->CollisionProp()->DestroyPartitionHandle();
+
+ CStudioHdr *pHdr = pEnt->GetModelPtr();
+ m_iNumPoseParams = pHdr ? pHdr->GetNumPoseParameters() : 0;
+
+ pModelInstance = pEnt;
+ return true;
+}
+void SEditModelRender::DestroyModel()
+{
+ if ( pModelInstance )
+ pModelInstance->Remove();
+
+ pModelInstance = nullptr;
+ m_szModelPath[0] = '\0';
+ m_iNumPoseParams = 0;
+}
+void SEditModelRender::GetModelCenter( float *pFl3_ViewOffset )
+{
+ Q_memset( pFl3_ViewOffset, 0, sizeof(float) * 3 );
+ if ( IsModelReady() )
+ {
+ MDLCACHE_CRITICAL_SECTION();
+ if ( pModelInstance->GetModelPtr() )
+ {
+ const Vector &vecMin = pModelInstance->GetModelPtr()->hull_min();
+ const Vector &vecMax = pModelInstance->GetModelPtr()->hull_max();
+ Vector vecPos = ( vecMin + ( vecMax - vecMin ) * 0.5f );
+ if ( pFl3_ViewOffset )
+ Q_memcpy( pFl3_ViewOffset, vecPos.Base(), sizeof(float) * 3 );
+ }
+ }
+}
+void SEditModelRender::DestroyCharPtrList( char ***szList )
+{
+ Assert( szList );
+ if ( *szList )
+ {
+ delete [] (**szList);
+ delete [] (*szList);
+ *szList = nullptr;
+ }
+}
+
+int SequenceSort( mstudioseqdesc_t *const *seq1, mstudioseqdesc_t *const *seq2 )
+{
+ return Q_stricmp( ( *seq1 )->pszLabel(), ( *seq2 )->pszLabel() );
+}
+int SEditModelRender::QuerySequences( char ***list )
+{
+ if ( !IsModelReady() )
+ return 0;
+
+ MDLCACHE_CRITICAL_SECTION();
+ CStudioHdr *pHdr = pModelInstance->GetModelPtr();
+ if ( !pHdr )
+ return 0;
+
+ CUtlVector< mstudioseqdesc_t* >hSeqs;
+ for ( int i = 0; i < pHdr->GetNumSeq(); i++ )
+ if ( !( pHdr->pSeqdesc( i ).flags & STUDIO_HIDDEN ) )
+ hSeqs.AddToTail( &pHdr->pSeqdesc( i ) );
+
+ int numSequences = hSeqs.Count();
+
+ if ( !numSequences )
+ return 0;
+
+ hSeqs.Sort( SequenceSort );
+
+ CUtlVector< const char* >hNameList;
+ for ( int i = 0; i < numSequences; i++ )
+ {
+ const char *seqName = nullptr;
+ const mstudioseqdesc_t &seqPtr = *hSeqs[ i ];
+ if ( seqPtr.pszLabel() )
+ seqName = seqPtr.pszLabel();
+ else
+ seqName = "Unknown Sequence";
+
+ hNameList.AddToTail( seqName );
+ }
+
+ *list = new char*[numSequences];
+
+ int iTotalLength = 0;
+ for ( int i = 0; i < numSequences; i++ )
+ iTotalLength += Q_strlen( hNameList[i] ) + 1;
+
+ **list = new char[ iTotalLength ];
+
+ int curpos = 0;
+ for ( int i = 0; i < numSequences; i++ )
+ {
+ int curLength = Q_strlen( hNameList[i] ) + 1;
+ (*list)[ i ] = **list + curpos;
+ Q_strcpy( (*list)[ i ], hNameList[i] );
+ curpos += curLength;
+ }
+
+ hNameList.Purge();
+ hSeqs.Purge();
+ return numSequences;
+}
+void SEditModelRender::SetSequence( const char *name )
+{
+ if ( !IsModelReady() )
+ return;
+
+ MDLCACHE_CRITICAL_SECTION();
+ pModelInstance->ResetSequence( pModelInstance->LookupSequence( name ) );
+}
+void SEditModelRender::ExecRender()
+{
+ if ( !IsModelReady() )
+ return;
+
+ MDLCACHE_CRITICAL_SECTION();
+ for ( int i = 0; i < m_iNumPoseParams; i++ )
+ pModelInstance->SetPoseParameter( i, 0 );
+
+#if SWARM_DLL
+ RenderableInstance_t instance;
+ instance.m_nAlpha = 255;
+#endif
+ pModelInstance->DrawModel( STUDIO_RENDER
+#if SWARM_DLL
+ , instance
+#endif
+ );
+}
+void SEditModelRender::DoPostProc( int x, int y, int w, int h )
+{
+#ifndef SOURCE_2006
+ if ( view && view->GetPlayerViewSetup()->m_bDoBloomAndToneMapping )
+ DoEnginePostProcessing( x, y, w, h, false, false );
+#endif
+}
+int SEditModelRender::MaterialPicker( char ***szMat )
+{
+ int mx, my;
+#ifdef SOURCE_2006
+ vgui::input()->GetCursorPos( mx, my );
+#else
+ vgui::input()->GetCursorPosition( mx, my );
+#endif
+
+ Vector ray;
+ const CViewSetup *pViewSetup = view->GetPlayerViewSetup();
+ float ratio =engine->GetScreenAspectRatio(
+#if SWARM_DLL
+ pViewSetup->width, pViewSetup->height
+#endif
+ );
+
+ ratio = ( 1.0f / ratio ) * (4.0f/3.0f);
+ float flFov = ScaleFOVByWidthRatio( pViewSetup->fov, ratio );
+ ScreenToWorld( mx, my, flFov, pViewSetup->origin, pViewSetup->angles, ray );
+
+ Vector start = pViewSetup->origin;
+ Vector end = start + ray * MAX_TRACE_LENGTH;
+ trace_t tr;
+ C_BaseEntity *pIgnore = input->CAM_IsThirdPerson() ? NULL : C_BasePlayer::GetLocalPlayer();
+ UTIL_TraceLine( start, end, MASK_SOLID, pIgnore, COLLISION_GROUP_NONE, &tr );
+
+ if ( !tr.DidHit() )
+ return 0;
+
+ int numMaterials = 0;
+ IMaterial **MatList = nullptr;
+ studiohdr_t *pSHdr = nullptr;
+
+ if ( tr.DidHitWorld() )
+ {
+ if ( tr.hitbox == 0 )
+ {
+ Vector dummy;
+ IMaterial *pMat = engine->TraceLineMaterialAndLighting( start, end, dummy, dummy );
+ if ( pMat )
+ {
+ numMaterials = 1;
+ MatList = new IMaterial*[1];
+ MatList[0] = pMat;
+ }
+ }
+ else
+ {
+ ICollideable *prop = staticpropmgr->GetStaticPropByIndex( tr.hitbox - 1 );
+ if ( prop )
+ {
+ IClientRenderable *pRenderProp = prop->GetIClientUnknown()->GetClientRenderable();
+ if ( pRenderProp )
+ {
+ const model_t *pModel = pRenderProp->GetModel();
+ if ( pModel )
+ pSHdr = modelinfo->GetStudiomodel( pModel );
+ }
+ }
+ }
+ }
+ else if ( tr.m_pEnt )
+ {
+ const model_t *pModel = tr.m_pEnt->GetModel();
+ if ( pModel )
+ pSHdr = modelinfo->GetStudiomodel( pModel );
+ }
+
+ if ( pSHdr )
+ {
+ Assert( !numMaterials && !MatList );
+ numMaterials = pSHdr->numtextures;
+ const int numPaths = pSHdr->numcdtextures;
+
+ if ( numMaterials )
+ {
+ CUtlVector< IMaterial* >hValidMaterials;
+ for ( int i = 0; i < numMaterials; i++ )
+ {
+ mstudiotexture_t *pStudioTex = pSHdr->pTexture( i );
+ const char *matName = pStudioTex->pszName();
+
+ for ( int p = 0; p < numPaths; p++ )
+ {
+ char tmpPath[MAX_PATH];
+ Q_snprintf( tmpPath, MAX_PATH, "%s%s\0", pSHdr->pCdtexture( p ), matName );
+ Q_FixSlashes( tmpPath );
+ IMaterial *pTempMat = materials->FindMaterial( tmpPath, TEXTURE_GROUP_MODEL );
+ if ( !IsErrorMaterial( pTempMat ) )
+ {
+ hValidMaterials.AddToTail( pTempMat );
+ break;
+ }
+ }
+ }
+
+ numMaterials = hValidMaterials.Count();
+ if ( numMaterials )
+ {
+ MatList = new IMaterial*[ numMaterials ];
+ for ( int i = 0; i < numMaterials; i++ )
+ MatList[i] = hValidMaterials[i];
+ }
+
+ hValidMaterials.Purge();
+ }
+ }
+
+ *szMat = new char*[ numMaterials ];
+
+ int iTotalLength = 0;
+ for ( int i = 0; i < numMaterials; i++ )
+ iTotalLength += Q_strlen( MatList[i]->GetName() ) + 1;
+
+ **szMat = new char[ iTotalLength ];
+
+ int curpos = 0;
+ for ( int i = 0; i < numMaterials; i++ )
+ {
+ const char *pszName = MatList[i]->GetName();
+
+ int curLength = Q_strlen( pszName ) + 1;
+ (*szMat)[ i ] = **szMat + curpos;
+ Q_strcpy( (*szMat)[ i ], pszName );
+ curpos += curLength;
+ }
+
+ if ( MatList )
+ delete [] MatList;
+
+ return numMaterials;
+}
\ No newline at end of file
diff --git a/mp/src/game/client/ShaderEditor/SEdit_ModelRender.h b/mp/src/game/client/ShaderEditor/SEdit_ModelRender.h
new file mode 100644
index 0000000000..346598961f
--- /dev/null
+++ b/mp/src/game/client/ShaderEditor/SEdit_ModelRender.h
@@ -0,0 +1,48 @@
+#ifndef SHEDITMRENDER_H
+#define SHEDITMRENDER_H
+
+#include "cbase.h"
+#include "ShaderEditor/ISEdit_ModelRender.h"
+
+class C_BaseFlex_OverrideLod;
+
+class SEditModelRender : public ISEditModelRender, public CAutoGameSystemPerFrame
+{
+public:
+ SEditModelRender( char const *name );
+ ~SEditModelRender();
+
+// autogamesystem
+ virtual bool Init();
+ virtual void Shutdown();
+ virtual void Update( float frametime );
+
+ virtual void LevelInitPostEntity();
+ virtual void LevelShutdownPostEntity();
+
+// interface
+ virtual bool LoadModel( const char *localPath );
+ virtual void DestroyModel();
+ virtual void GetModelCenter( float *pFl3_ViewOffset );
+
+ virtual int QuerySequences( char ***list );
+ virtual void SetSequence( const char *name );
+
+ virtual void ExecRender();
+ virtual void DoPostProc( int x, int y, int w, int h );
+
+ virtual int MaterialPicker( char ***szMat );
+
+ virtual void DestroyCharPtrList( char ***szList );
+
+private:
+
+ bool IsModelReady();
+ void ResetModel();
+
+ C_BaseFlex *pModelInstance;
+ char m_szModelPath[MAX_PATH];
+ int m_iNumPoseParams;
+};
+
+#endif
\ No newline at end of file
diff --git a/mp/src/game/client/ShaderEditor/ShaderEditorSystem.cpp b/mp/src/game/client/ShaderEditor/ShaderEditorSystem.cpp
new file mode 100644
index 0000000000..de830fec36
--- /dev/null
+++ b/mp/src/game/client/ShaderEditor/ShaderEditorSystem.cpp
@@ -0,0 +1,1174 @@
+// ******************************************************
+//
+// Purpose:
+// - Connects the shader editor
+// - Sends data from the main viewsetup
+// - exposes client callbacks to shaders
+//
+// ******************************************************
+
+#include "cbase.h"
+
+#include "ShaderEditor/IVShaderEditor.h"
+#include "ShaderEditor/SEdit_ModelRender.h"
+#include "beamdraw.h"
+#include "c_rope.h"
+#include "c_sun.h"
+#include "client_factorylist.h"
+#include "iviewrender.h"
+#include "ivrenderview.h"
+#include "model_types.h"
+#include "rendertexture.h"
+#include "tier0/icommandline.h"
+#include "view.h"
+#include "view_scene.h"
+#include "view_shared.h"
+#include "viewrender.h"
+
+#define Editor_MainViewOrigin MainViewOrigin()
+#define Editor_MainViewForward MainViewForward()
+
+ShaderEditorHandler __g_ShaderEditorSystem("ShEditUpdate");
+ShaderEditorHandler *g_ShaderEditorSystem = &__g_ShaderEditorSystem;
+
+CSysModule *shaderEditorModule = nullptr;
+IVShaderEditor *shaderEdit = nullptr;
+
+ShaderEditorHandler::ShaderEditorHandler(char const *name) : CAutoGameSystemPerFrame(name)
+{
+ m_bReady = false;
+ m_piCurrentViewId = nullptr;
+}
+
+ShaderEditorHandler::~ShaderEditorHandler() {}
+
+bool ShaderEditorHandler::IsReady() const { return m_bReady; }
+
+bool ShaderEditorHandler::Init()
+{
+ factorylist_t factories;
+ FactoryList_Retrieve(factories);
+
+ ConVarRef devEnabled("developer", true);
+ bool bShowPrimDebug = devEnabled.GetInt() != 0;
+
+ bool bCreateEditor = (CommandLine() != nullptr) && (CommandLine()->FindParm("-shaderedit") != 0);
+ SEDIT_SKYMASK_MODE iEnableSkymask = SKYMASK_OFF;
+
+#ifdef SHADEREDITOR_FORCE_ENABLED
+ bCreateEditor = true;
+ iEnableSkymask = SKYMASK_QUARTER;
+#endif
+
+ char modulePath[MAX_PATH * 4];
+ Q_snprintf(modulePath, sizeof(modulePath), "%s/bin/shadereditor_2013.dll\0", engine->GetGameDirectory());
+ shaderEditorModule = Sys_LoadModule(modulePath);
+ if (shaderEditorModule)
+ {
+ CreateInterfaceFn shaderEditorDLLFactory = Sys_GetFactory(shaderEditorModule);
+ shaderEdit = shaderEditorDLLFactory
+ ? static_cast(shaderEditorDLLFactory(SHADEREDIT_INTERFACE_VERSION, nullptr))
+ : NULL;
+
+ if (!shaderEdit)
+ {
+ Warning("Unable to pull IVShaderEditor interface.\n");
+ }
+ else if (!shaderEdit->Init(factories.appSystemFactory, gpGlobals, sEditMRender, bCreateEditor, bShowPrimDebug,
+ iEnableSkymask))
+ {
+ Warning("Cannot initialize IVShaderEditor.\n");
+ shaderEdit = nullptr;
+ }
+ }
+ else
+ {
+ Warning("Cannot load shadereditor.dll from %s!\n", modulePath);
+ }
+
+ m_bReady = shaderEdit != nullptr;
+
+ RegisterCallbacks();
+ RegisterViewRenderCallbacks();
+
+ if (IsReady())
+ {
+ shaderEdit->PrecacheData();
+ }
+
+ return true;
+}
+
+#ifdef SHADEREDITOR_FORCE_ENABLED
+CON_COMMAND(sedit_debug_toggle_ppe, "")
+{
+ if (!g_ShaderEditorSystem->IsReady())
+ return Warning("lib not ready.\n");
+
+ if (args.ArgC() < 2)
+ return;
+
+ const int idx = shaderEdit->GetPPEIndex(args[1]);
+ if (idx < 0)
+ return Warning("can't find ppe named: %s\n", args[1]);
+
+ shaderEdit->SetPPEEnabled(idx, !shaderEdit->IsPPEEnabled(idx));
+}
+#endif
+
+void ShaderEditorHandler::Shutdown()
+{
+ if (shaderEdit)
+ shaderEdit->Shutdown();
+ if (shaderEditorModule)
+ Sys_UnloadModule(shaderEditorModule);
+}
+
+void ShaderEditorHandler::Update(float frametime)
+{
+ if (IsReady())
+ shaderEdit->OnFrame(frametime);
+}
+
+CThreadMutex m_Lock;
+
+void ShaderEditorHandler::PreRender()
+{
+ if (IsReady() && view)
+ {
+ // make sure the class matches
+ const CViewSetup *v = view->GetPlayerViewSetup();
+ CViewSetup_SEdit_Shared stableVSetup(*v);
+ shaderEdit->OnPreRender(&stableVSetup);
+
+ m_Lock.Lock();
+ PrepareCallbackData();
+ m_Lock.Unlock();
+ }
+}
+void ShaderEditorHandler::PostRender() {}
+
+void ShaderEditorHandler::CustomViewRender(int *viewId, const VisibleFogVolumeInfo_t &fogVolumeInfo,
+ const WaterRenderInfo_t &waterRenderInfo)
+{
+ m_piCurrentViewId = viewId;
+ m_tFogVolumeInfo = fogVolumeInfo;
+ m_tWaterRenderInfo = waterRenderInfo;
+
+ if (IsReady())
+ shaderEdit->OnSceneRender();
+}
+void ShaderEditorHandler::UpdateSkymask(bool bCombineMode) const
+{
+ if (IsReady())
+ shaderEdit->OnUpdateSkymask(bCombineMode);
+}
+void ShaderEditorHandler::CustomPostRender() const
+{
+ if (IsReady())
+ shaderEdit->OnPostRender(true);
+}
+
+struct CallbackData_t
+{
+ void Reset()
+ {
+ sun_data.Init();
+ sun_dir.Init();
+
+ player_speed.Init();
+ player_pos.Init();
+ };
+ Vector4D sun_data;
+ Vector sun_dir;
+
+ Vector4D player_speed;
+ Vector player_pos;
+};
+
+static CallbackData_t clCallback_data;
+
+void ShaderEditorHandler::PrepareCallbackData() const
+{
+ clCallback_data.Reset();
+
+ float flSunAmt_Goal = 0;
+ static float s_flSunAmt_Last = 0;
+
+ C_BaseEntity *pEnt = ClientEntityList().FirstBaseEntity();
+ while (pEnt)
+ {
+ if (!Q_stricmp(pEnt->GetClassname(), "class C_Sun"))
+ {
+ C_Sun *pSun = static_cast(pEnt);
+ Vector dir = pSun->m_vDirection;
+ dir.NormalizeInPlace();
+
+ Vector screen;
+
+ if (ScreenTransform(Editor_MainViewOrigin + dir * 512, screen))
+ ScreenTransform((Editor_MainViewOrigin - dir * 512), screen);
+
+ screen = screen * Vector(0.5f, -0.5f, 0) + Vector(0.5f, 0.5f, 0);
+
+ Q_memcpy(clCallback_data.sun_data.Base(), screen.Base(), sizeof(float) * 2);
+ clCallback_data.sun_data[2] = DotProduct(dir, Editor_MainViewForward);
+ clCallback_data.sun_dir = dir;
+
+ trace_t tr;
+ UTIL_TraceLine(Editor_MainViewOrigin, Editor_MainViewOrigin + dir * MAX_TRACE_LENGTH, MASK_SOLID, nullptr,
+ COLLISION_GROUP_DEBRIS, &tr);
+ if (!tr.DidHitWorld())
+ break;
+
+ if (tr.surface.flags & SURF_SKY)
+ flSunAmt_Goal = 1;
+
+ break;
+ }
+ pEnt = ClientEntityList().NextBaseEntity(pEnt);
+ }
+
+ if (s_flSunAmt_Last != flSunAmt_Goal)
+ s_flSunAmt_Last =
+ Approach(flSunAmt_Goal, s_flSunAmt_Last, gpGlobals->frametime * ((!!flSunAmt_Goal) ? 4.0f : 0.75f));
+
+ clCallback_data.sun_data[3] = s_flSunAmt_Last;
+
+ C_BasePlayer *pPlayer = C_BasePlayer::GetLocalPlayer();
+ if (pPlayer)
+ {
+ Vector velo = pPlayer->GetLocalVelocity();
+ clCallback_data.player_speed[3] = velo.NormalizeInPlace();
+ Q_memcpy(clCallback_data.player_speed.Base(), velo.Base(), sizeof(float) * 3);
+
+ clCallback_data.player_pos = pPlayer->GetLocalOrigin();
+ }
+}
+
+pFnClCallback_Declare(ClCallback_SunData)
+{
+ m_Lock.Lock();
+ Q_memcpy(pfl4, clCallback_data.sun_data.Base(), sizeof(float) * 4);
+ m_Lock.Unlock();
+}
+
+pFnClCallback_Declare(ClCallback_SunDirection)
+{
+ m_Lock.Lock();
+ Q_memcpy(pfl4, clCallback_data.sun_dir.Base(), sizeof(float) * 3);
+ m_Lock.Unlock();
+}
+
+pFnClCallback_Declare(ClCallback_PlayerVelocity)
+{
+ m_Lock.Lock();
+ Q_memcpy(pfl4, clCallback_data.player_speed.Base(), sizeof(float) * 4);
+ m_Lock.Unlock();
+}
+
+pFnClCallback_Declare(ClCallback_PlayerPos)
+{
+ m_Lock.Lock();
+ Q_memcpy(pfl4, clCallback_data.player_pos.Base(), sizeof(float) * 3);
+ m_Lock.Unlock();
+}
+
+void ShaderEditorHandler::RegisterCallbacks() const
+{
+ if (!IsReady())
+ return;
+
+ // 4 components max
+ shaderEdit->RegisterClientCallback("sun data", ClCallback_SunData, 4);
+ shaderEdit->RegisterClientCallback("sun dir", ClCallback_SunDirection, 3);
+ shaderEdit->RegisterClientCallback("local player velocity", ClCallback_PlayerVelocity, 4);
+ shaderEdit->RegisterClientCallback("local player position", ClCallback_PlayerPos, 3);
+
+ shaderEdit->LockClientCallbacks();
+}
+
+extern bool DoesViewPlaneIntersectWater(float waterZ, int leafWaterDataID);
+
+// copy pasta from baseworldview
+class CBaseVCallbackView : public CRendering3dView
+{
+ DECLARE_CLASS(CBaseVCallbackView, CRendering3dView);
+
+ protected:
+ CBaseVCallbackView(CViewRender *pMainView) : CRendering3dView(pMainView){};
+
+ virtual bool AdjustView(float waterHeight) { return false; };
+
+ virtual void CallbackInitRenderList(int viewId) { BuildRenderableRenderLists(viewId); };
+
+ virtual bool ShouldDrawParticles() { return true; };
+
+ virtual bool ShouldDrawRopes() { return true; };
+
+ virtual bool ShouldDrawWorld() { return true; };
+
+ virtual bool ShouldDrawTranslucents() { return true; };
+
+ virtual bool ShouldDrawTranslucentWorld() { return true; };
+
+ void DrawSetup(float waterHeight, int nSetupFlags, float waterZAdjust, int iForceViewLeaf = -1)
+ {
+ int savedViewID = g_ShaderEditorSystem->GetViewIdForModify();
+
+ g_ShaderEditorSystem->GetViewIdForModify() = VIEW_ILLEGAL;
+
+ render->BeginUpdateLightmaps();
+
+ bool bDrawEntities = (nSetupFlags & DF_DRAW_ENTITITES) != 0;
+ BuildWorldRenderLists(bDrawEntities, iForceViewLeaf, true, false, nullptr);
+ PruneWorldListInfo();
+
+ if (bDrawEntities)
+ CallbackInitRenderList(savedViewID);
+
+ render->EndUpdateLightmaps();
+
+ g_ShaderEditorSystem->GetViewIdForModify() = savedViewID;
+ };
+
+ void DrawExecute(float waterHeight, view_id_t viewID, float waterZAdjust)
+ {
+ // ClientWorldListInfo_t is defined in viewrender.cpp...
+ // g_pClientShadowMgr->ComputeShadowTextures( *this, m_pWorldListInfo->m_LeafCount,
+ // m_pWorldListInfo->m_pLeafList );
+
+ engine->Sound_ExtraUpdate();
+
+ int savedViewID = g_ShaderEditorSystem->GetViewIdForModify();
+ g_ShaderEditorSystem->GetViewIdForModify() = viewID;
+
+ int iDrawFlagsBackup = m_DrawFlags;
+ m_DrawFlags |= m_pMainView->GetBaseDrawFlags();
+
+ PushView(waterHeight);
+
+ CMatRenderContextPtr pRenderContext(materials);
+
+ ITexture *pSaveFrameBufferCopyTexture = pRenderContext->GetFrameBufferCopyTexture(0);
+ if (engine->GetDXSupportLevel() >= 80)
+ {
+ pRenderContext->SetFrameBufferCopyTexture(GetPowerOfTwoFrameBufferTexture());
+ }
+
+ pRenderContext.SafeRelease();
+
+ static ConVarRef translucentNoWorld("r_drawtranslucentworld");
+ const int tnoWorldSaved = translucentNoWorld.GetInt();
+ translucentNoWorld.SetValue(ShouldDrawWorld() ? 0 : 1);
+
+ if (m_DrawFlags & DF_DRAW_ENTITITES)
+ {
+ if (ShouldDrawWorld())
+ DrawWorld(waterZAdjust);
+
+ DrawOpaqueRenderables_Custom(false);
+
+ if (ShouldDrawTranslucents() && ShouldDrawTranslucentWorld())
+ DrawTranslucentRenderables(false, false);
+ else if (ShouldDrawTranslucents())
+ DrawTranslucentRenderablesNoWorld(false);
+ else if (ShouldDrawTranslucentWorld())
+ DrawTranslucentWorldInLeaves(false);
+ }
+ else if (ShouldDrawWorld())
+ {
+ DrawWorld(waterZAdjust);
+
+ if (ShouldDrawTranslucentWorld())
+ DrawTranslucentWorldInLeaves(false);
+ }
+
+ translucentNoWorld.SetValue(tnoWorldSaved);
+
+ if (CurrentViewID() != VIEW_MAIN && CurrentViewID() != VIEW_INTRO_CAMERA)
+ PixelVisibility_EndCurrentView();
+
+ pRenderContext.GetFrom(materials);
+ pRenderContext->SetFrameBufferCopyTexture(pSaveFrameBufferCopyTexture);
+ PopView();
+
+ m_DrawFlags = iDrawFlagsBackup;
+
+ g_ShaderEditorSystem->GetViewIdForModify() = savedViewID;
+ };
+
+ virtual void PushView(float waterHeight)
+ {
+ float spread = 2.0f;
+ if (m_DrawFlags & DF_FUDGE_UP)
+ {
+ waterHeight += spread;
+ }
+ else
+ {
+ waterHeight -= spread;
+ }
+
+ MaterialHeightClipMode_t clipMode = MATERIAL_HEIGHTCLIPMODE_DISABLE;
+
+ if ((m_DrawFlags & DF_CLIP_Z))
+ {
+ if (m_DrawFlags & DF_CLIP_BELOW)
+ {
+ clipMode = MATERIAL_HEIGHTCLIPMODE_RENDER_ABOVE_HEIGHT;
+ }
+ else
+ {
+ clipMode = MATERIAL_HEIGHTCLIPMODE_RENDER_BELOW_HEIGHT;
+ }
+ }
+
+ CMatRenderContextPtr pRenderContext(materials);
+
+ if (m_ClearFlags & (VIEW_CLEAR_DEPTH | VIEW_CLEAR_COLOR | VIEW_CLEAR_STENCIL))
+ {
+ if (m_ClearFlags & VIEW_CLEAR_OBEY_STENCIL)
+ {
+ pRenderContext->ClearBuffersObeyStencil((m_ClearFlags & VIEW_CLEAR_COLOR) != 0,
+ (m_ClearFlags & VIEW_CLEAR_DEPTH) != 0);
+ }
+ else
+ {
+ pRenderContext->ClearBuffers((m_ClearFlags & VIEW_CLEAR_COLOR) != 0,
+ (m_ClearFlags & VIEW_CLEAR_DEPTH) != 0,
+ (m_ClearFlags & VIEW_CLEAR_STENCIL) != 0);
+ }
+ }
+
+ pRenderContext->SetHeightClipMode(clipMode);
+ if (clipMode != MATERIAL_HEIGHTCLIPMODE_DISABLE)
+ {
+ pRenderContext->SetHeightClipZ(waterHeight);
+ }
+ };
+
+ virtual void PopView()
+ {
+ CMatRenderContextPtr pRenderContext(materials);
+ pRenderContext->SetHeightClipMode(MATERIAL_HEIGHTCLIPMODE_DISABLE);
+ };
+
+ void DrawOpaqueRenderables_Custom(bool bShadowDepth)
+ {
+ // if( !r_drawopaquerenderables.GetBool() )
+ // return;
+
+ //if (!m_pMainView->ShouldDrawEntities())
+ //return;
+
+ render->SetBlend(1);
+
+ const bool bRopes = ShouldDrawRopes();
+ const bool bParticles = ShouldDrawParticles();
+
+ //
+ // Prepare to iterate over all leaves that were visible, and draw opaque things in them.
+ //
+ if (bRopes)
+ RopeManager()->ResetRenderCache();
+ if (bParticles)
+ g_pParticleSystemMgr->ResetRenderCache();
+
+ bool const bDrawopaquestaticpropslast = false; // r_drawopaquestaticpropslast.GetBool();
+
+ //
+ // First do the brush models
+ //
+ {
+ CClientRenderablesList::CEntry *pEntitiesBegin, *pEntitiesEnd;
+ pEntitiesBegin = m_pRenderablesList->m_RenderGroups[RENDER_GROUP_OPAQUE_BRUSH];
+ pEntitiesEnd = pEntitiesBegin + m_pRenderablesList->m_RenderGroupCounts[RENDER_GROUP_OPAQUE_BRUSH];
+ DrawOpaqueRenderables_DrawBrushModels(pEntitiesBegin, pEntitiesEnd, bShadowDepth);
+ }
+
+ //
+ // Sort everything that's not a static prop
+ //
+ int numOpaqueEnts = 0;
+ for (int bucket = 0; bucket < RENDER_GROUP_CFG_NUM_OPAQUE_ENT_BUCKETS; ++bucket)
+ numOpaqueEnts += m_pRenderablesList->m_RenderGroupCounts[RENDER_GROUP_OPAQUE_ENTITY_HUGE + 2 * bucket];
+
+ CUtlVector arrBoneSetupNpcsLast(
+ static_cast(_alloca(numOpaqueEnts * sizeof(C_BaseAnimating *))), numOpaqueEnts,
+ numOpaqueEnts);
+ CUtlVector arrRenderEntsNpcsFirst(
+ static_cast(
+ _alloca(numOpaqueEnts * sizeof(CClientRenderablesList::CEntry))),
+ numOpaqueEnts, numOpaqueEnts);
+ int numNpcs = 0, numNonNpcsAnimating = 0;
+
+ for (int bucket = 0; bucket < RENDER_GROUP_CFG_NUM_OPAQUE_ENT_BUCKETS; ++bucket)
+ {
+ for (CClientRenderablesList::CEntry *const
+ pEntitiesBegin = m_pRenderablesList->m_RenderGroups[RENDER_GROUP_OPAQUE_ENTITY_HUGE + 2 * bucket],
+ *const pEntitiesEnd =
+ pEntitiesBegin +
+ m_pRenderablesList->m_RenderGroupCounts[RENDER_GROUP_OPAQUE_ENTITY_HUGE + 2 * bucket],
+ *itEntity = pEntitiesBegin;
+ itEntity < pEntitiesEnd; ++itEntity)
+ {
+ C_BaseEntity *pEntity =
+ itEntity->m_pRenderable ? itEntity->m_pRenderable->GetIClientUnknown()->GetBaseEntity() : NULL;
+ if (pEntity)
+ {
+ if (pEntity->IsNPC())
+ {
+ C_BaseAnimating *pba = assert_cast(pEntity);
+ arrRenderEntsNpcsFirst[numNpcs++] = *itEntity;
+ arrBoneSetupNpcsLast[numOpaqueEnts - numNpcs] = pba;
+
+ itEntity->m_pRenderable = nullptr; // We will render NPCs separately
+ itEntity->m_RenderHandle = NULL;
+
+ continue;
+ }
+ else if (pEntity->GetBaseAnimating())
+ {
+ C_BaseAnimating *pba = assert_cast(pEntity);
+ arrBoneSetupNpcsLast[numNonNpcsAnimating++] = pba;
+ // fall through
+ }
+ }
+ }
+ }
+
+ //
+ // Draw static props + opaque entities from the biggest bucket to the smallest
+ //
+ {
+ CClientRenderablesList::CEntry *pEnts[RENDER_GROUP_CFG_NUM_OPAQUE_ENT_BUCKETS][2];
+ CClientRenderablesList::CEntry *pProps[RENDER_GROUP_CFG_NUM_OPAQUE_ENT_BUCKETS][2];
+
+ for (int bucket = 0; bucket < RENDER_GROUP_CFG_NUM_OPAQUE_ENT_BUCKETS; ++bucket)
+ {
+ pEnts[bucket][0] = m_pRenderablesList->m_RenderGroups[RENDER_GROUP_OPAQUE_ENTITY_HUGE + 2 * bucket];
+ pEnts[bucket][1] =
+ pEnts[bucket][0] +
+ m_pRenderablesList->m_RenderGroupCounts[RENDER_GROUP_OPAQUE_ENTITY_HUGE + 2 * bucket];
+
+ pProps[bucket][0] = m_pRenderablesList->m_RenderGroups[RENDER_GROUP_OPAQUE_STATIC_HUGE + 2 * bucket];
+ pProps[bucket][1] =
+ pProps[bucket][0] +
+ m_pRenderablesList->m_RenderGroupCounts[RENDER_GROUP_OPAQUE_STATIC_HUGE + 2 * bucket];
+ }
+
+ for (int bucket = 0; bucket < RENDER_GROUP_CFG_NUM_OPAQUE_ENT_BUCKETS; ++bucket)
+ {
+ if (bDrawopaquestaticpropslast)
+ {
+ DrawOpaqueRenderables_Range(pEnts[bucket][0], pEnts[bucket][1], bShadowDepth);
+ DrawOpaqueRenderables_DrawStaticProps(pProps[bucket][0], pProps[bucket][1], bShadowDepth);
+ }
+ else
+ {
+ DrawOpaqueRenderables_Range(pEnts[bucket][0], pEnts[bucket][1], bShadowDepth);
+ DrawOpaqueRenderables_DrawStaticProps(pProps[bucket][0], pProps[bucket][1], bShadowDepth);
+ }
+ }
+ }
+
+ //
+ // Draw NPCs now
+ //
+ DrawOpaqueRenderables_Range(arrRenderEntsNpcsFirst.Base(), arrRenderEntsNpcsFirst.Base() + numNpcs,
+ bShadowDepth);
+ //
+ // Ropes and particles
+ //
+ if (bRopes)
+ RopeManager()->DrawRenderCache(bShadowDepth);
+ if (bParticles)
+ g_pParticleSystemMgr->DrawRenderCache(bShadowDepth);
+ };
+ void DrawOpaqueRenderable(IClientRenderable *pEnt, bool bTwoPass, bool bShadowDepth)
+ {
+ float color[3];
+
+ pEnt->GetColorModulation(color);
+ render->SetColorModulation(color);
+
+ int flags = STUDIO_RENDER;
+ if (bTwoPass)
+ {
+ flags |= STUDIO_TWOPASS;
+ }
+
+ if (bShadowDepth)
+ {
+ flags |= STUDIO_SHADOWDEPTHTEXTURE;
+ }
+
+ float *pRenderClipPlane = pEnt->GetRenderClipPlane();
+
+ if (pRenderClipPlane)
+ {
+ CMatRenderContextPtr pRenderContext(materials);
+ if (!materials->UsingFastClipping()) // do NOT change the fast clip plane mid-scene, depth problems result.
+ // Regular user clip planes are fine though
+ pRenderContext->PushCustomClipPlane(pRenderClipPlane);
+#if DEBUG
+ else
+ AssertMsg(0, "can't link DrawClippedDepthBox externally so you either have to cope with even more "
+ "redundancy or move all this crap to viewrender");
+#endif
+ // DrawClippedDepthBox( pEnt, pRenderClipPlane );
+ Assert(view->GetCurrentlyDrawingEntity() == NULL);
+ view->SetCurrentlyDrawingEntity(pEnt->GetIClientUnknown()->GetBaseEntity());
+ pEnt->DrawModel(flags);
+ view->SetCurrentlyDrawingEntity(nullptr);
+ if (pRenderClipPlane && !materials->UsingFastClipping())
+ pRenderContext->PopCustomClipPlane();
+ }
+ else
+ {
+ Assert(view->GetCurrentlyDrawingEntity() == NULL);
+ view->SetCurrentlyDrawingEntity(pEnt->GetIClientUnknown()->GetBaseEntity());
+ pEnt->DrawModel(flags);
+ view->SetCurrentlyDrawingEntity(nullptr);
+ }
+ }
+
+ void DrawOpaqueRenderables_DrawBrushModels(CClientRenderablesList::CEntry *pEntitiesBegin,
+ CClientRenderablesList::CEntry *pEntitiesEnd, bool bShadowDepth)
+ {
+ for (CClientRenderablesList::CEntry *itEntity = pEntitiesBegin; itEntity < pEntitiesEnd; ++itEntity)
+ DrawOpaqueRenderable(itEntity->m_pRenderable, false, bShadowDepth);
+ }
+
+ void DrawOpaqueRenderables_DrawStaticProps(CClientRenderablesList::CEntry *pEntitiesBegin,
+ CClientRenderablesList::CEntry *pEntitiesEnd, bool bShadowDepth)
+ {
+ if (pEntitiesEnd == pEntitiesBegin)
+ return;
+
+ float one[4] = {1.0f, 1.0f, 1.0f, 1.0f};
+ render->SetColorModulation(one);
+ render->SetBlend(1.0f);
+
+ const int MAX_STATICS_PER_BATCH = 512;
+ IClientRenderable *pStatics[MAX_STATICS_PER_BATCH];
+
+ int numScheduled = 0, numAvailable = MAX_STATICS_PER_BATCH;
+
+ for (CClientRenderablesList::CEntry *itEntity = pEntitiesBegin; itEntity < pEntitiesEnd; ++itEntity)
+ {
+ if (itEntity->m_pRenderable)
+ NULL;
+ else
+ continue;
+
+ pStatics[numScheduled++] = itEntity->m_pRenderable;
+ if (--numAvailable > 0)
+ continue; // place a hint for compiler to predict more common case in the loop
+
+ staticpropmgr->DrawStaticProps(pStatics, numScheduled, bShadowDepth, vcollide_wireframe.GetBool());
+ numScheduled = 0;
+ numAvailable = MAX_STATICS_PER_BATCH;
+ }
+
+ if (numScheduled)
+ staticpropmgr->DrawStaticProps(pStatics, numScheduled, bShadowDepth, vcollide_wireframe.GetBool());
+ }
+
+ void DrawOpaqueRenderables_Range(CClientRenderablesList::CEntry *pEntitiesBegin,
+ CClientRenderablesList::CEntry *pEntitiesEnd, bool bShadowDepth)
+ {
+ for (CClientRenderablesList::CEntry *itEntity = pEntitiesBegin; itEntity < pEntitiesEnd; ++itEntity)
+ if (itEntity->m_pRenderable)
+ DrawOpaqueRenderable(itEntity->m_pRenderable, (itEntity->m_TwoPass != 0), bShadowDepth);
+ }
+};
+
+class CSimpleVCallbackView : public CBaseVCallbackView
+{
+ DECLARE_CLASS(CSimpleVCallbackView, CBaseVCallbackView);
+
+ public:
+ CSimpleVCallbackView(CViewRender *pMainView) : CBaseVCallbackView(pMainView) {}
+
+ struct EditorViewSettings
+ {
+ bool bDrawPlayers;
+ bool bDrawWeapons;
+ bool bDrawStaticProps;
+ bool bDrawMisc;
+ bool bDrawTranslucents;
+ bool bDrawWater;
+ bool bDrawWorld;
+ bool bDrawParticles;
+ bool bDrawRopes;
+ bool bDrawSkybox;
+ bool bClipSkybox;
+ bool bClearColor;
+ bool bClearDepth;
+ bool bClearStencil;
+ bool bClearObeyStencil;
+ bool bFogOverride;
+ bool bFogEnabled;
+
+ int iClearColorR;
+ int iClearColorG;
+ int iClearColorB;
+ int iClearColorA;
+ int iFogColorR;
+ int iFogColorG;
+ int iFogColorB;
+
+ float flFogStart;
+ float flFogEnd;
+ float flFogDensity;
+ };
+
+ EditorViewSettings settings;
+
+ void Setup(const CViewSetup &view, CSimpleVCallbackView::EditorViewSettings settings,
+ const VisibleFogVolumeInfo_t &fogInfo, const WaterRenderInfo_t &info)
+ {
+ this->settings = settings;
+
+ BaseClass::Setup(view);
+
+ m_ClearFlags = (settings.bClearColor ? VIEW_CLEAR_COLOR : 0) | (settings.bClearDepth ? VIEW_CLEAR_DEPTH : 0) |
+ (settings.bClearStencil ? VIEW_CLEAR_STENCIL : 0) |
+ (settings.bClearObeyStencil ? VIEW_CLEAR_OBEY_STENCIL : 0);
+
+ m_DrawFlags = (settings.bDrawPlayers || settings.bDrawStaticProps || settings.bDrawTranslucents ||
+ settings.bDrawWeapons || settings.bDrawMisc)
+ ? DF_DRAW_ENTITITES
+ : 0;
+
+ // if ( settings.bDrawWorld )
+ {
+ if (!info.m_bOpaqueWater)
+ {
+ m_DrawFlags |= DF_RENDER_UNDERWATER | DF_RENDER_ABOVEWATER;
+ }
+ else
+ {
+ bool bViewIntersectsWater =
+ DoesViewPlaneIntersectWater(fogInfo.m_flWaterHeight, fogInfo.m_nVisibleFogVolume);
+ if (bViewIntersectsWater)
+ {
+ // have to draw both sides if we can see both.
+ m_DrawFlags |= DF_RENDER_UNDERWATER | DF_RENDER_ABOVEWATER;
+ }
+ else if (fogInfo.m_bEyeInFogVolume)
+ {
+ m_DrawFlags |= DF_RENDER_UNDERWATER;
+ }
+ else
+ {
+ m_DrawFlags |= DF_RENDER_ABOVEWATER;
+ }
+ }
+ }
+
+ if (info.m_bDrawWaterSurface && settings.bDrawWater)
+ {
+ m_DrawFlags |= DF_RENDER_WATER;
+ }
+
+ if (!fogInfo.m_bEyeInFogVolume && settings.bDrawSkybox)
+ {
+ m_DrawFlags |= DF_DRAWSKYBOX;
+ }
+
+ if (settings.bClipSkybox)
+ m_DrawFlags |= DF_CLIP_SKYBOX;
+
+ m_pCustomVisibility = nullptr;
+ m_fogInfo = fogInfo;
+ };
+
+ void Draw() override
+ {
+ DrawSetup(0, m_DrawFlags, 0);
+
+ CMatRenderContextPtr pRenderContext(materials);
+
+ pRenderContext->ClearColor4ub(
+ static_cast(settings.iClearColorR), static_cast(settings.iClearColorG),
+ static_cast(settings.iClearColorB), static_cast(settings.iClearColorA));
+
+ if (settings.bFogOverride)
+ {
+ if (!settings.bFogEnabled)
+ pRenderContext->FogMode(MATERIAL_FOG_NONE);
+ else
+ {
+ pRenderContext->FogMode(MATERIAL_FOG_LINEAR);
+ pRenderContext->FogColor3ub(static_cast(settings.iFogColorR),
+ static_cast(settings.iFogColorG),
+ static_cast(settings.iFogColorB));
+ pRenderContext->FogStart(settings.flFogStart);
+ pRenderContext->FogEnd(settings.flFogEnd);
+ pRenderContext->FogMaxDensity(settings.flFogDensity);
+ }
+ }
+ else if (!m_fogInfo.m_bEyeInFogVolume)
+ {
+ EnableWorldFog();
+ }
+ else
+ {
+ m_ClearFlags |= VIEW_CLEAR_COLOR;
+
+ SetFogVolumeState(m_fogInfo, false);
+
+ pRenderContext.GetFrom(materials);
+
+ unsigned char ucFogColor[3];
+ pRenderContext->GetFogColor(ucFogColor);
+ pRenderContext->ClearColor4ub(ucFogColor[0], ucFogColor[1], ucFogColor[2], 255);
+ }
+
+ pRenderContext.SafeRelease();
+
+ DrawExecute(0, CurrentViewID(), 0);
+
+ pRenderContext.GetFrom(materials);
+ pRenderContext->ClearColor4ub(0, 0, 0, 255);
+
+ m_pMainView->DisableFog();
+ };
+
+ void CallbackInitRenderList(int viewId) override
+ {
+ BaseClass::CallbackInitRenderList(viewId);
+
+ if (settings.bDrawPlayers && settings.bDrawStaticProps && settings.bDrawTranslucents && settings.bDrawWeapons &&
+ settings.bDrawMisc)
+ return;
+
+ for (int i = 0; i < RENDER_GROUP_COUNT; i++)
+ {
+ const bool bStaticProp = i == 0 || i == 2 || i == 4 || i == 6;
+
+ for (int e = 0; e < m_pRenderablesList->m_RenderGroupCounts[i]; e++)
+ {
+ CClientRenderablesList::CEntry *pEntry = m_pRenderablesList->m_RenderGroups[i] + e;
+
+ if (!pEntry || !pEntry->m_pRenderable)
+ continue;
+
+ bool bRemove = false;
+ if (bStaticProp)
+ bRemove = !settings.bDrawStaticProps;
+ else
+ {
+ IClientUnknown *pUnknown = pEntry->m_pRenderable->GetIClientUnknown();
+
+ if (!pUnknown || !pUnknown->GetBaseEntity())
+ continue;
+
+ C_BaseEntity *pEntity = pUnknown->GetBaseEntity();
+
+ if (pEntity->IsPlayer())
+ bRemove = !settings.bDrawPlayers;
+ else if (dynamic_cast(pEntity) != nullptr)
+ bRemove = !settings.bDrawWeapons;
+ else if (pEntry->m_pRenderable->IsTransparent())
+ bRemove = !settings.bDrawTranslucents;
+ else
+ bRemove = !settings.bDrawMisc;
+ }
+
+ if (bRemove)
+ {
+ pEntry->m_pRenderable = nullptr;
+ pEntry->m_RenderHandle = NULL;
+ }
+ }
+
+ int eLast = -1;
+ for (int e = 0; e < m_pRenderablesList->m_RenderGroupCounts[i]; e++)
+ {
+ CClientRenderablesList::CEntry *pEntry = m_pRenderablesList->m_RenderGroups[i] + e;
+
+ if (!pEntry || !pEntry->m_pRenderable || !pEntry->m_RenderHandle)
+ {
+ for (int e2 = e + 1; e2 < m_pRenderablesList->m_RenderGroupCounts[i]; e2++)
+ {
+ CClientRenderablesList::CEntry *pEntry2 = m_pRenderablesList->m_RenderGroups[i] + e2;
+ if (pEntry2 && pEntry2->m_pRenderable && pEntry2->m_RenderHandle)
+ {
+ CClientRenderablesList::CEntry tmp = *pEntry;
+ *pEntry = *pEntry2;
+ *pEntry2 = tmp;
+ break;
+ }
+ }
+ }
+
+ if (pEntry && pEntry->m_pRenderable && pEntry->m_RenderHandle)
+ eLast = e;
+ }
+
+ m_pRenderablesList->m_RenderGroupCounts[i] = eLast + 1;
+ }
+ };
+
+ bool ShouldDrawParticles() override { return settings.bDrawParticles; };
+
+ bool ShouldDrawRopes() override { return settings.bDrawRopes; };
+
+ bool ShouldDrawWorld() override { return settings.bDrawWorld; };
+
+ bool ShouldDrawTranslucents() override { return settings.bDrawTranslucents; };
+
+ bool ShouldDrawTranslucentWorld() override { return settings.bDrawWorld && settings.bDrawTranslucents; };
+
+ private:
+ VisibleFogVolumeInfo_t m_fogInfo;
+};
+
+static bool UpdateRefractIfNeededByList(CUtlVector &list)
+{
+ int nCount = list.Count();
+ for (int i = 0; i < nCount; ++i)
+ {
+ IClientUnknown *pUnk = list[i]->GetIClientUnknown();
+ Assert(pUnk);
+
+ IClientRenderable *pRenderable = pUnk->GetClientRenderable();
+ Assert(pRenderable);
+
+ if (pRenderable->UsesPowerOfTwoFrameBufferTexture())
+ {
+ UpdateRefractTexture();
+ return true;
+ }
+ }
+
+ return false;
+}
+static void DrawRenderablesInList(CUtlVector &list, int flags = 0)
+{
+ CViewRender *pCView = assert_cast(view);
+ Assert(pCView->GetCurrentlyDrawingEntity() == NULL);
+
+ int nCount = list.Count();
+ for (int i = 0; i < nCount; ++i)
+ {
+ IClientUnknown *pUnk = list[i]->GetIClientUnknown();
+ Assert(pUnk);
+
+ IClientRenderable *pRenderable = pUnk->GetClientRenderable();
+ Assert(pRenderable);
+
+ // Non-view models wanting to render in view model list...
+ if (pRenderable->ShouldDraw())
+ {
+ pCView->SetCurrentlyDrawingEntity(pUnk->GetBaseEntity());
+ pRenderable->DrawModel(STUDIO_RENDER | flags);
+ }
+ }
+ pCView->SetCurrentlyDrawingEntity(nullptr);
+}
+
+int &ShaderEditorHandler::GetViewIdForModify() const
+{
+ Assert(m_piCurrentViewId != NULL);
+
+ return *m_piCurrentViewId;
+}
+
+const VisibleFogVolumeInfo_t &ShaderEditorHandler::GetFogVolumeInfo() const { return m_tFogVolumeInfo; }
+const WaterRenderInfo_t &ShaderEditorHandler::GetWaterRenderInfo() const { return m_tWaterRenderInfo; }
+
+pFnVrCallback_Declare(VrCallback_General)
+{
+ CViewRender *pCView = assert_cast(view);
+ Assert(pCView->GetViewSetup() != NULL);
+
+ const CViewSetup *setup = pCView->GetViewSetup();
+
+ CSimpleVCallbackView::EditorViewSettings settings;
+
+ settings.bDrawPlayers = pbOptions[0];
+ settings.bDrawWeapons = pbOptions[1];
+ settings.bDrawStaticProps = pbOptions[2];
+ settings.bDrawMisc = pbOptions[3];
+ settings.bDrawTranslucents = pbOptions[4];
+ settings.bDrawWater = pbOptions[5];
+ settings.bDrawWorld = pbOptions[6];
+ settings.bDrawParticles = pbOptions[7];
+ settings.bDrawRopes = pbOptions[8];
+ settings.bDrawSkybox = pbOptions[9];
+ settings.bClipSkybox = pbOptions[10];
+ settings.bClearColor = pbOptions[11];
+ settings.bClearDepth = pbOptions[12];
+ settings.bClearStencil = pbOptions[13];
+ settings.bClearObeyStencil = pbOptions[14];
+ settings.bFogOverride = pbOptions[15];
+ settings.bFogEnabled = pbOptions[16];
+
+ settings.iClearColorR = piOptions[0];
+ settings.iClearColorG = piOptions[1];
+ settings.iClearColorB = piOptions[2];
+ settings.iClearColorA = piOptions[3];
+ settings.iFogColorR = piOptions[4];
+ settings.iFogColorG = piOptions[5];
+ settings.iFogColorB = piOptions[6];
+
+ settings.flFogStart = pflOptions[0];
+ settings.flFogEnd = pflOptions[1];
+ settings.flFogDensity = pflOptions[2];
+
+ if (settings.flFogEnd < 0)
+ settings.flFogEnd = setup->zFar;
+
+ CRefPtr pGeneralCallbackView = new CSimpleVCallbackView(pCView);
+ pGeneralCallbackView->Setup(*setup, settings, g_ShaderEditorSystem->GetFogVolumeInfo(),
+ g_ShaderEditorSystem->GetWaterRenderInfo());
+ pCView->AddViewToScene(pGeneralCallbackView);
+}
+
+pFnVrCallback_Declare(VrCallback_ViewModel)
+{
+ CViewRender *pCView = assert_cast(view);
+ Assert(pCView->GetViewSetup() != NULL);
+
+ CMatRenderContextPtr pRenderContext(materials);
+
+ static ConVarRef drawVM("r_drawviewmodel");
+
+ const bool bHideVM = pbOptions[0];
+ const bool bFogOverride = pbOptions[5];
+ const int iClearFlags = (pbOptions[1] ? VIEW_CLEAR_COLOR : 0) | (pbOptions[2] ? VIEW_CLEAR_DEPTH : 0) |
+ (pbOptions[3] ? VIEW_CLEAR_STENCIL : 0) | (pbOptions[4] ? VIEW_CLEAR_OBEY_STENCIL : 0);
+
+ drawVM.SetValue(!bHideVM);
+
+ if (bFogOverride)
+ {
+ if (!pbOptions[6])
+ pCView->DisableFog();
+ else
+ {
+ pRenderContext->FogMode(MATERIAL_FOG_LINEAR);
+ pRenderContext->FogColor3ub(static_cast(piOptions[4]),
+ static_cast(piOptions[5]),
+ static_cast(piOptions[6]));
+ pRenderContext->FogStart(pflOptions[0]);
+ pRenderContext->FogEnd(pflOptions[1]);
+ pRenderContext->FogMaxDensity(pflOptions[2]);
+ }
+ }
+
+ int bbx, bby;
+ materials->GetBackBufferDimensions(bbx, bby);
+
+ // Restore the matrices
+ pRenderContext->MatrixMode(MATERIAL_PROJECTION);
+ pRenderContext->PushMatrix();
+
+ ITexture *pTex = pRenderContext->GetRenderTarget();
+ const CViewSetup &view = *pCView->GetViewSetup();
+ CViewSetup viewModelSetup(view);
+ viewModelSetup.zNear = view.zNearViewmodel;
+ viewModelSetup.zFar = view.zFarViewmodel;
+ viewModelSetup.fov = view.fovViewmodel;
+ viewModelSetup.m_flAspectRatio = engine->GetScreenAspectRatio();
+ viewModelSetup.width = pTex ? pTex->GetActualWidth() : bbx;
+ viewModelSetup.height = pTex ? pTex->GetActualHeight() : bby;
+
+ if (iClearFlags & VIEW_CLEAR_COLOR)
+ {
+ pRenderContext->ClearColor4ub(
+ static_cast(piOptions[0]), static_cast(piOptions[1]),
+ static_cast(piOptions[2]), static_cast(piOptions[3]));
+ }
+
+ render->Push3DView(viewModelSetup, iClearFlags, pTex, pCView->GetFrustum());
+ const bool bUseDepthHack = true;
+
+ float depthmin = 0.0f;
+ float depthmax = 1.0f;
+
+ // HACK HACK: Munge the depth range to prevent view model from poking into walls, etc.
+ // Force clipped down range
+ if (bUseDepthHack)
+ pRenderContext->DepthRange(0.0f, 0.1f);
+
+ CUtlVector opaqueViewModelList(32);
+ CUtlVector translucentViewModelList(32);
+ ClientLeafSystem()->CollateViewModelRenderables(opaqueViewModelList, translucentViewModelList);
+
+ const bool bUpdateRefractForOpaque = UpdateRefractIfNeededByList(opaqueViewModelList);
+ DrawRenderablesInList(opaqueViewModelList);
+
+ if (!bUpdateRefractForOpaque)
+ UpdateRefractIfNeededByList(translucentViewModelList);
+
+ DrawRenderablesInList(translucentViewModelList, STUDIO_TRANSPARENCY);
+
+ // Reset the depth range to the original values
+ if (bUseDepthHack)
+ pRenderContext->DepthRange(depthmin, depthmax);
+
+ render->PopView(pCView->GetFrustum());
+
+ // Restore the matrices
+ pRenderContext->MatrixMode(MATERIAL_PROJECTION);
+ pRenderContext->PopMatrix();
+
+ if (bFogOverride)
+ pCView->DisableFog();
+}
+
+void ShaderEditorHandler::RegisterViewRenderCallbacks() const
+{
+ if (!IsReady())
+ return;
+
+ const char *boolNames_generalVrc[] = {
+ "Draw players", "Draw weapons", "Draw static props", "Draw misc", "Draw translucents", "Draw water",
+ "Draw world", "Draw particles", "Draw ropes", "Draw skybox (2D)", "Clip skybox", "Clear color",
+ "Clear depth", "Clear stencil", "Clear obey stencil", "Fog override", "Fog force enabled",
+ };
+ const bool boolDefaults_generalVrc[] = {
+ true, true, true, true, true, true, true, true, true, true, false, true, true, false, false, false, true,
+ };
+ const char *intNames_generalVrc[] = {
+ "Clear color R (0-255)", "Clear color G (0-255)", "Clear color B (0-255)", "Clear color A (0-255)",
+ "Fog color R (0-255)", "Fog color G (0-255)", "Fog color B (0-255)",
+ };
+
+ const char *floatNames_generalVrc[] = {
+ "Fog start (units)", "Fog end (units)", "Fog density (0-1)",
+ };
+ const float floatDefaults_generalVrc[] = {
+ 0, 2000, 1,
+ };
+
+ const char *boolNames_vmVrc[] = {
+ "Hide default viewmodel", "Clear color", "Clear depth", "Clear stencil",
+ "Clear obey stencil", "Fog override", "Fog force enabled",
+ };
+ const bool boolDefaults_vmVrc[] = {
+ false, true, true, false, false, false, true,
+ };
+
+ Assert(ARRAYSIZE(boolNames_generalVrc) == ARRAYSIZE(boolDefaults_generalVrc));
+ Assert(ARRAYSIZE(floatNames_generalVrc) == ARRAYSIZE(floatDefaults_generalVrc));
+ Assert(ARRAYSIZE(boolNames_vmVrc) == ARRAYSIZE(boolDefaults_vmVrc));
+
+ shaderEdit->RegisterViewRenderCallback(
+ "General view", VrCallback_General, boolNames_generalVrc, boolDefaults_generalVrc,
+ ARRAYSIZE(boolNames_generalVrc), intNames_generalVrc, nullptr, ARRAYSIZE(intNames_generalVrc),
+ floatNames_generalVrc, floatDefaults_generalVrc, ARRAYSIZE(floatNames_generalVrc));
+
+ shaderEdit->RegisterViewRenderCallback("Viewmodel view", VrCallback_ViewModel, boolNames_vmVrc, boolDefaults_vmVrc,
+ ARRAYSIZE(boolNames_vmVrc), intNames_generalVrc, nullptr,
+ ARRAYSIZE(intNames_generalVrc), floatNames_generalVrc,
+ floatDefaults_generalVrc, ARRAYSIZE(floatNames_generalVrc));
+
+ shaderEdit->LockViewRenderCallbacks();
+}
\ No newline at end of file
diff --git a/mp/src/game/client/ShaderEditor/ShaderEditorSystem.h b/mp/src/game/client/ShaderEditor/ShaderEditorSystem.h
new file mode 100644
index 0000000000..5d09739f8d
--- /dev/null
+++ b/mp/src/game/client/ShaderEditor/ShaderEditorSystem.h
@@ -0,0 +1,49 @@
+#ifndef SHEDITSYSTEM_H
+#define SHEDITSYSTEM_H
+
+#include "cbase.h"
+
+#include "datacache/imdlcache.h"
+
+#include "iviewrender.h"
+#include "view_shared.h"
+#include "viewrender.h"
+
+
+class ShaderEditorHandler : public CAutoGameSystemPerFrame
+{
+public:
+ ShaderEditorHandler( char const *name );
+ ~ShaderEditorHandler();
+
+ bool Init() override;
+ void Shutdown() override;
+
+ void Update( float frametime ) override;
+ void PreRender() override;
+ void PostRender() override;
+ void CustomViewRender( int *viewId, const VisibleFogVolumeInfo_t &fogVolumeInfo, const WaterRenderInfo_t &waterRenderInfo );
+ void CustomPostRender() const;
+ void UpdateSkymask( bool bCombineMode = false ) const;
+
+ bool IsReady() const;
+ int &GetViewIdForModify() const;
+ const VisibleFogVolumeInfo_t &GetFogVolumeInfo() const;
+ const WaterRenderInfo_t &GetWaterRenderInfo() const;
+
+private:
+ bool m_bReady;
+
+ void RegisterCallbacks() const;
+ void PrepareCallbackData() const;
+
+ void RegisterViewRenderCallbacks() const;
+
+ int *m_piCurrentViewId;
+ VisibleFogVolumeInfo_t m_tFogVolumeInfo;
+ WaterRenderInfo_t m_tWaterRenderInfo;
+};
+
+extern ShaderEditorHandler *g_ShaderEditorSystem;
+
+#endif
\ No newline at end of file
diff --git a/mp/src/game/client/client_momentum.vpc b/mp/src/game/client/client_momentum.vpc
index 01939fbaf9..f79d1bd03c 100644
--- a/mp/src/game/client/client_momentum.vpc
+++ b/mp/src/game/client/client_momentum.vpc
@@ -1,45 +1,45 @@
//-----------------------------------------------------------------------------
-// CLIENT_MOMENTUM.VPC
+// CLIENT_MOMENTUM.VPC
//
-// Project Script
+// Project Script
//-----------------------------------------------------------------------------
-$Macro SRCDIR "..\.."
-$Macro GAMENAME "momentum"
+$Macro SRCDIR "..\.."
+$Macro GAMENAME "momentum"
$Include "$SRCDIR\game\client\client_base.vpc"
$Configuration
{
- $Compiler
- {
- $AdditionalIncludeDirectories "$BASE;momentum\ui\MapSelection,.\momentum\ui,.\momentum;$SRCDIR\game\shared\momentum;$SRCDIR\thirdparty\gason\src"
- $PreprocessorDefinitions "$BASE"
- }
+ $Compiler
+ {
+ $AdditionalIncludeDirectories "$BASE;momentum\ui\MapSelection,.\momentum\ui,.\momentum;$SRCDIR\game\shared\momentum;$SRCDIR\thirdparty\gason\src"
+ $PreprocessorDefinitions "$BASE;SOURCE_2013"
+ }
}
$Project "Client (Momentum)"
{
- $Folder "Source Files"
- {
- $File "c_team_objectiveresource.cpp"
- $File "c_team_objectiveresource.h"
+ $Folder "Source Files"
+ {
+ $File "c_team_objectiveresource.cpp"
+ $File "c_team_objectiveresource.h"
- $Folder "Momentum"
- {
- $Folder "UI"
- {
+ $Folder "Momentum"
+ {
+ $Folder "UI"
+ {
$Folder "MapSelection"
{
$Folder "Headers"
{
$File "momentum\ui\MapSelection\BaseMapsPage.h"
$File "momentum\ui\MapSelection\IMapList.h"
- $File "momentum\ui\MapSelection\IMapSelector.h"
+ $File "momentum\ui\MapSelection\IMapSelector.h"
$File "momentum\ui\MapSelection\LocalMaps.h"
$File "momentum\ui\MapSelection\MapContextMenu.h"
$File "momentum\ui\MapSelection\MapInfoDialog.h"
- $File "momentum\ui\MapSelection\MapSelector.h"
+ $File "momentum\ui\MapSelection\MapSelector.h"
$File "momentum\ui\MapSelection\MapSelectorDialog.h"
$File "momentum\ui\MapSelection\OnlineMaps.h"
$File "momentum\ui\MapSelection\pch_mapselection.h"
@@ -48,108 +48,142 @@ $Project "Client (Momentum)"
"momentum\ui\MapSelection\LocalMaps.cpp" \
"momentum\ui\MapSelection\MapContextMenu.cpp" \
"momentum\ui\MapSelection\MapInfoDialog.cpp" \
- "momentum\ui\MapSelection\MapSelector.cpp" \
+ "momentum\ui\MapSelection\MapSelector.cpp" \
"momentum\ui\MapSelection\MapSelectorDialog.cpp" \
"momentum\ui\MapSelection\OnlineMaps.cpp"
{
- $Configuration
- {
- $Compiler
- {
- $Create/UsePrecompiledHeader "Not Using Precompiled Headers"
- }
- }
- }
+ $Configuration
+ {
+ $Compiler
+ {
+ $Create/UsePrecompiledHeader "Not Using Precompiled Headers"
+ }
+ }
+ }
}
$File "momentum\ui\MomentumSettingsDialog.cpp"
$File "momentum\ui\IMomentumSettingsPanel.h"
- $File "momentum\ui\hud_speedometer.cpp"
- $File "momentum\ui\hud_strafesync.cpp"
- $File "momentum\ui\hud_timer.cpp"
- $File "momentum\ui\hud_cp_menu.cpp"
- $File "momentum\ui\hud_menu_static.h"
- $File "momentum\ui\hud_menu_static.cpp"
- $File "momentum\ui\hud_fillablebar.h"
+ $File "momentum\ui\hud_speedometer.cpp"
+ $File "momentum\ui\hud_strafesync.cpp"
+ $File "momentum\ui\hud_timer.cpp"
+ $File "momentum\ui\hud_cp_menu.cpp"
+ $File "momentum\ui\hud_menu_static.h"
+ $File "momentum\ui\hud_menu_static.cpp"
+ $File "momentum\ui\hud_fillablebar.h"
$File "momentum\ui\ClientTimesDisplay.h"
$File "momentum\ui\ClientTimesDisplay.cpp"
- $File "momentum\ui\IVersionWarnPanel.h"
- $File "momentum\ui\VersionWarnPanel.cpp"
- $File "momentum\ui\hud_versionwarn.cpp"
- $File "momentum\ui\hud_mapfinished.cpp"
- $File "momentum\ui\hud_keypress.cpp"
- $File "hl2\hud_credits.cpp"
- $File "hl2\hud_weaponselection.cpp"
- $File "hud_chat.cpp"
-
- }
+ $File "momentum\ui\IVersionWarnPanel.h"
+ $File "momentum\ui\VersionWarnPanel.cpp"
+ $File "momentum\ui\hud_versionwarn.cpp"
+ $File "momentum\ui\hud_mapfinished.cpp"
+ $File "momentum\ui\hud_mapfinished.h"
+ $File "momentum\ui\hud_keypress.cpp"
+ $File "hl2\hud_credits.cpp"
+ $File "hl2\hud_weaponselection.cpp"
+ $File "hud_chat.cpp"
+ $File "momentum\ui\hud_comparisons.cpp"
+ $File "momentum\ui\hud_comparisons.h"
+ $File "momentum\ui\hud_mapinfo.cpp"
+ $File "momentum\ui\momSpectatorGUI.cpp"
+ $File "momentum\ui\momSpectatorGUI.h"
+ }
- $File "momentum\client_events.h"
+ $File "momentum\client_events.h"
- $File "momentum\client_events.cpp"
- {
- $Configuration
- {
- $Compiler
- {
- $Create/UsePrecompiledHeader "Not Using Precompiled Headers"
- }
- }
- }
+ $File "momentum\client_events.cpp"
+ {
+ $Configuration
+ {
+ $Compiler
+ {
+ $Create/UsePrecompiledHeader "Not Using Precompiled Headers"
+ }
+ }
+ }
- $Folder "Weapons"
- {
- $File "$SRCDIR\game\shared\momentum\weapon_momentum_gun.cpp"
- $File "$SRCDIR\game\shared\momentum\basecsgrenade_projectile.cpp"
- $File "$SRCDIR\game\shared\momentum\basecsgrenade_projectile.h"
- $File "$SRCDIR\game\shared\momentum\cs_ammodef.cpp"
- $File "$SRCDIR\game\shared\momentum\cs_ammodef.h"
- $File "$SRCDIR\game\shared\momentum\cs_playeranimstate.cpp"
- $File "$SRCDIR\game\shared\momentum\cs_playeranimstate.h"
- $File "$SRCDIR\game\shared\momentum\cs_weapon_parse.cpp"
- $File "$SRCDIR\game\shared\momentum\cs_weapon_parse.h"
- $File "$SRCDIR\game\shared\momentum\weapon_csbase.h"
- $File "$SRCDIR\game\shared\momentum\weapon_csbase.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_csbasegun.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_csbasegun.h"
- $File "$SRCDIR\game\shared\momentum\weapon_cs_heavy.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_cs_pistols.cpp"
+ $Folder "Weapons"
+ {
+ $File "$SRCDIR\game\shared\momentum\weapon_momentum_gun.cpp"
+ $File "$SRCDIR\game\shared\momentum\basecsgrenade_projectile.cpp"
+ $File "$SRCDIR\game\shared\momentum\basecsgrenade_projectile.h"
+ $File "$SRCDIR\game\shared\momentum\cs_ammodef.cpp"
+ $File "$SRCDIR\game\shared\momentum\cs_ammodef.h"
+ $File "$SRCDIR\game\shared\momentum\cs_playeranimstate.cpp"
+ $File "$SRCDIR\game\shared\momentum\cs_playeranimstate.h"
+ $File "$SRCDIR\game\shared\momentum\cs_weapon_parse.cpp"
+ $File "$SRCDIR\game\shared\momentum\cs_weapon_parse.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_csbase.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_csbase.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_csbasegun.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_csbasegun.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_cs_heavy.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_cs_pistols.cpp"
$File "$SRCDIR\game\shared\momentum\weapon_cs_rifles.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_cs_smgs.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_basecsgrenade.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_basecsgrenade.h"
- $File "$SRCDIR\game\shared\momentum\weapon_flashbang.h"
- $File "$SRCDIR\game\shared\momentum\weapon_flashbang.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_hegrenade.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_hegrenade.h"
- $File "$SRCDIR\game\shared\momentum\weapon_knife.cpp"
- $File "$SRCDIR\game\shared\momentum\weapon_knife.h"
- $File "$SRCDIR\game\shared\momentum\weapon_smokegrenade.h"
- $File "$SRCDIR\game\shared\momentum\weapon_smokegrenade.cpp"
- }
+ $File "$SRCDIR\game\shared\momentum\weapon_cs_smgs.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_basecsgrenade.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_basecsgrenade.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_flashbang.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_flashbang.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_hegrenade.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_hegrenade.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_knife.cpp"
+ $File "$SRCDIR\game\shared\momentum\weapon_knife.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_smokegrenade.h"
+ $File "$SRCDIR\game\shared\momentum\weapon_smokegrenade.cpp"
+ }
- $Folder "Util"
- {
- $File "$SRCDIR\game\shared\momentum\util\mom_util.cpp"
- $File "$SRCDIR\game\shared\momentum\util\mom_util.h"
- }
+ $Folder "Util"
+ {
+ $File "$SRCDIR\game\shared\momentum\util\mom_util.cpp"
+ $File "$SRCDIR\game\shared\momentum\util\mom_util.h"
+ $File "$SRCDIR\game\shared\momentum\util\binary_reader.cpp"
+ $File "$SRCDIR\game\shared\momentum\util\binary_reader.h"
+ $File "$SRCDIR\game\shared\momentum\util\binary_writer.cpp"
+ $File "$SRCDIR\game\shared\momentum\util\binary_writer.h"
+ $File "$SRCDIR\game\shared\momentum\util\serialization.h"
+ $File "$SRCDIR\game\shared\momentum\util\baseautocompletefilelist.cpp"
+ $File "$SRCDIR\game\shared\momentum\util\baseautocompletefilelist.h"
+ $File "$SRCDIR\game\shared\momentum\util\run_compare.h"
+ $File "$SRCDIR\game\shared\momentum\util\run_stats.h"
+ $File "$SRCDIR\game\shared\momentum\util\run_stats.cpp"
+ }
+
+ $Folder "Shader Editor" [$WIN32]
+ {
+ $Folder "Header Files"
+ {
+ $File "$SRCDIR\game\client\ShaderEditor\ISEdit_ModelRender.h"
+ $File "$SRCDIR\game\client\ShaderEditor\IVShaderEditor.h"
+ $File "$SRCDIR\game\client\ShaderEditor\ShaderEditorSystem.h"
+ $File "$SRCDIR\game\client\ShaderEditor\SEdit_ModelRender.h"
+ }
+
+ $Folder "Implementation Files"
+ {
+ $File "$SRCDIR\game\client\ShaderEditor\ShaderEditorSystem.cpp"
+ $File "$SRCDIR\game\client\ShaderEditor\SEdit_ModelRender.cpp"
+ }
+ }
- $File "$SRCDIR\game\shared\momentum\mom_gamemovement.cpp"
- $File "$SRCDIR\game\shared\momentum\mom_gamemovement.h"
- $File "$SRCDIR\game\shared\momentum\mom_player_shared.h"
- $File "$SRCDIR\game\shared\momentum\mom_player_shared.cpp"
- $File "$SRCDIR\game\shared\momentum\mom_gamerules.cpp"
- $File "$SRCDIR\game\shared\momentum\mom_usermessages.cpp"
- $File "$SRCDIR\game\shared\momentum\mom_gamerules.h"
- $File "$SRCDIR\game\shared\momentum\mom_shareddefs.h"
- $File "momentum\c_mom_player.cpp"
- $File "momentum\c_mom_player.h"
- $File "momentum\c_te_shotgun_shot.cpp"
- $File "momentum\fx_cs_muzzleflash.cpp"
- $File "momentum\fx_cs_weaponfx.cpp"
+ $File "$SRCDIR\game\shared\momentum\mom_gamemovement.cpp"
+ $File "$SRCDIR\game\shared\momentum\mom_gamemovement.h"
+ $File "$SRCDIR\game\shared\momentum\mom_player_shared.h"
+ $File "$SRCDIR\game\shared\momentum\mom_player_shared.cpp"
+ $File "$SRCDIR\game\shared\momentum\mom_gamerules.cpp"
+ $File "$SRCDIR\game\shared\momentum\mom_usermessages.cpp"
+ $File "$SRCDIR\game\shared\momentum\mom_gamerules.h"
+ $File "$SRCDIR\game\shared\momentum\mom_shareddefs.h"
+ $File "momentum\c_mom_player.cpp"
+ $File "momentum\c_mom_player.h"
+ $File "momentum\c_mom_replay_entity.h"
+ $File "momentum\c_mom_replay_entity.cpp"
+ $File "momentum\c_te_shotgun_shot.cpp"
+ $File "momentum\fx_cs_muzzleflash.cpp"
+ $File "momentum\fx_cs_weaponfx.cpp"
$File "momentum\fx_mom_impacts.cpp"
- $File "$SRCDIR\game\shared\momentum\fx_cs_shared.h"
- $File "$SRCDIR\game\shared\momentum\fx_cs_shared.cpp"
+ $File "$SRCDIR\game\shared\momentum\fx_cs_shared.h"
+ $File "$SRCDIR\game\shared\momentum\fx_cs_shared.cpp"
$File "momentum\vgui_rootpanel_momentum.cpp"
$File "momentum\mom_prediction.cpp"
$File "momentum\mom_in_main.cpp"
@@ -158,24 +192,26 @@ $Project "Client (Momentum)"
$File "momentum\c_corpse.cpp"
$File "momentum\clientmode_mom_normal.h"
$File "momentum\clientmode_mom_normal.cpp"
- $File "momentum\mom_event_listener.h"
+ $File "momentum\mom_event_listener.h"
$File "momentum\mom_event_listener.cpp"
- }
+ $File "$SRCDIR\game\shared\momentum\mom_entity_run_data.h"
+ $File "$SRCDIR\game\shared\momentum\mom_entity_run_data.cpp"
+ }
- $Folder "JSON Parser"
- {
- $File "$SRCDIR\thirdparty\gason\src\gason.h"
- $File "$SRCDIR\thirdparty\gason\src\gason.cpp"
- {
- $Configuration
- {
+ $Folder "JSON Parser"
+ {
+ $File "$SRCDIR\thirdparty\gason\src\gason.h"
+ $File "$SRCDIR\thirdparty\gason\src\gason.cpp"
+ {
+ $Configuration
+ {
$Compiler
{
- $Create/UsePrecompiledHeader "Not Using Precompiled Headers"
+ $Create/UsePrecompiledHeader "Not Using Precompiled Headers"
$TreatWarningsAsErrors "No"
}
}
}
- }
+ }
}
}
\ No newline at end of file
diff --git a/mp/src/game/client/hl2/hud_credits.cpp b/mp/src/game/client/hl2/hud_credits.cpp
index 6ad1488ba6..e704131afe 100644
--- a/mp/src/game/client/hl2/hud_credits.cpp
+++ b/mp/src/game/client/hl2/hud_credits.cpp
@@ -1,47 +1,49 @@
//========= Copyright Valve Corporation, All rights reserved. ============//
//
-// Purpose:
+// Purpose:
//
//=============================================================================//
#include "cbase.h"
-#include "hudelement.h"
-#include "hud_numericdisplay.h"
-#include
+#include "filesystem.h"
#include "hud.h"
-#include "hud_suitpower.h"
#include "hud_macros.h"
+#include "hud_numericdisplay.h"
+#include "hud_suitpower.h"
+#include "hudelement.h"
#include "iclientmode.h"
-#include
-#include
+#include "in_buttons.h"
+#include "input.h"
#include
+#include
+#include
+#include
#include "KeyValues.h"
-#include "filesystem.h"
// memdbgon must be the last include file in a .cpp file!!!
#include "tier0/memdbgon.h"
struct creditname_t
{
- char szCreditName[256];
- char szFontName[256];
- float flYPos;
- float flXPos;
- bool bActive;
- float flTime;
- float flTimeAdd;
- float flTimeStart;
- int iSlot;
+ char szCreditName[256];
+ char szFontName[256];
+ float flYPos;
+ float flXPos;
+ bool bActive;
+ float flTime;
+ float flTimeAdd;
+ float flTimeStart;
+ int iSlot;
};
#define CREDITS_FILE "scripts/credits.txt"
enum
{
- LOGO_FADEIN = 0,
- LOGO_FADEHOLD,
- LOGO_FADEOUT,
- LOGO_FADEOFF,
+ LOGO_FADEIN = 0,
+ LOGO_FADEHOLD,
+ LOGO_FADEOUT,
+ LOGO_FADEOFF,
};
#define CREDITS_LOGO 1
@@ -57,679 +59,682 @@ int g_iCreditsPixelHeight = 0;
//-----------------------------------------------------------------------------
class CHudCredits : public CHudElement, public vgui::Panel
{
- DECLARE_CLASS_SIMPLE( CHudCredits, vgui::Panel );
+ DECLARE_CLASS_SIMPLE(CHudCredits, vgui::Panel);
public:
- CHudCredits( const char *pElementName );
- virtual void Init( void );
- virtual void LevelShutdown( void );
+ CHudCredits(const char *pElementName);
+ void Init(void) override;
+ void LevelShutdown(void) override;
- int GetStringPixelWidth ( wchar_t *pString, vgui::HFont hFont );
+ int GetStringPixelWidth(wchar_t *pString, vgui::HFont hFont);
- void MsgFunc_CreditsMsg( bf_read &msg );
- void MsgFunc_LogoTimeMsg( bf_read &msg );
+ void MsgFunc_CreditsMsg(bf_read &msg);
+ void MsgFunc_LogoTimeMsg(bf_read &msg);
- virtual bool ShouldDraw( void )
- {
- g_bRollingCredits = IsActive();
+ bool ShouldDraw(void) override
+ {
+ g_bRollingCredits = IsActive();
- if ( g_bRollingCredits && m_iCreditsType == CREDITS_INTRO )
- g_bRollingCredits = false;
+ if (g_bRollingCredits && m_iCreditsType == CREDITS_INTRO)
+ g_bRollingCredits = false;
- return IsActive();
- }
+ return IsActive();
+ }
protected:
- virtual void Paint();
- virtual void ApplySchemeSettings( vgui::IScheme *pScheme );
+ void Paint() override;
+ void ApplySchemeSettings(vgui::IScheme *pScheme) override;
private:
+ void Clear();
- void Clear();
-
- void ReadNames( KeyValues *pKeyValue );
- void ReadParams( KeyValues *pKeyValue );
- void PrepareCredits( const char *pKeyName );
- void DrawOutroCreditsName( void );
- void DrawIntroCreditsName( void );
- void DrawLogo( void );
-
- void PrepareLogo( float flTime );
- void PrepareOutroCredits( void );
- void PrepareIntroCredits( void );
+ void ReadNames(KeyValues *pKeyValue);
+ void ReadParams(KeyValues *pKeyValue);
+ void PrepareCredits(const char *pKeyName);
+ void DrawOutroCreditsName(void);
+ void DrawIntroCreditsName(void);
+ void DrawLogo(void);
- float FadeBlend( float fadein, float fadeout, float hold, float localTime );
+ void PrepareLogo(float flTime);
+ void PrepareOutroCredits(void);
+ void PrepareIntroCredits(void);
- void PrepareLine( vgui::HFont hFont, char const *pchLine );
+ float FadeBlend(float fadein, float fadeout, float hold, float localTime);
- CPanelAnimationVar( vgui::HFont, m_hTextFont, "TextFont", "Default" );
- CPanelAnimationVar( Color, m_TextColor, "TextColor", "FgColor" );
+ void PrepareLine(vgui::HFont hFont, char const *pchLine);
- CUtlVector m_CreditsList;
+ CPanelAnimationVar(vgui::HFont, m_hTextFont, "TextFont", "Default");
+ CPanelAnimationVar(Color, m_TextColor, "TextColor", "FgColor");
- float m_flScrollTime;
- float m_flSeparation;
- float m_flFadeTime;
- bool m_bLastOneInPlace;
- int m_Alpha;
+ CUtlVector m_CreditsList;
- int m_iCreditsType;
- int m_iLogoState;
+ float m_flScrollTime;
+ float m_flSeparation;
+ float m_flFadeTime;
+ bool m_bLastOneInPlace;
+ int m_Alpha;
- float m_flFadeInTime;
- float m_flFadeHoldTime;
- float m_flFadeOutTime;
- float m_flNextStartTime;
- float m_flPauseBetweenWaves;
+ int m_iCreditsType;
+ int m_iLogoState;
- float m_flLogoTimeMod;
- float m_flLogoTime;
- float m_flLogoDesiredLength;
+ float m_flFadeInTime;
+ float m_flFadeHoldTime;
+ float m_flFadeOutTime;
+ float m_flNextStartTime;
+ float m_flPauseBetweenWaves;
- float m_flX;
- float m_flY;
+ float m_flLogoTimeMod;
+ float m_flLogoTime;
+ float m_flLogoDesiredLength;
- char m_szLogo[256];
- char m_szLogo2[256];
+ float m_flX;
+ float m_flY;
- Color m_cColor;
-};
+ char m_szLogo[256];
+ char m_szLogo2[256];
+ Color m_cColor;
+};
-void CHudCredits::PrepareCredits( const char *pKeyName )
+void CHudCredits::PrepareCredits(const char *pKeyName)
{
- Clear();
+ Clear();
- KeyValues *pKV= new KeyValues( "CreditsFile" );
- if ( !pKV->LoadFromFile( filesystem, CREDITS_FILE, "MOD" ) )
- {
- pKV->deleteThis();
+ KeyValues *pKV = new KeyValues("CreditsFile");
+ if (!pKV->LoadFromFile(filesystem, CREDITS_FILE, "MOD"))
+ {
+ pKV->deleteThis();
- Assert( !"env_credits couldn't be initialized!" );
- return;
- }
+ Assert(!"env_credits couldn't be initialized!");
+ return;
+ }
- KeyValues *pKVSubkey;
- if ( pKeyName )
- {
- pKVSubkey = pKV->FindKey( pKeyName );
- ReadNames( pKVSubkey );
- }
+ KeyValues *pKVSubkey;
+ if (pKeyName)
+ {
+ pKVSubkey = pKV->FindKey(pKeyName);
+ ReadNames(pKVSubkey);
+ }
- pKVSubkey = pKV->FindKey( "CreditsParams" );
- ReadParams( pKVSubkey );
+ pKVSubkey = pKV->FindKey("CreditsParams");
+ ReadParams(pKVSubkey);
- pKV->deleteThis();
+ pKV->deleteThis();
}
using namespace vgui;
-DECLARE_HUDELEMENT( CHudCredits );
-DECLARE_HUD_MESSAGE( CHudCredits, CreditsMsg );
-DECLARE_HUD_MESSAGE( CHudCredits, LogoTimeMsg );
+DECLARE_HUDELEMENT(CHudCredits);
+DECLARE_HUD_MESSAGE(CHudCredits, CreditsMsg);
+DECLARE_HUD_MESSAGE(CHudCredits, LogoTimeMsg);
//-----------------------------------------------------------------------------
// Purpose: Constructor
//-----------------------------------------------------------------------------
-CHudCredits::CHudCredits( const char *pElementName ) : CHudElement( pElementName ), BaseClass( NULL, "HudCredits" )
+CHudCredits::CHudCredits(const char *pElementName) : CHudElement(pElementName), BaseClass(nullptr, "HudCredits")
{
- vgui::Panel *pParent = g_pClientMode->GetViewport();
- SetParent( pParent );
+ Panel *pParent = g_pClientMode->GetViewport();
+ SetParent(pParent);
}
-void CHudCredits::LevelShutdown()
-{
- Clear();
-}
+void CHudCredits::LevelShutdown() { Clear(); }
-void CHudCredits::Clear( void )
+void CHudCredits::Clear(void)
{
- SetActive( false );
- m_CreditsList.RemoveAll();
- m_bLastOneInPlace = false;
- m_Alpha = m_TextColor[3];
- m_iLogoState = LOGO_FADEOFF;
+ SetActive(false);
+ m_CreditsList.RemoveAll();
+ m_bLastOneInPlace = false;
+ m_Alpha = m_TextColor[3];
+ m_iLogoState = LOGO_FADEOFF;
}
//-----------------------------------------------------------------------------
-// Purpose:
+// Purpose:
//-----------------------------------------------------------------------------
void CHudCredits::Init()
{
- HOOK_HUD_MESSAGE( CHudCredits, CreditsMsg );
- HOOK_HUD_MESSAGE( CHudCredits, LogoTimeMsg );
- SetActive( false );
+ HOOK_HUD_MESSAGE(CHudCredits, CreditsMsg);
+ HOOK_HUD_MESSAGE(CHudCredits, LogoTimeMsg);
+ SetActive(false);
}
-void CHudCredits::ReadNames( KeyValues *pKeyValue )
+void CHudCredits::ReadNames(KeyValues *pKeyValue)
{
- if ( pKeyValue == NULL )
- {
- Assert( !"CHudCredits couldn't be initialized!" );
- return;
- }
-
- // Now try and parse out each act busy anim
- KeyValues *pKVNames = pKeyValue->GetFirstSubKey();
-
- while ( pKVNames )
- {
- creditname_t Credits;
- V_strcpy_safe( Credits.szCreditName, pKVNames->GetName() );
- V_strcpy_safe( Credits.szFontName, pKeyValue->GetString( Credits.szCreditName, "Default" ) );
-
- m_CreditsList.AddToTail( Credits );
- pKVNames = pKVNames->GetNextKey();
- }
+ if (pKeyValue == nullptr)
+ {
+ Assert(!"CHudCredits couldn't be initialized!");
+ return;
+ }
+
+ // Now try and parse out each act busy anim
+ KeyValues *pKVNames = pKeyValue->GetFirstSubKey();
+
+ while (pKVNames)
+ {
+ creditname_t Credits;
+ V_strcpy_safe(Credits.szCreditName, pKVNames->GetName());
+ V_strcpy_safe(Credits.szFontName, pKeyValue->GetString(Credits.szCreditName, "Default"));
+
+ m_CreditsList.AddToTail(Credits);
+ pKVNames = pKVNames->GetNextKey();
+ }
}
-void CHudCredits::ReadParams( KeyValues *pKeyValue )
+void CHudCredits::ReadParams(KeyValues *pKeyValue)
{
- if ( pKeyValue == NULL )
- {
- Assert( !"CHudCredits couldn't be initialized!" );
- return;
- }
+ if (pKeyValue == nullptr)
+ {
+ Assert(!"CHudCredits couldn't be initialized!");
+ return;
+ }
- m_flScrollTime = pKeyValue->GetFloat( "scrolltime", 57 );
- m_flSeparation = pKeyValue->GetFloat( "separation", 5 );
+ m_flScrollTime = pKeyValue->GetFloat("scrolltime", 57);
+ m_flSeparation = pKeyValue->GetFloat("separation", 5);
- m_flFadeInTime = pKeyValue->GetFloat( "fadeintime", 1 );
- m_flFadeHoldTime = pKeyValue->GetFloat( "fadeholdtime", 3 );
- m_flFadeOutTime = pKeyValue->GetFloat( "fadeouttime", 2 );
- m_flNextStartTime = pKeyValue->GetFloat( "nextfadetime", 2 );
- m_flPauseBetweenWaves = pKeyValue->GetFloat( "pausebetweenwaves", 2 );
+ m_flFadeInTime = pKeyValue->GetFloat("fadeintime", 1);
+ m_flFadeHoldTime = pKeyValue->GetFloat("fadeholdtime", 3);
+ m_flFadeOutTime = pKeyValue->GetFloat("fadeouttime", 2);
+ m_flNextStartTime = pKeyValue->GetFloat("nextfadetime", 2);
+ m_flPauseBetweenWaves = pKeyValue->GetFloat("pausebetweenwaves", 2);
- m_flLogoTimeMod = pKeyValue->GetFloat( "logotime", 2 );
+ m_flLogoTimeMod = pKeyValue->GetFloat("logotime", 2);
- m_flX = pKeyValue->GetFloat( "posx", 2 );
- m_flY = pKeyValue->GetFloat( "posy", 2 );
+ m_flX = pKeyValue->GetFloat("posx", 2);
+ m_flY = pKeyValue->GetFloat("posy", 2);
- m_cColor = pKeyValue->GetColor( "color" );
+ m_cColor = pKeyValue->GetColor("color");
- Q_strncpy( m_szLogo, pKeyValue->GetString( "logo", "HALF-LIFE'" ), sizeof( m_szLogo ) );
- Q_strncpy( m_szLogo2, pKeyValue->GetString( "logo2", "" ), sizeof( m_szLogo2 ) );
+ Q_strncpy(m_szLogo, pKeyValue->GetString("logo", "HALF-LIFE'"), sizeof(m_szLogo));
+ Q_strncpy(m_szLogo2, pKeyValue->GetString("logo2", ""), sizeof(m_szLogo2));
}
-int CHudCredits::GetStringPixelWidth( wchar_t *pString, vgui::HFont hFont )
+int CHudCredits::GetStringPixelWidth(wchar_t *pString, HFont hFont)
{
- int iLength = 0;
+ int iLength = 0;
- for ( wchar_t *wch = pString; *wch != 0; wch++ )
- {
- iLength += surface()->GetCharacterWidth( hFont, *wch );
- }
+ for (wchar_t *wch = pString; *wch != 0; wch++)
+ {
+ iLength += surface()->GetCharacterWidth(hFont, *wch);
+ }
- return iLength;
+ return iLength;
}
-void CHudCredits::DrawOutroCreditsName( void )
+void CHudCredits::DrawOutroCreditsName(void)
{
- if ( m_CreditsList.Count() == 0 )
- return;
-
- // fill the screen
- int iWidth, iTall;
- GetHudSize(iWidth, iTall);
- SetSize( iWidth, iTall );
-
- for ( int i = 0; i < m_CreditsList.Count(); i++ )
- {
- creditname_t *pCredit = &m_CreditsList[i];
-
- if ( pCredit == NULL )
- continue;
-
- vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
- vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName, true );
-
- int iFontTall = surface()->GetFontTall ( m_hTFont );
-
- if ( pCredit->flYPos < -iFontTall || pCredit->flYPos > iTall )
- {
- pCredit->bActive = false;
- }
- else
- {
- pCredit->bActive = true;
- }
-
- Color cColor = m_TextColor;
-
- //HACKHACK
- //Last one stays on screen and fades out
- if ( i == m_CreditsList.Count()-1 )
- {
- if ( m_bLastOneInPlace == false )
- {
- pCredit->flYPos -= gpGlobals->frametime * ( (float)g_iCreditsPixelHeight / m_flScrollTime );
-
- if ( (int)pCredit->flYPos + ( iFontTall / 2 ) <= iTall / 2 )
- {
- m_bLastOneInPlace = true;
-
- // 360 certification requires that we not hold a static image too long.
- m_flFadeTime = gpGlobals->curtime + ( IsConsole() ? 2.0f : 10.0f );
- }
- }
- else
- {
- if ( m_flFadeTime <= gpGlobals->curtime )
- {
- if ( m_Alpha > 0 )
- {
- m_Alpha -= gpGlobals->frametime * ( m_flScrollTime * 2 );
-
- if ( m_Alpha <= 0 )
- {
- pCredit->bActive = false;
- engine->ClientCmd( "creditsdone" );
- }
- }
- }
-
- cColor[3] = MAX( 0, m_Alpha );
- }
- }
- else
- {
- pCredit->flYPos -= gpGlobals->frametime * ( (float)g_iCreditsPixelHeight / m_flScrollTime );
- }
-
- if ( pCredit->bActive == false )
- continue;
-
- surface()->DrawSetTextFont( m_hTFont );
- surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], cColor[3] );
-
- wchar_t unicode[256];
-
- if ( pCredit->szCreditName[0] == '#' )
- {
- g_pVGuiLocalize->ConstructString( unicode, sizeof(unicode), g_pVGuiLocalize->Find(pCredit->szCreditName), 0 );
- }
- else
- {
- g_pVGuiLocalize->ConvertANSIToUnicode( pCredit->szCreditName, unicode, sizeof( unicode ) );
- }
-
- int iStringWidth = GetStringPixelWidth( unicode, m_hTFont );
-
- surface()->DrawSetTextPos( ( iWidth / 2 ) - ( iStringWidth / 2 ), pCredit->flYPos );
- surface()->DrawUnicodeString( unicode );
- }
+ if (m_CreditsList.Count() == 0)
+ return;
+
+ // fill the screen
+ int iWidth, iTall;
+ GetHudSize(iWidth, iTall);
+ SetSize(iWidth, iTall);
+
+ float p_flDesiedScrollTime = m_flScrollTime;
+ if (::input->GetButtonBits(1) & IN_ATTACK2)
+ {
+ p_flDesiedScrollTime = m_flScrollTime * 0.27f;
+ }
+
+ for (int i = 0; i < m_CreditsList.Count(); i++)
+ {
+ creditname_t *pCredit = &m_CreditsList[i];
+
+ if (pCredit == nullptr)
+ continue;
+
+ HScheme scheme = vgui::scheme()->GetScheme("ClientScheme");
+ HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont(pCredit->szFontName, true);
+
+ int iFontTall = surface()->GetFontTall(m_hTFont);
+
+ if (pCredit->flYPos < -iFontTall || pCredit->flYPos > iTall)
+ {
+ pCredit->bActive = false;
+ }
+ else
+ {
+ pCredit->bActive = true;
+ }
+
+ Color cColor = m_TextColor;
+
+ // HACKHACK
+ // Last one stays on screen and fades out
+ if (i == m_CreditsList.Count() - 1)
+ {
+ if (m_bLastOneInPlace == false)
+ {
+ pCredit->flYPos -= gpGlobals->frametime * (float(g_iCreditsPixelHeight) / p_flDesiedScrollTime);
+
+ if (int(pCredit->flYPos) + (iFontTall / 2) <= iTall / 2)
+ {
+ m_bLastOneInPlace = true;
+
+ // 360 certification requires that we not hold a static image too long.
+ m_flFadeTime = gpGlobals->curtime + (IsConsole() ? 2.0f : 5.0f);
+ }
+ }
+ else
+ {
+ if (m_flFadeTime <= gpGlobals->curtime)
+ {
+ if (m_Alpha > 0)
+ {
+ m_Alpha -= gpGlobals->frametime * (p_flDesiedScrollTime * 2);
+
+ if (m_Alpha <= 0)
+ {
+ pCredit->bActive = false;
+ engine->ClientCmd("creditsdone");
+ }
+ }
+ }
+
+ cColor[3] = MAX(0, m_Alpha);
+ }
+ }
+ else
+ {
+ pCredit->flYPos -= gpGlobals->frametime * (float(g_iCreditsPixelHeight) / p_flDesiedScrollTime);
+ }
+
+ if (pCredit->bActive == false)
+ continue;
+
+ surface()->DrawSetTextFont(m_hTFont);
+ surface()->DrawSetTextColor(cColor[0], cColor[1], cColor[2], cColor[3]);
+
+ wchar_t unicode[256];
+
+ if (pCredit->szCreditName[0] == '#')
+ {
+ g_pVGuiLocalize->ConstructString(unicode, sizeof(unicode), g_pVGuiLocalize->Find(pCredit->szCreditName), 0);
+ }
+ else
+ {
+ g_pVGuiLocalize->ConvertANSIToUnicode(pCredit->szCreditName, unicode, sizeof(unicode));
+ }
+
+ int iStringWidth = GetStringPixelWidth(unicode, m_hTFont);
+
+ surface()->DrawSetTextPos((iWidth / 2) - (iStringWidth / 2), pCredit->flYPos);
+ surface()->DrawUnicodeString(unicode);
+ }
}
-void CHudCredits::DrawLogo( void )
+void CHudCredits::DrawLogo(void)
{
- if( m_iLogoState == LOGO_FADEOFF )
- {
- SetActive( false );
- return;
- }
-
- switch( m_iLogoState )
- {
- case LOGO_FADEIN:
- {
- float flDeltaTime = ( m_flFadeTime - gpGlobals->curtime );
-
- m_Alpha = MAX( 0, RemapValClamped( flDeltaTime, 5.0f, 0, -128, 255 ) );
-
- if ( flDeltaTime <= 0.0f )
- {
- m_iLogoState = LOGO_FADEHOLD;
- m_flFadeTime = gpGlobals->curtime + m_flLogoDesiredLength;
- }
-
- break;
- }
-
- case LOGO_FADEHOLD:
- {
- if ( m_flFadeTime <= gpGlobals->curtime )
- {
- m_iLogoState = LOGO_FADEOUT;
- m_flFadeTime = gpGlobals->curtime + 2.0f;
- }
- break;
- }
-
- case LOGO_FADEOUT:
- {
- float flDeltaTime = ( m_flFadeTime - gpGlobals->curtime );
-
- m_Alpha = RemapValClamped( flDeltaTime, 0.0f, 2.0f, 0, 255 );
-
- if ( flDeltaTime <= 0.0f )
- {
- m_iLogoState = LOGO_FADEOFF;
- SetActive( false );
- }
-
- break;
- }
- }
-
- // fill the screen
- int iWidth, iTall;
- GetHudSize(iWidth, iTall);
- SetSize( iWidth, iTall );
-
- char szLogoFont[64];
-
- if ( IsXbox() )
- {
- Q_snprintf( szLogoFont, sizeof( szLogoFont ), "WeaponIcons_Small" );
- }
- else if ( hl2_episodic.GetBool() )
- {
- Q_snprintf( szLogoFont, sizeof( szLogoFont ), "ClientTitleFont" );
- }
- else
- {
- Q_snprintf( szLogoFont, sizeof( szLogoFont ), "WeaponIcons" );
- }
-
- vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
- vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( szLogoFont );
-
- int iFontTall = surface()->GetFontTall ( m_hTFont );
-
- Color cColor = m_TextColor;
- cColor[3] = m_Alpha;
-
- surface()->DrawSetTextFont( m_hTFont );
- surface()->DrawSetTextColor( cColor[0], cColor[1], cColor[2], cColor[3] );
-
- wchar_t unicode[256];
- g_pVGuiLocalize->ConvertANSIToUnicode( m_szLogo, unicode, sizeof( unicode ) );
-
- int iStringWidth = GetStringPixelWidth( unicode, m_hTFont );
-
- surface()->DrawSetTextPos( ( iWidth / 2 ) - ( iStringWidth / 2 ), ( iTall / 2 ) - ( iFontTall / 2 ) );
- surface()->DrawUnicodeString( unicode );
-
- if ( Q_strlen( m_szLogo2 ) > 0 )
- {
- g_pVGuiLocalize->ConvertANSIToUnicode( m_szLogo2, unicode, sizeof( unicode ) );
-
- iStringWidth = GetStringPixelWidth( unicode, m_hTFont );
-
- surface()->DrawSetTextPos( ( iWidth / 2 ) - ( iStringWidth / 2 ), ( iTall / 2 ) + ( iFontTall / 2 ));
- surface()->DrawUnicodeString( unicode );
- }
+ if (m_iLogoState == LOGO_FADEOFF)
+ {
+ SetActive(false);
+ return;
+ }
+
+ switch (m_iLogoState)
+ {
+ case LOGO_FADEIN:
+ {
+ float flDeltaTime = (m_flFadeTime - gpGlobals->curtime);
+
+ m_Alpha = MAX(0, RemapValClamped(flDeltaTime, 5.0f, 0, -128, 255));
+
+ if (flDeltaTime <= 0.0f)
+ {
+ m_iLogoState = LOGO_FADEHOLD;
+ m_flFadeTime = gpGlobals->curtime + m_flLogoDesiredLength;
+ }
+
+ break;
+ }
+
+ case LOGO_FADEHOLD:
+ {
+ if (m_flFadeTime <= gpGlobals->curtime)
+ {
+ m_iLogoState = LOGO_FADEOUT;
+ m_flFadeTime = gpGlobals->curtime + 2.0f;
+ }
+ break;
+ }
+
+ case LOGO_FADEOUT:
+ {
+ float flDeltaTime = (m_flFadeTime - gpGlobals->curtime);
+
+ m_Alpha = RemapValClamped(flDeltaTime, 0.0f, 2.0f, 0, 255);
+
+ if (flDeltaTime <= 0.0f)
+ {
+ m_iLogoState = LOGO_FADEOFF;
+ SetActive(false);
+ }
+
+ break;
+ }
+ }
+
+ // fill the screen
+ int iWidth, iTall;
+ GetHudSize(iWidth, iTall);
+ SetSize(iWidth, iTall);
+
+ char szLogoFont[64];
+
+ if (IsXbox())
+ {
+ Q_snprintf(szLogoFont, sizeof(szLogoFont), "WeaponIcons_Small");
+ }
+ else if (hl2_episodic.GetBool())
+ {
+ Q_snprintf(szLogoFont, sizeof(szLogoFont), "ClientTitleFont");
+ }
+ else
+ {
+ Q_snprintf(szLogoFont, sizeof(szLogoFont), "WeaponIcons");
+ }
+
+ HScheme scheme = vgui::scheme()->GetScheme("ClientScheme");
+ HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont(szLogoFont);
+
+ int iFontTall = surface()->GetFontTall(m_hTFont);
+
+ Color cColor = m_TextColor;
+ cColor[3] = m_Alpha;
+
+ surface()->DrawSetTextFont(m_hTFont);
+ surface()->DrawSetTextColor(cColor[0], cColor[1], cColor[2], cColor[3]);
+
+ wchar_t unicode[256];
+ g_pVGuiLocalize->ConvertANSIToUnicode(m_szLogo, unicode, sizeof(unicode));
+
+ int iStringWidth = GetStringPixelWidth(unicode, m_hTFont);
+
+ surface()->DrawSetTextPos((iWidth / 2) - (iStringWidth / 2), (iTall / 2) - (iFontTall / 2));
+ surface()->DrawUnicodeString(unicode);
+
+ if (Q_strlen(m_szLogo2) > 0)
+ {
+ g_pVGuiLocalize->ConvertANSIToUnicode(m_szLogo2, unicode, sizeof(unicode));
+
+ iStringWidth = GetStringPixelWidth(unicode, m_hTFont);
+
+ surface()->DrawSetTextPos((iWidth / 2) - (iStringWidth / 2), (iTall / 2) + (iFontTall / 2));
+ surface()->DrawUnicodeString(unicode);
+ }
}
//-----------------------------------------------------------------------------
-// Purpose:
+// Purpose:
//-----------------------------------------------------------------------------
-float CHudCredits::FadeBlend( float fadein, float fadeout, float hold, float localTime )
+float CHudCredits::FadeBlend(float fadein, float fadeout, float hold, float localTime)
{
- float fadeTime = fadein + hold;
- float fadeBlend;
-
- if ( localTime < 0 )
- return 0;
-
- if ( localTime < fadein )
- {
- fadeBlend = 1 - ((fadein - localTime) / fadein);
- }
- else if ( localTime > fadeTime )
- {
- if ( fadeout > 0 )
- fadeBlend = 1 - ((localTime - fadeTime) / fadeout);
- else
- fadeBlend = 0;
- }
- else
- fadeBlend = 1;
-
- if ( fadeBlend < 0 )
- fadeBlend = 0;
-
- return fadeBlend;
+ float fadeTime = fadein + hold;
+ float fadeBlend;
+
+ if (localTime < 0)
+ return 0;
+
+ if (localTime < fadein)
+ {
+ fadeBlend = 1 - ((fadein - localTime) / fadein);
+ }
+ else if (localTime > fadeTime)
+ {
+ if (fadeout > 0)
+ fadeBlend = 1 - ((localTime - fadeTime) / fadeout);
+ else
+ fadeBlend = 0;
+ }
+ else
+ fadeBlend = 1;
+
+ if (fadeBlend < 0)
+ fadeBlend = 0;
+
+ return fadeBlend;
}
-void CHudCredits::DrawIntroCreditsName( void )
+void CHudCredits::DrawIntroCreditsName(void)
{
- if ( m_CreditsList.Count() == 0 )
- return;
-
- // fill the screen
- int iWidth, iTall;
- GetHudSize(iWidth, iTall);
- SetSize( iWidth, iTall );
-
- for ( int i = 0; i < m_CreditsList.Count(); i++ )
- {
- creditname_t *pCredit = &m_CreditsList[i];
-
- if ( pCredit == NULL )
- continue;
-
- if ( pCredit->bActive == false )
- continue;
-
- vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
- vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName );
-
- float localTime = gpGlobals->curtime - pCredit->flTimeStart;
-
- surface()->DrawSetTextFont( m_hTFont );
- surface()->DrawSetTextColor( m_cColor[0], m_cColor[1], m_cColor[2], FadeBlend( m_flFadeInTime, m_flFadeOutTime, m_flFadeHoldTime + pCredit->flTimeAdd, localTime ) * m_cColor[3] );
-
- wchar_t unicode[256];
- g_pVGuiLocalize->ConvertANSIToUnicode( pCredit->szCreditName, unicode, sizeof( unicode ) );
-
- surface()->DrawSetTextPos( XRES( pCredit->flXPos ), YRES( pCredit->flYPos ) );
- surface()->DrawUnicodeString( unicode );
-
- if ( m_flLogoTime > gpGlobals->curtime )
- continue;
-
- if ( pCredit->flTime - m_flNextStartTime <= gpGlobals->curtime )
- {
- if ( m_CreditsList.IsValidIndex( i + 3 ) )
- {
- creditname_t *pNextCredits = &m_CreditsList[i + 3];
-
- if ( pNextCredits && pNextCredits->flTime == 0.0f )
- {
- pNextCredits->bActive = true;
-
- if ( i < 3 )
- {
- pNextCredits->flTimeAdd = ( i + 1.0f );
- pNextCredits->flTime = gpGlobals->curtime + m_flFadeInTime + m_flFadeOutTime + m_flFadeHoldTime + pNextCredits->flTimeAdd;
- }
- else
- {
- pNextCredits->flTimeAdd = m_flPauseBetweenWaves;
- pNextCredits->flTime = gpGlobals->curtime + m_flFadeInTime + m_flFadeOutTime + m_flFadeHoldTime + pNextCredits->flTimeAdd;
- }
-
- pNextCredits->flTimeStart = gpGlobals->curtime;
-
- pNextCredits->iSlot = pCredit->iSlot;
- }
- }
- }
-
- if ( pCredit->flTime <= gpGlobals->curtime )
- {
- pCredit->bActive = false;
-
- if ( i == m_CreditsList.Count()-1 )
- {
- Clear();
- }
- }
- }
+ if (m_CreditsList.Count() == 0)
+ return;
+
+ // fill the screen
+ int iWidth, iTall;
+ GetHudSize(iWidth, iTall);
+ SetSize(iWidth, iTall);
+
+ for (int i = 0; i < m_CreditsList.Count(); i++)
+ {
+ creditname_t *pCredit = &m_CreditsList[i];
+
+ if (pCredit == nullptr)
+ continue;
+
+ if (pCredit->bActive == false)
+ continue;
+
+ HScheme scheme = vgui::scheme()->GetScheme("ClientScheme");
+ HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont(pCredit->szFontName);
+
+ float localTime = gpGlobals->curtime - pCredit->flTimeStart;
+
+ surface()->DrawSetTextFont(m_hTFont);
+ surface()->DrawSetTextColor(
+ m_cColor[0], m_cColor[1], m_cColor[2],
+ FadeBlend(m_flFadeInTime, m_flFadeOutTime, m_flFadeHoldTime + pCredit->flTimeAdd, localTime) * m_cColor[3]);
+
+ wchar_t unicode[256];
+ g_pVGuiLocalize->ConvertANSIToUnicode(pCredit->szCreditName, unicode, sizeof(unicode));
+
+ surface()->DrawSetTextPos(XRES(pCredit->flXPos), YRES(pCredit->flYPos));
+ surface()->DrawUnicodeString(unicode);
+
+ if (m_flLogoTime > gpGlobals->curtime)
+ continue;
+
+ if (pCredit->flTime - m_flNextStartTime <= gpGlobals->curtime)
+ {
+ if (m_CreditsList.IsValidIndex(i + 3))
+ {
+ creditname_t *pNextCredits = &m_CreditsList[i + 3];
+
+ if (pNextCredits && pNextCredits->flTime == 0.0f)
+ {
+ pNextCredits->bActive = true;
+
+ if (i < 3)
+ {
+ pNextCredits->flTimeAdd = (i + 1.0f);
+ pNextCredits->flTime = gpGlobals->curtime + m_flFadeInTime + m_flFadeOutTime +
+ m_flFadeHoldTime + pNextCredits->flTimeAdd;
+ }
+ else
+ {
+ pNextCredits->flTimeAdd = m_flPauseBetweenWaves;
+ pNextCredits->flTime = gpGlobals->curtime + m_flFadeInTime + m_flFadeOutTime +
+ m_flFadeHoldTime + pNextCredits->flTimeAdd;
+ }
+
+ pNextCredits->flTimeStart = gpGlobals->curtime;
+
+ pNextCredits->iSlot = pCredit->iSlot;
+ }
+ }
+ }
+
+ if (pCredit->flTime <= gpGlobals->curtime)
+ {
+ pCredit->bActive = false;
+
+ if (i == m_CreditsList.Count() - 1)
+ {
+ Clear();
+ }
+ }
+ }
}
-void CHudCredits::ApplySchemeSettings( IScheme *pScheme )
+void CHudCredits::ApplySchemeSettings(IScheme *pScheme)
{
- BaseClass::ApplySchemeSettings( pScheme );
+ BaseClass::ApplySchemeSettings(pScheme);
- SetVisible( ShouldDraw() );
+ SetVisible(ShouldDraw());
- SetBgColor( Color(0, 0, 0, 0) );
+ SetBgColor(Color(0, 0, 0, 0));
}
void CHudCredits::Paint()
{
- if ( m_iCreditsType == CREDITS_LOGO )
- {
- DrawLogo();
- }
- else if ( m_iCreditsType == CREDITS_INTRO )
- {
- DrawIntroCreditsName();
- }
- else if ( m_iCreditsType == CREDITS_OUTRO )
- {
- DrawOutroCreditsName();
- }
+ if (m_iCreditsType == CREDITS_LOGO)
+ {
+ DrawLogo();
+ }
+ else if (m_iCreditsType == CREDITS_INTRO)
+ {
+ DrawIntroCreditsName();
+ }
+ else if (m_iCreditsType == CREDITS_OUTRO)
+ {
+ DrawOutroCreditsName();
+ }
}
-void CHudCredits::PrepareLogo( float flTime )
+void CHudCredits::PrepareLogo(float flTime)
{
- // Only showing the logo. Just load the CreditsParams section.
- PrepareCredits( NULL );
-
- m_Alpha = 0;
- m_flLogoDesiredLength = flTime;
- m_flFadeTime = gpGlobals->curtime + 5.0f;
- m_iLogoState = LOGO_FADEIN;
- SetActive( true );
+ // Only showing the logo. Just load the CreditsParams section.
+ PrepareCredits(nullptr);
+
+ m_Alpha = 0;
+ m_flLogoDesiredLength = flTime;
+ m_flFadeTime = gpGlobals->curtime + 5.0f;
+ m_iLogoState = LOGO_FADEIN;
+ SetActive(true);
}
-void CHudCredits::PrepareLine( vgui::HFont hFont, char const *pchLine )
+void CHudCredits::PrepareLine(HFont hFont, char const *pchLine)
{
- Assert( pchLine );
+ Assert(pchLine);
- wchar_t unicode[256];
+ wchar_t unicode[256];
- if ( pchLine[0] == '#' )
- {
- g_pVGuiLocalize->ConstructString( unicode, sizeof(unicode), g_pVGuiLocalize->Find(pchLine), 0 );
- }
- else
- {
- g_pVGuiLocalize->ConvertANSIToUnicode( pchLine, unicode, sizeof( unicode ) );
- }
+ if (pchLine[0] == '#')
+ {
+ g_pVGuiLocalize->ConstructString(unicode, sizeof(unicode), g_pVGuiLocalize->Find(pchLine), 0);
+ }
+ else
+ {
+ g_pVGuiLocalize->ConvertANSIToUnicode(pchLine, unicode, sizeof(unicode));
+ }
- surface()->PrecacheFontCharacters( hFont, unicode );
+ surface()->PrecacheFontCharacters(hFont, unicode);
}
-void CHudCredits::PrepareOutroCredits( void )
+void CHudCredits::PrepareOutroCredits(void)
{
- PrepareCredits( "OutroCreditsNames" );
-
- if ( m_CreditsList.Count() == 0 )
- return;
+ PrepareCredits("OutroCreditsNames");
- // fill the screen
- int iWidth, iTall;
- GetHudSize(iWidth, iTall);
- SetSize( iWidth, iTall );
+ if (m_CreditsList.Count() == 0)
+ return;
- int iHeight = iTall;
+ // fill the screen
+ int iWidth, iTall;
+ GetHudSize(iWidth, iTall);
+ SetSize(iWidth, iTall);
- for ( int i = 0; i < m_CreditsList.Count(); i++ )
- {
- creditname_t *pCredit = &m_CreditsList[i];
+ int iHeight = iTall;
- if ( pCredit == NULL )
- continue;
+ for (int i = 0; i < m_CreditsList.Count(); i++)
+ {
+ creditname_t *pCredit = &m_CreditsList[i];
- vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
- vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName, true );
+ if (pCredit == nullptr)
+ continue;
- pCredit->flYPos = iHeight;
- pCredit->bActive = false;
+ HScheme scheme = vgui::scheme()->GetScheme("ClientScheme");
+ HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont(pCredit->szFontName, true);
- iHeight += surface()->GetFontTall ( m_hTFont ) + m_flSeparation;
+ pCredit->flYPos = iHeight;
+ pCredit->bActive = false;
- PrepareLine( m_hTFont, pCredit->szCreditName );
- }
+ iHeight += surface()->GetFontTall(m_hTFont) + m_flSeparation;
- SetActive( true );
+ PrepareLine(m_hTFont, pCredit->szCreditName);
+ }
- g_iCreditsPixelHeight = iHeight;
-}
+ SetActive(true);
-void CHudCredits::PrepareIntroCredits( void )
-{
- PrepareCredits( "IntroCreditsNames" );
-
- int iSlot = 0;
-
- for ( int i = 0; i < m_CreditsList.Count(); i++ )
- {
- creditname_t *pCredit = &m_CreditsList[i];
-
- if ( pCredit == NULL )
- continue;
-
- vgui::HScheme scheme = vgui::scheme()->GetScheme( "ClientScheme" );
- vgui::HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont( pCredit->szFontName );
-
- pCredit->flYPos = m_flY + ( iSlot * surface()->GetFontTall ( m_hTFont ) );
- pCredit->flXPos = m_flX;
-
- if ( i < 3 )
- {
- pCredit->bActive = true;
- pCredit->iSlot = iSlot;
- pCredit->flTime = gpGlobals->curtime + m_flFadeInTime + m_flFadeOutTime + m_flFadeHoldTime;
- pCredit->flTimeStart = gpGlobals->curtime;
- m_flLogoTime = pCredit->flTime + m_flLogoTimeMod;
- }
- else
- {
- pCredit->bActive = false;
- pCredit->flTime = 0.0f;
- }
-
- iSlot = ( iSlot + 1 ) % 3;
-
- PrepareLine( m_hTFont, pCredit->szCreditName );
- }
-
- SetActive( true );
+ g_iCreditsPixelHeight = iHeight;
}
-void CHudCredits::MsgFunc_CreditsMsg( bf_read &msg )
+void CHudCredits::PrepareIntroCredits(void)
{
- m_iCreditsType = msg.ReadByte();
-
- switch ( m_iCreditsType )
- {
- case CREDITS_LOGO:
- {
- PrepareLogo( 5.0f );
- break;
- }
- case CREDITS_INTRO:
- {
- PrepareIntroCredits();
- break;
- }
- case CREDITS_OUTRO:
- {
- PrepareOutroCredits();
- break;
- }
- }
+ PrepareCredits("IntroCreditsNames");
+
+ int iSlot = 0;
+
+ for (int i = 0; i < m_CreditsList.Count(); i++)
+ {
+ creditname_t *pCredit = &m_CreditsList[i];
+
+ if (pCredit == nullptr)
+ continue;
+
+ HScheme scheme = vgui::scheme()->GetScheme("ClientScheme");
+ HFont m_hTFont = vgui::scheme()->GetIScheme(scheme)->GetFont(pCredit->szFontName);
+
+ pCredit->flYPos = m_flY + (iSlot * surface()->GetFontTall(m_hTFont));
+ pCredit->flXPos = m_flX;
+
+ if (i < 3)
+ {
+ pCredit->bActive = true;
+ pCredit->iSlot = iSlot;
+ pCredit->flTime = gpGlobals->curtime + m_flFadeInTime + m_flFadeOutTime + m_flFadeHoldTime;
+ pCredit->flTimeStart = gpGlobals->curtime;
+ m_flLogoTime = pCredit->flTime + m_flLogoTimeMod;
+ }
+ else
+ {
+ pCredit->bActive = false;
+ pCredit->flTime = 0.0f;
+ }
+
+ iSlot = (iSlot + 1) % 3;
+
+ PrepareLine(m_hTFont, pCredit->szCreditName);
+ }
+
+ SetActive(true);
}
-void CHudCredits::MsgFunc_LogoTimeMsg( bf_read &msg )
+void CHudCredits::MsgFunc_CreditsMsg(bf_read &msg)
{
- m_iCreditsType = CREDITS_LOGO;
- PrepareLogo( msg.ReadFloat() );
+ m_iCreditsType = msg.ReadByte();
+
+ switch (m_iCreditsType)
+ {
+ case CREDITS_LOGO:
+ {
+ PrepareLogo(5.0f);
+ break;
+ }
+ case CREDITS_INTRO:
+ {
+ PrepareIntroCredits();
+ break;
+ }
+ case CREDITS_OUTRO:
+ {
+ PrepareOutroCredits();
+ break;
+ }
+ }
}
-
+void CHudCredits::MsgFunc_LogoTimeMsg(bf_read &msg)
+{
+ m_iCreditsType = CREDITS_LOGO;
+ PrepareLogo(msg.ReadFloat());
+}
\ No newline at end of file
diff --git a/mp/src/game/client/hud_crosshair.cpp b/mp/src/game/client/hud_crosshair.cpp
index fc7714fef3..cec7bd754c 100644
--- a/mp/src/game/client/hud_crosshair.cpp
+++ b/mp/src/game/client/hud_crosshair.cpp
@@ -29,8 +29,8 @@
// memdbgon must be the last include file in a .cpp file!!!
#include "tier0/memdbgon.h"
-ConVar crosshair( "crosshair", "1", FCVAR_ARCHIVE );
-ConVar cl_observercrosshair( "cl_observercrosshair", "1", FCVAR_ARCHIVE );
+ConVar crosshair( "crosshair", "0", FCVAR_ARCHIVE );
+ConVar cl_observercrosshair( "cl_observercrosshair", "0", FCVAR_ARCHIVE );
using namespace vgui;
diff --git a/mp/src/game/client/momentum/c_mom_player.cpp b/mp/src/game/client/momentum/c_mom_player.cpp
index 6a8c76b8dc..37802bae8e 100644
--- a/mp/src/game/client/momentum/c_mom_player.cpp
+++ b/mp/src/game/client/momentum/c_mom_player.cpp
@@ -4,20 +4,16 @@
#include "tier0/memdbgon.h"
-
IMPLEMENT_CLIENTCLASS_DT(C_MomentumPlayer, DT_MOM_Player, CMomentumPlayer)
RecvPropInt(RECVINFO(m_iShotsFired)),
RecvPropInt(RECVINFO(m_iDirection)),
RecvPropBool(RECVINFO(m_bResumeZoom)),
RecvPropInt(RECVINFO(m_iLastZoom)),
-RecvPropBool(RECVINFO(m_bAutoBhop)),
RecvPropBool(RECVINFO(m_bDidPlayerBhop)),
RecvPropInt(RECVINFO(m_iSuccessiveBhops)),
-RecvPropFloat(RECVINFO(m_flStrafeSync)),
-RecvPropFloat(RECVINFO(m_flStrafeSync2)),
-RecvPropFloat(RECVINFO(m_flLastJumpVel)),
-//RecvPropDataTable(RECVINFO_DT(m_HL2Local), 0, &REFERENCE_RECV_TABLE(DT_HL2Local)),
-//RecvPropBool(RECVINFO(m_fIsSprinting)),
+RecvPropBool(RECVINFO(m_bHasPracticeMode)),
+RecvPropDataTable(RECVINFO_DT(m_RunData), SPROP_PROXY_ALWAYS_YES, &REFERENCE_RECV_TABLE(DT_MOM_RunEntData)),
+RecvPropDataTable(RECVINFO_DT(m_RunStats), SPROP_PROXY_ALWAYS_YES, &REFERENCE_RECV_TABLE(DT_MOM_RunStats)),
END_RECV_TABLE()
@@ -25,6 +21,10 @@ C_MomentumPlayer::C_MomentumPlayer()
{
ConVarRef scissor("r_flashlightscissor");
scissor.SetValue("0");
+ m_RunData.m_bMapFinished = false;
+ m_RunData.m_flLastJumpTime = 0.0f;
+ m_bHasPracticeMode = false;
+ m_RunStats.Init();
}
C_MomentumPlayer::~C_MomentumPlayer()
diff --git a/mp/src/game/client/momentum/c_mom_player.h b/mp/src/game/client/momentum/c_mom_player.h
index 3cbb740fd5..8c8c5f6933 100644
--- a/mp/src/game/client/momentum/c_mom_player.h
+++ b/mp/src/game/client/momentum/c_mom_player.h
@@ -6,36 +6,47 @@
#include "cbase.h"
#include "momentum/mom_shareddefs.h"
+#include "c_mom_replay_entity.h"
+#include "mom_entity_run_data.h"
+#include "util/run_stats.h"
class C_MomentumPlayer : public C_BasePlayer
{
public:
DECLARE_CLASS(C_MomentumPlayer, C_BasePlayer);
-
+ DECLARE_CLIENTCLASS();
+
C_MomentumPlayer();
~C_MomentumPlayer();
- DECLARE_CLIENTCLASS();
-
Vector m_lastStandingPos; // used by the gamemovement code for finding ladders
void SurpressLadderChecks(const Vector& pos, const Vector& normal);
bool CanGrabLadder(const Vector& pos, const Vector& normal);
bool DidPlayerBhop() { return m_bDidPlayerBhop; }
- bool HasAutoBhop() { return m_bAutoBhop; }
- void ResetStrafeSync();
+ bool HasAutoBhop() { return m_RunData.m_bAutoBhop; }
+ //void ResetStrafeSync();
+
+ bool IsWatchingReplay() const
+ {
+ return m_hObserverTarget.Get() && GetReplayEnt();
+ }
+
+ //Returns the replay entity that the player is watching (first person only)
+ C_MomentumReplayGhostEntity *GetReplayEnt() const
+ {
+ return dynamic_cast(m_hObserverTarget.Get());
+ }
int m_iShotsFired;
int m_iDirection;
bool m_bResumeZoom;
int m_iLastZoom;
- bool m_bAutoBhop;
bool m_bDidPlayerBhop;
+ bool m_bHasPracticeMode;
- float m_flStrafeSync, m_flStrafeSync2;
- float m_flLastJumpVel;
-
- int m_nLastRunTime;
+ CMOMRunEntityData m_RunData;
+ CMomRunStats m_RunStats;
void GetBulletTypeParameters(
int iBulletType,
@@ -77,8 +88,6 @@ class C_MomentumPlayer : public C_BasePlayer
bool m_duckUntilOnGround;
float m_flStamina;
-
-
friend class CMomentumGameMovement;
};
diff --git a/mp/src/game/client/momentum/c_mom_replay_entity.cpp b/mp/src/game/client/momentum/c_mom_replay_entity.cpp
new file mode 100644
index 0000000000..b951d4caee
--- /dev/null
+++ b/mp/src/game/client/momentum/c_mom_replay_entity.cpp
@@ -0,0 +1,25 @@
+#include "cbase.h"
+#include "c_mom_replay_entity.h"
+
+#include "tier0/memdbgon.h"
+
+
+IMPLEMENT_CLIENTCLASS_DT(C_MomentumReplayGhostEntity, DT_MOM_ReplayEnt, CMomentumReplayGhostEntity)
+RecvPropInt(RECVINFO(m_nReplayButtons)),
+RecvPropInt(RECVINFO(m_iTotalStrafes)),
+RecvPropInt(RECVINFO(m_iTotalJumps)),
+RecvPropFloat(RECVINFO(m_flTickRate)),
+RecvPropString(RECVINFO(m_pszPlayerName)),
+RecvPropDataTable(RECVINFO_DT(m_RunData), 0, &REFERENCE_RECV_TABLE(DT_MOM_RunEntData)),
+RecvPropDataTable(RECVINFO_DT(m_RunStats), SPROP_PROXY_ALWAYS_YES, &REFERENCE_RECV_TABLE(DT_MOM_RunStats)),
+END_RECV_TABLE();
+
+C_MomentumReplayGhostEntity::C_MomentumReplayGhostEntity()
+{
+ m_nReplayButtons = 0;
+ m_iTotalStrafes = 0;
+ m_iTotalJumps = 0;
+ m_flTickRate = 0.0f;
+ m_pszPlayerName[0] = '\0';
+ m_RunStats.Init();
+}
\ No newline at end of file
diff --git a/mp/src/game/client/momentum/c_mom_replay_entity.h b/mp/src/game/client/momentum/c_mom_replay_entity.h
new file mode 100644
index 0000000000..fc2f43036f
--- /dev/null
+++ b/mp/src/game/client/momentum/c_mom_replay_entity.h
@@ -0,0 +1,31 @@
+#pragma once
+
+#include "cbase.h"
+#include "mom_entity_run_data.h"
+#include "util/run_stats.h"
+
+class C_MomentumReplayGhostEntity : public C_BaseAnimating
+{
+ DECLARE_CLASS(C_MomentumReplayGhostEntity, C_BaseAnimating);
+ DECLARE_CLIENTCLASS();
+
+public:
+ C_MomentumReplayGhostEntity();
+
+ CMOMRunEntityData m_RunData;
+ CMomRunStats m_RunStats;
+
+ float m_flTickRate;
+
+ int m_nReplayButtons;
+ //These are stored here because run stats already has the ones obtained from the run
+ int m_iTotalStrafes;
+ int m_iTotalJumps;
+
+ char m_pszPlayerName[MAX_PLAYER_NAME_LENGTH];
+ bool ShouldInterpolate() override
+ {
+ return true;
+ }
+
+};
\ No newline at end of file
diff --git a/mp/src/game/client/momentum/clientmode_mom_normal.cpp b/mp/src/game/client/momentum/clientmode_mom_normal.cpp
index 90ee69269d..a6fb99d37c 100644
--- a/mp/src/game/client/momentum/clientmode_mom_normal.cpp
+++ b/mp/src/game/client/momentum/clientmode_mom_normal.cpp
@@ -4,24 +4,24 @@
//
//=============================================================================
#include "cbase.h"
+
+#include "ClientTimesDisplay.h"
#include "clientmode_mom_normal.h"
+#include "hud.h"
+#include "ienginevgui.h"
+#include "iinput.h"
+#include "momSpectatorGUI.h"
#include "momentum/mom_shareddefs.h"
#include "vgui_int.h"
-#include "hud.h"
#include
#include
#include
-#include "ClientTimesDisplay.h"
#include
-#include "iinput.h"
-#include "ienginevgui.h"
// memdbgon must be the last include file in a .cpp file!!!
#include "tier0/memdbgon.h"
-//extern bool g_bRollingCredits; MOM_TODO: reinstate this boolean!!
-
-ConVar fov_desired("fov_desired", "90", FCVAR_ARCHIVE | FCVAR_USERINFO, "Sets the base field-of-view.\n", true, 90.0, true, 179.0);
+extern bool g_bRollingCredits;
//-----------------------------------------------------------------------------
// Globals
@@ -40,94 +40,151 @@ IClientMode *GetClientModeNormal()
//-----------------------------------------------------------------------------
class CHudViewport : public CBaseViewport
{
-private:
+ private:
DECLARE_CLASS_SIMPLE(CHudViewport, CBaseViewport);
-protected:
- virtual void ApplySchemeSettings(vgui::IScheme *pScheme)
+ protected:
+ void ApplySchemeSettings(vgui::IScheme *pScheme) override
{
BaseClass::ApplySchemeSettings(pScheme);
gHUD.InitColors(pScheme);
-
+
SetPaintBackgroundEnabled(false);
}
- IViewPortPanel *CreatePanelByName(const char *pzName)
+ IViewPortPanel *CreatePanelByName(const char *pzName) override
{
- IViewPortPanel *panel = BaseClass::CreatePanelByName(pzName);
- if (!panel)
+
+ if (!Q_strcmp(PANEL_TIMES, pzName))
{
- if (!Q_strcmp(PANEL_TIMES, pzName))
- {
- panel = new CClientTimesDisplay(this);
- }
+ return new CClientTimesDisplay(this);
+ }
+ if (!Q_strcmp(PANEL_SPECMENU, pzName))
+ {
+ return new CMOMSpectatorMenu(this);
+ }
+ if (!Q_strcmp(PANEL_SPECGUI, pzName))
+ {
+ return new CMOMSpectatorGUI(this);
}
- return panel;
+ return BaseClass::CreatePanelByName(pzName);
}
- virtual void CreateDefaultPanels(void)
+ void CreateDefaultPanels(void) override
{
AddNewPanel(CreatePanelByName(PANEL_TIMES), "PANEL_TIMES");
-
- BaseClass::CreateDefaultPanels();// MOM_TODO: do we want the other panels?
- };
+ AddNewPanel(CreatePanelByName(PANEL_SPECMENU), "PANEL_SPECMENU");
+ AddNewPanel(CreatePanelByName(PANEL_SPECGUI), "PANEL_SPECGUI");
+ //BaseClass::CreateDefaultPanels(); // MOM_TODO: do we want the other panels?
+ }
};
-
//-----------------------------------------------------------------------------
// ClientModeHLNormal implementation
//-----------------------------------------------------------------------------
ClientModeMOMNormal::ClientModeMOMNormal()
{
- m_pHudMenuStatic = NULL;
+ m_pHudMenuStatic = nullptr;
+ m_pHudMapFinished = nullptr;
+ m_pLeaderboards = nullptr;
m_pViewport = new CHudViewport();
m_pViewport->Start(gameuifuncs, gameeventmanager);
}
-
//-----------------------------------------------------------------------------
-// Purpose:
+// Purpose:
//-----------------------------------------------------------------------------
ClientModeMOMNormal::~ClientModeMOMNormal()
{
+ //MOM_TODO: delete pointers (m_pViewport) here?
}
-
//-----------------------------------------------------------------------------
-// Purpose:
+// Purpose:
//-----------------------------------------------------------------------------
void ClientModeMOMNormal::Init()
{
BaseClass::Init();
- m_pHudMenuStatic = static_cast(GET_HUDELEMENT(CHudMenuStatic));
-
+ m_pHudMenuStatic = GET_HUDELEMENT(CHudMenuStatic);
+ m_pHudMapFinished = GET_HUDELEMENT(CHudMapFinishedDialog);
+ m_pLeaderboards = dynamic_cast(m_pViewport->FindPanelByName(PANEL_TIMES));
// Load up the combine control panel scheme
- g_hVGuiCombineScheme = vgui::scheme()->LoadSchemeFromFileEx(enginevgui->GetPanel(PANEL_CLIENTDLL), IsXbox() ? "resource/ClientScheme.res" : "resource/CombinePanelScheme.res", "CombineScheme");
+ g_hVGuiCombineScheme = vgui::scheme()->LoadSchemeFromFileEx(
+ enginevgui->GetPanel(PANEL_CLIENTDLL),
+ IsXbox() ? "resource/ClientScheme.res" : "resource/CombinePanelScheme.res", "CombineScheme");
if (!g_hVGuiCombineScheme)
{
Warning("Couldn't load combine panel scheme!\n");
}
}
-bool ClientModeMOMNormal::ShouldDrawCrosshair(void)
-{
- return true;//MOM_TODO: reinstate the g_bRollingCredits when hud_credits is copied over.
- //return (g_bRollingCredits == false);
-}
+bool ClientModeMOMNormal::ShouldDrawCrosshair(void) { return (g_bRollingCredits == false); }
int ClientModeMOMNormal::HudElementKeyInput(int down, ButtonCode_t keynum, const char *pszCurrentBinding)
{
+ //Swallow the key input if a hud menu is open
if (m_pHudMenuStatic && m_pHudMenuStatic->IsMenuDisplayed())
{
if (down >= 1 && keynum >= KEY_0 && keynum <= KEY_9)
{
m_pHudMenuStatic->SelectMenuItem(keynum - KEY_0);
- return 0;//The hud menu static swallowed the key input
+ return 0; // The hud menu static swallowed the key input
}
}
-
+
+ //Detach the mouse if the user right-clicked while the leaderboards are open
+
+ if (m_pLeaderboards && m_pLeaderboards->IsVisible())
+ {
+ if (keynum == MOUSE_RIGHT)
+ {
+ m_pLeaderboards->SetMouseInputEnabled(true);
+ return 0;
+ }
+ }
+
+ //Detach the mouse if the user right-clicked while the map finished dialog is open
+ if (m_pHudMapFinished && m_pHudMapFinished->IsVisible())
+ {
+ if (keynum == MOUSE_RIGHT)
+ {
+ m_pHudMapFinished->SetMouseInputEnabled(true);
+ return 0;
+ }
+ }
+
return BaseClass::HudElementKeyInput(down, keynum, pszCurrentBinding);
+}
+
+int ClientModeMOMNormal::HandleSpectatorKeyInput(int down, ButtonCode_t keynum, const char *pszCurrentBinding)
+{
+ // MOM_TODO: re-enable this in beta when we add movie-style controls to the spectator menu!
+ /*
+ // we are in spectator mode, open spectator menu
+ if (down && pszCurrentBinding && Q_strcmp(pszCurrentBinding, "+duck") == 0)
+ {
+ m_pViewport->ShowPanel(PANEL_SPECMENU, true);
+ return 0; // we handled it, don't handle twice or send to server
+ }
+ */
+ if (down && pszCurrentBinding && Q_strcmp(pszCurrentBinding, "+attack") == 0)
+ {
+ engine->ClientCmd("spec_next");
+ return 0;
+ }
+ else if (down && pszCurrentBinding && Q_strcmp(pszCurrentBinding, "+attack2") == 0)
+ {
+ engine->ClientCmd("spec_prev");
+ return 0;
+ }
+ else if (down && pszCurrentBinding && Q_strcmp(pszCurrentBinding, "+jump") == 0)
+ {
+ engine->ClientCmd("spec_mode");
+ return 0;
+ }
+
+ return 1;
}
\ No newline at end of file
diff --git a/mp/src/game/client/momentum/clientmode_mom_normal.h b/mp/src/game/client/momentum/clientmode_mom_normal.h
index 54ecab0cfe..c40995b66b 100644
--- a/mp/src/game/client/momentum/clientmode_mom_normal.h
+++ b/mp/src/game/client/momentum/clientmode_mom_normal.h
@@ -1,12 +1,12 @@
//========= Copyright Valve Corporation, All rights reserved. ============//
//
-// Purpose:
+// Purpose:
//
// $Workfile: $
// $Date: $
// $NoKeywords: $
//=============================================================================//
-#if !defined( CLIENTMODE_MOM_NORM_H )
+#if !defined(CLIENTMODE_MOM_NORM_H)
#define CLIENTMODE_MOM_NORM_H
#ifdef _WIN32
#pragma once
@@ -14,34 +14,39 @@
#include "clientmode_shared.h"
#include "hud_menu_static.h"
-#include
+#include "hud_mapfinished.h"
+#include "ClientTimesDisplay.h"
#include
+#include
class CHudViewport;
namespace vgui
{
- typedef unsigned long HScheme;
+typedef unsigned long HScheme;
}
-
//-----------------------------------------------------------------------------
-// Purpose:
+// Purpose:
//-----------------------------------------------------------------------------
class ClientModeMOMNormal : public ClientModeShared
{
-public:
+ public:
DECLARE_CLASS(ClientModeMOMNormal, ClientModeShared);
ClientModeMOMNormal();
~ClientModeMOMNormal();
- virtual void Init();
- virtual bool ShouldDrawCrosshair(void);
- virtual int HudElementKeyInput(int down, ButtonCode_t keynum, const char *pszCurrentBinding);
+ void Init() override;
+ bool ShouldDrawCrosshair(void) override;
+ //NOTE: This includes mouse inputs!!!
+ int HudElementKeyInput(int down, ButtonCode_t keynum, const char *pszCurrentBinding) override;
+ int HandleSpectatorKeyInput(int down, ButtonCode_t keynum, const char *pszCurrentBinding) override;
-private:
+ private:
CHudMenuStatic *m_pHudMenuStatic;
+ CHudMapFinishedDialog *m_pHudMapFinished;
+ CClientTimesDisplay *m_pLeaderboards;
};
extern IClientMode *GetClientModeNormal();
diff --git a/mp/src/game/client/momentum/mom_event_listener.cpp b/mp/src/game/client/momentum/mom_event_listener.cpp
index 2d035647ab..7d290d2165 100644
--- a/mp/src/game/client/momentum/mom_event_listener.cpp
+++ b/mp/src/game/client/momentum/mom_event_listener.cpp
@@ -6,62 +6,27 @@
void C_Momentum_EventListener::Init()
{
//add listeners for all of our custom events
- if (gameeventmanager)
- {
- gameeventmanager->AddListener(this, "timer_stopped", false);
- gameeventmanager->AddListener(this, "new_stage", false);
- gameeventmanager->AddListener(this, "run_save", false);
- gameeventmanager->AddListener(this, "timer_started", false);
- gameeventmanager->AddListener(this, "player_inside_mapzone", false);
- gameeventmanager->AddListener(this, "practice_mode", false);
- gameeventmanager->AddListener(this, "keypress", false);
- }
+ ListenForGameEvent("run_save");
+ ListenForGameEvent("run_upload");
+ ListenForGameEvent("map_init");
}
void C_Momentum_EventListener::FireGameEvent(IGameEvent *pEvent)
{
- if (!Q_strcmp("timer_stopped", pEvent->GetName()))
- {
- m_flStartSpeed = pEvent->GetFloat("start_vel");
- m_flEndSpeed = pEvent->GetFloat("end_vel");
- m_flStrafeSyncAvg = pEvent->GetFloat("avg_sync");
- m_flStrafeSync2Avg = pEvent->GetFloat("avg_sync2");
- m_flVelocityAvg = pEvent->GetFloat("avg_vel");
- m_flVelocityMax = pEvent->GetFloat("max_vel");
- }
- if (!Q_strcmp("new_stage", pEvent->GetName()))
- {
- m_iCurrentStage = pEvent->GetInt("stage_num");
- m_iStageTicks[m_iCurrentStage] = pEvent->GetInt("stage_ticks");
- m_flStageStrafeSyncAvg[m_iCurrentStage] = pEvent->GetFloat("avg_sync");
- m_flStageStrafeSync2Avg[m_iCurrentStage] = pEvent->GetFloat("avg_sync2");
- m_flStageStartSpeed[m_iCurrentStage] = pEvent->GetFloat("start_vel");
- m_flStageVelocityAvg[m_iCurrentStage] = pEvent->GetFloat("avg_vel");
- m_flStageVelocityMax[m_iCurrentStage] = pEvent->GetFloat("max_vel");
- }
if (!Q_strcmp("run_save", pEvent->GetName()))
{
m_bTimeDidSave = pEvent->GetBool("run_saved");
- m_bTimeDidUpload = pEvent->GetBool("run_posted");
- }
- if (!Q_strcmp("timer_started", pEvent->GetName()))
- {
- m_bTimerIsRunning = pEvent->GetBool("timer_isrunning");
}
- if (!Q_strcmp("player_inside_mapzone", pEvent->GetName()))
+ else if (!Q_strcmp("run_upload", pEvent->GetName()))
{
- m_bPlayerInsideStartZone = pEvent->GetBool("inside_startzone");
- m_bPlayerInsideEndZone = pEvent->GetBool("inside_endzone");
- m_bMapFinished = pEvent->GetBool("map_finished"); //different from "inside endzone", this is only fired if the player finished when their timer was running
- }
- if (!Q_strcmp("practice_mode", pEvent->GetName()))
- {
- m_bPlayerHasPracticeMode = pEvent->GetBool("has_practicemode");
+ m_bTimeDidUpload = pEvent->GetBool("run_posted");
+ Q_strncpy(m_szRunUploadStatus, pEvent->GetString("web_msg"), sizeof(m_szRunUploadStatus));
+ //MOM_TODO: potentially have stuff like new rank or something?
}
- if (!Q_strcmp("keypress", pEvent->GetName()))
+ else if (!Q_strcmp("map_init", pEvent->GetName()))
{
- m_iTotalJumps = pEvent->GetInt("num_jumps");
- m_iTotalStrafes = pEvent->GetInt("num_strafes");
+ m_bMapIsLinear = pEvent->GetBool("is_linear");
+ m_iMapZoneCount = pEvent->GetInt("num_zones");
}
}
diff --git a/mp/src/game/client/momentum/mom_event_listener.h b/mp/src/game/client/momentum/mom_event_listener.h
index bdaae1e16e..51075a3720 100644
--- a/mp/src/game/client/momentum/mom_event_listener.h
+++ b/mp/src/game/client/momentum/mom_event_listener.h
@@ -1,35 +1,26 @@
#pragma once
#include "mom_shareddefs.h"
+#include "util/run_stats.h"
-
-class C_Momentum_EventListener : public IGameEventListener2
+class C_Momentum_EventListener : public CGameEventListener
{
public:
- C_Momentum_EventListener() {};
- ~C_Momentum_EventListener(){
- if (gameeventmanager)
- gameeventmanager->RemoveListener(this);
- }
+ C_Momentum_EventListener() :
+ m_bTimeDidSave(false),
+ m_bTimeDidUpload(false), m_bMapIsLinear(false), m_iMapZoneCount(0)
+ { }
void Init();
- void FireGameEvent(IGameEvent* pEvent);
+ void FireGameEvent(IGameEvent* pEvent) override;
- bool m_bTimerIsRunning, m_bMapFinished;
bool m_bTimeDidSave, m_bTimeDidUpload;
+ bool m_bMapIsLinear;
- bool m_bPlayerInsideStartZone, m_bPlayerInsideEndZone;
- bool m_bPlayerHasPracticeMode;
-
- int m_iTotalStrafes, m_iTotalJumps;
- float m_flStartSpeed, m_flEndSpeed, m_flVelocityMax, m_flVelocityAvg, m_flStrafeSyncAvg, m_flStrafeSync2Avg;
-
- int m_iCurrentStage, m_iStageTicks[MAX_STAGES], m_iStageJumps[MAX_STAGES], m_iStageStrafes[MAX_STAGES];
- float m_flStageStartSpeed[MAX_STAGES], m_flStageVelocityMax[MAX_STAGES],
- m_flStageVelocityAvg[MAX_STAGES], m_flStageStrafeSyncAvg[MAX_STAGES],
- m_flStageStrafeSync2Avg[MAX_STAGES];
+ int m_iMapZoneCount;
+ char m_szRunUploadStatus[512];//MOM_TODO: determine best (max) size for this
};
extern C_Momentum_EventListener *g_MOMEventListener;
\ No newline at end of file
diff --git a/mp/src/game/client/momentum/mom_in_main.cpp b/mp/src/game/client/momentum/mom_in_main.cpp
index 671e95ab76..ef954338ad 100644
--- a/mp/src/game/client/momentum/mom_in_main.cpp
+++ b/mp/src/game/client/momentum/mom_in_main.cpp
@@ -21,7 +21,7 @@ class CMOMInput : public CInput
typedef CInput BaseClass;
public:
- int GetButtonBits(int bResetState)
+ int GetButtonBits(int bResetState) override
{
int bits = BaseClass::GetButtonBits(bResetState);
CalcButtonBits(bits, IN_TIMES, s_ClearInputState, &in_times, bResetState);
@@ -36,7 +36,7 @@ class CMOMInput : public CInput
return bits;
}
- void ClearInputButton(int bits)
+ void ClearInputButton(int bits) override
{
s_ClearInputState |= bits;
BaseClass::ClearInputButton(bits);
diff --git a/mp/src/game/client/momentum/ui/ClientTimesDisplay.cpp b/mp/src/game/client/momentum/ui/ClientTimesDisplay.cpp
index 39e2e328a6..c3e1051967 100644
--- a/mp/src/game/client/momentum/ui/ClientTimesDisplay.cpp
+++ b/mp/src/game/client/momentum/ui/ClientTimesDisplay.cpp
@@ -50,7 +50,7 @@ using namespace vgui;
//-----------------------------------------------------------------------------
// Purpose: Constructor
//-----------------------------------------------------------------------------
-CClientTimesDisplay::CClientTimesDisplay(IViewPort *pViewPort) : EditablePanel(NULL, PANEL_TIMES)
+CClientTimesDisplay::CClientTimesDisplay(IViewPort *pViewPort) : EditablePanel(nullptr, PANEL_TIMES)
{
m_iPlayerIndexSymbol = KeyValuesSystem()->GetSymbolForString("playerIndex");
m_nCloseKey = BUTTON_CODE_INVALID;
@@ -60,6 +60,8 @@ CClientTimesDisplay::CClientTimesDisplay(IViewPort *pViewPort) : EditablePanel(N
SetProportional(true);
SetKeyBoardInputEnabled(false);
SetMouseInputEnabled(false);
+ //Create a "popup" so we can get the mouse to detach
+ surface()->CreatePopup(GetVPanel(), false, false, false, false, false);
// set the scheme before any child control is created
SetScheme("ClientScheme");
@@ -106,17 +108,21 @@ CClientTimesDisplay::CClientTimesDisplay(IViewPort *pViewPort) : EditablePanel(N
m_pLocalLeaderboards->SetVerticalScrollbar(false);
m_pFriendsLeaderboards->SetVerticalScrollbar(false);
+ m_pLocalLeaderboards->SetMouseInputEnabled(true);
+ m_pOnlineLeaderboards->SetMouseInputEnabled(true);
+ m_pFriendsLeaderboards->SetMouseInputEnabled(true);
+
m_pMomentumLogo->GetImage()->SetSize(scheme()->GetProportionalScaledValue(256), scheme()->GetProportionalScaledValue(64));
m_iDesiredHeight = GetTall();
m_pPlayerList->SetVisible(false); // hide this until we load the images in applyschemesettings
// update scoreboard instantly if on of these events occur
- gameeventmanager->LoadEventsFromFile("resource/modevents.res");
ListenForGameEvent("run_save");
+ ListenForGameEvent("run_upload");
ListenForGameEvent("game_newmap");
- m_pImageList = NULL;
+ m_pImageList = nullptr;
m_mapAvatarsToImageList.SetLessFunc(DefLessFunc(CSteamID));
m_mapAvatarsToImageList.RemoveAll();
}
@@ -126,10 +132,10 @@ CClientTimesDisplay::CClientTimesDisplay(IViewPort *pViewPort) : EditablePanel(N
//-----------------------------------------------------------------------------
CClientTimesDisplay::~CClientTimesDisplay()
{
- if (NULL != m_pImageList)
+ if (m_pImageList)
{
delete m_pImageList;
- m_pImageList = NULL;
+ m_pImageList = nullptr;
}
// MOM_TODO: Ensure a good destructor
}
@@ -220,8 +226,6 @@ void CClientTimesDisplay::Reset(bool pFullReset)
//-----------------------------------------------------------------------------
void CClientTimesDisplay::InitScoreboardSections()
{
-#define SCALE(num) scheme()->GetProportionalScaledValueEx(GetScheme(), (num))
-
if (m_pLocalLeaderboards)
{
m_pLocalLeaderboards->AddSection(m_iSectionId, "", StaticLocalTimeSortFunc);
@@ -248,7 +252,6 @@ void CClientTimesDisplay::InitScoreboardSections()
m_pFriendsLeaderboards->AddColumnToSection(m_iSectionId, "name", "#MOM_Name", 0, NAME_WIDTH*1.8);
m_pFriendsLeaderboards->AddColumnToSection(m_iSectionId, "time", "#MOM_Time", 0, SCALE(m_aiColumnWidths[2] * 1.8));
}
-#undef SCALE
}
//-----------------------------------------------------------------------------
@@ -257,7 +260,7 @@ void CClientTimesDisplay::InitScoreboardSections()
void CClientTimesDisplay::ApplySchemeSettings(IScheme *pScheme)
{
BaseClass::ApplySchemeSettings(pScheme);
-
+
if (m_pImageList)
delete m_pImageList;
m_pImageList = new ImageList(false);
@@ -272,7 +275,6 @@ void CClientTimesDisplay::ApplySchemeSettings(IScheme *pScheme)
//-----------------------------------------------------------------------------
void CClientTimesDisplay::PostApplySchemeSettings(vgui::IScheme *pScheme)
{
-#define SCALE(num) scheme()->GetProportionalScaledValueEx(GetScheme(), (num))
// resize the images to our resolution
for (int i = 0; i < m_pImageList->GetImageCount(); i++)
{
@@ -314,7 +316,7 @@ void CClientTimesDisplay::ShowPanel(bool bShow)
{
// Catch the case where we call ShowPanel before ApplySchemeSettings, eg when
// going from windowed <-> fullscreen
- if (m_pImageList == NULL)
+ if (m_pImageList == nullptr)
{
InvalidateLayout(true, true);
}
@@ -331,12 +333,13 @@ void CClientTimesDisplay::ShowPanel(bool bShow)
{
Reset(true);
SetVisible(true);
+ //SetEnabled(true);
MoveToFront();
}
else
- {
- BaseClass::SetVisible(false);
- SetMouseInputEnabled(false);
+ {
+ SetVisible(false);
+ SetMouseInputEnabled(false);//Turn mouse off
SetKeyBoardInputEnabled(false);
}
}
@@ -347,18 +350,19 @@ void CClientTimesDisplay::FireGameEvent(IGameEvent *event)
const char * type = event->GetName();
- if (Q_strcmp(type, "runtime_saved") == 0)
+ if (Q_strcmp(type, "run_save") == 0)
{
//this updates the local times file, needing a reload of it
- bLocalTimesNeedUpdate = true;
+ m_bLocalTimesNeedUpdate = true;
}
- else if (Q_strcmp(type, "runtime_posted") == 0)
+ else if (Q_strcmp(type, "run_upload") == 0)
{
//MOM_TODO: this updates your rank (friends/online panel)
+ m_bOnlineNeedUpdate = event->GetBool("run_posted");
}
else if (Q_strcmp(type, "game_newmap") == 0)
{
- bLocalTimesLoaded = false;
+ m_bLocalTimesLoaded = false;
}
//MOM_TODO: there's a crash here if you uncomment it,
@@ -514,7 +518,7 @@ bool CClientTimesDisplay::StaticOnlineTimeSortFunc(vgui::SectionedListPanel *lis
void CClientTimesDisplay::LoadLocalTimes(KeyValues *kv)
{
- if (!bLocalTimesLoaded || bLocalTimesNeedUpdate)
+ if (!m_bLocalTimesLoaded || m_bLocalTimesNeedUpdate)
{
//Clear the local times for a refresh
m_vLocalTimes.RemoveAll();
@@ -522,10 +526,9 @@ void CClientTimesDisplay::LoadLocalTimes(KeyValues *kv)
//Load from .tim file
KeyValues *pLoaded = new KeyValues("local");
char fileName[MAX_PATH];
- Q_strcpy(fileName, "maps/");
- //Q_strncat(fileName, g_pGameRules->MapName(), MAX_PATH);
- Q_strncat(fileName, g_pGameRules->MapName() ? g_pGameRules->MapName() : "FIXME", MAX_PATH);
- Q_strncat(fileName, ".tim", MAX_PATH);
+
+ Q_snprintf(fileName, MAX_PATH, "maps/%s.tim", g_pGameRules->MapName() ? g_pGameRules->MapName() : "FIXME");
+
if (pLoaded->LoadFromFile(filesystem, fileName, "MOD"))
{
DevLog("Loading from file %s...\n", fileName);
@@ -534,8 +537,8 @@ void CClientTimesDisplay::LoadLocalTimes(KeyValues *kv)
Time t = Time(kvLocalTime);
m_vLocalTimes.AddToTail(t);
}
- bLocalTimesLoaded = true;
- bLocalTimesNeedUpdate = false;
+ m_bLocalTimesLoaded = true;
+ m_bLocalTimesNeedUpdate = false;
}
pLoaded->deleteThis();
}
@@ -551,15 +554,14 @@ void CClientTimesDisplay::ConvertLocalTimes(KeyValues *kvInto)
FOR_EACH_VEC(m_vLocalTimes, i)
{
Time t = m_vLocalTimes[i];
- float secondsF = ((float) t.ticks) * t.rate;
//MOM_TODO: consider adding a "100 tick" column?
KeyValues *kvLocalTimeFormatted = new KeyValues("localtime");
- kvLocalTimeFormatted->SetFloat("time_f", secondsF);//Used for static compare
+ kvLocalTimeFormatted->SetFloat("time_f", t.time_sec);//Used for static compare
kvLocalTimeFormatted->SetInt("date_t", t.date);//Used for finding
char timeString[BUFSIZETIME];
- mom_UTIL.FormatTime(t.ticks, t.rate, timeString);
+ mom_UTIL->FormatTime(t.time_sec, timeString);
kvLocalTimeFormatted->SetString("time", timeString);
char dateString[64];
diff --git a/mp/src/game/client/momentum/ui/ClientTimesDisplay.h b/mp/src/game/client/momentum/ui/ClientTimesDisplay.h
index 3836830bc2..a13eb8faea 100644
--- a/mp/src/game/client/momentum/ui/ClientTimesDisplay.h
+++ b/mp/src/game/client/momentum/ui/ClientTimesDisplay.h
@@ -1,6 +1,6 @@
//========= Copyright Valve Corporation, All rights reserved. ============//
//
-// Purpose:
+// Purpose:
//
// $NoKeywords: $
//=============================================================================//
@@ -11,63 +11,87 @@
#pragma once
#endif
-#include "GameEventListener.h"
#include "cbase.h"
+
+#include "GameEventListener.h"
#include "momentum/mom_shareddefs.h"
#include
#include
#include
+#include
-#define TYPE_NOTEAM 0 // NOTEAM must be zero :)
-#define TYPE_TEAM 1 // a section for a single team
-#define TYPE_PLAYERS 2
-#define TYPE_SPECTATORS 3 // a section for a spectator group
-#define TYPE_BLANK 4
+#define TYPE_NOTEAM 0 // NOTEAM must be zero :)
+#define TYPE_TEAM 1 // a section for a single team
+#define TYPE_PLAYERS 2
+#define TYPE_SPECTATORS 3 // a section for a spectator group
+#define TYPE_BLANK 4
+#define SCALE(num) scheme()->GetProportionalScaledValueEx(GetScheme(), (num))
//-----------------------------------------------------------------------------
// Purpose: Game ScoreBoard
//-----------------------------------------------------------------------------
class CClientTimesDisplay : public vgui::EditablePanel, public IViewPortPanel, public CGameEventListener
{
-private:
+ private:
DECLARE_CLASS_SIMPLE(CClientTimesDisplay, vgui::EditablePanel);
-protected:
+ protected:
// column widths at 640
- enum { NAME_WIDTH = 160, SCORE_WIDTH = 60, DEATH_WIDTH = 60, PING_WIDTH = 80, VOICE_WIDTH = 0, FRIENDS_WIDTH = 0 };
+ enum
+ {
+ NAME_WIDTH = 160,
+ SCORE_WIDTH = 60,
+ DEATH_WIDTH = 60,
+ PING_WIDTH = 80,
+ VOICE_WIDTH = 0,
+ FRIENDS_WIDTH = 0
+ };
// total = 340
-public:
+ public:
CClientTimesDisplay(IViewPort *pViewPort);
~CClientTimesDisplay();
- virtual const char *GetName(void) { return PANEL_TIMES; }
- virtual void SetData(KeyValues *data) {};
- virtual void Reset();
- virtual void Update();
+ const char *GetName(void) override { return PANEL_TIMES; }
+
+ void SetData(KeyValues *data) override{};
+
+ void Reset() override;
+ void Update() override;
void Update(bool pFullUpdate);
void Reset(bool pFullReset);
- virtual bool NeedsUpdate(void);
- virtual bool HasInputElements(void) { return true; }
- virtual void ShowPanel(bool bShow);
+ bool NeedsUpdate(void) override;
- virtual bool ShowAvatars()
- {
- return IsPC();
- }
+ bool HasInputElements(void) override { return true; }
+
+ void ShowPanel(bool bShow) override;
+
+ virtual bool ShowAvatars() { return IsPC(); }
// both vgui::Frame and IViewPortPanel define these, so explicitly define them here as passthroughs to vgui
- vgui::VPANEL GetVPanel(void) { return BaseClass::GetVPanel(); }
- virtual bool IsVisible() { return BaseClass::IsVisible(); }
- virtual void SetParent(vgui::VPANEL parent) { BaseClass::SetParent(parent); }
+ vgui::VPANEL GetVPanel(void) override { return BaseClass::GetVPanel(); }
+
+ bool IsVisible() override { return BaseClass::IsVisible(); }
+
+ void SetParent(vgui::VPANEL parent) override { BaseClass::SetParent(parent); }
// IGameEventListener interface:
- virtual void FireGameEvent(IGameEvent *event);
+ void FireGameEvent(IGameEvent *event) override;
virtual void UpdatePlayerAvatar(int playerIndex, KeyValues *kv);
-protected:
+ void OnMousePressed(vgui::MouseCode code) override
+ {
+ //Log("MOUSE RELEASED: %i\n", code);
+
+ if (code == MOUSE_RIGHT)
+ {
+ //MOM_TODO: Show a menu with like "Watch Replay"
+ }
+ }
+
+ protected:
MESSAGE_FUNC_INT(OnPollHideCode, "PollHideCode", code);
// functions to override
@@ -75,8 +99,8 @@ class CClientTimesDisplay : public vgui::EditablePanel, public IViewPortPanel, p
virtual void InitScoreboardSections();
virtual void UpdateTeamInfo();
virtual void UpdatePlayerInfo(KeyValues *outPlayerInfo);
- virtual void OnThink();
- virtual void AddHeader(vgui::Label *pMapSummary); // add the start header of the scoreboard
+ void OnThink() override;
+ virtual void AddHeader(vgui::Label *pMapSummary); // add the start header of the scoreboard
virtual void AddSection(int teamType, int teamNumber); // add a new section header for a team
virtual int GetAdditionalHeight() { return 0; }
@@ -84,7 +108,7 @@ class CClientTimesDisplay : public vgui::EditablePanel, public IViewPortPanel, p
static bool StaticLocalTimeSortFunc(vgui::SectionedListPanel *list, int itemID1, int itemID2);
static bool StaticOnlineTimeSortFunc(vgui::SectionedListPanel *list, int itemID1, int itemID2);
- virtual void ApplySchemeSettings(vgui::IScheme *pScheme);
+ void ApplySchemeSettings(vgui::IScheme *pScheme) override;
virtual void PostApplySchemeSettings(vgui::IScheme *pScheme);
@@ -96,14 +120,14 @@ class CClientTimesDisplay : public vgui::EditablePanel, public IViewPortPanel, p
int m_iNumTeams;
vgui::SectionedListPanel *m_pPlayerList;
- int m_iSectionId; // the current section we are entering into
+ int m_iSectionId; // the current section we are entering into
float m_fNextUpdateTime;
void MoveLabelToFront(const char *textEntryName);
void MoveToCenterOfScreen();
- vgui::ImageList *m_pImageList;
+ vgui::ImageList *m_pImageList;
vgui::Panel *m_pHeader;
vgui::Panel *m_pPlayerStats;
vgui::Panel *m_pLeaderboards;
@@ -117,50 +141,48 @@ class CClientTimesDisplay : public vgui::EditablePanel, public IViewPortPanel, p
vgui::ImagePanel *m_pPlayerAvatar;
vgui::ImagePanel *m_pMomentumLogo;
+ CUtlMap m_mapAvatarsToImageList;
- CUtlMap m_mapAvatarsToImageList;
-
- CPanelAnimationVar(int, m_iAvatarWidth, "avatar_width", "34"); // Avatar width doesn't scale with resolution
+ CPanelAnimationVar(int, m_iAvatarWidth, "avatar_width", "34"); // Avatar width doesn't scale with resolution
CPanelAnimationVarAliasType(int, m_iNameWidth, "name_width", "136", "proportional_int");
CPanelAnimationVarAliasType(int, m_iClassWidth, "class_width", "35", "proportional_int");
CPanelAnimationVarAliasType(int, m_iScoreWidth, "score_width", "35", "proportional_int");
CPanelAnimationVarAliasType(int, m_iDeathWidth, "death_width", "35", "proportional_int");
CPanelAnimationVarAliasType(int, m_iPingWidth, "ping_width", "23", "proportional_int");
-private:
- int m_iPlayerIndexSymbol;
- int m_iDesiredHeight;
- IViewPort *m_pViewPort;
+ private:
+ int m_iPlayerIndexSymbol;
+ int m_iDesiredHeight;
+ IViewPort *m_pViewPort;
ButtonCode_t m_nCloseKey;
struct Time
{
- int ticks;
- float rate;
+ float time_sec, rate;
time_t date;
- Time(KeyValues* kv)
+ explicit Time(KeyValues *kv)
{
- ticks = Q_atoi(kv->GetName());
+ time_sec = Q_atof(kv->GetName());
rate = kv->GetFloat("rate", gpGlobals->interval_per_tick);
- date = (time_t) kv->GetInt("date", 0);
+ date = static_cast(kv->GetInt("date", 0));
};
};
CUtlVector