|  | @@ -42,6 +42,7 @@ type
 | 
											
												
													
														|  |      function GetVisible(Index: Integer): Boolean;
 |  |      function GetVisible(Index: Integer): Boolean;
 | 
											
												
													
														|  |      function GetWidths(Index: Integer): Integer;
 |  |      function GetWidths(Index: Integer): Integer;
 | 
											
												
													
														|  |      procedure SetAlignments(Index: Integer; Value: TAlignment);
 |  |      procedure SetAlignments(Index: Integer; Value: TAlignment);
 | 
											
												
													
														|  | 
 |  | +    procedure SetVisibleInternal(Index: Integer; Value: Boolean; SaveWidth: Boolean);
 | 
											
												
													
														|  |      procedure SetVisible(Index: Integer; Value: Boolean);
 |  |      procedure SetVisible(Index: Integer; Value: Boolean);
 | 
											
												
													
														|  |      procedure SetWidths(Index: Integer; Value: Integer);
 |  |      procedure SetWidths(Index: Integer; Value: Integer);
 | 
											
												
													
														|  |      function GetCaptions(Index: Integer): string;
 |  |      function GetCaptions(Index: Integer): string;
 | 
											
										
											
												
													
														|  | @@ -146,6 +147,7 @@ var
 | 
											
												
													
														|  |    ColStr: string;
 |  |    ColStr: string;
 | 
											
												
													
														|  |    Index: Integer;
 |  |    Index: Integer;
 | 
											
												
													
														|  |    NeedInvalidate, NewVisible: Boolean;
 |  |    NeedInvalidate, NewVisible: Boolean;
 | 
											
												
													
														|  | 
 |  | +  NewWidth: Integer;
 | 
											
												
													
														|  |  begin
 |  |  begin
 | 
											
												
													
														|  |    Index := 0;
 |  |    Index := 0;
 | 
											
												
													
														|  |    NeedInvalidate := False;
 |  |    NeedInvalidate := False;
 | 
											
										
											
												
													
														|  | @@ -154,11 +156,14 @@ begin
 | 
											
												
													
														|  |      while (Value <> '') and (Index < Count) do
 |  |      while (Value <> '') and (Index < Count) do
 | 
											
												
													
														|  |      begin
 |  |      begin
 | 
											
												
													
														|  |        ColStr := CutToChar(Value, ';', True);
 |  |        ColStr := CutToChar(Value, ';', True);
 | 
											
												
													
														|  | -      Widths[Index] := LoadDimension(StrToInt(CutToChar(ColStr, ',', True)), PixelsPerInch, FListView);
 |  | 
 | 
											
												
													
														|  | 
 |  | +      NewWidth := LoadDimension(StrToInt(CutToChar(ColStr, ',', True)), PixelsPerInch, FListView);
 | 
											
												
													
														|  | 
 |  | +      Widths[Index] := NewWidth;
 | 
											
												
													
														|  |        NewVisible := Boolean(StrToInt(CutToChar(ColStr, ',', True)));
 |  |        NewVisible := Boolean(StrToInt(CutToChar(ColStr, ',', True)));
 | 
											
												
													
														|  |        if Visible[Index] <> NewVisible then
 |  |        if Visible[Index] <> NewVisible then
 | 
											
												
													
														|  |        begin
 |  |        begin
 | 
											
												
													
														|  | -        Visible[Index] := NewVisible;
 |  | 
 | 
											
												
													
														|  | 
 |  | +        // As we are within BeginUpdate guard, the width set just above is not propadated to WinAPI.
 | 
											
												
													
														|  | 
 |  | +        // As reading width retrieves it from WinAPI (if the control is already allocated), we actually save wrong width.
 | 
											
												
													
														|  | 
 |  | +        SetVisibleInternal(Index, NewVisible, False);
 | 
											
												
													
														|  |          NeedInvalidate := True;
 |  |          NeedInvalidate := True;
 | 
											
												
													
														|  |        end;
 |  |        end;
 | 
											
												
													
														|  |        Inc(Index);
 |  |        Inc(Index);
 | 
											
										
											
												
													
														|  | @@ -351,7 +356,7 @@ begin
 | 
											
												
													
														|  |    SetOrderStr(OrderStr);
 |  |    SetOrderStr(OrderStr);
 | 
											
												
													
														|  |  end;
 |  |  end;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -procedure TCustomListViewColProperties.SetVisible(Index: Integer; Value: Boolean);
 |  | 
 | 
											
												
													
														|  | 
 |  | +procedure TCustomListViewColProperties.SetVisibleInternal(Index: Integer; Value: Boolean; SaveWidth: Boolean);
 | 
											
												
													
														|  |  var
 |  |  var
 | 
											
												
													
														|  |    I: Integer;
 |  |    I: Integer;
 | 
											
												
													
														|  |    Properties: TCustomListViewColProperty;
 |  |    Properties: TCustomListViewColProperty;
 | 
											
										
											
												
													
														|  | @@ -381,7 +386,7 @@ begin
 | 
											
												
													
														|  |        Properties.Visible := True;
 |  |        Properties.Visible := True;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |        if ColumnsExists then
 |  |        if ColumnsExists then
 | 
											
												
													
														|  | -        SetRuntimeVisible(Index, True, True);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        SetRuntimeVisible(Index, True, SaveWidth);
 | 
											
												
													
														|  |      end
 |  |      end
 | 
											
												
													
														|  |        else
 |  |        else
 | 
											
												
													
														|  |      begin
 |  |      begin
 | 
											
										
											
												
													
														|  | @@ -389,7 +394,7 @@ begin
 | 
											
												
													
														|  |        Properties.Visible := False;
 |  |        Properties.Visible := False;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |        if ColumnsExists then
 |  |        if ColumnsExists then
 | 
											
												
													
														|  | -        SetRuntimeVisible(Index, False, True);
 |  | 
 | 
											
												
													
														|  | 
 |  | +        SetRuntimeVisible(Index, False, SaveWidth);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |        // hidden column is moved to the front,
 |  |        // hidden column is moved to the front,
 | 
											
												
													
														|  |        // unless column to the left is not hidden already
 |  |        // unless column to the left is not hidden already
 | 
											
										
											
												
													
														|  | @@ -418,6 +423,11 @@ begin
 | 
											
												
													
														|  |    end;
 |  |    end;
 | 
											
												
													
														|  |  end;
 |  |  end;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +procedure TCustomListViewColProperties.SetVisible(Index: Integer; Value: Boolean);
 | 
											
												
													
														|  | 
 |  | +begin
 | 
											
												
													
														|  | 
 |  | +  SetVisibleInternal(Index, Value, True);
 | 
											
												
													
														|  | 
 |  | +end;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  procedure TCustomListViewColProperties.SetRuntimeVisible(
 |  |  procedure TCustomListViewColProperties.SetRuntimeVisible(
 | 
											
												
													
														|  |    Index: Integer; Value: Boolean; SaveWidth: Boolean);
 |  |    Index: Integer; Value: Boolean; SaveWidth: Boolean);
 | 
											
												
													
														|  |  var
 |  |  var
 |