2 * Copyright(c) 2017 Samsung Electronics Co., Ltd.
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
8 * http://www.apache.org/licenses/LICENSE-2.0
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.
18 using System.Runtime.InteropServices;
23 /// TextureSet is a handle to an object that specifies the set of images used as textures by a renderer.<br />
24 /// The images have to be ordered in the same order they are declared in the shader.
26 /// <since_tizen> 3 </since_tizen>
27 public class TextureSet : BaseHandle
29 private global::System.Runtime.InteropServices.HandleRef swigCPtr;
32 /// Create an instance of TextureSet.
34 /// <since_tizen> 3 </since_tizen>
35 public TextureSet() : this(Interop.TextureSet.TextureSet_New(), true)
37 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
40 internal TextureSet(global::System.IntPtr cPtr, bool cMemoryOwn) : base(Interop.TextureSet.TextureSet_SWIGUpcast(cPtr), cMemoryOwn)
42 swigCPtr = new global::System.Runtime.InteropServices.HandleRef(this, cPtr);
46 /// Sets the texture at position "index".
48 /// <param name="index">The position in the texture set of the texture.</param>
49 /// <param name="texture">The texture.</param>
50 /// <since_tizen> 3 </since_tizen>
51 public void SetTexture(uint index, Texture texture)
53 Interop.TextureSet.TextureSet_SetTexture(swigCPtr, index, Texture.getCPtr(texture));
54 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
58 /// Gets the image at position "index".
60 /// <param name="index">The position in the texture set of the image.</param>
61 /// <returns>A handle to the image at the the specified position.</returns>
62 /// <since_tizen> 3 </since_tizen>
63 public Texture GetTexture(uint index)
65 //to fix memory leak issue, match the handle count with native side.
66 System.IntPtr cPtr = Interop.TextureSet.TextureSet_GetTexture(swigCPtr, index);
67 HandleRef CPtr = new global::System.Runtime.InteropServices.HandleRef(this, cPtr);
68 Texture ret = Registry.GetManagedBaseHandleFromNativePtr(CPtr.Handle) as Texture;
69 if (cPtr != null && ret == null)
71 ret = new Texture(cPtr, false);
72 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
75 Interop.BaseHandle.delete_BaseHandle(CPtr);
76 CPtr = new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero);
78 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
83 /// Sets the sampler to be used by the image at position "index".
85 /// <param name="index">The position in the texture set of the image.</param>
86 /// <param name="sampler">The sampler to use.</param>
87 /// <since_tizen> 3 </since_tizen>
88 public void SetSampler(uint index, Sampler sampler)
90 Interop.TextureSet.TextureSet_SetSampler(swigCPtr, index, Sampler.getCPtr(sampler));
91 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
95 /// Sets the sampler to be used by the image at position "index".
97 /// <param name="index">The position in the texture set of the image.</param>
98 /// <returns>A handle to the sampler at the specified position.</returns>
99 /// <since_tizen> 3 </since_tizen>
100 public Sampler GetSampler(uint index)
102 //to fix memory leak issue, match the handle count with native side.
103 System.IntPtr cPtr = Interop.TextureSet.TextureSet_GetSampler(swigCPtr, index);
104 HandleRef CPtr = new global::System.Runtime.InteropServices.HandleRef(this, cPtr);
105 Sampler ret = Registry.GetManagedBaseHandleFromNativePtr(CPtr.Handle) as Sampler;
106 Interop.BaseHandle.delete_BaseHandle(CPtr);
107 CPtr = new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero);
109 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
114 /// Gets the number of textures present in the TextureSet.
116 /// <returns>The number of textures in the TextureSet.</returns>
117 /// <since_tizen> 3 </since_tizen>
118 public uint GetTextureCount()
120 uint ret = Interop.TextureSet.TextureSet_GetTextureCount(swigCPtr);
121 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
125 internal static global::System.Runtime.InteropServices.HandleRef getCPtr(TextureSet obj)
127 return (obj == null) ? new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero) : obj.swigCPtr;
133 /// <since_tizen> 3 </since_tizen>
134 protected override void Dispose(DisposeTypes type)
141 //Release your own unmanaged resources here.
142 //You should not access any managed member here except static instance.
143 //because the execution order of Finalizes is non-deterministic.
145 if (swigCPtr.Handle != global::System.IntPtr.Zero)
150 Interop.TextureSet.delete_TextureSet(swigCPtr);
152 swigCPtr = new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero);