1: <?php
2: /**
3: * LICENSE (BSD)
4: *
5: * Copyright (c) 2012, Gerd Christian Kunze
6: * All rights reserved.
7: *
8: * Redistribution and use in source and binary forms, with or without
9: * modification, are permitted provided that the following conditions are
10: * met:
11: *
12: * * Redistributions of source code must retain the above copyright
13: * notice, this list of conditions and the following disclaimer.
14: *
15: * * Redistributions in binary form must reproduce the above copyright
16: * notice, this list of conditions and the following disclaimer in the
17: * documentation and/or other materials provided with the distribution.
18: *
19: * * Neither the name of Gerd Christian Kunze nor the names of the
20: * contributors may be used to endorse or promote products derived from
21: * this software without specific prior written permission.
22: *
23: * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS
24: * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
25: * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
26: * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
27: * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
28: * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
29: * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
30: * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
31: * LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
32: * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
33: * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34: *
35: * Filter
36: * 13.09.2012 23:20
37: */
38: namespace MOC\Module\Office\Image;
39: use MOC\Api;
40: use MOC\Generic\Device\Module;
41: use MOC\Module\Office\Image\Resource;
42:
43: /**
44: *
45: */
46: class Filter implements Module {
47: /**
48: * Get Singleton/Instance
49: *
50: * @static
51: * @return Filter
52: */
53: public static function InterfaceInstance() {
54: return new Filter();
55: }
56:
57: /**
58: * Get Dependencies
59: *
60: * @static
61: * @return \MOC\Core\Depending
62: */
63: public static function InterfaceDepending() {
64: return Api::Core()->Depending();
65: }
66:
67: /**
68: * Get Changelog
69: *
70: * @static
71: * @return \MOC\Core\Changelog
72: */
73: public static function InterfaceChangelog() {
74: return Api::Core()->Changelog();
75: }
76:
77:
78: /** @var Resource $Resource */
79: private $Resource = null;
80:
81: /**
82: * @param Resource $Resource
83: *
84: * @return Filter
85: */
86: public function UseResource( Resource $Resource ) {
87: $this->Resource = $Resource;
88: return $this;
89: }
90:
91: /**
92: * @return Filter
93: */
94: public function Negative() {
95: imagefilter( $this->Resource->Get(), IMG_FILTER_NEGATE );
96: return $this;
97: }
98:
99: /**
100: * @return Filter
101: */
102: public function GrayScale() {
103: imagefilter( $this->Resource->Get(), IMG_FILTER_GRAYSCALE );
104: return $this;
105: }
106:
107: /**
108: * @return Filter
109: */
110: public function EdgeDetect() {
111: imagefilter( $this->Resource->Get(), IMG_FILTER_EDGEDETECT );
112: return $this;
113: }
114:
115: /**
116: * @return Filter
117: */
118: public function Emboss() {
119: imagefilter( $this->Resource->Get(), IMG_FILTER_EMBOSS );
120: return $this;
121: }
122:
123: /**
124: * @return Filter
125: */
126: public function GaussianBlur() {
127: imagefilter( $this->Resource->Get(), IMG_FILTER_GAUSSIAN_BLUR );
128: return $this;
129: }
130:
131: /**
132: * @return Filter
133: */
134: public function SelectiveBlur() {
135: imagefilter( $this->Resource->Get(), IMG_FILTER_SELECTIVE_BLUR );
136: return $this;
137: }
138:
139: /**
140: * @return Filter
141: */
142: public function MeanRemoval() {
143: imagefilter( $this->Resource->Get(), IMG_FILTER_MEAN_REMOVAL );
144: return $this;
145: }
146:
147: /**
148: * @param $Level
149: *
150: * @return Filter
151: */public function Brightness( $Level ) {
152: imagefilter( $this->Resource->Get(), IMG_FILTER_BRIGHTNESS, $Level );
153: return $this;
154: }
155:
156: /**
157: * @param $Level
158: *
159: * @return Filter
160: */public function Contrast( $Level ) {
161: imagefilter( $this->Resource->Get(), IMG_FILTER_CONTRAST, $Level );
162: return $this;
163: }
164:
165: /**
166: * @param $Level
167: *
168: * @return Filter
169: */public function Smooth( $Level ) {
170: imagefilter( $this->Resource->Get(), IMG_FILTER_SMOOTH, $Level );
171: return $this;
172: }
173: }
174: