Поделиться через


Make an object into a button

This page applies to WPF and Silverlight 2

You can use the Make Button feature in Microsoft Expression Blend to make a button out of any object on the artboard, such as an image or a shape. The Make Button tool wraps the object in a style resource that you can apply to any other button object.

Tip

An object in Expression Blend is anything that you place onto the artboard, such as a layout panel, shape, text control, image, button, control template, or any other user interface (UI) design element. Placing a UI element onto the artboard creates an object instance of the element in your application.

To create a button from an ellipse

  1. If you have not already done so, open or create a new project. For more information, see Create a new document or project.

  2. On the artboard, draw a circle by using the Ellipse Cc295271.d7a04618-e35a-44f9-b78c-1f22e38016c1(en-us,Expression.10).png tool in the Toolbox. To make the ellipse more visible, you can change its appearance by altering its properties under Brushes in the Properties panel. For more information, see Apply a brush to an object's fill or stroke.

  3. With the ellipse selected under Objects and Timeline in the Interaction panel, click Make Button on the Tools menu to convert the ellipse to a button.The Create Style Resource dialog box opens.

  4. Under Resource name (Key), select the first radio button (default), and then enter a name to be used to identify the button style. Alternatively, you could select the Apply to all option that would apply the style to all buttons on the artboard that do not already reference a style by name.

  5. Under Define in, click the option that reflects where you want the button style to be defined. Click Application to make the button style available to any document in your application. Click This document (Window: Window) to make the button style available only to the current document. Click Resource dictionary to define the button style in a resource dictionary in your application.

  6. Click OK to exit the Create Style Resource dialog box and to create the button style.

    Notice that under Objects and Timeline, the ellipse object is converted to a button object whose style is set to your new button style.

    Additionally, the button style is listed in the Resources tab in the node where it was defined (for example, in the Window node).

    The new button style as it appears in the Resources tab of Expression Blend

    Cc295271.53d9464b-bf8b-4dcb-90c0-6fb85b0df530(en-us,Expression.10).png

Cc295271.7e183f1f-37d8-4dcb-980c-19a5d61ca087(en-us,Expression.10).gifBack to top

To modify the style of your button

  1. To modify the button style that you just created, right-click the new button object under Objects and Timeline, point to Edit Control Parts (Template), and then click Edit Template.

    The artboard switches to the editing scope of the control template.

    Tip

    There are multiple ways that you can enter the editing scope of a control template. For example, you can view your button style in the Resources tab, and then click the Edit resource button beside the resource name. This takes you to the editing scope of the style, from which you can go to the editing scope of the control template by right-clicking the style object under Objects and Timeline, pointing to Edit Control Parts (Template), and then clicking Edit Template.

    To exit the editing scope of a control template, click the Scope Up Cc295271.55844eb3-ed98-4f20-aa66-a6f5b23eeb2b(en-us,Expression.10).png button under Objects and Timeline. If you entered the editing scope of the control template from the editing scope of the style, you will be returned to the style. Click the Scope Up button again to return to the editing mode of the document.

    Tip

    The Make Button tool wraps the original object (the ellipse) in a style resource that contains a control template. The style defines the properties that are set on the object to which the style is applied (in this case, a button object). The control template defines the states, structure, and appearance of the object.

  2. Inside the control template is a Grid panel that contains the original object (the ellipse) and a ContentPresenter element that displays the content of the button object. Placing your object inside a Grid panel enables you to quickly add and arrange other elements.

    The structure of the control template for the new button style

    Cc295271.d16a098c-d0c2-4f72-8e2f-19ce6469c4f8(en-us,Expression.10).png

    You can see how the style and the control template are related by looking at the Extensible Application Markup Language (XAML) for the resource. For example, the structure of the button style might look like the following:

      <Window.Resources>
        <Style x:Key="ButtonStyle1" ...>
          <Setter Property="Template">
            <Setter.Value>
              <ControlTemplate TargetType="{x:Type Button}">
                <Grid>
                  <Ellipse>
                    ...
                  </Ellipse>
                  <ContentPresenter .../>
                </Grid>
                <ControlTemplate.Triggers>
                  ...
                </ControlTemplate.Triggers>
              </ControlTemplate>
            </Setter.Value>
          </Setter>
        </Style>
      </Window.Resources>
    
  3. Under Triggers in the Interaction panel, define the states of the button as desired. For example, click IsMouseOver = True to activate trigger recording for the state when the user passes their mouse over the button. Select the ellipse under Objects and Timeline, and then under Appearance in the Properties panel, change the Fill property of the ellipse to a different color. Notice that a new property change for ellipse.Fill is added under Triggers under Properties when active, as shown in the following image.

    Note

    You might have to adjust the size of the Triggers pane to see the Properties when active section. To adjust the size, click and drag the borders of the pane and the border within the pane.

    The Triggers panel after changing the Fill of the ellipse when the pointer is over the button

    Cc295271.6be5825d-f291-410b-bc75-423fee8f5d00(en-us,Expression.10).png

  4. You can also add animation to the button. For example, in the Triggers panel, click IsPressed = True to activate trigger recording for the state when the user clicks the button. With the ellipse still selected under Objects and Timeline, hold the SHIFT and ALT keys while you drag one corner of the ellipse. (The SHIFT+ALT key combination maintains the center point of the object.)

    Alternatively, you can add more complicated animation by creating a new storyboard and triggering that storyboard from an Event Trigger for the IsPressed event. For more information, see Triggers and user interactivity.

  5. After you have defined the states of the button as desired, click the Scope Up Cc295271.55844eb3-ed98-4f20-aa66-a6f5b23eeb2b(en-us,Expression.10).png button under Objects and Timeline to return to the editing scope of the document.

  6. To test the states, click Test Project on the Project menu (or press F5), and then see if the button states are working properly. For example, when you move the pointer over the button, the fill color should change.

Cc295271.7e183f1f-37d8-4dcb-980c-19a5d61ca087(en-us,Expression.10).gifBack to top

To apply a button style to a button

  1. Make sure that you are in the editing scope that you want. You can apply a style to a button in any scope, including within the scope of a control template.

  2. On the artboard, draw a button by using the Button Cc295271.05df1779-a68f-436b-b834-a91b7995a3ec(en-us,Expression.10).png control in the Toolbox.

  3. Right-click the new button object under Objects and Timeline, point to Edit Control Parts (Template), point to Apply Resource, and then select your button style from the list.

    You can also use the Edit Style and Edit Control Parts (Template) commands on the Object menu to apply a style resource.

    Applying the button style to a button object, by using the right-click method

    Cc295271.dc12debc-7711-47d9-84ce-10322a384397(en-us,Expression.10).png

Cc295271.7e183f1f-37d8-4dcb-980c-19a5d61ca087(en-us,Expression.10).gifBack to top

To remove or change the style of a button

  • Because the button style is a resource, you can treat it like any other resource. For information about removing or altering style resources, see the How to topics in Resources.

Cc295271.7e183f1f-37d8-4dcb-980c-19a5d61ca087(en-us,Expression.10).gifBack to top

See also

Concepts

Create a control from existing objects