CodeProject
data:image/s3,"s3://crabby-images/d1d4a/d1d4a52c6cd002a10c409d69f66deb69c12ff06f" alt="The finished Button The finished Button"
It’s amazing how a simple effect can transform an application. I have tried to find ways to create a simple glass effect as quickly as possible and with as few brushes and layers as possible to aid in render performance, particularly for Windows mobile 7. My previous attempts looked more like a pipe than glass and involved too many brushes. I have managed to get mine down to two brushes. I think I could get it down further and just use colour substitution but that’s for another post! So here is how I am currently doing it…
Step 1 – Create the First Rectangle
Start with a blank user control and ensure you have a layout root grid. This will be very important for the scaling later on.
data:image/s3,"s3://crabby-images/d3b53/d3b537db146a2291adfbac4bc3bf570e38bd7b8f" alt="Start expression blend Expression blend project start"
Create a new rectangle in your required dimensions, in my case its 150 x 50 pixels. Set the fill to a gradient fill maintaining the default gradient. Set the first colour to Black and the second colour to a dark grey, I have used #FF454444 as the dark grey. Set the corner radius to 3 for both x and y.
data:image/s3,"s3://crabby-images/0fe94/0fe9428a7f341827c73cca75cb8b9aba72e66cf8" alt="Create the first rectangle Create the first rectangle"
Step 2 – Create the Glass Effect Rectangle
The next step is to create the inner rectangle which will give us the glass effect. To do this, simply copy the previous rectangle and paste. For now, we just want to shrink it so we can get the look right and feel right. Shrink the inner rectangle so that it’s just under half the height of the first rectangle and so that there is a nice gap on either side. Change the gradient colours to white and set the Alpha of the first colour to 10 and the second to 75.
data:image/s3,"s3://crabby-images/15945/159452beb42d6490d559c9747ab88f8fd32edad1" alt="Create the glass rectangle Create the glass rectangle"
Step 3 – Make the Button
Now it’s time to make a Button out of the rectangles we have. First we need to group everything into a Grid. So right click and select “Group Into” and select “Grid” or Ctrl + G.
data:image/s3,"s3://crabby-images/b561c/b561c379add1b4d52b5db83d26e5212e6df89a7f" alt="Group the elements into a grid Group the elements into a Grid"
Now select “Tools” -> “Make into control” and select the button control. Give the template a name.
data:image/s3,"s3://crabby-images/f6d41/f6d41309d0aad94ce6f8ca9323c7214a589c31e4" alt="Make the elements into a control Make the elements into a control"
data:image/s3,"s3://crabby-images/d6e0e/d6e0e08e7bbdf9c73c5d247e01197c535514a673" alt="Make the elements into a button control Make the elements into a button control"
You should now see the button text appear in the centre of the control. This will also put you in template edit mode. You will need to either double click on the canvas or click the ‘Button’ element at the top of the designer. This is so that you can set the font size and colour of the button to the desired settings. I have set them to 23 and White.
data:image/s3,"s3://crabby-images/26746/26746eacc131f24c52c8b58b4b08afedbffbddae" alt="Exit template mode Exit template mode"
Step 4 – Make the Button Scalable
You should now have something that looks like a button, however if you try to scale it the elements won’t stay in proportion to the height and width of the actual button.
data:image/s3,"s3://crabby-images/1aeff/1aeff1bfb8ede4ab09cf0801939e9bc94cafaf5b" alt="Button layout is complete Button layout complete"
The easiest way to get around this is to place the elements into a layout element that scales its content. I find the Grid makes the most sense so enter template edit mode by right clicking the control and selecting “Edit Template” -> “Edit Current”.
data:image/s3,"s3://crabby-images/3e1c6/3e1c6f4ff940008d0acc996d84a6b92d652eb38e" alt="Enter template edit mode Enter template edit mode"
Select the Grid you grouped the elements into earlier from the “Objects and Timeline” toolbar and add to it three columns and three rows. You can do this from the layout tool bar.
data:image/s3,"s3://crabby-images/ee093/ee093290a20c49c144271c3cf993b1784030a28b" alt="Select the grid Select the grid"
data:image/s3,"s3://crabby-images/2c183/2c1835be72df371940170b7bbe44985b755663e4" alt="Add rows and columns from the layout toolbar Add rows and columns from the layout toolbar"
Set the column with to 0.025,1 and 0.025 star respectively and the row heights to 0.15, 0.75 and 1 star respectively. This is very important as it is what will retain the relevant proportions of the elements.
data:image/s3,"s3://crabby-images/29489/2948985d1b56926a60ab2899e76d6c826716533d" alt="Add rows and columns to the grid and set the width and height Add rows and columns to the grid and set the width and height"
Place the background rectangle and the content presenter in row and column 0 with row span and column span set to 3. Place the glassy rectangle in row 1 column 1 and now set the glassy margins to 0 and its height and width to Auto with horizontal and vertical alignment set to stretch.
data:image/s3,"s3://crabby-images/9234b/9234b0880248356baefd5de286ab6a1a31a33ac8" alt="Set element grid removeds Set element grid positions"
Make sure that the Content element is a layer behind the glassy rectangle by moving it in the Objects and Timeline toolbar. This is so that the whole button will appear to be glass including the text. You can test this is the case by changing the foreground of the button to a shade that will make this clear to see.
data:image/s3,"s3://crabby-images/c7bc9/c7bc950d2c80786871ddde950737fc78bee73c81" alt="Set element ordering Set element ordering"
That’s it. You should now have a very simple scalable glass button.
data:image/s3,"s3://crabby-images/a0fcb/a0fcb84551b63befa171a1dc7088cfc529c41b56" alt=""