Hi,
I have upgraded to v7.3 infragistics and code which previously worked (in 5.1) is no longer.
Basically I have a grid with 3 columns, the 3rd column is used to display data in both value and progress bar, I achieved this previously by associating each cell.EditorControl with a new instance of UltraProgressBar. However when the code runs, the %value's appear but the progress bar itself fails to paint on each cell.
So at run time we can add an item to the grid and its value and %value in the bar would appear.
cell.EditorControl = CreateBar();
then later when I want to update the value foreach(row/cell in the column of columns)
at this point the percent value updates but the bar fails to be displayed.
The sample you attached here is not using WinGrid, it's using WinTree. And it's not using v7.3, it's using v5.3.
I updated the sample to v7.3 and it works fine for me, the progress bars display correctly.
appologies for the confusion, I'm using the WinTree as an advanced grid for display of results, the progress bar gives us both numerical and visual indication of data as the results update. The example code is what I used as a basis for a bigger control in our application.
When I upgraded the project to 7.3 the bars did not display. So there must be something else I missed in the setup of the control.
I've attached the example project after the upgrade both VS2005 and Infragistics, when I run this I don't see the bars, but I suspect somthing is wrong in the settings of the Cell appearance that is overriding the bar settings.
Cheers
Malcolm.
Mike,
I think I found my problem, its in the settings for my PC, beingold skool windows lover I have my display properties - Themes of my desktop set to use 'Windows Classic', if I set my machine to use the Windows XP then the bars appear, so whats gone wrong is the use themes being ignored by the infragistics control.
I know this is a corner case but its certainly had me pulling my hair out. Let me know if you want me to submit an incedent report to the support node.
Hi Malcolm,
Yes, you should definately Submit an incident to Infragistics Developer Support so they can check it out. The ProgresBar should work whether it's themed or not.
Incident no WTR2571 has been allocated for this issue. I'll follow up if I get a result.
cheers
I am facing a similar issue. I am trying to embed an ultraprogressbar in a ultragrid and i need the progress bar to be smooth filled (rather than default windows blocks)
If i create a progressbar on the form and set its properties (and UseOSThemes as false) it uses any color/smooth fill that i want. However the progress bar embedded in the ultragrid just uses the default os theme fill.
Please let me know if there is a resolution.
shattangadi said:If i create a progressbar on the form and set its properties (and UseOSThemes as false) it uses any color/smooth fill that i want. However the progress bar embedded in the ultragrid just uses the default os theme fill.
That's correct behavior. The UseOsThemes property doesn't affect the grid because the grid has it's own UseOsThemes property. You can either turn off themes in the entire grid or else set the column.CellAppearance.ThemedElementAlpha to Transparent to affect on the one column.
Hi Tony,
Check out the PercentSettings on the ProgressBar control. You can assign appearance properties based on the percentage value of the progressbar.
Sorry for the confusion - You're right (of course!) that the CellActivation doesn't really matter. I think I confused myself on that...
Setting BackColor & BackColorDisabled to the same value works a charm.
On a related note - is there anyway to set the attributes of the progress bar such that it's color changes based on the cell values? I tried using InitializeRow, but it seems that the value for EditorControl is not set at the time of InitializeRow... I know I could create and assign a new object instance to EditorControl, but if I do that don't I also have to deal with disposing of the object?
Thanks again,
tonyB.
Okay... I'm puzzled by a couple of things.
The sample you sent me has CellClickAction set to RowSelect. So the CellActivation should not matter, when you click on the progress bar, the entire row gets selected. The cell might get activated internally, but why does that matter?
Also... I already gave you another potential solution. If you don't want to change the CellActivation on the column, all you have to do is set both BackColor AND BackColorDisabled on the FillAppearance for the ProgressBar to the same color. Did you try that and it didn't work or something?
Thanks for that - definately a step in the right direction. However the downside of not setting the progress bar column to disabled (column.CellActivation = Activation.Disabled) means that when the user clicks on the progress bar, the cell is activated (adding a BeforeCellActivation handler and setting e.Cancel = true doesn't stop the activation it seems). Not what I want. All of my grids are read/display-only.
The reason for my setting all the appearances is I have many grids, across many screens and I use a common function to initialize them rather than waste spend time fiddling about with every gird property via the designer.
Is there a better way to globally disable all individual cell activation (forcing row selection) and turn off all editing functions?
I did a little trial and error testing and it looks like the problem is this line of code:
column.CellActivation = Activation.Disabled;
Since the cell is disabled, it's using the BackColorDisabled instead of the BackColor of the FillAppearance you assigned.
Normally, this would not be a problem, but you are also setting displayLayout.Override.CellAppearance = defCellAppearance, which has a BackColorDisabled of Window, so basically, the fill appearance on the progress cell is resolved to white when disabled.
So you can either set BackColorDisabled in addition to BackColor, or else don't disable the ProgressBar column.