You are viewing a plain text version of this content. The canonical link for it is here.
Posted to commits@royale.apache.org by yi...@apache.org on 2019/01/28 11:05:49 UTC

[royale-asjs] branch develop updated: Added DarkenedBevelFilter

This is an automated email from the ASF dual-hosted git repository.

yishayw pushed a commit to branch develop
in repository https://gitbox.apache.org/repos/asf/royale-asjs.git


The following commit(s) were added to refs/heads/develop by this push:
     new d14e0e9  Added DarkenedBevelFilter
     new 3c15ace  Merge branch 'develop' of https://github.com/apache/royale-asjs into develop
d14e0e9 is described below

commit d14e0e958f18e3f8a011a654a81bae57406f0b02
Author: DESKTOP-RH4S838\Yishay <yi...@hotmail.com>
AuthorDate: Mon Jan 28 13:05:28 2019 +0200

    Added DarkenedBevelFilter
---
 .../Graphics/src/main/resources/svg-manifest.xml   |  1 +
 .../org/apache/royale/svg/DarkenedBevelFilter.as   | 80 ++++++++++++++++++++++
 2 files changed, 81 insertions(+)

diff --git a/frameworks/projects/Graphics/src/main/resources/svg-manifest.xml b/frameworks/projects/Graphics/src/main/resources/svg-manifest.xml
index 7c797d6..d8d4c2f 100644
--- a/frameworks/projects/Graphics/src/main/resources/svg-manifest.xml
+++ b/frameworks/projects/Graphics/src/main/resources/svg-manifest.xml
@@ -24,6 +24,7 @@
 	<component id="ClipBead" class="org.apache.royale.svg.ClipBead" />
 	<component id="DropShadowFilter" class="org.apache.royale.svg.DropShadowFilter" />
 	<component id="BevelFilter" class="org.apache.royale.svg.BevelFilter" />
+	<component id="DarkenedBevelFilter" class="org.apache.royale.svg.DarkenedBevelFilter" />
 	<component id="Filter" class="org.apache.royale.svg.Filter" />
 	<component id="OffsetFilterElement" class="org.apache.royale.svg.OffsetFilterElement" />
 	<component id="TileFilterElement" class="org.apache.royale.svg.TileFilterElement" />
diff --git a/frameworks/projects/Graphics/src/main/royale/org/apache/royale/svg/DarkenedBevelFilter.as b/frameworks/projects/Graphics/src/main/royale/org/apache/royale/svg/DarkenedBevelFilter.as
new file mode 100644
index 0000000..7e7fa5f
--- /dev/null
+++ b/frameworks/projects/Graphics/src/main/royale/org/apache/royale/svg/DarkenedBevelFilter.as
@@ -0,0 +1,80 @@
+////////////////////////////////////////////////////////////////////////////////
+//
+//  Licensed to the Apache Software Foundation (ASF) under one or more
+//  contributor license agreements.  See the NOTICE file distributed with
+//  this work for additional information regarding copyright ownership.
+//  The ASF licenses this file to You under the Apache License, Version 2.0
+//  (the "License"); you may not use this file except in compliance with
+//  the License.  You may obtain a copy of the License at
+//
+//      http://www.apache.org/licenses/LICENSE-2.0
+//
+//  Unless required by applicable law or agreed to in writing, software
+//  distributed under the License is distributed on an "AS IS" BASIS,
+//  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+//  See the License for the specific language governing permissions and
+//  limitations under the License.
+//
+////////////////////////////////////////////////////////////////////////////////
+package org.apache.royale.svg
+{
+	
+	/**
+	 *  DarkenedBevelFilter extends BevelFilter to and darkens it somewhat in an attempt to retain the original colors in its the graphics core.
+	 *  This is an exprimental component designed to emulate PhotoShop's behavior.
+	 *  
+	 *  @langversion 3.0
+	 *  @playerversion Flash 10.2
+	 *  @playerversion AIR 2.6
+	 *  @productversion Royale 0.9.5
+	 */
+	public class DarkenedBevelFilter extends BevelFilter
+	{
+		
+
+		public function DarkenedBevelFilter()
+		{
+		}
+		
+		override public function build():void
+		{
+			super.build();
+			var lastFilterElement:FilterElement = children[children.length - 1] as FilterElement;
+			lastFilterElement.result = "FirstBevel";
+			if (result)
+			{
+				lastFilterElement.result += "_" + result;
+			}
+			var offsetFilterElement:OffsetFilterElement = new OffsetFilterElement();
+			offsetFilterElement.height = 4;
+			offsetFilterElement.width = 4;
+			offsetFilterElement.y = 40;
+			offsetFilterElement.x = 40;
+			children.push(offsetFilterElement);
+			var tileFilterElement:TileFilterElement = new TileFilterElement();
+			children.push(tileFilterElement);
+			var blurFilterElement:BlurFilterElement = new BlurFilterElement();
+			blurFilterElement.stdDeviation = 5;
+			children.push(blurFilterElement);
+			var compositeFilterElement:CompositeFilterElement = new CompositeFilterElement();
+			compositeFilterElement.in2 = "SourceGraphic";
+			compositeFilterElement.operator = "in";
+			children.push(compositeFilterElement);
+			var blendFilterElement:BlendFilterElement = new BlendFilterElement();
+			blendFilterElement.result = "difference";
+			if (result)
+			{
+				blendFilterElement.result += "_" + result;
+			}
+			blendFilterElement.in2 = "SourceGraphic";
+			blendFilterElement.mode = "difference";
+			children.push(blendFilterElement);
+			var blendFilterElement2:BlendFilterElement = new BlendFilterElement();
+			blendFilterElement2.in2 = "difference";
+			blendFilterElement2.in = "FirstBevel";
+			blendFilterElement2.mode = "difference";
+			children.push(blendFilterElement2);
+		}
+	}
+}
+