mirror of
				https://github.com/nicbarker/clay.git
				synced 2025-11-04 08:36:17 +00:00 
			
		
		
		
	[Core] Fixed a bug where Clay_Hovered didn't work with explicit IDs
This commit is contained in:
		
							parent
							
								
									9d940c1f8e
								
							
						
					
					
						commit
						95fcd85a2a
					
				
							
								
								
									
										22
									
								
								clay.h
									
									
									
									
									
								
							
							
						
						
									
										22
									
								
								clay.h
									
									
									
									
									
								
							| 
						 | 
					@ -801,6 +801,7 @@ typedef struct { // todo get this struct into a single cache line
 | 
				
			||||||
    intptr_t hoverFunctionUserData;
 | 
					    intptr_t hoverFunctionUserData;
 | 
				
			||||||
    int32_t nextIndex;
 | 
					    int32_t nextIndex;
 | 
				
			||||||
    uint32_t generation;
 | 
					    uint32_t generation;
 | 
				
			||||||
 | 
					    uint32_t idAlias;
 | 
				
			||||||
    Clay__DebugElementData *debugData;
 | 
					    Clay__DebugElementData *debugData;
 | 
				
			||||||
} Clay_LayoutElementHashMapItem;
 | 
					} Clay_LayoutElementHashMapItem;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1210,12 +1211,12 @@ bool Clay__PointIsInsideRect(Clay_Vector2 point, Clay_BoundingBox rect) {
 | 
				
			||||||
    return point.x >= rect.x && point.x <= rect.x + rect.width && point.y >= rect.y && point.y <= rect.y + rect.height;
 | 
					    return point.x >= rect.x && point.x <= rect.x + rect.width && point.y >= rect.y && point.y <= rect.y + rect.height;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Clay_LayoutElementHashMapItem* Clay__AddHashMapItem(Clay_ElementId elementId, Clay_LayoutElement* layoutElement) {
 | 
					Clay_LayoutElementHashMapItem* Clay__AddHashMapItem(Clay_ElementId elementId, Clay_LayoutElement* layoutElement, uint32_t idAlias) {
 | 
				
			||||||
    Clay_Context* context = Clay_GetCurrentContext();
 | 
					    Clay_Context* context = Clay_GetCurrentContext();
 | 
				
			||||||
    if (context->layoutElementsHashMapInternal.length == context->layoutElementsHashMapInternal.capacity - 1) {
 | 
					    if (context->layoutElementsHashMapInternal.length == context->layoutElementsHashMapInternal.capacity - 1) {
 | 
				
			||||||
        return NULL;
 | 
					        return NULL;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    Clay_LayoutElementHashMapItem item = { .elementId = elementId, .layoutElement = layoutElement, .nextIndex = -1, .generation = context->generation + 1 };
 | 
					    Clay_LayoutElementHashMapItem item = { .elementId = elementId, .layoutElement = layoutElement, .nextIndex = -1, .generation = context->generation + 1, .idAlias = idAlias };
 | 
				
			||||||
    uint32_t hashBucket = elementId.id % context->layoutElementsHashMap.capacity;
 | 
					    uint32_t hashBucket = elementId.id % context->layoutElementsHashMap.capacity;
 | 
				
			||||||
    int32_t hashItemPrevious = -1;
 | 
					    int32_t hashItemPrevious = -1;
 | 
				
			||||||
    int32_t hashItemIndex = context->layoutElementsHashMap.internalArray[hashBucket];
 | 
					    int32_t hashItemIndex = context->layoutElementsHashMap.internalArray[hashBucket];
 | 
				
			||||||
| 
						 | 
					@ -1271,7 +1272,7 @@ void Clay__GenerateIdForAnonymousElement(Clay_LayoutElement *openLayoutElement)
 | 
				
			||||||
    Clay_LayoutElement *parentElement = Clay_LayoutElementArray_Get(&context->layoutElements, Clay__int32_tArray_GetValue(&context->openLayoutElementStack, context->openLayoutElementStack.length - 2));
 | 
					    Clay_LayoutElement *parentElement = Clay_LayoutElementArray_Get(&context->layoutElements, Clay__int32_tArray_GetValue(&context->openLayoutElementStack, context->openLayoutElementStack.length - 2));
 | 
				
			||||||
    Clay_ElementId elementId = Clay__HashNumber(parentElement->childrenOrTextContent.children.length, parentElement->id);
 | 
					    Clay_ElementId elementId = Clay__HashNumber(parentElement->childrenOrTextContent.children.length, parentElement->id);
 | 
				
			||||||
    openLayoutElement->id = elementId.id;
 | 
					    openLayoutElement->id = elementId.id;
 | 
				
			||||||
    Clay__AddHashMapItem(elementId, openLayoutElement);
 | 
					    Clay__AddHashMapItem(elementId, openLayoutElement, 0);
 | 
				
			||||||
    Clay__StringArray_Add(&context->layoutElementIdStrings, elementId.stringId);
 | 
					    Clay__StringArray_Add(&context->layoutElementIdStrings, elementId.stringId);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -1483,7 +1484,7 @@ void Clay__OpenTextElement(Clay_String text, Clay_TextElementConfig *textConfig)
 | 
				
			||||||
    Clay__MeasureTextCacheItem *textMeasured = Clay__MeasureTextCached(&text, textConfig);
 | 
					    Clay__MeasureTextCacheItem *textMeasured = Clay__MeasureTextCached(&text, textConfig);
 | 
				
			||||||
    Clay_ElementId elementId = Clay__HashNumber(parentElement->childrenOrTextContent.children.length, parentElement->id);
 | 
					    Clay_ElementId elementId = Clay__HashNumber(parentElement->childrenOrTextContent.children.length, parentElement->id);
 | 
				
			||||||
    textElement->id = elementId.id;
 | 
					    textElement->id = elementId.id;
 | 
				
			||||||
    Clay__AddHashMapItem(elementId, textElement);
 | 
					    Clay__AddHashMapItem(elementId, textElement, 0);
 | 
				
			||||||
    Clay__StringArray_Add(&context->layoutElementIdStrings, elementId.stringId);
 | 
					    Clay__StringArray_Add(&context->layoutElementIdStrings, elementId.stringId);
 | 
				
			||||||
    Clay_Dimensions textDimensions = { .width = textMeasured->unwrappedDimensions.width, .height = textConfig->lineHeight > 0 ? (float)textConfig->lineHeight : textMeasured->unwrappedDimensions.height };
 | 
					    Clay_Dimensions textDimensions = { .width = textMeasured->unwrappedDimensions.width, .height = textConfig->lineHeight > 0 ? (float)textConfig->lineHeight : textMeasured->unwrappedDimensions.height };
 | 
				
			||||||
    textElement->dimensions = textDimensions;
 | 
					    textElement->dimensions = textDimensions;
 | 
				
			||||||
| 
						 | 
					@ -2184,6 +2185,12 @@ void Clay__CalculateFinalLayout(void) {
 | 
				
			||||||
                Clay_LayoutElementHashMapItem *hashMapItem = Clay__GetHashMapItem(currentElement->id);
 | 
					                Clay_LayoutElementHashMapItem *hashMapItem = Clay__GetHashMapItem(currentElement->id);
 | 
				
			||||||
                if (hashMapItem) {
 | 
					                if (hashMapItem) {
 | 
				
			||||||
                    hashMapItem->boundingBox = currentElementBoundingBox;
 | 
					                    hashMapItem->boundingBox = currentElementBoundingBox;
 | 
				
			||||||
 | 
					                    if (hashMapItem->idAlias) {
 | 
				
			||||||
 | 
					                        Clay_LayoutElementHashMapItem *hashMapItemAlias = Clay__GetHashMapItem(hashMapItem->idAlias);
 | 
				
			||||||
 | 
					                        if (hashMapItemAlias) {
 | 
				
			||||||
 | 
					                            hashMapItemAlias->boundingBox = currentElementBoundingBox;
 | 
				
			||||||
 | 
					                        }
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
 | 
					
 | 
				
			||||||
                int32_t sortedConfigIndexes[20];
 | 
					                int32_t sortedConfigIndexes[20];
 | 
				
			||||||
| 
						 | 
					@ -2512,8 +2519,9 @@ Clay_ElementId Clay__AttachId(Clay_ElementId elementId) {
 | 
				
			||||||
        return Clay_ElementId_DEFAULT;
 | 
					        return Clay_ElementId_DEFAULT;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
    Clay_LayoutElement *openLayoutElement = Clay__GetOpenLayoutElement();
 | 
					    Clay_LayoutElement *openLayoutElement = Clay__GetOpenLayoutElement();
 | 
				
			||||||
 | 
					    uint32_t idAlias = openLayoutElement->id;
 | 
				
			||||||
    openLayoutElement->id = elementId.id;
 | 
					    openLayoutElement->id = elementId.id;
 | 
				
			||||||
    Clay__AddHashMapItem(elementId, openLayoutElement);
 | 
					    Clay__AddHashMapItem(elementId, openLayoutElement, idAlias);
 | 
				
			||||||
    Clay__StringArray_Add(&context->layoutElementIdStrings, elementId.stringId);
 | 
					    Clay__StringArray_Add(&context->layoutElementIdStrings, elementId.stringId);
 | 
				
			||||||
    return elementId;
 | 
					    return elementId;
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -3254,6 +3262,10 @@ void Clay_SetPointerState(Clay_Vector2 position, bool isPointerDown) {
 | 
				
			||||||
                    }
 | 
					                    }
 | 
				
			||||||
                    Clay__ElementIdArray_Add(&context->pointerOverIds, mapItem->elementId);
 | 
					                    Clay__ElementIdArray_Add(&context->pointerOverIds, mapItem->elementId);
 | 
				
			||||||
                    found = true;
 | 
					                    found = true;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					                    if (mapItem->idAlias != 0) {
 | 
				
			||||||
 | 
					                        Clay__ElementIdArray_Add(&context->pointerOverIds, CLAY__INIT(Clay_ElementId) { .id = mapItem->idAlias });
 | 
				
			||||||
 | 
					                    }
 | 
				
			||||||
                }
 | 
					                }
 | 
				
			||||||
                if (Clay__ElementHasConfig(currentElement, CLAY__ELEMENT_CONFIG_TYPE_TEXT)) {
 | 
					                if (Clay__ElementHasConfig(currentElement, CLAY__ELEMENT_CONFIG_TYPE_TEXT)) {
 | 
				
			||||||
                    dfsBuffer.length--;
 | 
					                    dfsBuffer.length--;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
		Reference in a new issue