¡Fernando Cortés Hierro! MCSD

Experimentando con el usuario

Recent posts

Tags

Categories

Navigation

Pages

    Archive

    Blogroll

    Disclaimer

    The opinions expressed herein are my own personal opinions and do not represent my employer's view in anyway.

    Las Cosas Claras: Desde Javascript interactuar con Silverlight

    En el último post de la serie esta que comencé de "Las Cosas Claras" estuvimos viendo como podíamos acceder al DOM del explorador para, en el ejemplo, llamar a funciones javascript. Pues bien, hoy veremos como hacer precisamente lo contrario.

    En el siguiente ejemplo veremos como desde javascript podemos provocar cambios en el Silverlight, en este caso cambiar la orientación de los elementos de un StackPanel, pero también podríamos provocar el inicio de una animación o pararla, etc.

    En primer lugar utilizaremos el siguiente namespace ya que contiene lo necesario para realizar esto:

    using System.Windows.Browser;

     

    Centrándonos en la página principal del Silverlight Page.xaml. El código XAML será muy sencillo, un simple StackPanel con varios botones:

        <StackPanel x:Name="LayoutRoot" Background="White">
            <Button Content="Rojo" Background="Red"/>
            <Button Content="Verde" Background="Green"/>
            <Button Content="Azul" Background="Blue"/>
            <Button Content="Amarillo" Background="Yellow"/>
            <Button Content="Blanco" Background="White"/>
            <Button Content="Negro" Background="Black"/>
        </StackPanel>

    Y en el código fuente debemos registrar la clase MiTipoScriptable para poderla usar desde javascript de la siguiente manera:

    • En el evento Loaded de la página registraremos el objeto que será usados para acceder desde javascript al método.
    HtmlPage.RegisterScriptableObject("slObject", this);
    • Y por último decoraremos un método de la clase Page, donde hemos realizado el registro del objeto del punto anterior, con el decorador [ScriptableMember] el cual será el método al que podremos llamar desde javascript.
    [ScriptableMember]
    public void slMethod(string o)
    {
        if (o != "H")
            LayoutRoot.Orientation = Orientation.Vertical;
        else
            LayoutRoot.Orientation = Orientation.Horizontal;
    }

    Ahora nos vamos a la página ASPX desde la cual llamaremos al método slMethod del Silverlight. Para esto en primer lugar obtendremos el contenedor del Silverlight el cual en nuestro caso del ejemplo se llama SilverlightContainer y por último accederemos al método registrado mediante la siguiente sintaxis:

    function Orientacion(oo)
    {
        var slPlugin = $get("SilverlightContainer");
         
        slPlugin.Content.slObject.slMethod(oo);
    }

    PD: Se han creado dos botones Vertical y Horizontal que llamarán a la función Orientacion para cambiar el tipo de orientación del StackPanel.

    Stackpanel

    Stackpanel2



    Posted: Jul 02 2008, 12:20 by Fernando | Comments (0) RSS comment feed |
    • Currently 5/5 Stars.
    • 1
    • 2
    • 3
    • 4
    • 5
    Filed under: ASP.NET | Silverlight

    Related posts

    Add comment


    (Will show your Gravatar icon)  

      Country flag

    [b][/b] - [i][/i] - [u][/u]- [quote][/quote]



    Live preview

    said:

    # December 01 2008, 11:44