mirror of
				https://github.com/isledecomp/isle.git
				synced 2025-10-26 09:54:18 +00:00 
			
		
		
		
	Implement LegoTextureContainer::Insert (#589)
* WIP * Fix * Fix * Match * Match
This commit is contained in:
		 Christian Semmler
					Christian Semmler
				
			
				
					committed by
					
						 GitHub
						GitHub
					
				
			
			
				
	
			
			
			 GitHub
						GitHub
					
				
			
						parent
						
							51520aaae6
						
					
				
				
					commit
					9d0ff0425c
				
			| @@ -1,5 +1,9 @@ | ||||
| #include "legocontainer.h" | ||||
| 
 | ||||
| #include "lego/legoomni/include/legoomni.h" | ||||
| #include "lego/legoomni/include/legovideomanager.h" | ||||
| #include "tgl/d3drm/impl.h" | ||||
| 
 | ||||
| DECOMP_SIZE_ASSERT(LegoContainerInfo<LegoTexture>, 0x10); | ||||
| // DECOMP_SIZE_ASSERT(LegoContainer<LegoTexture>, 0x18);
 | ||||
| DECOMP_SIZE_ASSERT(LegoTextureContainer, 0x24); | ||||
| @@ -9,16 +13,106 @@ LegoTextureContainer::~LegoTextureContainer() | ||||
| { | ||||
| } | ||||
| 
 | ||||
| // STUB: LEGO1 0x100998e0
 | ||||
| LegoTextureInfo* LegoTextureContainer::Create(undefined* p_und) | ||||
| // FUNCTION: LEGO1 0x100998e0
 | ||||
| LegoTextureInfo* LegoTextureContainer::Insert(LegoTextureInfo* p_textureInfo) | ||||
| { | ||||
| 	DDSURFACEDESC desc, newDesc; | ||||
| 	DWORD width, height; | ||||
| 	memset(&desc, 0, sizeof(desc)); | ||||
| 	desc.dwSize = sizeof(desc); | ||||
| 
 | ||||
| 	if (p_textureInfo->m_surface->Lock(NULL, &desc, DDLOCK_SURFACEMEMORYPTR, NULL) == DD_OK) { | ||||
| 		width = desc.dwWidth; | ||||
| 		height = desc.dwHeight; | ||||
| 		p_textureInfo->m_surface->Unlock(desc.lpSurface); | ||||
| 	} | ||||
| 
 | ||||
| 	for (LegoTextureList::iterator it = m_list.begin(); it != m_list.end(); it++) { | ||||
| 		if ((*it).second == FALSE && (*it).first->m_texture->AddRef() != 0 && (*it).first->m_texture->Release() == 1) { | ||||
| 			if (!strcmp((*it).first->m_name, p_textureInfo->m_name)) { | ||||
| 				memset(&newDesc, 0, sizeof(newDesc)); | ||||
| 				newDesc.dwSize = sizeof(newDesc); | ||||
| 
 | ||||
| 				if ((*it).first->m_surface->Lock(NULL, &newDesc, DDLOCK_SURFACEMEMORYPTR, NULL) == DD_OK) { | ||||
| 					BOOL und = FALSE; | ||||
| 					if (newDesc.dwWidth == width && newDesc.dwHeight == height) { | ||||
| 						und = TRUE; | ||||
| 					} | ||||
| 
 | ||||
| 					(*it).first->m_surface->Unlock(newDesc.lpSurface); | ||||
| 
 | ||||
| 					if (und) { | ||||
| 						(*it).second = TRUE; | ||||
| 						(*it).first->m_texture->AddRef(); | ||||
| 						return (*it).first; | ||||
| 					} | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	LegoTextureInfo* textureInfo = new LegoTextureInfo(); | ||||
| 
 | ||||
| 	textureInfo->m_palette = p_textureInfo->m_palette; | ||||
| 	p_textureInfo->m_palette->Release(); | ||||
| 
 | ||||
| 	memset(&newDesc, 0, sizeof(newDesc)); | ||||
| 	newDesc.dwWidth = desc.dwWidth; | ||||
| 	newDesc.dwHeight = desc.dwHeight; | ||||
| 	newDesc.dwSize = sizeof(newDesc); | ||||
| 	newDesc.dwFlags = DDSD_PIXELFORMAT | DDSD_WIDTH | DDSD_HEIGHT | DDSD_CAPS; | ||||
| 	newDesc.ddsCaps.dwCaps = DDCAPS_OVERLAYCANTCLIP | DDCAPS_OVERLAY; | ||||
| 	newDesc.ddpfPixelFormat.dwSize = sizeof(desc.ddpfPixelFormat); | ||||
| 	newDesc.ddpfPixelFormat.dwFlags = DDPF_RGB | DDPF_PALETTEINDEXED8; | ||||
| 	newDesc.ddpfPixelFormat.dwRGBBitCount = 8; | ||||
| 
 | ||||
| 	if (VideoManager()->GetDirect3D()->DirectDraw()->CreateSurface(&newDesc, &textureInfo->m_surface, NULL) == DD_OK) { | ||||
| 		RECT rect; | ||||
| 		rect.left = 0; | ||||
| 		rect.top = newDesc.dwWidth - 1; | ||||
| 		rect.right = 0; | ||||
| 		rect.bottom = newDesc.dwHeight - 1; | ||||
| 
 | ||||
| 		textureInfo->m_surface->SetPalette(textureInfo->m_palette); | ||||
| 
 | ||||
| 		if (textureInfo->m_surface->BltFast(0, 0, p_textureInfo->m_surface, &rect, DDBLTFAST_WAIT) != DD_OK) { | ||||
| 			textureInfo->m_surface->Release(); | ||||
| 			textureInfo->m_palette->Release(); | ||||
| 			delete textureInfo; | ||||
| 			return NULL; | ||||
| 		} | ||||
| 		else { | ||||
| 			if (((TglImpl::RendererImpl*) VideoManager()->GetRenderer()) | ||||
| 					->CreateTextureFromSurface(textureInfo->m_surface, &textureInfo->m_texture) != D3DRM_OK) { | ||||
| 				textureInfo->m_surface->Release(); | ||||
| 				textureInfo->m_palette->Release(); | ||||
| 				delete textureInfo; | ||||
| 				return NULL; | ||||
| 			} | ||||
| 			else { | ||||
| 				textureInfo->m_texture->SetAppData((DWORD) textureInfo); | ||||
| 				m_list.push_back(LegoTextureListElement(textureInfo, TRUE)); | ||||
| 
 | ||||
| 				textureInfo->m_texture->AddRef(); | ||||
| 
 | ||||
| 				if (textureInfo->m_name != NULL) { | ||||
| 					delete[] textureInfo->m_name; | ||||
| 				} | ||||
| 
 | ||||
| 				textureInfo->m_name = new char[strlen(p_textureInfo->m_name) + 1]; | ||||
| 				strcpy(textureInfo->m_name, p_textureInfo->m_name); | ||||
| 				return textureInfo; | ||||
| 			} | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	return NULL; | ||||
| } | ||||
| 
 | ||||
| // FUNCTION: LEGO1 0x10099cc0
 | ||||
| void LegoTextureContainer::Destroy(LegoTextureInfo* p_data) | ||||
| void LegoTextureContainer::Erase(LegoTextureInfo* p_textureInfo) | ||||
| { | ||||
| 	if (p_data == NULL) { | ||||
| 	if (p_textureInfo == NULL) { | ||||
| 		return; | ||||
| 	} | ||||
| 
 | ||||
| @@ -28,12 +122,11 @@ void LegoTextureContainer::Destroy(LegoTextureInfo* p_data) | ||||
| #else | ||||
| 	for (LegoTextureList::iterator it = m_list.begin(); it != m_list.end(); it++) { | ||||
| #endif | ||||
| 		if (((*it).first) == p_data) { | ||||
| 			// TODO: Element type
 | ||||
| 			(*it).second = 0; | ||||
| 		if ((*it).first == p_textureInfo) { | ||||
| 			(*it).second = FALSE; | ||||
| 
 | ||||
| 			if (p_data->m_texture->Release() == TRUE) { | ||||
| 				delete p_data; | ||||
| 			if (p_textureInfo->m_texture->Release() == TRUE) { | ||||
| 				delete p_textureInfo; | ||||
| 				m_list.erase(it); | ||||
| 			} | ||||
| 
 | ||||
|   | ||||
| @@ -67,7 +67,7 @@ protected: | ||||
| // class LegoContainer<LegoTextureInfo>
 | ||||
| 
 | ||||
| // TODO: Element type
 | ||||
| typedef pair<LegoTextureInfo*, undefined4> LegoTextureListElement; | ||||
| typedef pair<LegoTextureInfo*, BOOL> LegoTextureListElement; | ||||
| typedef list<LegoTextureListElement> LegoTextureList; | ||||
| 
 | ||||
| // VTABLE: LEGO1 0x100d86fc
 | ||||
| @@ -77,8 +77,8 @@ public: | ||||
| 	LegoTextureContainer() { m_ownership = TRUE; } | ||||
| 	~LegoTextureContainer() override; | ||||
| 
 | ||||
| 	LegoTextureInfo* Create(undefined* p_und); | ||||
| 	void Destroy(LegoTextureInfo* p_data); | ||||
| 	LegoTextureInfo* Insert(LegoTextureInfo* p_textureInfo); | ||||
| 	void Erase(LegoTextureInfo* p_textureInfo); | ||||
| 
 | ||||
| protected: | ||||
| 	LegoTextureList m_list; // 0x18
 | ||||
| @@ -119,7 +119,7 @@ protected: | ||||
| // _Tree<char const *,pair<char const * const,LegoTextureInfo *>,map<char const *,LegoTextureInfo *,LegoContainerInfoComparator,allocator<LegoTextureInfo *> >::_Kfn,LegoContainerInfoComparator,allocator<LegoTextureInfo *> >::_Erase
 | ||||
| 
 | ||||
| // TEMPLATE: LEGO1 0x1005a250
 | ||||
| // list<pair<LegoTextureInfo *,unsigned int>,allocator<pair<LegoTextureInfo *,unsigned int> > >::~list<pair<LegoTextureInfo *,unsigned int>,allocator<pair<LegoTextureInfo *,unsigned int> > >
 | ||||
| // list<pair<LegoTextureInfo *,int>,allocator<pair<LegoTextureInfo *,int> > >::~list<pair<LegoTextureInfo *,int>,allocator<pair<LegoTextureInfo *,int> > >
 | ||||
| 
 | ||||
| // TEMPLATE: LEGO1 0x1005a2c0
 | ||||
| // map<char const *,LegoTextureInfo *,LegoContainerInfoComparator,allocator<LegoTextureInfo *> >::~map<char const *,LegoTextureInfo *,LegoContainerInfoComparator,allocator<LegoTextureInfo *> >
 | ||||
| @@ -137,7 +137,7 @@ protected: | ||||
| // LegoTextureContainer::`scalar deleting destructor'
 | ||||
| 
 | ||||
| // TEMPLATE: LEGO1 0x1005a5a0
 | ||||
| // List<pair<LegoTextureInfo *,unsigned int> >::~List<pair<LegoTextureInfo *,unsigned int> >
 | ||||
| // List<pair<LegoTextureInfo *,int> >::~List<pair<LegoTextureInfo *,int> >
 | ||||
| 
 | ||||
| // TEMPLATE: LEGO1 0x1005b660
 | ||||
| // LegoContainer<LegoTextureInfo>::~LegoContainer<LegoTextureInfo>
 | ||||
|   | ||||
		Reference in New Issue
	
	Block a user