From cd91412e7b538d867870b3c4b96bbddf22dc32eb Mon Sep 17 00:00:00 2001 From: MohabMohamed Date: Tue, 6 Mar 2018 22:14:34 +0200 Subject: setting up godot 3 project --- CRTDisplayShader.shd | Bin 2107 -> 0 bytes CRTFrame.png | Bin 17559 -> 0 bytes CRTViewportDisplay/CRT.scn | Bin 3540 -> 0 bytes CRTViewportDisplay/CRTDisplayShader.shd | Bin 2126 -> 0 bytes CRTViewportDisplay/CRTFrame.png | Bin 17559 -> 0 bytes CRTViewportDisplay/white.png | Bin 174 -> 0 bytes ShaderTestsScreen.scn | Bin 4209 -> 0 bytes engine.cfg | 5 ---- godot2/CRTDisplayShader.shd | Bin 0 -> 2107 bytes godot2/CRTFrame.png | Bin 0 -> 17559 bytes godot2/CRTViewportDisplay/CRT.scn | Bin 0 -> 3540 bytes godot2/CRTViewportDisplay/CRTDisplayShader.shd | Bin 0 -> 2126 bytes godot2/CRTViewportDisplay/CRTFrame.png | Bin 0 -> 17559 bytes godot2/CRTViewportDisplay/white.png | Bin 0 -> 174 bytes godot2/ShaderTestsScreen.scn | Bin 0 -> 4209 bytes godot2/engine.cfg | 5 ++++ godot2/icon.png | Bin 0 -> 2736 bytes godot2/icon.png.flags | 1 + godot2/sample.png | Bin 0 -> 254953 bytes godot2/white.png | Bin 0 -> 174 bytes ...Frame.png-96837578d803d46c371247267c1fa407.stex | Bin 0 -> 18732 bytes .../icon.png-487276ed1e3a0c39cad0279d744ee560.stex | Bin 0 -> 3533 bytes ...ample.png-e83d904df67be35a3470a03c20e2b3c2.stex | Bin 0 -> 254985 bytes ...white.png-d8533361663a5f8fe5200e5b5262a62d.stex | Bin 0 -> 185 bytes godot3/CRTFrame.png | Bin 0 -> 17559 bytes godot3/CRTFrame.png.import | 32 +++++++++++++++++++++ godot3/default_env.tres | 5 ++++ godot3/icon.png | Bin 0 -> 3498 bytes godot3/icon.png.import | 32 +++++++++++++++++++++ godot3/project.godot | 18 ++++++++++++ godot3/sample.png | Bin 0 -> 254953 bytes godot3/sample.png.import | 32 +++++++++++++++++++++ godot3/white.png | Bin 0 -> 174 bytes godot3/white.png.import | 32 +++++++++++++++++++++ icon.png | Bin 2736 -> 0 bytes icon.png.flags | 1 - white.png | Bin 174 -> 0 bytes 37 files changed, 157 insertions(+), 6 deletions(-) delete mode 100644 CRTDisplayShader.shd delete mode 100644 CRTFrame.png delete mode 100644 CRTViewportDisplay/CRT.scn delete mode 100644 CRTViewportDisplay/CRTDisplayShader.shd delete mode 100644 CRTViewportDisplay/CRTFrame.png delete mode 100644 CRTViewportDisplay/white.png delete mode 100644 ShaderTestsScreen.scn delete mode 100644 engine.cfg create mode 100644 godot2/CRTDisplayShader.shd create mode 100644 godot2/CRTFrame.png create mode 100644 godot2/CRTViewportDisplay/CRT.scn create mode 100644 godot2/CRTViewportDisplay/CRTDisplayShader.shd create mode 100644 godot2/CRTViewportDisplay/CRTFrame.png create mode 100644 godot2/CRTViewportDisplay/white.png create mode 100644 godot2/ShaderTestsScreen.scn create mode 100644 godot2/engine.cfg create mode 100644 godot2/icon.png create mode 100644 godot2/icon.png.flags create mode 100644 godot2/sample.png create mode 100644 godot2/white.png create mode 100644 godot3/.import/CRTFrame.png-96837578d803d46c371247267c1fa407.stex create mode 100644 godot3/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex create mode 100644 godot3/.import/sample.png-e83d904df67be35a3470a03c20e2b3c2.stex create mode 100644 godot3/.import/white.png-d8533361663a5f8fe5200e5b5262a62d.stex create mode 100644 godot3/CRTFrame.png create mode 100644 godot3/CRTFrame.png.import create mode 100644 godot3/default_env.tres create mode 100644 godot3/icon.png create mode 100644 godot3/icon.png.import create mode 100644 godot3/project.godot create mode 100644 godot3/sample.png create mode 100644 godot3/sample.png.import create mode 100644 godot3/white.png create mode 100644 godot3/white.png.import delete mode 100644 icon.png delete mode 100644 icon.png.flags delete mode 100644 white.png diff --git a/CRTDisplayShader.shd b/CRTDisplayShader.shd deleted file mode 100644 index 6b0c8a3..0000000 Binary files a/CRTDisplayShader.shd and /dev/null differ diff --git a/CRTFrame.png b/CRTFrame.png deleted file mode 100644 index 9c5ca46..0000000 Binary files a/CRTFrame.png and /dev/null differ diff --git a/CRTViewportDisplay/CRT.scn b/CRTViewportDisplay/CRT.scn deleted file mode 100644 index caf3a18..0000000 Binary files a/CRTViewportDisplay/CRT.scn and /dev/null differ diff --git a/CRTViewportDisplay/CRTDisplayShader.shd b/CRTViewportDisplay/CRTDisplayShader.shd deleted file mode 100644 index 4ca4ed4..0000000 Binary files a/CRTViewportDisplay/CRTDisplayShader.shd and /dev/null differ diff --git a/CRTViewportDisplay/CRTFrame.png b/CRTViewportDisplay/CRTFrame.png deleted file mode 100644 index 9c5ca46..0000000 Binary files a/CRTViewportDisplay/CRTFrame.png and /dev/null differ diff --git a/CRTViewportDisplay/white.png b/CRTViewportDisplay/white.png deleted file mode 100644 index 573faa3..0000000 Binary files a/CRTViewportDisplay/white.png and /dev/null differ diff --git a/ShaderTestsScreen.scn b/ShaderTestsScreen.scn deleted file mode 100644 index 2624d54..0000000 Binary files a/ShaderTestsScreen.scn and /dev/null differ diff --git a/engine.cfg b/engine.cfg deleted file mode 100644 index 44f4999..0000000 --- a/engine.cfg +++ /dev/null @@ -1,5 +0,0 @@ -[application] - -name="ShaderTest" -main_scene="res://ShaderTestsScreen.scn" -icon="res://icon.png" diff --git a/godot2/CRTDisplayShader.shd b/godot2/CRTDisplayShader.shd new file mode 100644 index 0000000..6b0c8a3 Binary files /dev/null and b/godot2/CRTDisplayShader.shd differ diff --git a/godot2/CRTFrame.png b/godot2/CRTFrame.png new file mode 100644 index 0000000..9c5ca46 Binary files /dev/null and b/godot2/CRTFrame.png differ diff --git a/godot2/CRTViewportDisplay/CRT.scn b/godot2/CRTViewportDisplay/CRT.scn new file mode 100644 index 0000000..caf3a18 Binary files /dev/null and b/godot2/CRTViewportDisplay/CRT.scn differ diff --git a/godot2/CRTViewportDisplay/CRTDisplayShader.shd b/godot2/CRTViewportDisplay/CRTDisplayShader.shd new file mode 100644 index 0000000..4ca4ed4 Binary files /dev/null and b/godot2/CRTViewportDisplay/CRTDisplayShader.shd differ diff --git a/godot2/CRTViewportDisplay/CRTFrame.png b/godot2/CRTViewportDisplay/CRTFrame.png new file mode 100644 index 0000000..9c5ca46 Binary files /dev/null and b/godot2/CRTViewportDisplay/CRTFrame.png differ diff --git a/godot2/CRTViewportDisplay/white.png b/godot2/CRTViewportDisplay/white.png new file mode 100644 index 0000000..573faa3 Binary files /dev/null and b/godot2/CRTViewportDisplay/white.png differ diff --git a/godot2/ShaderTestsScreen.scn b/godot2/ShaderTestsScreen.scn new file mode 100644 index 0000000..2624d54 Binary files /dev/null and b/godot2/ShaderTestsScreen.scn differ diff --git a/godot2/engine.cfg b/godot2/engine.cfg new file mode 100644 index 0000000..44f4999 --- /dev/null +++ b/godot2/engine.cfg @@ -0,0 +1,5 @@ +[application] + +name="ShaderTest" +main_scene="res://ShaderTestsScreen.scn" +icon="res://icon.png" diff --git a/godot2/icon.png b/godot2/icon.png new file mode 100644 index 0000000..c019ef6 Binary files /dev/null and b/godot2/icon.png differ diff --git a/godot2/icon.png.flags b/godot2/icon.png.flags new file mode 100644 index 0000000..5130fd1 --- /dev/null +++ b/godot2/icon.png.flags @@ -0,0 +1 @@ +gen_mipmaps=false diff --git a/godot2/sample.png b/godot2/sample.png new file mode 100644 index 0000000..200fbf8 Binary files /dev/null and b/godot2/sample.png differ diff --git a/godot2/white.png b/godot2/white.png new file mode 100644 index 0000000..573faa3 Binary files /dev/null and b/godot2/white.png differ diff --git a/godot3/.import/CRTFrame.png-96837578d803d46c371247267c1fa407.stex b/godot3/.import/CRTFrame.png-96837578d803d46c371247267c1fa407.stex new file mode 100644 index 0000000..821c0b6 Binary files /dev/null and b/godot3/.import/CRTFrame.png-96837578d803d46c371247267c1fa407.stex differ diff --git a/godot3/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex b/godot3/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex new file mode 100644 index 0000000..1f08a3c Binary files /dev/null and b/godot3/.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex differ diff --git a/godot3/.import/sample.png-e83d904df67be35a3470a03c20e2b3c2.stex b/godot3/.import/sample.png-e83d904df67be35a3470a03c20e2b3c2.stex new file mode 100644 index 0000000..47ee8a5 Binary files /dev/null and b/godot3/.import/sample.png-e83d904df67be35a3470a03c20e2b3c2.stex differ diff --git a/godot3/.import/white.png-d8533361663a5f8fe5200e5b5262a62d.stex b/godot3/.import/white.png-d8533361663a5f8fe5200e5b5262a62d.stex new file mode 100644 index 0000000..8efe585 Binary files /dev/null and b/godot3/.import/white.png-d8533361663a5f8fe5200e5b5262a62d.stex differ diff --git a/godot3/CRTFrame.png b/godot3/CRTFrame.png new file mode 100644 index 0000000..9c5ca46 Binary files /dev/null and b/godot3/CRTFrame.png differ diff --git a/godot3/CRTFrame.png.import b/godot3/CRTFrame.png.import new file mode 100644 index 0000000..23593e8 --- /dev/null +++ b/godot3/CRTFrame.png.import @@ -0,0 +1,32 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/CRTFrame.png-96837578d803d46c371247267c1fa407.stex" + +[deps] + +source_file="res://CRTFrame.png" +source_md5="df84d0e7c378fc804ee71ab344da073a" + +dest_files=[ "res://.import/CRTFrame.png-96837578d803d46c371247267c1fa407.stex" ] +dest_md5="1a94df3d4e5bfe9a966b0b9368f408a8" + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/godot3/default_env.tres b/godot3/default_env.tres new file mode 100644 index 0000000..98f26a7 --- /dev/null +++ b/godot3/default_env.tres @@ -0,0 +1,5 @@ +[gd_resource type="Environment" load_steps=2 format=2] +[sub_resource type="ProceduralSky" id=1] +[resource] +background_mode = 2 +background_sky = SubResource( 1 ) diff --git a/godot3/icon.png b/godot3/icon.png new file mode 100644 index 0000000..a0b64ee Binary files /dev/null and b/godot3/icon.png differ diff --git a/godot3/icon.png.import b/godot3/icon.png.import new file mode 100644 index 0000000..7e34d87 --- /dev/null +++ b/godot3/icon.png.import @@ -0,0 +1,32 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex" + +[deps] + +source_file="res://icon.png" +source_md5="ae7e641067601e2184afcade49abd283" + +dest_files=[ "res://.import/icon.png-487276ed1e3a0c39cad0279d744ee560.stex" ] +dest_md5="84511021bbc8c9d37c7f0f4d181de883" + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/godot3/project.godot b/godot3/project.godot new file mode 100644 index 0000000..31ba6b8 --- /dev/null +++ b/godot3/project.godot @@ -0,0 +1,18 @@ +; Engine configuration file. +; It's best edited using the editor UI and not directly, +; since the parameters that go here are not all obvious. +; +; Format: +; [section] ; section goes between [] +; param=value ; assign values to parameters + +config_version=3 + +[application] + +config/name="ShaderTest" +config/icon="res://icon.png" + +[rendering] + +environment/default_environment="res://default_env.tres" diff --git a/godot3/sample.png b/godot3/sample.png new file mode 100644 index 0000000..200fbf8 Binary files /dev/null and b/godot3/sample.png differ diff --git a/godot3/sample.png.import b/godot3/sample.png.import new file mode 100644 index 0000000..f21cd63 --- /dev/null +++ b/godot3/sample.png.import @@ -0,0 +1,32 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/sample.png-e83d904df67be35a3470a03c20e2b3c2.stex" + +[deps] + +source_file="res://sample.png" +source_md5="03ef0b3e4f811b7b8aeb5aa43211853b" + +dest_files=[ "res://.import/sample.png-e83d904df67be35a3470a03c20e2b3c2.stex" ] +dest_md5="99120c8fe78b2b814e2068903e4a4f0e" + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/godot3/white.png b/godot3/white.png new file mode 100644 index 0000000..573faa3 Binary files /dev/null and b/godot3/white.png differ diff --git a/godot3/white.png.import b/godot3/white.png.import new file mode 100644 index 0000000..b1e0205 --- /dev/null +++ b/godot3/white.png.import @@ -0,0 +1,32 @@ +[remap] + +importer="texture" +type="StreamTexture" +path="res://.import/white.png-d8533361663a5f8fe5200e5b5262a62d.stex" + +[deps] + +source_file="res://white.png" +source_md5="b68844373120b3795a9b80a7922d0c76" + +dest_files=[ "res://.import/white.png-d8533361663a5f8fe5200e5b5262a62d.stex" ] +dest_md5="f17f3e225bc88873851ebd43ba696987" + +[params] + +compress/mode=0 +compress/lossy_quality=0.7 +compress/hdr_mode=0 +compress/normal_map=0 +flags/repeat=0 +flags/filter=true +flags/mipmaps=false +flags/anisotropic=false +flags/srgb=2 +process/fix_alpha_border=true +process/premult_alpha=false +process/HDR_as_SRGB=false +stream=false +size_limit=0 +detect_3d=true +svg/scale=1.0 diff --git a/icon.png b/icon.png deleted file mode 100644 index c019ef6..0000000 Binary files a/icon.png and /dev/null differ diff --git a/icon.png.flags b/icon.png.flags deleted file mode 100644 index 5130fd1..0000000 --- a/icon.png.flags +++ /dev/null @@ -1 +0,0 @@ -gen_mipmaps=false diff --git a/white.png b/white.png deleted file mode 100644 index 573faa3..0000000 Binary files a/white.png and /dev/null differ -- cgit v1.2.3 From c3e8c9bab4756919c4a270c87a7cbe15458ed282 Mon Sep 17 00:00:00 2001 From: MohabMohamed Date: Tue, 6 Mar 2018 23:56:15 +0200 Subject: Curvature done in godot 3 --- godot3/ShaderTestScreen.tscn | 109 +++++++++++++++++++++++++++++++++++++++++++ godot3/default_env.tres | 96 +++++++++++++++++++++++++++++++++++++ godot3/project.godot | 1 + 3 files changed, 206 insertions(+) create mode 100644 godot3/ShaderTestScreen.tscn diff --git a/godot3/ShaderTestScreen.tscn b/godot3/ShaderTestScreen.tscn new file mode 100644 index 0000000..9355bce --- /dev/null +++ b/godot3/ShaderTestScreen.tscn @@ -0,0 +1,109 @@ +[gd_scene load_steps=5 format=2] + +[ext_resource path="res://sample.png" type="Texture" id=1] +[ext_resource path="res://white.png" type="Texture" id=2] + +[sub_resource type="Shader" id=1] + +code = "shader_type canvas_item; + +uniform float BarrelPower =1.1; + +vec2 distort(vec2 p) +{ + + float angle = p.y / p.x; + float theta = atan(p.y,p.x); + float radius = pow(length(p), BarrelPower); + + p.x = radius * cos(theta); + p.y = radius * sin(theta); + + return 0.5 * (p + vec2(1.0,1.0)); +} +void fragment() +{ + +vec2 xy = SCREEN_UV * 2.0; +xy.x -= 1.0; +xy.y -= 1.0; + +float d = length(xy); +if(d < 1.5){ + xy = distort(xy); +} +else{ + xy = SCREEN_UV; +} +COLOR = textureLod(SCREEN_TEXTURE,xy,0); +} + + + +" + +[sub_resource type="ShaderMaterial" id=2] + +render_priority = 0 +shader = SubResource( 1 ) +shader_param/BarrelPower = 1.1 +_sections_unfolded = [ "shader_param" ] + +[node name="Control" type="Control" index="0"] + +anchor_left = 0.0 +anchor_top = 0.0 +anchor_right = 0.0 +anchor_bottom = 0.0 +margin_right = 40.0 +margin_bottom = 40.0 +rect_pivot_offset = Vector2( 0, 0 ) +rect_clip_content = false +mouse_filter = 0 +mouse_default_cursor_shape = 0 +size_flags_horizontal = 1 +size_flags_vertical = 1 +_sections_unfolded = [ "Rect" ] + +[node name="Sprite" type="Sprite" parent="." index="0"] + +texture = ExtResource( 1 ) +centered = false +_sections_unfolded = [ "Offset" ] + +[node name="Shaders" type="Control" parent="." index="1"] + +anchor_left = 0.0 +anchor_top = 0.0 +anchor_right = 0.0 +anchor_bottom = 0.0 +margin_right = 40.0 +margin_bottom = 40.0 +rect_pivot_offset = Vector2( 0, 0 ) +rect_clip_content = false +mouse_filter = 0 +mouse_default_cursor_shape = 0 +size_flags_horizontal = 1 +size_flags_vertical = 1 + +[node name="Curvature" type="TextureRect" parent="Shaders" index="0"] + +material = SubResource( 2 ) +anchor_left = 0.0 +anchor_top = 0.0 +anchor_right = 0.0 +anchor_bottom = 0.0 +margin_right = 1024.0 +margin_bottom = 600.0 +rect_pivot_offset = Vector2( 0, 0 ) +rect_clip_content = false +mouse_filter = 1 +mouse_default_cursor_shape = 0 +size_flags_horizontal = 1 +size_flags_vertical = 1 +texture = ExtResource( 2 ) +expand = true +stretch_mode = 0 +_sections_unfolded = [ "Material", "Mouse", "Rect" ] + + diff --git a/godot3/default_env.tres b/godot3/default_env.tres index 98f26a7..ad86b72 100644 --- a/godot3/default_env.tres +++ b/godot3/default_env.tres @@ -1,5 +1,101 @@ [gd_resource type="Environment" load_steps=2 format=2] + [sub_resource type="ProceduralSky" id=1] + +radiance_size = 4 +sky_top_color = Color( 0.0470588, 0.454902, 0.976471, 1 ) +sky_horizon_color = Color( 0.556863, 0.823529, 0.909804, 1 ) +sky_curve = 0.25 +sky_energy = 1.0 +ground_bottom_color = Color( 0.101961, 0.145098, 0.188235, 1 ) +ground_horizon_color = Color( 0.482353, 0.788235, 0.952941, 1 ) +ground_curve = 0.01 +ground_energy = 1.0 +sun_color = Color( 1, 1, 1, 1 ) +sun_latitude = 35.0 +sun_longitude = 0.0 +sun_angle_min = 1.0 +sun_angle_max = 100.0 +sun_curve = 0.05 +sun_energy = 16.0 +texture_size = 2 + [resource] + background_mode = 2 background_sky = SubResource( 1 ) +background_sky_custom_fov = 0.0 +background_color = Color( 0, 0, 0, 1 ) +background_energy = 1.0 +background_canvas_max_layer = 0 +ambient_light_color = Color( 0, 0, 0, 1 ) +ambient_light_energy = 1.0 +ambient_light_sky_contribution = 1.0 +fog_enabled = false +fog_color = Color( 0.5, 0.6, 0.7, 1 ) +fog_sun_color = Color( 1, 0.9, 0.7, 1 ) +fog_sun_amount = 0.0 +fog_depth_enabled = true +fog_depth_begin = 10.0 +fog_depth_curve = 1.0 +fog_transmit_enabled = false +fog_transmit_curve = 1.0 +fog_height_enabled = false +fog_height_min = 0.0 +fog_height_max = 100.0 +fog_height_curve = 1.0 +tonemap_mode = 0 +tonemap_exposure = 1.0 +tonemap_white = 1.0 +auto_exposure_enabled = false +auto_exposure_scale = 0.4 +auto_exposure_min_luma = 0.05 +auto_exposure_max_luma = 8.0 +auto_exposure_speed = 0.5 +ss_reflections_enabled = false +ss_reflections_max_steps = 64 +ss_reflections_fade_in = 0.15 +ss_reflections_fade_out = 2.0 +ss_reflections_depth_tolerance = 0.2 +ss_reflections_roughness = true +ssao_enabled = false +ssao_radius = 1.0 +ssao_intensity = 1.0 +ssao_radius2 = 0.0 +ssao_intensity2 = 1.0 +ssao_bias = 0.01 +ssao_light_affect = 0.0 +ssao_color = Color( 0, 0, 0, 1 ) +ssao_quality = 0 +ssao_blur = 3 +ssao_edge_sharpness = 4.0 +dof_blur_far_enabled = false +dof_blur_far_distance = 10.0 +dof_blur_far_transition = 5.0 +dof_blur_far_amount = 0.1 +dof_blur_far_quality = 1 +dof_blur_near_enabled = false +dof_blur_near_distance = 2.0 +dof_blur_near_transition = 1.0 +dof_blur_near_amount = 0.1 +dof_blur_near_quality = 1 +glow_enabled = false +glow_levels/1 = false +glow_levels/2 = false +glow_levels/3 = true +glow_levels/4 = false +glow_levels/5 = true +glow_levels/6 = false +glow_levels/7 = false +glow_intensity = 0.8 +glow_strength = 1.0 +glow_bloom = 0.0 +glow_blend_mode = 2 +glow_hdr_threshold = 1.0 +glow_hdr_scale = 2.0 +glow_bicubic_upscale = false +adjustment_enabled = false +adjustment_brightness = 1.0 +adjustment_contrast = 1.0 +adjustment_saturation = 1.0 + diff --git a/godot3/project.godot b/godot3/project.godot index 31ba6b8..403539f 100644 --- a/godot3/project.godot +++ b/godot3/project.godot @@ -11,6 +11,7 @@ config_version=3 [application] config/name="ShaderTest" +run/main_scene="res://ShaderTestScreen.tscn" config/icon="res://icon.png" [rendering] -- cgit v1.2.3 From 3770cfa4cc36325be244f34c174db7c38f6c4872 Mon Sep 17 00:00:00 2001 From: MohabMohamed Date: Wed, 7 Mar 2018 00:53:50 +0200 Subject: color bleeding done in godot 3 --- godot3/ShaderTestScreen.tscn | 49 ++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 47 insertions(+), 2 deletions(-) diff --git a/godot3/ShaderTestScreen.tscn b/godot3/ShaderTestScreen.tscn index 9355bce..2cbbb1a 100644 --- a/godot3/ShaderTestScreen.tscn +++ b/godot3/ShaderTestScreen.tscn @@ -1,4 +1,4 @@ -[gd_scene load_steps=5 format=2] +[gd_scene load_steps=7 format=2] [ext_resource path="res://sample.png" type="Texture" id=1] [ext_resource path="res://white.png" type="Texture" id=2] @@ -35,7 +35,7 @@ if(d < 1.5){ else{ xy = SCREEN_UV; } -COLOR = textureLod(SCREEN_TEXTURE,xy,0); +COLOR = texture(SCREEN_TEXTURE,xy); } @@ -49,6 +49,31 @@ shader = SubResource( 1 ) shader_param/BarrelPower = 1.1 _sections_unfolded = [ "shader_param" ] +[sub_resource type="Shader" id=3] + +code = "shader_type canvas_item; + +uniform float color_bleeding = 0.9; +uniform float bleeding_range = 2; +uniform float screen_width = 1024; +void fragment() +{ + float pixel_size = 1.0/screen_width*bleeding_range; + vec4 color_left = texture(SCREEN_TEXTURE,SCREEN_UV - vec2(pixel_size, 0)); + vec4 current_color = texture(SCREEN_TEXTURE,SCREEN_UV); + current_color = current_color*vec4(color_bleeding,0.5,0.25,1); + color_left = color_left*vec4(0.25,0.5,color_bleeding,1); + COLOR.rgba = (current_color + color_left); +}" + +[sub_resource type="ShaderMaterial" id=4] + +render_priority = 0 +shader = SubResource( 3 ) +shader_param/color_bleeding = null +shader_param/bleeding_range = null +shader_param/screen_width = null + [node name="Control" type="Control" index="0"] anchor_left = 0.0 @@ -106,4 +131,24 @@ expand = true stretch_mode = 0 _sections_unfolded = [ "Material", "Mouse", "Rect" ] +[node name="ColorBleeding" type="TextureRect" parent="Shaders" index="1"] + +material = SubResource( 4 ) +anchor_left = 0.0 +anchor_top = 0.0 +anchor_right = 0.0 +anchor_bottom = 0.0 +margin_right = 1024.0 +margin_bottom = 600.0 +rect_pivot_offset = Vector2( 0, 0 ) +rect_clip_content = false +mouse_filter = 1 +mouse_default_cursor_shape = 0 +size_flags_horizontal = 1 +size_flags_vertical = 1 +texture = ExtResource( 2 ) +expand = true +stretch_mode = 0 +_sections_unfolded = [ "Material", "Rect" ] + -- cgit v1.2.3 From 9271ac7da04b06770024edb9a2038cc687933278 Mon Sep 17 00:00:00 2001 From: MohabMohamed Date: Wed, 7 Mar 2018 15:41:02 +0200 Subject: scanline in godot3 --- godot3/ShaderTestScreen.tscn | 77 ++++++++++++++++++++++++++++++++++++++++++-- 1 file changed, 75 insertions(+), 2 deletions(-) diff --git a/godot3/ShaderTestScreen.tscn b/godot3/ShaderTestScreen.tscn index 2cbbb1a..e6d22fa 100644 --- a/godot3/ShaderTestScreen.tscn +++ b/godot3/ShaderTestScreen.tscn @@ -1,7 +1,8 @@ -[gd_scene load_steps=7 format=2] +[gd_scene load_steps=10 format=2] [ext_resource path="res://sample.png" type="Texture" id=1] [ext_resource path="res://white.png" type="Texture" id=2] +[ext_resource path="res://CRTFrame.png" type="Texture" id=3] [sub_resource type="Shader" id=1] @@ -47,7 +48,7 @@ COLOR = texture(SCREEN_TEXTURE,xy); render_priority = 0 shader = SubResource( 1 ) shader_param/BarrelPower = 1.1 -_sections_unfolded = [ "shader_param" ] +_sections_unfolded = [ "Resource", "shader_param" ] [sub_resource type="Shader" id=3] @@ -74,6 +75,38 @@ shader_param/color_bleeding = null shader_param/bleeding_range = null shader_param/screen_width = null +[sub_resource type="Shader" id=5] + +code = "shader_type canvas_item; + +uniform float lines_distance = 4.0; +uniform float pixel_size = 2.0; +uniform float size_screen = 600; +uniform float scanline_alpha = 0.9; +uniform float lines_velocity = 30.0; + +void fragment() +{ + float line_row = floor((SCREEN_UV.y * size_screen/pixel_size) + mod(TIME*lines_velocity, lines_distance)); + + float n = 1.0 - ceil((mod(line_row,lines_distance)/lines_distance)); + +vec4 c = texture(SCREEN_TEXTURE,SCREEN_UV); +c = c - n*c*(1.0 - scanline_alpha); +c.a = 1.0; +COLOR = c; +}" + +[sub_resource type="ShaderMaterial" id=6] + +render_priority = 0 +shader = SubResource( 5 ) +shader_param/lines_distance = null +shader_param/pixel_size = null +shader_param/size_screen = null +shader_param/scanline_alpha = null +shader_param/lines_velocity = null + [node name="Control" type="Control" index="0"] anchor_left = 0.0 @@ -133,6 +166,7 @@ _sections_unfolded = [ "Material", "Mouse", "Rect" ] [node name="ColorBleeding" type="TextureRect" parent="Shaders" index="1"] +visible = false material = SubResource( 4 ) anchor_left = 0.0 anchor_top = 0.0 @@ -151,4 +185,43 @@ expand = true stretch_mode = 0 _sections_unfolded = [ "Material", "Rect" ] +[node name="ScanLine" type="TextureRect" parent="Shaders" index="2"] + +material = SubResource( 6 ) +anchor_left = 0.0 +anchor_top = 0.0 +anchor_right = 0.0 +anchor_bottom = 0.0 +margin_right = 1024.0 +margin_bottom = 600.0 +rect_pivot_offset = Vector2( 0, 0 ) +rect_clip_content = false +mouse_filter = 1 +mouse_default_cursor_shape = 0 +size_flags_horizontal = 1 +size_flags_vertical = 1 +texture = ExtResource( 2 ) +expand = true +stretch_mode = 0 +_sections_unfolded = [ "Material", "Rect" ] + +[node name="CRTFrame" type="TextureRect" parent="." index="2"] + +anchor_left = 0.0 +anchor_top = 0.0 +anchor_right = 0.0 +anchor_bottom = 0.0 +margin_right = 1082.0 +margin_bottom = 812.0 +rect_scale = Vector2( 0.946396, 0.738916 ) +rect_pivot_offset = Vector2( 0, 0 ) +rect_clip_content = false +mouse_filter = 1 +mouse_default_cursor_shape = 0 +size_flags_horizontal = 1 +size_flags_vertical = 1 +texture = ExtResource( 3 ) +stretch_mode = 0 +_sections_unfolded = [ "Rect" ] + -- cgit v1.2.3 From f4ff3531b7e42b9b4591dd7460140b2389d520ff Mon Sep 17 00:00:00 2001 From: MohabMohamed Date: Tue, 13 Mar 2018 00:22:31 +0200 Subject: CRT done in Godot3 --- godot3/ShaderTestScreen.tscn | 115 ++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 114 insertions(+), 1 deletion(-) diff --git a/godot3/ShaderTestScreen.tscn b/godot3/ShaderTestScreen.tscn index e6d22fa..5440580 100644 --- a/godot3/ShaderTestScreen.tscn +++ b/godot3/ShaderTestScreen.tscn @@ -1,4 +1,4 @@ -[gd_scene load_steps=10 format=2] +[gd_scene load_steps=12 format=2] [ext_resource path="res://sample.png" type="Texture" id=1] [ext_resource path="res://white.png" type="Texture" id=2] @@ -107,6 +107,97 @@ shader_param/size_screen = null shader_param/scanline_alpha = null shader_param/lines_velocity = null +[sub_resource type="Shader" id=7] + +code = "shader_type canvas_item; + +uniform float screen_width = 1024; +uniform float screen_height = 600; + +// Curvature +uniform float BarrelPower =1.1; +// Color bleeding +uniform float color_bleeding = 1.2; +uniform float bleeding_range_x = 3; +uniform float bleeding_range_y = 3; +// Scanline +uniform float lines_distance = 4.0; +uniform float scan_size = 2.0; +uniform float scanline_alpha = 0.9; +uniform float lines_velocity = 30.0; +vec2 distort(vec2 p) +{ + + float angle = p.y / p.x; + float theta = atan(p.y,p.x); + float radius = pow(length(p), BarrelPower); + + p.x = radius * cos(theta); + p.y = radius * sin(theta); + + return 0.5 * (p + vec2(1.0,1.0)); +} + +void get_color_bleeding(inout vec4 current_color,inout vec4 color_left){ + + current_color = current_color*vec4(color_bleeding,0.5,0.25,1); + color_left = color_left*vec4(0.25,0.5,color_bleeding,1); +} + +void get_color_scanline(vec2 uv,inout vec4 c,float TIME){ + float line_row = floor((uv.y * screen_height/scan_size) + mod(TIME*lines_velocity, lines_distance)); + + float n = 1.0 - ceil((mod(line_row,lines_distance)/lines_distance)); + + c = c - n*c*(1.0 - scanline_alpha); + c.a = 1.0; + +} + +void fragment() +{ + +vec2 xy = SCREEN_UV * 2.0; +xy.x -= 1.0; +xy.y -= 1.0; + +float d = length(xy); +if(d < 1.5){ + xy = distort(xy); +} +else{ + xy = SCREEN_UV; +} + +float pixel_size_x = 1.0/screen_width*bleeding_range_x; +float pixel_size_y = 1.0/screen_height*bleeding_range_y; +vec4 color_left = texture(SCREEN_TEXTURE,SCREEN_UV - vec2(pixel_size_x, pixel_size_y)); +vec4 current_color = texture(SCREEN_TEXTURE,SCREEN_UV); +get_color_bleeding(current_color,color_left); +vec4 c = current_color+color_left; +get_color_scanline(xy,c,TIME); +COLOR = c; + +} +" +_sections_unfolded = [ "Resource" ] + +[sub_resource type="ShaderMaterial" id=8] + +render_priority = 0 +shader = SubResource( 7 ) +shader_param/screen_width = null +shader_param/screen_height = null +shader_param/BarrelPower = null +shader_param/color_bleeding = null +shader_param/bleeding_range_x = null +shader_param/bleeding_range_y = null +shader_param/lines_distance = null +shader_param/scan_size = null +shader_param/scanline_alpha = null +shader_param/lines_velocity = null +_sections_unfolded = [ "shader_param" ] + [node name="Control" type="Control" index="0"] anchor_left = 0.0 @@ -146,6 +237,7 @@ size_flags_vertical = 1 [node name="Curvature" type="TextureRect" parent="Shaders" index="0"] +visible = false material = SubResource( 2 ) anchor_left = 0.0 anchor_top = 0.0 @@ -187,6 +279,7 @@ _sections_unfolded = [ "Material", "Rect" ] [node name="ScanLine" type="TextureRect" parent="Shaders" index="2"] +visible = false material = SubResource( 6 ) anchor_left = 0.0 anchor_top = 0.0 @@ -205,6 +298,26 @@ expand = true stretch_mode = 0 _sections_unfolded = [ "Material", "Rect" ] +[node name="CRT" type="TextureRect" parent="Shaders" index="3"] + +material = SubResource( 8 ) +anchor_left = 0.0 +anchor_top = 0.0 +anchor_right = 0.0 +anchor_bottom = 0.0 +margin_right = 1024.0 +margin_bottom = 600.0 +rect_pivot_offset = Vector2( 0, 0 ) +rect_clip_content = false +mouse_filter = 1 +mouse_default_cursor_shape = 0 +size_flags_horizontal = 1 +size_flags_vertical = 1 +texture = ExtResource( 2 ) +expand = true +stretch_mode = 0 +_sections_unfolded = [ "Material", "Rect" ] + [node name="CRTFrame" type="TextureRect" parent="." index="2"] anchor_left = 0.0 -- cgit v1.2.3