Hi,
I am having a different kind of requirement.
I have two lines of text in a single cell in Ultrawingrid.
I have to apply font size of 14 and color black to first line text.
And font size of 12 and color blue to second line text.
Could you please let me know how to do it?
Thanks,
Venkat.
Hi Venkat,
You could set the Style of the column to FormattedText. And then use XML as the Value of the cell to control the formatting. The custom XML format used by a FormattedText cell in the grid is the same one used by the UltraFormattedLinkLabel or UltraFormattedTextEditor controls.
i have used e.Row.Cells[i].CellDisplayStyle = CellDisplayStyle.FullEditorDisplay into ultraGrid_InitializeRow event. Then how i can use two different font sizes for the text of the same cell?
pls let me know if any options avail.
Mosam
I'm not sure I'm following you. In my sample, I had AutoSize on both labels set to true. But the size of the labels will not have any bearing on the size of the UserControl. They are two completely different things. The UserControl needs to be resizable, so that it will fit inside the grid cell. The grid will size the control to the cellas it paints each cell. So the code I added which re-positions the buttons in SetBoundsCore is needed so that the control itself responds properly to resizing. AutoSizing related to when the user double-clicks on the right edge of the column header. In that case, the grid will ask the editor (in this case the UltraControlContainerEditor) for the preferred size based on the value of the cell. The grid also asks the editor for the size of preferred size if you are using other AutoSize settings like AllowColSize or RowSizing settings that include "Auto" for the initial size of the column or row. The UltraControlContainerEditor, of course, has no idea how to do that since the contents of the cell are determined by a bunch of arbitrary controls inside the UserControl. So it's up to you to make that calculation and implement GetPreferredSize on your UserControl.The sample you posted here seems to be working in that regard. The columns appear to be coming up correctly sized - presumably the default implementation of UserControl is figuring out some kind of size based on the contained controls. But you can't AutoSize the columns or rows in your sample beyond that since your properrty settings don't allow the user to resize rows or columns. And you are not even overring GetPreferredSize on the UserControl.So I am not sure what you are asking.
Hi Mike,
In earlier sample that I have posted is the same one which you have attached in your response and plus I have added code related to AutoSizeHeightOnly property through which label height get autosized which was not happening previously. Now, if you observe yellow highlighted cell values in screenshot Which is posted in my last reply, you will find that texts in label is not getting displayed fully as cell is not getting resized and texts within Label is so long that it requires cell resize as well I guess to display full text values within.
So, I need to resize usercontrol/ultra grid cell/labels accordingly so that it can displays full length of label value data which is there in last sample attached. Some of the cell is having values as below.
e.g. "888 aaaaaaaaaaaaaaaaaaaaaaabbbbbbbbbbbbbbb ccccccccccc eddddddddddddd 123457888\n(140011-24558667 %)"
So, here texts before \n should be added into first label and text after \n should be added into second label. Ultra grid cell should display such values properly.
I hope, it helps to understand the actual issue now.
Can you pls help here - if you can provide updated sample with the same.
Hi ,
One more observation - i would like to share with you.
In my original sample applicaiton - if you observe adding image to cell and button is written inside ultraGrid_InitializeRow() event where i am looping through row band columns one by one and will decide to add image and button based upon specific column/cell value. As per your sample POC - adding image and button logic is within setter of Value of CellInfoControl.cs so, can you pls let me know how i can shift that logic inside ultraGrid_InitializeRow() or any other way to do so.
Hi Mosam,
I'm still confused. Why are you using AutoSizeHeightOnly? That means that the label will only resize it's height and never it's width. Also, this property is obsolete and the same effect can be acheived another way as mentioned by the warning you can see in the application.
So are you thinking that you want the width of the column to be fixed and only the height of the rows will AutoSize to the contents? That's the only way that would make sense. But that's also going to make the preferred width of the UserControl ambiguous. So I'm having a a hard time wrapping my head around how that would work. I guess you could base the width on the OTHER labels and buttons and ignore width as far as the second label is concerned. But you have both labels set to AutoSizeHeightOnly, so that seems contradictory. That means there is no way to estabslihed the preferred Width. It's not clear to me what you want here. It sounds like what you want might not even be possible because there is a contradiction there. I recommend that you override GetPreferredSize on your UserControl and maybe play around with it and see how is works. Regarding the Image and/or buttons in the cells, you can't do that in InitializeRow when using UltraControlContainerEditor. The UltraControlContainerEditor essentially replaces the entire cell with a control. The grid will apply some Appearence property to your control like BackColor and ForeColor, because those are properties on Control. But it can't possible apply the Appearance.Image, and UltraControlContainerEditor doesn't suppose EditorButtons. If you want to change the button(s) that exist in the UserControl, then you would have to do that in the Value property setter and base that decision on something in the cell's value, just like I am doing with the Arrows image now. And the same applies to any other images.
Hi Team,
1) If you observe grid column width has been set to 200 if cell text goes beyond some length in sample application which I have sent you. So, it should auto size height in the scenarios where text goes beyond cell display limit. I have used AutoSizeHeightOnly property in sample application to do so. Ultralabel1 can have long texts within but ultralabel2 can have max 60-70 chars limit as per our requirement. So, in this scenario label1 should display full texts and should increase its height accordingly. I have tried to use GetPreferredSize on usercontrol but still its not showing label1 text values fully into cell. attaching sample poc here.
Can you pls update sample app for the same and send me. I have already provided long text example in my previous reply. e.g. "888 aaaaaaaaaaaaaaaaaaaaaaabbbbbbbbbbbbbbb ccccccccccc eddddddddddddd 123457888\n(140011-24558667 %)". Here texts before \n should be added into first label and text after \n should be added into second label. Ultra grid cell should display such values properly.
I hope, now it's pretty clear.
2) For second issue regarding image and button should be visible into cell - As per our requirement, based upon specific value in cell - it should add image and button into cell so, currently we are checking different column values for the same in Grid_inititalrow() event. In your sample - its added into setter of value property. Is there any other way to hide controls and then unhide them on initializerow() event or can we access other column values at setter of value property?
We are evaluating this usercontrol approach based upon our requirement to display full texts, image and button on same cell of ultragrid.
If it doesn’t work then other alternative for us to go to xml approach using UltraFormattedTextEditor for which I have attached sample in my previous replies. Into that approach - can we show image on top right corner of the cell instead immediately after first text of the cell?
Also, if too long text come up then can we resize cell of ultragrid to show full texts within?
Based upon solutions to be provided for above issues, we would decide on which approach to go further for implementation.
Can you please help us here soon as we need to apply solutions quickly to our application.
4643.SampleUltraGrid (2).zip
mosam patel said:Thanks for looking into it. Can you pls provide example as you mentioned for using the SetBoundsCore and GetPreferredSize. Also, if you can update sample poc - it would save several back and fro as resolving one issue actually starts seeing another issue within sample poc which we have seen so far.
I have provided you with several iterations of the sample that handle both of these methods and arrange the controls or return an ideal size. So you have all the pieces you need to determine how you want the controls within the UserControl to be arranged and what the ideal size of the UserControl should be. You will need to take it from there and determine what you requirements are.
mosam patel said:I have asked you query for alternative xml approach using UltraFormattedTextEditor for which I have attached sample in my previous replies. Into that approach - can we show image on top right corner of the cell instead immediately after first text of the cell? Also, if too long text come up then can we resize cell of ultragrid to show full texts within instead currently it displays scroll bars on cell if long text values come. Can you pls provide your suggestion on this ?
The img tag allows you to place an image in-line with the text or also floating separately. That tag (and all of the supported Xml tags) are documented here. So you could try using a floating image.
Hi Mike,Thanks for looking into it. Can you pls provide example as you mentioned for using the SetBoundsCore and GetPreferredSize. Also, if you can update sample poc - it would save several back and fro as resolving one issue actually starts seeing another issue within sample poc which we have seen so far.
As per my last reply- i have mentioned one another issue as well that is on click on cell, label2 starts displaying overlapping with label1 texts and label1 text displays not fully on top of label2 - can you pls provide your input for this ?
I have asked you query for alternative xml approach using UltraFormattedTextEditor for which I have attached sample in my previous replies. Into that approach - can we show image on top right corner of the cell instead immediately after first text of the cell? Also, if too long text come up then can we resize cell of ultragrid to show full texts within instead currently it displays scroll bars on cell if long text values come. Can you pls provide your suggestion on this ?
So I guess I was mixed up about which text you were putting into each label. But at this point, this is really going way beyond what I can do for you in terms of support. You need to figure out what you want this control to look like in the cell and arrange the controls sing the SetBoundsCore and GetPreferredSize. I can only provide you with an example, I can't write a working control for you. What you are seeing here, I think, is that you have the UltraLabel1 set to AutoSizeHeightOnly and you are setting it to a very long string, so it's increasing it's own height and covering up UltraLabel2. The solution to that problem is to change the code in SetBoundsCore which is arranging the controls inside the UserControl and place them in such a way that that doesn't happen. When I wrote that code, I was assuming that UltraLabel1 was always going to be one line, but that is apparently not the case. So you can force UltraLabel1 to refresh it's PreferredSize by setting AutoSize to false and back to true, get the PreferredSize and the position UltraLabel2 such that it is underneath UltraLabel1. And then you will probably need to do the same thing to get the correct PreferredSize of UltraLabel1 inside of GetPreferredSize, because my sample code currently is not doing that because, as I said, I was assuming UltraLabel1 is always a single line.
After applying above GetPreferredSize, It starts displaying label1 text but yet not displaying label2 texts in cell. see in below screenshot.
we require to display label1 full texts and then label2 full text in new line.
Also, when i click on column3 highlighted cell then it displays as below. Here, label2 starts displaying overlapping with label1 texts and label1 text displays not fully on top of label2.
Can you pls give your input and update sample application for above issues.
Nope. I am wrong. The first line is wrapping in the middle of a word, so that can't be right. So I think the issue is that PreferredSize on the UltraLabel2 is stale, so we just need to give the label a kick.
It seems to work better if I force it to resize before getting the PreferredSize...
public override System.Drawing.Size GetPreferredSize(System.Drawing.Size proposedSize) { var idealHeight = this.ultraLabel1.Top + this.ultraLabel1.Height; idealHeight += 8; // padding this.ultraLabel2.AutoSize = false; this.ultraLabel2.AutoSize = true; idealHeight += this.ultraLabel2.PreferredSize.Height; idealHeight += 8; // padding return new Size(200, idealHeight);
}The height is now too big, but that's likely because I just used 8 for padding and that's not the correct value.