Как поместить приложение Silverlight на страницу просмотра ASP MVC? - PullRequest
3 голосов
/ 02 июля 2010

Я работаю как с Silverlight, так и с asv mvc. Приложение silverlight выполняет запрос страницы, и он отлично работает (на тестовой странице, сгенерированной VS), но я не могу найти способ отобразить его.

MiniSIG

<div id="silverlightControlHost"> 

    <object data="data:application/x-silverlight-2," type="application/x-silverlight-2" width="100%" height="100%">


      <param name="source" value="/ClientBin/MiniSIG.xap"/>
      <param name="onError" value="onSilverlightError" />
      <param name="background" value="white" />
      <param name="minRuntimeVersion" value="3.0.40818.0" />
      <param name="autoUpgrade" value="true" />
      <a href="http://go.microsoft.com/fwlink/?LinkID=149156&v=3.0.40818.0" style="text-decoration:none">
          <img src="http://go.microsoft.com/fwlink/?LinkId=161376" alt="Get Microsoft Silverlight" style="border-style:none"/>
      </a>
    </object>

</div> 

Я перепробовал почти все (от размещения всего этого на странице Site.Master до загрузки Silverlight.js оттуда). Кто-нибудь может дать мне несколько советов, как мне это сделать?

Мой взгляд теперь выглядит так:

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
    <h2>MiniSIG</h2>

    <div id="silverlightControlHost"> 

        <object data="data:application/x-silverlight-2," type="application/x-silverlight-2" width="100%" height="100%">


          <param name="source" value="/ClientBin/MiniSIG.xap"/>
          <param name="onError" value="onSilverlightError" />
          <param name="background" value="white" />
          <param name="minRuntimeVersion" value="3.0.40818.0" />
          <param name="autoUpgrade" value="true" />
          <a href="http://go.microsoft.com/fwlink/?LinkID=149156&v=3.0.40818.0" style="text-decoration:none">
              <img src="http://go.microsoft.com/fwlink/?LinkId=161376" alt="Get Microsoft Silverlight" style="border-style:none"/>
          </a>
        </object>

    </div> 

</asp:Content>

И мой сайт. Мастер:

<head runat="server">
    <title><asp:ContentPlaceHolder ID="TitleContent" runat="server" /></title>
    <link href="../../Content/Site.css" rel="stylesheet" type="text/css" />
     <style type="text/css">
    html, body {
        height: 100%;
        overflow: auto;
    }
    body {
        padding: 0;
        margin: 0;
    }
    #silverlightControlHost {
        height: 100%;
        text-align:center;
    }
    </style>
    <script type="text/javascript" src="Silverlight.js"></script>
    <script type="text/javascript">
        function onSilverlightError(sender, args) {
            var appSource = "";
            if (sender != null && sender != 0) {
                appSource = sender.getHost().Source;
            }

            var errorType = args.ErrorType;
            var iErrorCode = args.ErrorCode;

            if (errorType == "ImageError" || errorType == "MediaError") {
                return;
            }

            var errMsg = "Unhandled Error in Silverlight Application " + appSource + "\n";

            errMsg += "Code: " + iErrorCode + "    \n";
            errMsg += "Category: " + errorType + "       \n";
            errMsg += "Message: " + args.ErrorMessage + "     \n";

            if (errorType == "ParserError") {
                errMsg += "File: " + args.xamlFile + "     \n";
                errMsg += "Line: " + args.lineNumber + "     \n";
                errMsg += "Position: " + args.charPosition + "     \n";
            }
            else if (errorType == "RuntimeError") {
                if (args.lineNumber != 0) {
                    errMsg += "Line: " + args.lineNumber + "     \n";
                    errMsg += "Position: " + args.charPosition + "     \n";
                }
                errMsg += "MethodName: " + args.methodName + "     \n";
            }

            throw new Error(errMsg);
        }
    </script>

</head>

Я не вижу здесь никакой проблемы, имена div одинаковы.

Ответы [ 2 ]

4 голосов
/ 02 июля 2010

Одна ошибка, которую я вижу, заключается в том, что перед папкой ClientBin должна быть косая черта ...

<param name="source" value="/ClientBin/MiniSIG.xap"/>

Кроме того, я бы включил этот код для обеспечения совместимости с Firefox:

<style type="text/css">     
#silverlightControlHost
{
  height: 100%;
}
</style>

<div id="silverlightControlHost"> 
  <!-- Silverlight object goes here -->
</div> 

(В противном случае приложение Silverlight будет свернуто и невидимо в Firefox.)

2 голосов
/ 05 июля 2010

Я решил проблему, используя половину решения, которое дал Стив Уортам: вместо того, чтобы набирать 100%, я набрал 480px, то есть размер моего приложения Silverlight, которое теперь работает и в Firefox.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...