SignalR в режиме реального времени Gauge

Я действительно надеюсь, что кто-то может мне помочь. Я пытаюсь построить датчик в реальном времени, который связан с SQL Server Express с signalR,

Вот мой код

Класс запуска

using System;
using System.Configuration;
using System.Threading.Tasks;
using Microsoft.Owin;`enter code here`
using Owin;
using Microsoft.AspNet.SignalR;

[assembly: OwinStartupAttribute(typeof(Real_Time_Gauge.Startup))]
namespace Real_Time_Gauge
{
    public class Startup
    {
        public void Configuration(IAppBuilder app)
        {
            app.MapSignalR();
        }
    }
}

Класс хаб

using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using Microsoft.AspNet.SignalR;
using System.Configuration;
using System.Data.SqlClient;
using System.Data;
using Microsoft.AspNet.SignalR.Hubs;

namespace Real_Time_Gauge
{
    public class GaugeHub : Hub
    {
        Int16 value = 0;
        [HubMethodName("sendNotifications")]
        public string SendNotifications()
        {
            using (var connection = new SqlConnection(ConfigurationManager.ConnectionStrings["GaugeConnection"].ConnectionString))
            {
                string query = "SELECT top 1 [value] FROM [Values]";
                connection.Open();
                using (SqlCommand command = new SqlCommand(query, connection))
                {
                    command.Notification = null;
                    DataTable dt = new DataTable();
                    SqlDependency dependency = new SqlDependency(command);
                    dependency.OnChange += new        `enter code here`
                    OnChangeEventHandler(dependency_OnChange);
                    if (connection.State == ConnectionState.Closed)


                        connection.Open();

                    var reader = command.ExecuteReader();
                    dt.Load(reader);
                    if (dt.Rows.Count > 0)
                    {
                        value = Int16.Parse(dt.Rows[0]["value"].ToString());
                    }
                }
            }
            IHubContext context = GlobalHost.ConnectionManager.GetHubContext<GaugeHub>();
            return context.Clients.All.RecieveNotification(value);
        }
        private void dependency_OnChange(object sender, SqlNotificationEventArgs e)
        {
            if (e.Type == SqlNotificationType.Change)
            {
                GaugeHub nHub = new GaugeHub();
                nHub.SendNotifications();

            }
        }
    }
}

web.config

<?xml version="1.0"?>


<configuration>
  <connectionStrings>
    <add name="GaugeConnection" connectionString="Server=72NHD02-PC\SQLEXPRESS;Database=SignalR;User Id=**;Password=*******;" providerName="System.Data.SqlClient" />
  </connectionStrings>
    <system.web>
      <compilation debug="true" targetFramework="4.5" />
      <httpRuntime targetFramework="4.5" />
    </system.web>

</configuration>

HTML и JavaScript

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    <title>Gauge Test</title>
    <link href="css/style.css" rel="stylesheet" />
    <script src="Scripts/jquery-1.6.4.min.js"></script>
    <script src="Scripts/jquery.signalR-2.2.0.min.js"></script>
    <script src="/signalr/hubs"></script>
    <script src="Scripts/gauge.min.js"></script>
    <script src="Scripts/script.js"></script>
    <script src="signalr/hubs"></script>
</head>
<body>

    <input type="text" id="value" />
    <canvas id="gauge"></canvas>

    <script type="text/javascript">
        var gauge = new Gauge({
            renderTo: 'gauge',
            width: document.body.offsetWidth,
            height: document.body.offsetHeight,
            glow: true,
            units: 'KPI',
            title: "Sales",
            minValue: 0,
            maxValue: 100,
            majorTicks: ['0', '10', '20', '30', '40', '50', '60', '70', '80', '90', '100'],
            minorTicks: 10,
            strokeTicks: false,
            highlights: [
                { from: 0, to: 40, color: 'rgb(237, 28,  36)' },
                { from: 40, to: 60, color: 'rgb(242, 101,  34)' },
                { from: 60, to: 70, color: 'rgb(247, 147,  29)' },
                { from: 70, to: 80, color: 'rgb(255, 242, 0)' },
                { from: 80, to: 100, color: 'rgb(0,   144, 58)' }
            ],
            colors: {
                plate: '#222',
                majorTicks: '#f5f5f5',
                minorTicks: '#ddd',
                title: '#fff',
                units: '#ccc',
                numbers: '#eee',
                needle: { start: 'rgba(240, 128, 128, 1)', end: 'rgba(255, 160, 122, .9)' }
            }
        });
        gauge.onready = function () {
            setInterval(function () {
                gauge.setValue($value);
            }, 1000);
        };
        gauge.draw();
        window.onresize = function () {
            gauge.updateConfig({
                width: document.body.offsetWidth,
                height: document.body.offsetHeight
            });
        };
    </script>
</body>
</html>

Калибровочный javascript

/// <reference path="jquery-1.6.4.min.js" />
/// <reference path="jquery.signalR-2.2.0.min.js" />


$(function() {
    // Declare a proxy to reference the hub.
    var notifications = $.connection.notificationHub;
    // Create a function that the hub can call to broadcast messages.
    notifications.client.recieveNotification = function () {
        // Add the message to the page.
        $('#value').text(value);
    };
    // Start the connection.
    $.connection.hub.start().done(function () {
        notifications.server.sendNotifications();
    }).fail(function (e) {
        alert(e);
    });
    //$.connection.hub.start();
});

$value = value;

Моя база данных называется SignalR со значениями в виде идентификатора таблицы =1 значение =80. Я был бы очень признателен за любую помощь, поскольку я новичок в signalR.

Спасибо

0 ответов

Другие вопросы по тегам