首先按照上一篇博客中的順序來新建一個項目。新建好之后就點開 MainPage.xaml 開始敲代碼了。
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
<Grid.RowDefinitions>
<RowDefinition Height="100"/>
<RowDefinition Height="auto"/>
<RowDefinition Height="*"/>
</Grid.RowDefinitions>
<Grid.ColumnDefinitions>
<ColumnDefinition Width="4*"/>
<ColumnDefinition Width="6*"/>
</Grid.ColumnDefinitions>
<StackPanel Grid.Row="0" Grid.ColumnSpan="2" Orientation="Horizontal">
<TextBlock Text="頁面布局" Foreground="Red" FontSize="40" Margin="12"
Width="200" Height="80" />
<TextBlock Text="基本導航" Foreground="Green" FontSize="40" Margin="12"
Width="200" Height="80" />
</StackPanel>
<Grid Grid.Row="1" Grid.Column="0">
<Button Content="導航到第二頁" Foreground="Blue" FontSize="35"
Margin="12,480,0,0" Name="btnGoSecondPage" Click="btnGoSecondPage_Click"/>
</Grid>
<Canvas Grid.Row="1" Grid.Column="1" HorizontalAlignment="Center" VerticalAlignment="Center">
<Rectangle Fill="Blue"/>
<Rectangle Fill="Yellow" Height="100" Width="100" Canvas.Left="50" Canvas.Top="20"/>
<Rectangle Fill="White" Height="100" Width="100" Canvas.Left="70" Canvas.Top="90"/>
</Canvas>
</Grid>
下面就來依次介紹上面這段代碼到底做了寫什么。
1)首先將最外圍的 Grid 控件分成了3行2列。其中第一行的高度是 100 像素;第二行的高度是自動的,所謂自動呢,就是會根據(jù)將來在其中添加的控件的所占的高度來決定的;第三行的高度就是剩余的啦,這么說可能不夠清楚到底星號是什么意思。那再看看切成的這兩列就好啦,它的寬度比就是 4:6。很顯然不一定是非得比例加起來等于10,即便是 4:100 也可以的。
2)在最外層的 Grid 內嵌套了一個 StackPanel,并且將其定位在第一行,而且橫跨 2 列。Grid 最擅長的就是操作具體的像素,它可以將任何控件精確的定位到任何一點。而 StackPanel 最重要的 Orientation 屬性則可以安排其內的控件的排列方式,比如這里就是讓兩個 TextBlock 控件按水平方向來排列。
3)在這里又嵌套了 Grid,里面有一個 Button,F(xiàn)oreground 屬性是定義字體顏色,F(xiàn)ontSize 屬性是定義字體大小。下面重點來看看 Margin 屬性。我們定義的 Marin="12,480,0,0",從左至右依次是左、上、右和下四個方向距離外圍邊框的距離。
在設計器中已經標注了左邊距是 12,而上邊距沒有體現(xiàn)出來,但確實是 480。還記得之前的那個 auto 么,在這里就體現(xiàn)出來了啦,因為下邊距是 0,所以 Grid 的分割線就剛好在 Button 下面啦。但為什么右邊的分割線不剛好在Button 的右邊呢,這是因為我們之前的 2 列是按照 4:6 的比例來切的呀,而不是設置的 auto。
4)Canvas 位于其外圍的 Grid 控件的正中央,HorizontalAligment 和 VerticalAlignment 分別表示水平方向和垂直方向的擺放位置。Canvas.Top 和 Canvas.Left 分別表示離 Canvas 最上邊和最下邊的距離。
5)給Button設置一個名字,然后敲下 Click="" 之后,就會出現(xiàn)如下圖所示,這是直接按下 Enter 鍵就可以直接命名咯。小技巧啦。
然后雙擊 Click 事件的名字后,直接按 F12 鍵就會自動生成一個事件并且跳轉到 C# 文件啦。下面這段代碼就是會讓頁面從 MainPage 跳轉到 SecondPage。
private void btnGoSecondPage_Click(object sender, RoutedEventArgs e)
{
if (this.Frame != null)
{
this.Frame.Navigate(typeof(SecondPage));
}
}
寫完這段代碼也先別急著調試,因為還沒有創(chuàng)建 SecondPage 呢。建議創(chuàng)建好之后最好再往里面加點東西,不然跳轉過去了就是黑茫茫的一片還以為是出 Bug 了呢,添加一個基本的 TextBlock 就可以了。
<TextBlock Text="Second Page" FontSize=" 50"/>
我再來簡單介紹一下 VS 中常用的一些東西,僅僅面向初學者。在下面的圖中,方框 1 處可以讓設計器和 XAML 代碼的位置對換哦,截圖里我就是將設計器放到了右邊,不過只是為了截圖,設計器還是在左邊比較習慣。
方框 2 處可以讓設計器和 XAML 代碼上下擺列和左右擺列也可以不顯示它們中的某一個。旁邊還可以設置網格對齊以及設計器的縮放比例。
方框 3 和方框 4 中可以設置的東西就太多啦,可以設置漸變色,也可以設置 Click 事件,還可以設置控件的布局等。
Windows 上的 modern 應用我倒是不常用,不過 WP8 上的應用我覺得和安卓什么的最大的區(qū)別就是它的應用欄了,下面就來講講應用欄是怎么做出來的。
在 Document Outline(在視圖中找到,或者按 Ctrl+W,U)中有 TopAppBar 和 BottomAppBar,分別是頂部和底部的應用欄。點鼠標右鍵可以快速定義 AppBar 和 CommandBar,通常將 AppBar 放在應用上端也就是 TopAppBar 內,CommandBar 放在下端也就是 BottomAppBar 內。
或許很多人都不知道,在 Modern 應用下,按 Win+Z 鍵可以直接呼出應用欄喲。另外要注意 AppBar 與 CommandBar 不同,前者只能包含一條子內容,通常定義一個 Grid 控件,然后在 Grid 內嵌套其他控件。下面貼出一段 AppBar 的示例:
<Page.TopAppBar>
<AppBar IsSticky="True">
<Grid>
<Grid.ColumnDefinitions>
<ColumnDefinition/>
<ColumnDefinition/>
</Grid.ColumnDefinitions>
<StackPanel Orientation="Horizontal">
<Button Content="Main Page" Width="140" Height="80" Click="AppBarButton1_Click"/>
<Button Content="Second Page" Width="140" Height="80" Click="AppBarButton2_Click"/>
<Button Content="Third Page" Width="140" Height="80" Click="AppBarButton3_Click"/>
<TextBlock Text="AppBar" Foreground="Red" FontSize="40"
VerticalAlignment="Center" Margin="12" Width="200"/>
</StackPanel>
<SearchBox Grid.Column="1" Width="300" Height="50" HorizontalAlignment="Right"/>
</Grid>
</AppBar>
</Page.TopAppBar>
<Page.BottomAppBar>
<CommandBar>
<AppBarButton Label="Refresh" Icon="Refresh"
Click="appBarBtn4_Click"/>
<AppBarButton Label="Redo" Icon="Redo"
Click="appBarBtn5_Click"/>
<CommandBar.SecondaryCommands>
<AppBarButton Label="Add" Icon="Add" Click="AppBarButton6_Click"/>
<AppBarButton Label="Delete" Icon="Delete" Click="AppBarButton7_Click"/>
<AppBarButton Label="Edit" Icon="Edit" Click="AppBarButton8_Click"/>
</CommandBar.SecondaryCommands>
</CommandBar>
</Page.BottomAppBar>
但是大家應該都發(fā)現(xiàn)了,默認情況下應用欄是隱藏起來的,如果想要在加載的時候就是啟動的,那該怎么辦呢?很簡單,直接在 AppBar 定義 IsOpen 屬性為真就好。
<CommandBar IsOpen="True">
<!-- -->
</CommandBar>
另外還有粘滯屬性喲。也就是說,原本當用右鍵呼出應用欄后,再用左鍵等點一下其他位置應用欄就會自己消失啦,但如果 IsSticky 屬性為真的話呢,非得再多按幾下右鍵才會消失的。
<AppBar IsSticky="True">
<!-- -->
</AppBar>
除了在 XAML 中定義這些屬性外,我們也可以在后臺代碼中用函數(shù)來實現(xiàn)呢,這里我就是用的 2 個 Button 的 Click 事件。
private void btnSetAppBar_Click(object sender, RoutedEventArgs e)
{
if (this.TopAppBar != null)
{
this.TopAppBar.IsSticky = true;
}
}
private void btnSetAppBar2_Click(object sender, RoutedEventArgs e)
{
if (BottomAppBar.IsOpen ==false)
{
this.BottomAppBar.IsOpen = true;
}
}
既然是通用應用了,那么 WP 這邊自然也是類似的,不過暫時還只有 BottomAppBar 卻沒有 TopAppBar 呢,以下是系統(tǒng)給生成的代碼,和 Windows 上的一樣。
<Page.BottomAppBar>
<CommandBar>
<AppBarButton Icon="Accept" Label="appbarbutton"/>
<AppBarButton Icon="Cancel" Label="appbarbutton"/>
</CommandBar>
</Page.BottomAppBar>
想要了解更多關于應用欄的內容,大家可以看這里喲:【萬里征程——Windows App開發(fā)】應用欄。
<Button Background="Red" BorderBrush="Blue" BorderThickness="5" Height="66" Width="153"/>
ClickMode:點擊模式,具體有 3 種:懸停(Hover)、按壓(Press)、釋放(Release)
更多建議: