# Monday, March 06, 2006

WPF ContentModel

With WPF we are far more flexible in creating UI solutions since now almost every control can contain other controls.

The classic example being ofcourse the button.
A button cannot just have a text on the surface of the button, it can just as easily have an image.

Example of button with text.

<Button Name="button1">Just text</Button>

Example of button with image.

<Button Name="button1">
 <Image Source="C:\Documents and Settings\Mark\Desktop\banner.jpg" Name="image1" Width="100"/>
</Button>

Now a lot of buttons will have an image and also some text.
With our HTML background we'll probably attempt:

<Button Name="button1">
 Just text<br/>
 <Image Source="C:\Documents and Settings\Mark\Desktop\banner.jpg" Name="image1" Width="100"/>
</Button>

Wrong! A button can contain controls, but has no 'knowledge' of how to produce a layout for multiple controls.
WPF has special controls that provide layout implementation. These are panels. There are four kinds of panels:
- DockPanel
- StackPanel
- Grid
- Canvas

The same is actually true of the Window control. A Window has no 'default' knowledge of layout. VS2005 will by
default add a 'Grid' control as the root panel.

A StackPanel is easiest to use. It will stack items either horizontally or vertically.
In our button example we would want to use the StackPanel as the child of our Button.

<Button Name="button1">
  <StackPanel Orientation="Vertical">
    <TextBlock>Just text</TextBlock>
    <Image Source="C:\Documents and Settings\Mark\Desktop\banner.jpg" Name="image1" Width="100"/>
  </StackPanel>
</Button>

Notice that we don't need the <BR> tag anymore.
The linefeed is really layout information and our StackPanel is in charge of layouting the content.
If however we have a lot of text, then we could put a newline within the TextBlock.

<Button Name="button1">
  <StackPanel Orientation="Vertical">
    <TextBlock>
      Just text
      <LineBreak/>
      The next line
    </TextBlock>
    <Image Source="C:\Documents and Settings\Mark\Desktop\banner.jpg" Name="image1" Width="100"/>
  </StackPanel>
</Button>

A Grid offers more options and acts much more like a table with rows and columns. I'll show a quick example:

<Grid ShowGridLines="True">
  <Grid.ColumnDefinitions>
    <ColumnDefinition/>
    <ColumnDefinition/>
    <ColumnDefinition/>
  </Grid.ColumnDefinitions>
  <Grid.RowDefinitions>
    <RowDefinition/>
    <RowDefinition/>
    <RowDefinition/>
  </Grid.RowDefinitions>
  <TextBlock Grid.Column="0" Grid.Row="0">Top left</TextBlock>
  <TextBlock Grid.Column="1" Grid.Row="1">Middle</TextBlock>
  <TextBlock Grid.Column="2" Grid.Row="2">Bottom right</TextBlock>
  <Image Source="C:\Documents and Settings\Mark\Desktop\banner.jpg" Name="image1"
      Width="50" Grid.Column="1" Grid.Row="0"/>
</Grid>

As you can see the content of an actual cell is not placed in the cell, but instead the content is listed below the column and row definitions. I must say that I'm still getting used to this notation.

The DockPanel allows you to dock content to a border of the window.
The Canvas panel performs no layout functionality, you're in charge of all layout matters. Much the way 'regular' WinForms let you do all the layouting.

 

#    Comments [0] |
Tracked by:
"dvd xcopy platinum" (dvd xcopy platinum) [Trackback]
"lined wicker laundry baskets" (lined wicker laundry baskets) [Trackback]
"Alberta Incorporation" (Alberta Incorporation) [Trackback]
"2005 ford expedition" (2005 ford expedition) [Trackback]
"first compound microscope" (first compound microscope) [Trackback]
"Flagyl and diverticulitis" (Flagyl and diverticulitis) [Trackback]
"hookah diving with out tanks" (hookah diving with out tanks) [Trackback]
"vulnerability scanner" (vulnerability scanner) [Trackback]
"protonix in surgery use" (protonix in surgery use) [Trackback]
"hud property" (hud property) [Trackback]
"compromises of the constitution" (compromises of the constitution) [Trackback]
"exotic canopy beds" (exotic canopy beds) [Trackback]
"residence inn seaworld" (residence inn seaworld) [Trackback]
"dawn of war mod" (dawn of war mod) [Trackback]
"Camouflage Wetsuits" (Camouflage Wetsuits) [Trackback]
"real audio player" (real audio player) [Trackback]
"cervical disc problems" (cervical disc problems) [Trackback]
"moving companies quotes" (moving companies quotes) [Trackback]
"SAGUARO CACTUS DERMATITIS" (SAGUARO CACTUS DERMATITIS) [Trackback]
"excel communications" (excel communications) [Trackback]
"vacation rentals massachusetts" (vacation rentals massachusetts) [Trackback]
"open response questions" (open response questions) [Trackback]
"banner graphic, greencastle" (banner graphic, greencastle) [Trackback]
"mineral make-up" (mineral make-up) [Trackback]
"actonel d" (actonel d) [Trackback]
"don gabriel cigar shop" (don gabriel cigar shop) [Trackback]
"white pages perth" (white pages perth) [Trackback]
"baby photo contest" (baby photo contest) [Trackback]
"soft serve ice cream" (soft serve ice cream) [Trackback]
"jagg oil cooler" (jagg oil cooler) [Trackback]
"Victorian Clothing" (Victorian Clothing) [Trackback]
"bed and breakfast maine" (bed and breakfast maine) [Trackback]
"anti deppresant Celexa" (anti deppresant Celexa) [Trackback]
"asian bitches online" (asian bitches online) [Trackback]
"what is human resources" (what is human resources) [Trackback]
"child abuse stories" (child abuse stories) [Trackback]
"used pontoon boat trailers in wisconsin" (used pontoon boat trailers in wiscons... [Trackback]
"water injection for cummins" (water injection for cummins) [Trackback]
"doppler rentals" (doppler rentals) [Trackback]
"auto air conditioning repair" (auto air conditioning repair) [Trackback]
"Hair Color Advice" (Hair Color Advice) [Trackback]
"columbia greene community college" (columbia greene community college) [Trackback]
"freshman mandated to live in dorms" (freshman mandated to live in dorms) [Trackback]
"yamaha keyboards" (yamaha keyboards) [Trackback]
"arizona child support guidelines" (arizona child support guidelines) [Trackback]
"manatee online banking" (manatee online banking) [Trackback]
"summit county colorado real estate" (summit county colorado real estate) [Trackback]
"drag boat racing pictures" (drag boat racing pictures) [Trackback]
"Funny Voice Mail Greetings" (Funny Voice Mail Greetings) [Trackback]
"hong kong restaurants" (hong kong restaurants) [Trackback]
"Maintaining a Healthy Prostate" (Maintaining a Healthy Prostate) [Trackback]
"Adderall in Mexico" (Adderall in Mexico) [Trackback]
"orange county ca real estate" (orange county ca real estate) [Trackback]
"narrow water ireland" (narrow water ireland) [Trackback]
"advertising comps" (advertising comps) [Trackback]
"2004 suzuki marauder 1600 horsepower" (2004 suzuki marauder 1600 horsepower) [Trackback]
"Suunto sm-36" (Suunto sm-36) [Trackback]
"orchid lore" (orchid lore) [Trackback]
"cum on face prague escorts" (cum on face prague escorts) [Trackback]
"license plate restoration" (license plate restoration) [Trackback]
"florida museum of natural history" (florida museum of natural history) [Trackback]
"disegnodisney" (disegnodisney) [Trackback]
"Building a Sniper Rifle" (Building a Sniper Rifle) [Trackback]
"Concrete Foundation Fort Worth" (Concrete Foundation Fort Worth) [Trackback]
"phi relationship to major planetary events" (phi relationship to major planetar... [Trackback]
"pet doors for screen" (pet doors for screen) [Trackback]
"emailgratuita" (emailgratuita) [Trackback]
"scottsdale condo" (scottsdale condo) [Trackback]
"diabetic supplies" (diabetic supplies) [Trackback]
"3 stone diamond anniversary ring" (3 stone diamond anniversary ring) [Trackback]
"furnace construction" (furnace construction) [Trackback]
"port orange florida" (port orange florida) [Trackback]
"limpieza mantenimiento madrid" (limpieza mantenimiento madrid) [Trackback]
"geforce fx agp 4x 8x performance comparison" (geforce fx agp 4x 8x performance ... [Trackback]
"temisvoltimaturita" (temisvoltimaturita) [Trackback]
"incontrocattolica" (incontrocattolica) [Trackback]
"buy acyclovir" (buy acyclovir) [Trackback]
"Lesson Plan for Travel Brochure" (Lesson Plan for Travel Brochure) [Trackback]
"autonoleggiobarcellona" (autonoleggiobarcellona) [Trackback]
"veneer laminate to recover cabinets" (veneer laminate to recover cabinets) [Trackback]
"fibromyalgia heavy perspiration" (fibromyalgia heavy perspiration) [Trackback]
"spyware nuker serial" (spyware nuker serial) [Trackback]
"visaelectronics" (visaelectronics) [Trackback]
"nfl futures bets" (nfl futures bets) [Trackback]
"finanziamentoparma" (finanziamentoparma) [Trackback]
"stampantelaserricaricacartuccia" (stampantelaserricaricacartuccia) [Trackback]
"albergoeconomicobudapest" (albergoeconomicobudapest) [Trackback]
"search engine optimization for dentists" (search engine optimization for dentis... [Trackback]
"goodfighetteoralefotti" (goodfighetteoralefotti) [Trackback]
"betting on american idol" (betting on american idol) [Trackback]
"enlight server case" (enlight server case) [Trackback]
"online multiplayer black jack sport" (online multiplayer black jack sport) [Trackback]
"Unclaimed Money New York" (Unclaimed Money New York) [Trackback]
"bank of america AND money laundering" (bank of america AND money laundering) [Trackback]
"dimensions for a crap table" (dimensions for a crap table) [Trackback]
"slot machine senior citizen oxygen tank" (slot machine senior citizen oxygen ta... [Trackback]
"internet craps" (internet craps) [Trackback]
"Football Betting Line" (Football Betting Line) [Trackback]
"motoraduni" (motoraduni) [Trackback]
"piacevoletedescostrip" (piacevoletedescostrip) [Trackback]
"cheat roulette bets" (cheat roulette bets) [Trackback]
"mai" (mai) [Trackback]
"adeguatomamma" (adeguatomamma) [Trackback]
"mary" (mary) [Trackback]
"annuncioimmobiliareroma" (annuncioimmobiliareroma) [Trackback]
"vecchiegratis" (vecchiegratis) [Trackback]
"zip code 78745 showtimes black dahlia" (zip code 78745 showtimes black dahlia) [Trackback]
"adult dvds" (adult dvds) [Trackback]
"dwayne the roc johnson hairline" (dwayne the roc johnson hairline) [Trackback]
"dwayne kurowski" (dwayne kurowski) [Trackback]
"daihatsu extol head gasket" (daihatsu extol head gasket) [Trackback]
"pse mach handboog" (pse mach handboog) [Trackback]
"polaris ranger bumper guard" (polaris ranger bumper guard) [Trackback]
"daiichi keiki pressure gauge" (daiichi keiki pressure gauge) [Trackback]
"tecumseh psc compressor" (tecumseh psc compressor) [Trackback]
"dwarf frogs" (dwarf frogs) [Trackback]
"strawberry daiquiri" (strawberry daiquiri) [Trackback]
"niles audio ps-1" (niles audio ps-1) [Trackback]
"find sony dcr trv60e handycam mini dv" (find sony dcr trv60e handycam mini dv) [Trackback]
"dwanye wade" (dwanye wade) [Trackback]
"soap suds daily" (soap suds daily) [Trackback]
"reconditioned daiwa reels" (reconditioned daiwa reels) [Trackback]
"mod light dwarf chassis" (mod light dwarf chassis) [Trackback]
"daikin solenoid valve" (daikin solenoid valve) [Trackback]
"limbs for pse quantum" (limbs for pse quantum) [Trackback]
"lg 23 lcd hdtv monitor dvd player 23lx1rv" (lg 23 lcd hdtv monitor dvd player 2... [Trackback]
"daily sport newspaper babes" (daily sport newspaper babes) [Trackback]
"coast guard auxillary" (coast guard auxillary) [Trackback]
"ryobi 7.0 hp 3000 psi gas pressure washer" (ryobi 7.0 hp 3000 psi gas pressure ... [Trackback]
"barstow daggett solar power" (barstow daggett solar power) [Trackback]
"dagmara dominczyk sensual" (dagmara dominczyk sensual) [Trackback]
"daito tryu" (daito tryu) [Trackback]
"cliff dwellers" (cliff dwellers) [Trackback]
"dagney" (dagney) [Trackback]
"rohld dahl" (rohld dahl) [Trackback]
"ps2 cheats career juiced" (ps2 cheats career juiced) [Trackback]
"haunted places in dyersburg tennessee" (haunted places in dyersburg tennessee) [Trackback]
"dopey dwarf" (dopey dwarf) [Trackback]
"compaq dvi 5330us" (compaq dvi 5330us) [Trackback]
"canon zr200 mini dv camcorder" (canon zr200 mini dv camcorder) [Trackback]
"pat dailey 60's,70's ,80's" (pat dailey 60's,70's ,80's) [Trackback]
"jvc grd93 mini dv camcorder" (jvc grd93 mini dv camcorder) [Trackback]
"pictures of great dains" (pictures of great dains) [Trackback]
"brother of hide hiroshi matsumoto" (brother of hide hiroshi matsumoto) [Trackback]
"dvorak in america whitefire theatre" (dvorak in america whitefire theatre) [Trackback]
"http://blastpr.com/wiki/js/pages/zoloft/index.html" (http://blastpr.com/wiki/js... [Pingback]
"http://morningside.edu/mics/_notes/pages/accutane/index.html" (http://morningsi... [Pingback]
"http://morningside.edu/mics/_notes/pages/synthroid/index.html" (http://mornings... [Pingback]
"http://morningside.edu/mics/_notes/pages/nexium/index.html" (http://morningside... [Pingback]
"http://blastpr.com/wiki/js/pages/lexapro/index.html" (http://blastpr.com/wiki/j... [Pingback]
"http://morningside.edu/mics/_notes/pages/celexa/index.html" (http://morningside... [Pingback]
"http://morningside.edu/mics/_notes/pages/tramadol/index.html" (http://morningsi... [Pingback]
"http://morningside.edu/mics/_notes/pages/soma/index.html" (http://morningside.e... [Pingback]
"http://morningside.edu/mics/_notes/pages/prozac/index.html" (http://morningside... [Pingback]
"http://morningside.edu/mics/_notes/pages/viagra/index.html" (http://morningside... [Pingback]
"http://blastpr.com/wiki/js/pages/viagra/index.html" (http://blastpr.com/wiki/js... [Pingback]
"http://blastpr.com/wiki/js/pages/cialis/index.html" (http://blastpr.com/wiki/js... [Pingback]
"http://morningside.edu/mics/_notes/pages/prilosec/index.html" (http://morningsi... [Pingback]
"http://morningside.edu/mics/_notes/pages/lexapro/index.html" (http://morningsid... [Pingback]
"http://morningside.edu/mics/_notes/pages/cialis/index.html" (http://morningside... [Pingback]
"http://morningside.edu/mics/_notes/pages/celebrex/index.html" (http://morningsi... [Pingback]
"http://morningside.edu/mics/_notes/pages/cymbalta/index.html" (http://morningsi... [Pingback]
"http://blastpr.com/wiki/js/pages/coumadin/index.html" (http://blastpr.com/wiki/... [Pingback]
"http://blastpr.com/wiki/js/pages/prozac/index.html" (http://blastpr.com/wiki/js... [Pingback]
"http://blastpr.com/wiki/js/pages/ultram/index.html" (http://blastpr.com/wiki/js... [Pingback]
"http://morningside.edu/mics/_notes/pages/lipitor/index.html" (http://morningsid... [Pingback]
"http://blastpr.com/wiki/js/pages/claritin/index.html" (http://blastpr.com/wiki/... [Pingback]
"http://morningside.edu/mics/_notes/pages/coumadin/index.html" (http://morningsi... [Pingback]
"http://morningside.edu/mics/_notes/pages/paxil/index.html" (http://morningside.... [Pingback]
"http://morningside.edu/mics/_notes/pages/wellbutrin/index.html" (http://morning... [Pingback]
"http://blastpr.com/wiki/js/pages/cymbalta/index.html" (http://blastpr.com/wiki/... [Pingback]
"http://blastpr.com/wiki/js/pages/tramadol/index.html" (http://blastpr.com/wiki/... [Pingback]
"http://blastpr.com/wiki/js/pages/wellbutrin/index.html" (http://blastpr.com/wik... [Pingback]
"http://morningside.edu/mics/_notes/pages/hoodia/index.html" (http://morningside... [Pingback]
"http://blastpr.com/wiki/js/pages/soma/index.html" (http://blastpr.com/wiki/js/p... [Pingback]
"http://morningside.edu/mics/_notes/pages/effexor/index.html" (http://morningsid... [Pingback]