JQuery и flot в гаджете боковой панели Windows - PullRequest
1 голос
/ 06 февраля 2010

Я пытаюсь создать гаджет для боковой панели Windows с JQuery и flot .

Когда я запускаю гаджет в FF, график отображается нормально. Но когда я запускаю его из гаджета, он не работает. Я знаю, что код JQuery работает, потому что я могу использовать его для изменения HTML, стиля и т. Д.

Так что проблема в части флот.

Есть идеи? мысли?

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


HTML-код:

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />
    <script language="javascript" type="text/javascript" src="js/jquery.js"></script>
    <script language="javascript" type="text/javascript" src="js/jquery.flot.js"></script>
    <script language="javascript" type="text/javascript" src="js/Docked.js" ></script>
    <link href="css/Docked.css" rel="stylesheet" type="text/css" />
</head>
<body onload="CheckDockState();">
    <g:background id="imgBackground">
    <div id="gadgetContent">
    </div>
    </g:background>
</body>
</html>

Код JavaScript:

// Gadget width and height.
var gadgetWidth = 800;
var gadgetHeight = 800;

// Amount to scale gadget when docked or undocked.
var scaleDocked = 1;
var scaleUndocked = 2;

// Amount of time desired to perform transition (in seconds).
var timeTransition = 2;

// Declare the dock and undock event handlers.
try
{
    System.Gadget.onDock = CheckDockState;
    System.Gadget.onUndock = CheckDockState;
}
catch(err){}

// --------------------------------------------------------------------
// Check the gadget dock state; set the gadget style.
// --------------------------------------------------------------------
function CheckDockState()
{
    try
    {
        var oBackground = document.getElementById("imgBackground");
        System.Gadget.beginTransition();

        var oBody = document.body.style;
        if (System.Gadget.docked)
        {
            oBody.width = gadgetWidth*scaleDocked;
            oBody.height = gadgetHeight*scaleDocked;

            oBackground.src = "../images/bg_docked.png";

            //txtDocked.innerText = 'Docked';
            gadgetContent.innerHTML = 'Docked <button onclick="ShowChart();">press me</button>';
            gadgetContent.className = 'gadgetDocked';
        }
        else
        {
            oBody.width = gadgetWidth*scaleUndocked;
            oBody.height = gadgetHeight*scaleUndocked;  

            oBackground.src = "../images/bg_undocked.png";

            //txtDocked.innerText = 'Undocked';
            gadgetContent.innerHTML = 'Docked <button onclick="ShowChart();">press me</button>';
            gadgetContent.className = 'gadgetUndocked';
        }
        System.Gadget.endTransition(System.Gadget.TransitionType.morph, timeTransition);
    }
    catch(err)
    {
        // in a browser, some variables are different/missing then in the gadget, so i'm using this
        gadgetContent.innerHTML = 'Docked <button onclick="ShowChart();">press me</button>';
    }
}

function ShowChart()
{
    var d1 = [];
    for (var i = 0; i < 14; i += 0.5)
        d1.push([i, Math.sin(i)]);

    var d2 = [[0, 3], [4, 8], [8, 5], [9, 13]];

    // a null signifies separate line segments
    var d3 = [[0, 12], [7, 12], null, [7, 2.5], [12, 2.5]];

    // just to see the jquery works
    $("#gadgetContent").width(200);
    $("#gadgetContent").height(200);

    jQuery.plot($("#gadgetContent"), [ d1, d2, d3 ]);
}

Ответы [ 2 ]

1 голос
/ 06 февраля 2010

IE не поддерживает элемент <canvas>, но flot поддерживает excanvas , который эмулирует его с помощью VML. Загрузите excanvas и добавьте его в теги сценария, например

<script language="javascript" type="text/javascript" 
    src="js/excanvas.min.js"></script>

Кроме того, не оборачивайте тег g:background вокруг остальной части тела гаджета. Это не нужно, и хотя это работает, у вас могут возникнуть проблемы с обходом DOM. Просто откройте и закройте сразу:

<g:background id="imgBackground"></g:background>
<div id="gadgetContent"> 
</div>

Дополнительное примечание, так как FYI - beginTransition() и endTransition() устарели и не будут ничего делать в Windows 7. Это потому, что морфинг обычно выглядит немного мусорным. Вы можете оставить это для пользователей Vista, но я просто подумал, что дам вам знать.

0 голосов
/ 17 февраля 2010

Я без проблем использовал Google image API диаграмм в гаджетах боковой панели.

http://code.google.com/apis/chart/image_charts.html

Я не знаю, как API их интерактивных диаграмм ведет себя с гаджетами Windows.

...