WinCE6.0中实现SilverLight for Embedded界面中的框架效果

这段时间在考虑如何在SilverLight for Embedded(SE)中实现向网页的框架那样的效果,有若干个独立的XAML来组成一个页面。奋斗了好多天,网上实在是无法找到代码,搜啊搜,最终无意中在MSDN上找到解决方案,我晕啊,全英文,看的够呛。

 

//------------------------------------------------

int WINAPI WinMain(HINSTANCE hInstance,
                   HINSTANCE hPrevInstance,
                   LPTSTR    lpCmdLine,
                   int       nCmdShow)
{

if (!XamlRuntimeInitialize())
   return -1;
 IXRFrameworkElementPtr root;
 HRESULT retcode;
 IXRApplicationPtr app;
 XRWindowCreateParams wp;
 IXRVisualHostPtr vhost;
 
 if (FAILED(retcode=GetXRApplicationInstance(&app)))
    return -1;

 if (FAILED(retcode=app->AddResourceModule(hInstance)))
    return -1;

 ZeroMemory(&wp, sizeof(XRWindowCreateParams));
 wp.Style       = WS_OVERLAPPED;
 wp.pTitle      = L"S4E Test";
 wp.Left        = 0;
 wp.Top         = 0;

 XRXamlSource xamlsrc;
 
 xamlsrc.SetFile(L"//storage card/page.xaml");
 
 app->ParseXaml(&xamlsrc,&root);

 if (FAILED(retcode=app->CreateHostFromElementTree(root,&wp,&vhost)))
  return -1;

 

//#####以上部分的代码很多地方都有的参考,可以直接跳过##################

//######重点来了,以下代码展示如何把另外一个xaml文件中的内容作为一个部分放到page.xaml文件的StackPanel中
 IXRFrameworkElementPtr root1;
 XRXamlSource xamlsrc1;
 
 xamlsrc1.SetFile(L"//storage card/UserControl1.xaml");


 //app->ParseXaml(&xamlsrc1,&root1); //注意这个地方,这个方法是把xaml文件解析为一个IXRDependencyObject对象

 IXRStackPanelPtr canvas;
 root->FindName(L"spanel1",&canvas); //page.xaml文件的StackPanel的name为spanel1

 

//注意这个地方,重点中的重点啊,否则就不行啦,研究MSDN帮助的成果啊

//ParseXamlWithExistingRoot,这个方式是解析Xaml文件并把它加入到一个已经存在的visual tree的root当中

//MSDN英文原文如下:This method parses the source XAML and adds it to an existing root in the visual tree.

app->ParseXamlWithExistingRoot(&xamlsrc1,canvas);

 

//############################################################## 

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值