/////////////////////////////////////////////////////////////////////////////////////////////////// // OpenGL Mathematics Copyright (c) 2005 - 2011 G-Truc Creation (www.g-truc.net) /////////////////////////////////////////////////////////////////////////////////////////////////// // Created : 2009-11-25 // Updated : 2010-02-13 // Licence : This source is under MIT License // File : glm/gtx/wrap.inl /////////////////////////////////////////////////////////////////////////////////////////////////// // Dependency: // - GLM core /////////////////////////////////////////////////////////////////////////////////////////////////// namespace glm{ namespace gtx{ namespace wrap { //////////////////////// // clamp template GLM_FUNC_QUALIFIER genType clamp ( genType const & Texcoord ) { return glm::clamp(Texcoord, genType(0), genType(1)); } template GLM_FUNC_QUALIFIER detail::tvec2 clamp ( detail::tvec2 const & Texcoord ) { detail::tvec2 Result; for(typename detail::tvec2::size_type i = 0; i < detail::tvec2::value_size(); ++i) Result[i] = clamp(Texcoord[i]); return Result; } template GLM_FUNC_QUALIFIER detail::tvec3 clamp ( detail::tvec3 const & Texcoord ) { detail::tvec3 Result; for(typename detail::tvec3::size_type i = 0; i < detail::tvec3::value_size(); ++i) Result[i] = clamp(Texcoord[i]); return Result; } template GLM_FUNC_QUALIFIER detail::tvec4 clamp ( detail::tvec4 const & Texcoord ) { detail::tvec4 Result; for(typename detail::tvec4::size_type i = 0; i < detail::tvec4::value_size(); ++i) Result[i] = clamp(Texcoord[i]); return Result; } //////////////////////// // repeat template GLM_FUNC_QUALIFIER genType repeat ( genType const & Texcoord ) { return glm::fract(Texcoord); } template GLM_FUNC_QUALIFIER detail::tvec2 repeat ( detail::tvec2 const & Texcoord ) { detail::tvec2 Result; for(typename detail::tvec2::size_type i = 0; i < detail::tvec2::value_size(); ++i) Result[i] = repeat(Texcoord[i]); return Result; } template GLM_FUNC_QUALIFIER detail::tvec3 repeat ( detail::tvec3 const & Texcoord ) { detail::tvec3 Result; for(typename detail::tvec3::size_type i = 0; i < detail::tvec3::value_size(); ++i) Result[i] = repeat(Texcoord[i]); return Result; } template GLM_FUNC_QUALIFIER detail::tvec4 repeat ( detail::tvec4 const & Texcoord ) { detail::tvec4 Result; for(typename detail::tvec4::size_type i = 0; i < detail::tvec4::value_size(); ++i) Result[i] = repeat(Texcoord[i]); return Result; } //////////////////////// // mirrorRepeat template GLM_FUNC_QUALIFIER genType mirrorRepeat ( genType const & Texcoord ) { genType const Clamp = genType(int(glm::floor(Texcoord)) % 2); genType const Floor = glm::floor(Texcoord); genType const Rest = Texcoord - Floor; genType const Mirror = Clamp + Rest; genType Out; if(Mirror >= genType(1)) Out = genType(1) - Rest; else Out = Rest; return Out; } template GLM_FUNC_QUALIFIER detail::tvec2 mirrorRepeat ( detail::tvec2 const & Texcoord ) { detail::tvec2 Result; for(typename detail::tvec2::size_type i = 0; i < detail::tvec2::value_size(); ++i) Result[i] = mirrorRepeat(Texcoord[i]); return Result; } template GLM_FUNC_QUALIFIER detail::tvec3 mirrorRepeat ( detail::tvec3 const & Texcoord ) { detail::tvec3 Result; for(typename detail::tvec3::size_type i = 0; i < detail::tvec3::value_size(); ++i) Result[i] = mirrorRepeat(Texcoord[i]); return Result; } template GLM_FUNC_QUALIFIER detail::tvec4 mirrorRepeat ( detail::tvec4 const & Texcoord ) { detail::tvec4 Result; for(typename detail::tvec4::size_type i = 0; i < detail::tvec4::value_size(); ++i) Result[i] = mirrorRepeat(Texcoord[i]); return Result; } }//namespace wrap }//namespace gtx }//namespace glm