| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * $Id$ | 
					
						
							| 
									
										
										
										
											2008-04-16 22:40:48 +00:00
										 |  |  |  * ***** BEGIN GPL LICENSE BLOCK ***** | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is free software; you can redistribute it and/or | 
					
						
							|  |  |  |  * modify it under the terms of the GNU General Public License | 
					
						
							|  |  |  |  * as published by the Free Software Foundation; either version 2 | 
					
						
							| 
									
										
										
										
											2008-04-16 22:40:48 +00:00
										 |  |  |  * of the License, or (at your option) any later version. | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  |  * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  |  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  |  * GNU General Public License for more details. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * You should have received a copy of the GNU General Public License | 
					
						
							|  |  |  |  * along with this program; if not, write to the Free Software Foundation, | 
					
						
							|  |  |  |  * Inc., 59 Temple Place - Suite 330, Boston, MA  02111-1307, USA. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is: all of this file. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): none yet. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2008-04-16 22:40:48 +00:00
										 |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "RAS_TexVert.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-11-25 15:29:57 +00:00
										 |  |  | #ifdef HAVE_CONFIG_H
 | 
					
						
							|  |  |  | #include <config.h>
 | 
					
						
							|  |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-17 05:23:17 +00:00
										 |  |  | #define SHORT(x) short(x*32767.0)
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | RAS_TexVert::RAS_TexVert(const MT_Point3& xyz, | 
					
						
							|  |  |  | 						 const MT_Point2& uv, | 
					
						
							| 
									
										
										
										
											2007-01-07 04:39:39 +00:00
										 |  |  | 						 const MT_Point2& uv2, | 
					
						
							| 
									
										
										
										
											2006-02-13 05:45:32 +00:00
										 |  |  | 						 const MT_Vector4& tangent, | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 						 const unsigned int rgba, | 
					
						
							| 
									
										
										
										
											2004-06-30 13:41:19 +00:00
										 |  |  | 						 const MT_Vector3& normal, | 
					
						
							| 
									
										
										
										
											2008-07-10 12:47:20 +00:00
										 |  |  | 						 const short flag, | 
					
						
							|  |  |  | 						 const unsigned int origindex) | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	xyz.getValue(m_localxyz); | 
					
						
							|  |  |  | 	uv.getValue(m_uv1); | 
					
						
							| 
									
										
										
										
											2007-01-07 04:39:39 +00:00
										 |  |  | 	uv2.getValue(m_uv2); | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 	SetRGBA(rgba); | 
					
						
							| 
									
										
										
										
											2004-06-30 13:41:19 +00:00
										 |  |  | 	SetNormal(normal); | 
					
						
							| 
									
										
										
										
											2006-02-13 05:45:32 +00:00
										 |  |  | 	tangent.getValue(m_tangent); | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 	m_flag = flag; | 
					
						
							| 
									
										
										
										
											2008-07-10 12:47:20 +00:00
										 |  |  | 	m_origindex = origindex; | 
					
						
							| 
									
										
										
										
											2006-01-06 03:46:54 +00:00
										 |  |  | 	m_unit = 2; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const MT_Point3& RAS_TexVert::xyz() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	g_pt3.setValue(m_localxyz); | 
					
						
							|  |  |  | 	return g_pt3; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-05-30 11:09:46 +00:00
										 |  |  | void RAS_TexVert::SetRGBA(const MT_Vector4& rgba) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	unsigned char *colp = (unsigned char*) &m_rgba; | 
					
						
							| 
									
										
										
										
											2005-01-03 18:05:24 +00:00
										 |  |  | 	colp[0] = (unsigned char) (rgba[0]*255.0); | 
					
						
							|  |  |  | 	colp[1] = (unsigned char) (rgba[1]*255.0); | 
					
						
							|  |  |  | 	colp[2] = (unsigned char) (rgba[2]*255.0); | 
					
						
							|  |  |  | 	colp[3] = (unsigned char) (rgba[3]*255.0); | 
					
						
							| 
									
										
										
										
											2004-05-30 11:09:46 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-07-17 05:23:17 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | void RAS_TexVert::SetXYZ(const MT_Point3& xyz) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	xyz.getValue(m_localxyz); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void RAS_TexVert::SetUV(const MT_Point2& uv) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uv.getValue(m_uv1); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-06 03:46:54 +00:00
										 |  |  | void RAS_TexVert::SetUV2(const MT_Point2& uv) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	uv.getValue(m_uv2); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void RAS_TexVert::SetRGBA(const unsigned int rgba) | 
					
						
							|  |  |  | {  | 
					
						
							|  |  |  | 	m_rgba = rgba; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void RAS_TexVert::SetFlag(const short flag) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	m_flag = flag; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2006-01-06 03:46:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | void RAS_TexVert::SetUnit(const unsigned int u) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	m_unit = u<=TV_MAX?u:TV_MAX; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | void RAS_TexVert::SetNormal(const MT_Vector3& normal) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2004-06-30 13:41:19 +00:00
										 |  |  | 	normal.getValue(m_normal); | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // compare two vertices, and return TRUE if both are almost identical (they can be shared)
 | 
					
						
							|  |  |  | bool RAS_TexVert::closeTo(const RAS_TexVert* other) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2004-05-16 12:55:37 +00:00
										 |  |  | 	return (m_flag == other->m_flag && | 
					
						
							|  |  |  | 		m_rgba == other->m_rgba && | 
					
						
							| 
									
										
										
										
											2004-06-30 13:41:19 +00:00
										 |  |  | 		MT_fuzzyEqual(MT_Vector3(m_normal), MT_Vector3(other->m_normal)) && | 
					
						
							|  |  |  | 		MT_fuzzyEqual(MT_Vector2(m_uv1), MT_Vector2(other->m_uv1)) && | 
					
						
							| 
									
										
										
										
											2007-01-07 04:39:39 +00:00
										 |  |  | 		MT_fuzzyEqual(MT_Vector2(m_uv2), MT_Vector2(other->m_uv2)) && // p --
 | 
					
						
							| 
									
										
										
										
											2004-06-30 13:41:19 +00:00
										 |  |  | 		MT_fuzzyEqual(MT_Vector3(m_localxyz), MT_Vector3(other->m_localxyz))) ; | 
					
						
							| 
									
										
										
										
											2002-10-12 11:37:38 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | short RAS_TexVert::getFlag() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return m_flag; | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2004-03-22 22:02:18 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-01-06 03:46:54 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | unsigned int RAS_TexVert::getUnit() const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	return m_unit; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-03-22 22:02:18 +00:00
										 |  |  | void RAS_TexVert::getOffsets(void* &xyz, void* &uv1, void* &rgba, void* &normal) const | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	xyz = (void *) m_localxyz; | 
					
						
							|  |  |  | 	uv1 = (void *) m_uv1; | 
					
						
							| 
									
										
										
										
											2004-06-30 13:41:19 +00:00
										 |  |  | 	rgba = (void *) &m_rgba; | 
					
						
							| 
									
										
										
										
											2004-03-22 22:02:18 +00:00
										 |  |  | 	normal = (void *) m_normal; | 
					
						
							|  |  |  | } |