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.
21 /// Sampler is a handle to an object that can be used to provide the sampling parameters to sample textures.
23 public class Sampler : BaseHandle
25 private global::System.Runtime.InteropServices.HandleRef swigCPtr;
27 internal Sampler(global::System.IntPtr cPtr, bool cMemoryOwn) : base(NDalicPINVOKE.Sampler_SWIGUpcast(cPtr), cMemoryOwn)
29 swigCPtr = new global::System.Runtime.InteropServices.HandleRef(this, cPtr);
32 internal static global::System.Runtime.InteropServices.HandleRef getCPtr(Sampler obj)
34 return (obj == null) ? new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero) : obj.swigCPtr;
40 /// <since_tizen> 3 </since_tizen>
41 protected override void Dispose(DisposeTypes type)
48 if (type == DisposeTypes.Explicit)
51 //Release your own managed resources here.
52 //You should release all of your own disposable objects here.
56 //Release your own unmanaged resources here.
57 //You should not access any managed member here except static instance.
58 //because the execution order of Finalizes is non-deterministic.
61 if (swigCPtr.Handle != global::System.IntPtr.Zero)
66 NDalicPINVOKE.delete_Sampler(swigCPtr);
68 swigCPtr = new global::System.Runtime.InteropServices.HandleRef(null, global::System.IntPtr.Zero);
75 /// Create an instance of Sampler.
77 /// <since_tizen> 3 </since_tizen>
78 public Sampler() : this(NDalicPINVOKE.Sampler_New(), true)
80 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
85 /// Sets the filter modes for this sampler.
87 /// <param name="minFilter">The minification filter that will be used.</param>
88 /// <param name="magFilter">The magnification filter that will be used.</param>
89 /// <since_tizen> 3 </since_tizen>
90 public void SetFilterMode(FilterModeType minFilter, FilterModeType magFilter)
92 NDalicPINVOKE.Sampler_SetFilterMode(swigCPtr, (int)minFilter, (int)magFilter);
93 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
97 /// Sets the wrap modes for this sampler.
99 /// <param name="uWrap">Wrap mode for u coordinates.</param>
100 /// <param name="vWrap">Wrap mode for v coordinates.</param>
101 /// <since_tizen> 3 </since_tizen>
102 public void SetWrapMode(WrapModeType uWrap, WrapModeType vWrap)
104 NDalicPINVOKE.Sampler_SetWrapMode__SWIG_0(swigCPtr, (int)uWrap, (int)vWrap);
105 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();
109 /// Sets the wrap modes for this sampler.
111 /// <param name="rWrap">Wrap mode for the x direction.</param>
112 /// <param name="sWrap">Wrap mode for the y direction.</param>
113 /// <param name="tWrap">Wrap mode for the z direction.</param>
114 /// <since_tizen> 3 </since_tizen>
115 public void SetWrapMode(WrapModeType rWrap, WrapModeType sWrap, WrapModeType tWrap)
117 NDalicPINVOKE.Sampler_SetWrapMode__SWIG_1(swigCPtr, (int)rWrap, (int)sWrap, (int)tWrap);
118 if (NDalicPINVOKE.SWIGPendingException.Pending) throw NDalicPINVOKE.SWIGPendingException.Retrieve();