Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 1 | /* |
| 2 | * Copyright (C) 2012 The Android Open Source Project |
| 3 | * |
| 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
| 5 | * you may not use this file except in compliance with the License. |
| 6 | * You may obtain a copy of the License at |
| 7 | * |
| 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
| 9 | * |
| 10 | * Unless required by applicable law or agreed to in writing, software |
| 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
| 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| 13 | * See the License for the specific language governing permissions and |
| 14 | * limitations under the License. |
| 15 | */ |
| 16 | |
| 17 | package android.renderscript; |
| 18 | |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 19 | /** |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 20 | * Intrinsic Gausian blur filter. Applies a gaussian blur of the |
| 21 | * specified radius to all elements of an allocation. |
| 22 | * |
| 23 | * |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 24 | **/ |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 25 | public final class ScriptIntrinsicBlur extends ScriptIntrinsic { |
| 26 | private final float[] mValues = new float[9]; |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 27 | private Allocation mInput; |
| 28 | |
Tim Murray | 460a049 | 2013-11-19 12:45:54 -0800 | [diff] [blame] | 29 | private ScriptIntrinsicBlur(long id, RenderScript rs) { |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 30 | super(id, rs); |
| 31 | } |
| 32 | |
| 33 | /** |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 34 | * Create an intrinsic for applying a blur to an allocation. The |
| 35 | * default radius is 5.0. |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 36 | * |
Miao Wang | c242fa6 | 2016-04-13 16:43:10 -0700 | [diff] [blame] | 37 | * Supported elements types are {@link Element#U8}, |
| 38 | * {@link Element#U8_4}. |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 39 | * |
Tim Murray | c11e25c | 2013-04-09 11:01:01 -0700 | [diff] [blame] | 40 | * @param rs The RenderScript context |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 41 | * @param e Element type for inputs and outputs |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 42 | * |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 43 | * @return ScriptIntrinsicBlur |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 44 | */ |
| 45 | public static ScriptIntrinsicBlur create(RenderScript rs, Element e) { |
Tim Murray | bddc7ff | 2013-04-01 11:35:35 -0700 | [diff] [blame] | 46 | if ((!e.isCompatible(Element.U8_4(rs))) && (!e.isCompatible(Element.U8(rs)))) { |
Stephen Hines | ad57e33 | 2016-04-11 13:05:55 -0700 | [diff] [blame] | 47 | throw new RSIllegalArgumentException("Unsupported element type."); |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 48 | } |
Tim Murray | 460a049 | 2013-11-19 12:45:54 -0800 | [diff] [blame] | 49 | long id = rs.nScriptIntrinsicCreate(5, e.getID(rs)); |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 50 | ScriptIntrinsicBlur sib = new ScriptIntrinsicBlur(id, rs); |
| 51 | sib.setRadius(5.f); |
| 52 | return sib; |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 53 | } |
| 54 | |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 55 | /** |
| 56 | * Set the input of the blur. |
| 57 | * Must match the element type supplied during create. |
| 58 | * |
| 59 | * @param ain The input allocation |
| 60 | */ |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 61 | public void setInput(Allocation ain) { |
Yang Ni | bb67137 | 2017-04-18 14:04:55 -0700 | [diff] [blame] | 62 | if (ain.getType().getY() == 0) { |
| 63 | throw new RSIllegalArgumentException("Input set to a 1D Allocation"); |
| 64 | } |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 65 | mInput = ain; |
Jason Sams | e6a7886 | 2012-10-15 15:45:12 -0700 | [diff] [blame] | 66 | setVar(1, ain); |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 67 | } |
| 68 | |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 69 | /** |
| 70 | * Set the radius of the Blur. |
| 71 | * |
Jason Sams | 31864d7 | 2012-10-02 15:21:11 -0700 | [diff] [blame] | 72 | * Supported range 0 < radius <= 25 |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 73 | * |
| 74 | * @param radius The radius of the blur |
| 75 | */ |
| 76 | public void setRadius(float radius) { |
Jason Sams | 31864d7 | 2012-10-02 15:21:11 -0700 | [diff] [blame] | 77 | if (radius <= 0 || radius > 25) { |
| 78 | throw new RSIllegalArgumentException("Radius out of range (0 < r <= 25)."); |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 79 | } |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 80 | setVar(0, radius); |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 81 | } |
| 82 | |
Jason Sams | 80d8190 | 2012-09-13 17:00:48 -0700 | [diff] [blame] | 83 | /** |
| 84 | * Apply the filter to the input and save to the specified |
| 85 | * allocation. |
| 86 | * |
| 87 | * @param aout Output allocation. Must match creation element |
| 88 | * type. |
| 89 | */ |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 90 | public void forEach(Allocation aout) { |
Yang Ni | bb67137 | 2017-04-18 14:04:55 -0700 | [diff] [blame] | 91 | if (aout.getType().getY() == 0) { |
| 92 | throw new RSIllegalArgumentException("Output is a 1D Allocation"); |
| 93 | } |
Chris Wailes | 9496106 | 2014-06-11 12:01:28 -0700 | [diff] [blame] | 94 | forEach(0, (Allocation) null, aout, null); |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 95 | } |
| 96 | |
Jason Sams | 08a8158 | 2012-09-18 12:32:10 -0700 | [diff] [blame] | 97 | /** |
Tim Murray | 6f842ac | 2014-01-13 11:47:53 -0800 | [diff] [blame] | 98 | * Apply the filter to the input and save to the specified |
| 99 | * allocation. |
| 100 | * |
| 101 | * @param aout Output allocation. Must match creation element |
| 102 | * type. |
| 103 | * @param opt LaunchOptions for clipping |
| 104 | */ |
| 105 | public void forEach(Allocation aout, Script.LaunchOptions opt) { |
Yang Ni | bb67137 | 2017-04-18 14:04:55 -0700 | [diff] [blame] | 106 | if (aout.getType().getY() == 0) { |
| 107 | throw new RSIllegalArgumentException("Output is a 1D Allocation"); |
| 108 | } |
Stephen Hines | 48ba506 | 2014-07-09 07:39:38 -0700 | [diff] [blame] | 109 | forEach(0, (Allocation) null, aout, null, opt); |
Tim Murray | 6f842ac | 2014-01-13 11:47:53 -0800 | [diff] [blame] | 110 | } |
| 111 | |
| 112 | |
| 113 | /** |
Jason Sams | 08a8158 | 2012-09-18 12:32:10 -0700 | [diff] [blame] | 114 | * Get a KernelID for this intrinsic kernel. |
| 115 | * |
| 116 | * @return Script.KernelID The KernelID object. |
| 117 | */ |
| 118 | public Script.KernelID getKernelID() { |
| 119 | return createKernelID(0, 2, null, null); |
| 120 | } |
| 121 | |
| 122 | /** |
| 123 | * Get a FieldID for the input field of this intrinsic. |
| 124 | * |
| 125 | * @return Script.FieldID The FieldID object. |
| 126 | */ |
| 127 | public Script.FieldID getFieldID_Input() { |
| 128 | return createFieldID(1, null); |
| 129 | } |
Jason Sams | 3a5b801 | 2012-09-08 22:16:14 -0700 | [diff] [blame] | 130 | } |