如何在ASP.NET面板中更改Silverlight应用程序的高度?

时间:2012-02-03 05:57:14

标签: c# asp.net .net silverlight silverlight-4.0

如何动态更改ASP.NET面板中嵌入的Silverlight应用程序的高度?'

ASP.NET面板标记

<asp:Panel ID="pnlResult" runat="server" Visible="false">
<br />
<div class="cpHeader">
<asp:Label ID="Label1" runat="server" Text="Search Results"></asp:Label>
</div>
<asp:Panel ID="Panel3" runat="server" class='cpResultBody'>
</asp:Panel>
</asp:Panel>

我动态地将Silverlight添加到上面的ASP.NET面板Panel3,如下所示: (这样做是为了动态传递initparams)

HtmlGenericControl myHtmlObject = new HtmlGenericControl("object");
myHtmlObject.Attributes["data"] = "data:application/x-silverlight-2";
myHtmlObject.Attributes["type"] =  "application/x-silverlight-2";
HtmlGenericControl mySourceParam = new  HtmlGenericControl("param");
mySourceParam.Attributes["name"] = "source";
mySourceParam.Attributes["value"] = "ClientBin/MySilverlightApp.xap";
myHtmlObject.Controls.Add(mySourceParam);    
HtmlGenericControl myOnErrorParam = new HtmlGenericControl("param");   

HtmlGenericControl myInputParam = new HtmlGenericControl("param");
myInputParam.Attributes["name"] = "initparams";
myInputParam.Attributes["value"] = string.Format("param1={0},param2={1},param2={2}", param1.ToString(), param2.ToString(), param3.ToString());
myHtmlObject.Controls.Add(myInputParam);    

myHtmlObject.Attributes["width"] = "100%";
myHtmlObject.Attributes["height"] = "100%";

Panel3.Controls.Add(myHtmlObject);

最后我的MainPage.xaml如下。在这里,我没有设定身高。

<UserControl x:Class="MySilverlightApp.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
xmlns:my="clr-namespace:MySilverlightApp"
xmlns:sdk="http://schemas.microsoft.com/winfx/2006/xaml/presentation/sdk">
<Grid x:Name="LayoutRoot" Background="WhiteSmoke" >
<Canvas Name="canvas1" HorizontalAlignment="Left" Margin="-1,-1,0,0"
VerticalAlignment="Top"/>
</Grid>
</UserControl>

我的应用程序是这样的,一些数据在Canvas canvas1中表示为数字,其高度无法预先知道。

截至目前,Silverlight应用程序正在被削减。如何避免这种情况并确保根据内容放大高度。

观察:如果我手动将创建代码的silverlight对象中的Height100%更改为1500px,则高度似乎会增加一点,但即使我仍然会剪切内容进一步加高。

2 个答案:

答案 0 :(得分:1)

您可以这样做:当在浏览器中加载Silverlight控件(Loaded事件)时,向浏览器发送命令以增加托管控件的div以匹配控件的ActualHeight。 (Vb.net)

    'tell the web page to give Silverlight more room.
    Dim so As ScriptObject = TryCast(HtmlPage.Window.Eval("jsnamespace"), ScriptObject)
    so.Invoke("GrowDiv", LayoutRoot.ActualHeight)

这是剧本:

var jsnamespace = {

GrowDiv:function(divheight){         //警报(divheight);         jQuery(“body”)。css(“height”,divheight);         jQuery(“#silverlightControlHost”)。css(“height”,divheight);         jQuery(“#Panel3”)。css(“height”,divheight);     } }

答案 1 :(得分:0)

我对Silverlight的专家不多,但我对这个问题的快速反应是,修复Grid(layoutroot)的高度并允许滚动(水平和垂直,无论数据被剪裁的方式)然后提供固定高度HTML中的silverlight对象。