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);
+ }
+ }
+}
+