0

我想制作推文的分析图,类似于以下网站链接

网站链接

我想知道开源中可用的最佳选择是什么?

我听说 Raphael.js 很好。其他建议?

4

1 回答 1

1

您列出的网站使用http://www.flotcharts.org。我以前成功使用过它。

编辑 5/25

Flot 包含一些优秀的文档,以及许多示例(示例可以在这里找到http://www.flotcharts.org/flot/examples/)。然而,为了简单起见,我采用了他们最简单的示例并删除了一些不需要的代码(示例来自http://www.flotcharts.org/flot/examples/basic-usage/index.html)。

代码示例

    <title>Flot Example</title>

    <!-- Import Flot Scripts -->
    <!--[if lte IE 8]><script language="javascript" type="text/javascript" src="../../excanvas.min.js"></script><![endif]-->
    <script language="javascript" type="text/javascript" src="../../jquery.js"></script>
    <script language="javascript" type="text/javascript" src="../../jquery.flot.js"></script>   
    <!-- /End Import Flot Scripts -->

    <script type="text/javascript">
    <!-- This is just a simple example, creating the data in-line. -->

    $(function() {

        // This will generate the curved line you will see on the page.
        var d1 = [];
        for (var i = 0; i < 14; i += 0.5) {
            d1.push([i, Math.sin(i)]);
        }

        // Create static data for second data series.
        var d2 = [[0, 3], [4, 8], [8, 5], [9, 13]];

        // A null signifies separate line segments
        // Create static data for third data series, with line segments.
        var d3 = [[0, 12], [7, 12], null, [7, 2.5], [12, 2.5]];

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

    </script>

    <style>
        <!-- These styles come from http://www.flotcharts.org/flot/examples/examples.css.
             The most important thing is that your chart needs a height and width set for it
             before you try to create it with JavaScript. -->
        .demo-container {
            box-sizing: border-box;
            width: 850px;
            height: 450px;
            padding: 20px 15px 15px 15px;
            margin: 15px auto 30px auto;
            border: 1px solid #ddd;
            background: #fff;
            background: linear-gradient(#f6f6f6 0, #fff 50px);
            background: -o-linear-gradient(#f6f6f6 0, #fff 50px);
            background: -ms-linear-gradient(#f6f6f6 0, #fff 50px);
            background: -moz-linear-gradient(#f6f6f6 0, #fff 50px);
            background: -webkit-linear-gradient(#f6f6f6 0, #fff 50px);
            box-shadow: 0 3px 10px rgba(0,0,0,0.15);
            -o-box-shadow: 0 3px 10px rgba(0,0,0,0.1);
            -ms-box-shadow: 0 3px 10px rgba(0,0,0,0.1);
            -moz-box-shadow: 0 3px 10px rgba(0,0,0,0.1);
            -webkit-box-shadow: 0 3px 10px rgba(0,0,0,0.1);
        }

        .demo-placeholder {
            width: 100%;
            height: 100%;
            font-size: 14px;
            line-height: 1.2em;
        }

        .legend table {
            border-spacing: 5px;
        }
    </style>
</head>
<body>

    <!-- Begin fancy chart container. -->
    <div class="demo-container">
        <!-- Begin chart placeholder. This is wher your chart will appear -->
        <div id="placeholder" class="demo-placeholder"></div>
        <!-- /End chart placeholder. -->
    </div>
    <!-- /End fancy chart container. -->

</body>
</html>

现在,您将希望从 PHP、.NET(或任何其他服务器端语言 - 或 - 使用 ajax 连接到 API)(可能会从 Twitter 或其他聚合数据源中提取数据)获取数据。但这必须是另一个问题!

于 2013-05-25T07:23:35.930 回答