好了,从这节起,我们可能要暂时远离我们的象棋库了,因为我们要开始进入一些周边的事情了。
像登陆啊,登陆后创建房间大厅啊,进入后除了象棋还有用户列表,聊天窗口等等,中间少不了WCF通讯。
好了,开始登陆小节,先上一张小图:
看,多简洁,一个ID一个昵称一个登陆就完了。虽然简洁,可是也会有很多想法的。
不过想法待会再说,新建页面先:对着Silverlight应用程序右键-》添加新建项-》Silverlight用户控件
-》输入:Login.xaml
回车一页面就出来了。
往页面里拉两个TextBlock,两个TextBox,一个Button[双击后就有一个Click事件了],如下:
<TextBox Height="23" HorizontalAlignment="Left" Margin="37,68,0,0" Name="txtNickName" VerticalAlignment="Top" Width="143" />
<Button Content="登陆" Height="23" HorizontalAlignment="Left" Margin="65,109,0,0" Name="btnLogin" VerticalAlignment="Top" Width="75" Click="btnLogin_Click" />
<TextBlock Height="23" HorizontalAlignment="Left" Margin="6,68,0,0" Name="textBlock1" Text="昵称:" VerticalAlignment="Top" Width="35" />
<TextBox Height="23" HorizontalAlignment="Left" Margin="37,29,0,0" Name="txtUserID" VerticalAlignment="Top" Width="143" />
<TextBlock Height="23" HorizontalAlignment="Left" Margin="6,29,0,0" Name="textBlock2" Text="ID:" VerticalAlignment="Top" />
</Grid>
改下名称改下ID,噢,注意,没ID了,全都是Name了。
好,界面有好,双击那个Button也有btnLogin_Click事件了。
我们右键,查看代码,进入cs代码页面:
我们先看一下btnLogin_Click事件写什么代码:
全局变量:
string nickName = "";//昵称
事件代码:
{
nickName = txtNickName.Text.Trim();
if (nickName == "")
{
MessageBox.Show("请输入昵称!");
return;
}
if (nickName.Contains(","))
{
MessageBox.Show("昵称不能包含非法字符!");
return;
}
btnLogin.IsEnabled = false;
//设置Cookie
System.Windows.Browser.HtmlPage.Document.Cookies =userID + "," + nickName;
//紧接着转到房间页面去,咋转?
}
对昵称进行判断,然后写Cookie,之后页面转向,这里少了一个ID,还有就是页面咋转的问题。
为什么这里不对ID是不是为空进行判断?因为我们要补充一个Load方法,让页面加载时,先从Cookie里读读看有没有用户ID和昵称,
有的话就直接显示在文件框上:
{
InitializeComponent();
Load();
}
private void Load()
{
LoadFromCookie();
txtUserID.Text = userID.ToString();
txtUserID.IsReadOnly = true;
txtNickName.Text = nickName;
}
private void LoadFromCookie()
{
string cookies = System.Windows.Browser.HtmlPage.Document.Cookies;
if (cookies.Contains(","))
{
string[] para = cookies.Split(',');
if (para.Length == 2 && para[0].Length == Guid.Empty.ToString().Length)
{
userID = new Guid(para[0]);
nickName = para[1];
return;
}
}
userID = Guid.NewGuid();
}
最长一点的就是从Cookie里拿ID和昵称,按“,”号分隔下,如果没Cookie,默认就的ID就NewGuid()一下了。
读取后,我们默认给txtUserID设置了值并设置为只读,所以啊,我们的Click事件里并没有对ID进行处理了。
接下来我们来看看怎么转向?其实转向啊,博园里就有相关文章了,很N个人写过,不过都是一个样的,谁是第二手来源已说不清了。
不过原创的一定是微软官方了。
我们看一下Silverlight应用程序下,是不是有一个App.xaml,我们点进去看看它的代码,看下这行:
{
this.RootVisual = new MainPage();
}
默认第一手启动的是MainPage,如果我们换成new Login(),那启动的首页面就是Login页了。
不过了,这里不是设为Login就算了,我们再看看这下代码:
private void Application_Startup(object sender, StartupEventArgs e)
{
this.RootVisual = root;
root.Children.Add(new Login());
}
public void RedirectTo(Control ct)
{
root.Children.Clear();
root.Children.Add(ct);
}
看到没有,小小改动了两行代码,只要调用RedirectTo方法,来切换root控件,就可以实现转向了。
这里我们顺便改一下另一行代码,最下面那行:
private void ReportErrorToDOM(ApplicationUnhandledExceptionEventArgs e)
{
try
{
string errorMsg = e.ExceptionObject.Message + e.ExceptionObject.StackTrace;
errorMsg = errorMsg.Replace('"', '\'').Replace("\r\n", @"\n");
System.Windows.Browser.HtmlPage.Window.Eval("throw new Error(\"Unhandled Error in Silverlight Application " + errorMsg + "\");");
}
catch (Exception)
{
}
}
//我们把它改成这样:
private void ReportErrorToDOM(ApplicationUnhandledExceptionEventArgs e)
{
try
{
string errorMsg = e.ExceptionObject.Message + e.ExceptionObject.StackTrace;
errorMsg = errorMsg.Replace('"', '\'').Replace("\r\n", @"\n");
System.Windows.Browser.HtmlPage.Window.Alert("Error: " + errorMsg );
}
catch (Exception)
{
}
}
其实就是把Eval改成Alert,这样在出现未捕获异常的时候,弹出下说明就行了,不用弹出那个调试器。
OK了,转向函数已经有了,我们可以在登陆页里写上转行代码了:
((App)(Application.Current)).RedirectTo(new MainPage());
我们运行F5一下看下效果:
起始登陆:
点击登陆,转入MainPage页
OK,正常转向了。
登陆就先讲到这了,当然,随着WCF通讯开始后,我们肯定会回来登陆页做很多事情,而且会在App里也初始化很多代码的。
下节,我们创建房间大厅,然后让转向转到房间大厅里。