mirror of
				https://github.com/ocornut/imgui.git
				synced 2025-10-26 12:27:30 +00:00 
			
		
		
		
	Tables: demo inner_size + scrollx + stretch, added TableGetRowIndex(), renamed _WidthAlwaysAutoResize to _WidthAutoResize.
This commit is contained in:
		| @@ -567,14 +567,14 @@ static ImGuiTableColumnFlags TableFixColumnFlags(ImGuiTable* table, ImGuiTableCo | ||||
|     // Sizing Policy | ||||
|     if ((flags & ImGuiTableColumnFlags_WidthMask_) == 0) | ||||
|     { | ||||
|         // FIXME-TABLE: Inconsistent to promote columns to WidthAlwaysAutoResize | ||||
|         // FIXME-TABLE: Inconsistent to promote columns to WidthAutoResize | ||||
|         if (table->Flags & ImGuiTableFlags_SizingPolicyFixedX) | ||||
|             flags |= ((table->Flags & ImGuiTableFlags_Resizable) && !(flags & ImGuiTableColumnFlags_NoResize)) ? ImGuiTableColumnFlags_WidthFixed : ImGuiTableColumnFlags_WidthAlwaysAutoResize; | ||||
|             flags |= ((table->Flags & ImGuiTableFlags_Resizable) && !(flags & ImGuiTableColumnFlags_NoResize)) ? ImGuiTableColumnFlags_WidthFixed : ImGuiTableColumnFlags_WidthAutoResize; | ||||
|         else | ||||
|             flags |= ImGuiTableColumnFlags_WidthStretch; | ||||
|     } | ||||
|     IM_ASSERT(ImIsPowerOfTwo(flags & ImGuiTableColumnFlags_WidthMask_)); // Check that only 1 of each set is used. | ||||
|     if ((flags & ImGuiTableColumnFlags_WidthAlwaysAutoResize))// || ((flags & ImGuiTableColumnFlags_WidthStretch) && (table->Flags & ImGuiTableFlags_SizingPolicyStretchX))) | ||||
|     if (flags & ImGuiTableColumnFlags_WidthAutoResize) | ||||
|         flags |= ImGuiTableColumnFlags_NoResize; | ||||
|     //if ((flags & ImGuiTableColumnFlags_WidthStretch) && (table->Flags & ImGuiTableFlags_SizingPolicyFixedX)) | ||||
|     //    flags = (flags & ~ImGuiTableColumnFlags_WidthMask_) | ImGuiTableColumnFlags_WidthFixed; | ||||
| @@ -614,9 +614,9 @@ static float TableGetMinColumnWidth() | ||||
|  | ||||
| // Layout columns for the frame | ||||
| // Runs on the first call to TableNextRow(), to give a chance for TableSetupColumn() to be called first. | ||||
| // FIXME-TABLE: Our width (and therefore our WorkRect) will be minimal in the first frame for WidthAlwaysAutoResize | ||||
| // FIXME-TABLE: Our width (and therefore our WorkRect) will be minimal in the first frame for WidthAutoResize | ||||
| // columns, increase feedback side-effect with widgets relying on WorkRect.Max.x. Maybe provide a default distribution | ||||
| // for WidthAlwaysAutoResize columns? | ||||
| // for WidthAutoResize columns? | ||||
| void    ImGui::TableUpdateLayout(ImGuiTable* table) | ||||
| { | ||||
|     ImGuiContext& g = *GImGui; | ||||
| @@ -669,11 +669,11 @@ void    ImGui::TableUpdateLayout(ImGuiTable* table) | ||||
|  | ||||
|         column->WidthAuto = width_auto; | ||||
|  | ||||
|         if (column->Flags & (ImGuiTableColumnFlags_WidthAlwaysAutoResize | ImGuiTableColumnFlags_WidthFixed)) | ||||
|         if (column->Flags & (ImGuiTableColumnFlags_WidthFixed | ImGuiTableColumnFlags_WidthAutoResize)) | ||||
|         { | ||||
|             // Process auto-fit for non-stretched columns | ||||
|             // Latch initial size for fixed columns and update it constantly for auto-resizing column (unless clipped!) | ||||
|             if ((column->AutoFitQueue != 0x00) || ((column->Flags & ImGuiTableColumnFlags_WidthAlwaysAutoResize) && !column->IsClipped)) | ||||
|             if ((column->AutoFitQueue != 0x00) || ((column->Flags & ImGuiTableColumnFlags_WidthAutoResize) && !column->IsClipped)) | ||||
|                 column->WidthRequest = width_auto; | ||||
|  | ||||
|             // FIXME-TABLE: Increase minimum size during init frame to avoid biasing auto-fitting widgets | ||||
| @@ -847,7 +847,7 @@ void    ImGui::TableUpdateLayout(ImGuiTable* table) | ||||
|  | ||||
|         column->IsClipped = (column->ClipRect.Max.x <= column->ClipRect.Min.x) && (column->AutoFitQueue & 1) == 0 && (column->CannotSkipItemsQueue & 1) == 0; | ||||
|         if (column->IsClipped) | ||||
|             table->VisibleUnclippedMaskByIndex &= ~((ImU64)1 << column_n);  // Columns with the _WidthAlwaysAutoResize sizing policy will never be updated then. | ||||
|             table->VisibleUnclippedMaskByIndex &= ~((ImU64)1 << column_n);  // Columns with the _WidthAutoResize sizing policy will never be updated then. | ||||
|  | ||||
|         column->IsSkipItems = !column->IsVisible || table->HostSkipItems; | ||||
|  | ||||
| @@ -893,7 +893,7 @@ void    ImGui::TableUpdateLayout(ImGuiTable* table) | ||||
|     } | ||||
|  | ||||
|     // Clear Resizable flag if none of our column are actually resizable (either via an explicit _NoResize flag, | ||||
|     // either because of using _WidthAlwaysAutoResize/_WidthStretch). | ||||
|     // either because of using _WidthAutoResize/_WidthStretch). | ||||
|     // This will hide the resizing option from the context menu. | ||||
|     if (count_resizable == 0 && (table->Flags & ImGuiTableFlags_Resizable)) | ||||
|         table->Flags &= ~ImGuiTableFlags_Resizable; | ||||
| @@ -1621,7 +1621,7 @@ void    ImGui::TableSetupColumn(const char* label, ImGuiTableColumnFlags flags, | ||||
|     table->DeclColumnsCount++; | ||||
|  | ||||
|     // When passing a width automatically enforce WidthFixed policy | ||||
|     // (vs TableFixColumnFlags would default to WidthAlwaysAutoResize) | ||||
|     // (vs TableFixColumnFlags would default to WidthAutoResize) | ||||
|     // (we write to FlagsIn which is a little misleading, another solution would be to pass init_width_or_weight to TableFixColumnFlags) | ||||
|     if ((flags & ImGuiTableColumnFlags_WidthMask_) == 0) | ||||
|         if ((table->Flags & ImGuiTableFlags_SizingPolicyFixedX) && (init_width_or_weight > 0.0f)) | ||||
| @@ -2023,6 +2023,15 @@ int     ImGui::TableGetColumnIndex() | ||||
|     return table->CurrentColumn; | ||||
| } | ||||
|  | ||||
| int     ImGui::TableGetRowIndex() | ||||
| { | ||||
|     ImGuiContext& g = *GImGui; | ||||
|     ImGuiTable* table = g.CurrentTable; | ||||
|     if (!table) | ||||
|         return 0; | ||||
|     return table->CurrentRow; | ||||
| } | ||||
|  | ||||
| // Return the cell rectangle based on currently known height. | ||||
| // - Important: we generally don't know our row height until the end of the row, so Max.y will be incorrect in many situations. | ||||
| //   The only case where this is correct is if we provided a min_row_height to TableNextRow() and don't go below it. | ||||
| @@ -3019,9 +3028,9 @@ void ImGui::DebugNodeTable(ImGuiTable* table) | ||||
|             column->ContentMaxXFrozen - column->WorkMinX, column->ContentMaxXUnfrozen - column->WorkMinX, column->ContentMaxXHeadersUsed - column->WorkMinX, column->ContentMaxXHeadersIdeal - column->WorkMinX, | ||||
|             column->SortOrder, (column->SortDirection == ImGuiSortDirection_Ascending) ? "Ascending" : (column->SortDirection == ImGuiSortDirection_Descending) ? "Descending" : "None", | ||||
|             column->UserID, column->Flags, | ||||
|             (column->Flags & ImGuiTableColumnFlags_WidthFixed) ? "WidthFixed " : "", | ||||
|             (column->Flags & ImGuiTableColumnFlags_WidthStretch) ? "WidthStretch " : "", | ||||
|             (column->Flags & ImGuiTableColumnFlags_WidthAlwaysAutoResize) ? "WidthAlwaysAutoResize " : "", | ||||
|             (column->Flags & ImGuiTableColumnFlags_WidthFixed) ? "WidthFixed " : "", | ||||
|             (column->Flags & ImGuiTableColumnFlags_WidthAutoResize) ? "WidthAutoResize " : "", | ||||
|             (column->Flags & ImGuiTableColumnFlags_NoResize) ? "NoResize " : ""); | ||||
|         Bullet(); | ||||
|         Selectable(buf); | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 ocornut
					ocornut