Go Back

The Silverlight PageCurl implementation

I started working on a Silverlight Page Curl when I encountered one on the internet and realized I had not seen it done in Silverlight yet. Read the manual to learn how to customize the Silvelight Page Curl using intialization parameters.

A basic function is to use a small footprint for the plug-in and enlarging that to a new plug-in size. This way most of the original page can be used for content and links close to the plug-in can be clicked, while you can still show a good part of an image beneath the curl when the mouse cursor is hovered over the plug-in. The plug-in size has to be reduced again when the mouse cursor is outside the plug-in area.

PageCurlOpen

The page curl is customized using initialization parameters on the plug-in:

<param name="initParams" value="
    imageUrl=/images/SLPageCurl.jpg,
    imageLink=http://antonidol.nl/pagecurl,
    curlColor=#FFC4D8F8,
    isCloseable=true
"/>

These are efficiently picked up and added to the Application Resources in a foreach loop in App.xaml.cs:

//Place initParams in Resources
foreach (var item in e.InitParams)
{
    this.Resources.Add(item.Key, item.Value);
}

When retrieved, these are Strings and need to be converted before they can be used:

if (App.Current.Resources.Contains("imageUrl"))
{
    imageUrl = new Uri(App.Current.Resources["imageUrl"].ToString(),
         UriKind.Relative);
    Image.Source = new BitmapImage(imageUrl);
    Image.ImageFailed +=
         new EventHandler<ExceptionRoutedEventArgs>(Image_ImageFailed);
}

In this case a default image should become visible when the image cannot be loaded. Remember, the path and filename come from the initParams, so they could be wrong. The ImageFailed event allows you to provide an alternative when the imageUrl setting doesn’t lead to a valid image:

void Image_ImageFailed(object sender, ExceptionRoutedEventArgs e)
{
    imageUrl = new Uri("Images/SLPageCurlDefault.jpg", UriKind.Relative);
    Image.Source = new BitmapImage(imageUrl);
}

 

To move the curl, animations XAML in are called. The plug-in size has to be altered by changing the style attributes on the SLPageCurlContainer DIV. The SetStyleAttribute in the HTML-bridge is the way to do that.

//grow
private void sizeUp(object sender, System.Windows.Input.MouseEventArgs e)
{
    HtmlElement htmlEl =
            HtmlPage.Document.GetElementById("SLPageCurlContainer");
    htmlEl.SetStyleAttribute("height", "500px");
    htmlEl.SetStyleAttribute("width" , "500px");

    aniSizeUp.Completed += new EventHandler(aniSizeUp_Completed);
    aniSizeUp.Begin();
}

 

When the plug-in is enlarged, the mouseEnter and mouseLeave events are triggered. This results is the Page Curl closing the second it is opened. Therefore it is necessary to add and remove the mouse events on the completed events of the animations that start, grow, shrink and close the page curl. This way animations cannot be triggered when they don’t have to.

void aniSizeUp_Completed(object sender, EventArgs e)
{
    LayoutRoot.MouseEnter -= sizeUp;
    LayoutRoot.MouseLeave += new MouseEventHandler(sizeDown);
}

 

Showing the image URL in the browser status bar also works via the HTML-bridge. With the System.Windows.Browser namespace in the page, you can access the status bar with the setProperty method. This takes a string for the name of the property and a value.

//show URL in Statusbar
private void showUrl(object sender, System.Windows.Input.MouseEventArgs e)
{
    HtmlPage.Window.SetProperty("status", imageLink);
}

 

The isCloseable option, in combination with the internal Closed state offered some challenges because they interact with each other. Furthermore, because the setting is stored in Isolated Storage, it will not show again after it is closed. Only by setting the isCloseable initialization parameter to false and duplicating that value in the Closed Boolean internally, it is possible to make it visible again. Handy when debugging…

The Page Curl Manual is available online and the Silverlight application is available on my SkyDrive.

 

Njoy!

Facebook Twitter DZone It! Digg It! StumbleUpon Technorati Del.icio.us NewsVine Reddit Blinklist Add diigo bookmark

Comments  11

  • http:///trackback.ashx 03 mei

  • http:///trackback.ashx 03 mei

  • Trackback from SilverlightShow.net 03 mei

    Trackback from SilverlightShow.net
  • aapbfdaj 01 jul

    aapbfdaj
  • dfsdfer 06 jul

    Our company support http://www.jordanus.com http://www.uggaustraliaboots-sale.com http://www.christianlouboutinpumps-sale.com http://www.yslheelsofficial.com http://www.ghd-hair-zone.com all of them have top quality and cheapest price,during the sales promotions,we have discounts to our clients,please click the link and visit it.thank you.
  • p90x 24 aug

    [url=http://www.super-p90x.com/]P90X Workout DVDs[/url]
    [url=http://www.super-p90x.com/]P90X Workout[/url]
    [url=http://www.super-p90x.com/]P90X[/url]
    [url=http://www.super-p90x.com/]P90x reviews[/url]
    [url=http://www.perfectwatchs.net/]Replica Watches[/url]
    [url=http://www.perfectwatchs.net/zenith]Zenith Replica Watch Revolution[/url]
    [url=http://www.perfectwatchs.net/zenith-defy]Replica Zenith defy[/url]
    [url=http://www.perfectwatchs.net/zenith-el-primero]Replica Zenith el-primero[/url]
    [url=http://www.perfectwatchs.net/zenith-elite]Replica Zenith elite[/url]
  • p90x 24 aug

    <a href=http://www.super-p90x.com/>P90X Workout DVDs</a>
    <a href=http://www.super-p90x.com/>P90X Workout</a>
    <a href=http://www.super-p90x.com/>P90X</a>
    <a href=http://www.super-p90x.com/>P90x reviews</a>
    <a href=http://www.perfectwatchs.net/>Replica Watches</a>
    <a href=http://www.perfectwatchs.net/emporio-armani>Replica Emporio Armani</a>
    <a href=http://www.perfectwatchs.net/emporio-armani-classic>Replica Emporio-Armani classic</a>
    <a href=http://www.perfectwatchs.net/emporio-armani-sport>Replica Emporio-Armani sport</a>
  • gift-cards 27 aug

    http://www.itunes-gift-cards.net          itunes gift cards,itunes store
    http://www.agoodeman.com/     p90x DVD
    http://www.aurautah.com     Rosetta Stone English (American)
    http://www.highwaytowatches.com      swiss replica watches
    http://www.watches-mens.com       mens watches 
    http://www.cnaweb.net/product/fitness_programs/insanity.shtml      insanity workout DVD price,insanity workout.com 
    http://www.cnaweb.net/product/fitness_programs/turbofire.shtml      Turbo Jam Workout DVD,Turbo Jam.com 
    http://www.cnaweb.net/product/fitness_programs/turbofire.shtml      Turbo Fire Workout DVD,Turbo Fire.com 
    http://www.cnaweb.net/product/fitness_programs/body-gospel.shtml       Body Gospel Workout DVD,Body Gospel.com 
    http://www.cnaweb.net/product/fitness_programs/power90.shtml        Power 90 Workout DVD,Power 90.com 
    http://www.cnaweb.net/product/fitness_programs/brazil_butt_lift.shtml        Brazil Butt Lift Workouts DVD 
    http://www.cnaweb.net/product/fitness_programs/best_sellers/slim_in_6.shtml        Slim in 6 Workout DVD,Slim in 6.com 
    http://www.cnaweb.net/product/fitness_programs/hip_hop_abs.shtml        Hip Hop Abs Workout DVD,Hip Hop Abs.com
  • p90x 31 aug

    <a href="http://www.newwatchs.com">Swiss Replica Watches</a>
    <a href="http://www.newwatchs.com/hublot-replica-watches-c-43.html">Hublot Watches</a>
    <a href="http://www.newwatchs.com/porsche-design-replica-watches-c-52.html">Porsche Design Watches</a>
    <a href="http://www.newwatchs.com/richard-mille-replica-watches-c-51.html">Richard Mille Watches</a>
    <a href="http://www.newwatchs.com/rolex-replica-watches-c-64.html">Rolex Watches</a>
    <a href="http://www.newwatchs.com/tag-heuer-replica-watches-c-55.html">TAG Heuer Watches</a>
    <a href="http://www.newwatchs.com/uboat-replica-watches-c-56.html">U-Boat Watches</a>
    <a href="http://www.newwatchs.com/vacheron-constantin-watches-c-57.html">Vacheron Constantin Watches</a>
    <a href="http://www.newwatchs.com/zenith-replica-watches-c-60.html">Zenith Watches</a>
    <a href="http://www.super-p90x.com"/>P90X Workout DVDs</a>
    <a href="http://www.super-p90x.com"/>P90X Workout</a>
    <a href=http://www.super-p90x.com/>P90X</a>
    <a href=http://www.super-p90x.com/>P90x reviews</a>



  • coolsoftwarelist 03 sep

    http://www.coolsoftwarelist.com/
  • asd 09 sep




    http://www.perfectwatchs.net/
    http://www.perfectwatchs.net/breitling-navitimer
    http://www.perfectwatchs.net/breitling-aeromarine
    http://www.perfectwatchs.net/breitling-avenger
    http://www.perfectwatchs.net/breitling-chronomat
    http://www.perfectwatchs.net/breitling-certifie
    http://www.perfectwatchs.net/breitling-crosswind
    http://www.perfectwatchs.net/breitling-montbrilliant
    http://www.perfectwatchs.net/breitling-superocean
    http://www.perfectwatchs.net/breitling-super-avenger
    http://www.perfectwatchs.net/breitling-windrider
    http://www.perfectwatchs.net/breitling-bentley
    http://www.perfectwatchs.net/breitling-professional
    http://www.super-p90x.com/
Post a comment!
  1. Formatting options