monitor de temperatura

Post on 19-Jan-2016

36 Views

Category:

Documents

0 Downloads

Preview:

Click to see full reader

DESCRIPTION

Monitor de Temperatura. OBJETIVO. Monitoreo de Temperatura en Salas de Computo Elaborar graficas de comportamiento Envío de Alertas. Termómetro Digital interfase Serial. Diagrama de Clases de Persistencia. Capas significativas de la Aplicaci ó n. Vista. Servicios. Integración. .Net. - PowerPoint PPT Presentation

TRANSCRIPT

Monitor de Temperatura

OBJETIVO

Monitoreo de Temperatura en Salas de Computo

Elaborar graficas de comportamiento

Envío de Alertas

Termómetro Digital interfase Serial

Diagrama de Clases de Persistencia

class System

Ubicacion

- IdUbicacion: int- Descripcion: char- Volumen: int

Lectura

- IdLectura: int- Valor: int- Fecha: int- Hora: int

Alarm

- IdAlarm: int- Status: boolean- Max: int- Min: int

Unidad

- IdUnidad: int- NombreUnidad: int- Status: boolean

AlarmLog

- IdAlarmLog: int- Hora: int- Fecha: int

1 0..*

1

1

1

0..*

1

1

1

0..*

1 1..*

.Net

Vista Servicios Integración

Capas significativas de la Aplicación

Mapeo de capas con Vista Física

Vista -> Administrador Web, MotorTemperatura.exeServicios -> MonitorTemperatura.Operaciones , EmailIntegración -> MonitorTemperatura.DataAccess : Acceso a Servidor DB4O

Vistas

Configuracion DB4O Client/Server

Iniciar Servidor

class Monitor {...private void buttonStart_Click(object sender, EventArgs e) { Comun c = new Comun(); c.AsyncStartServer(); }

}

class Comun{...public delegate void MethodDelegate();

public void AsyncStartServer() { MethodDelegate dlgt = startServer; IAsyncResult ar = dlgt.BeginInvoke(null,null); } private void startServer() { StartServer server = new StartServer(); server.RunServer(); }}

Cliente

Operaciones

Configuracion DB4O Client/ServerClass StartServer : Util {…public void RunServer() { lock (this) { try { IObjectServer server = Db4oFactory.OpenServer(YapFileName, PORT); server.GrantAccess(USER, PASS); server.Ext().Configure().ClientServer().SetMessageRecipient(this); try { if (!this.stop) { Monitor.Wait(this); } } catch (Exception exception) { System.Diagnostics.EventLog.WriteEntry("MonitorTemperatura", exception.ToString()); } server.Close(); } catch (Exception ex) { System.Diagnostics.EventLog.WriteEntry("MonitorTemperatura", ex.ToString()); } }}

Acceso a Datos

Configuracion DB4O Client/Server

Detener Servidor

class Monitor {...private void buttonStop_Click(object sender, EventArgs e) { Comun c = new Comun(); c.stopServer(); }}

class Comun{... public void stopServer() { StopServer.Stop(); }}

Cliente

Operaciones

Configuracion DB4O Client/Server

Class StopServer : Util{

public static void Stop() { IObjectContainer container = null; try { container = Db4oFactory.OpenClient("localhost", PORT, USER, PASS); } catch (Exception exception) { System.Diagnostics.EventLog.WriteEntry("MonitorTemperatura", exception.ToString()); } if (container != null) { container.Ext().Configure().ClientServer().GetMessageSender().Send(new StopServer()); container.Close(); } }}

Acceso a Datos

Configuracion Base de Datos public class Util { public static readonly string ServerPassword = "password"; public static readonly string ServerUser = "user“; public static readonly string YapFileName = “MonitorTemperaturaDB.yap"; public static readonly string PASS = "db4o"; public static readonly string HOST = "localhost"; public static readonly int PORT = 0x1188; public static readonly string USER = "db4o";}

public class ComunDAO { private IObjectContainer OpenFileRemote() { IObjectContainer db = Db4oFactory.OpenClient(Util.HOST, Util.PORT, Util.USER, Util.PASS); ConfigureDBObjects(); return db; } private void CloseFile(IObjectContainer db) { db.Close(); } private void ConfigureDBObjects() // Permite la Actualizacion de Objetos y el Borrado en Cascada { Db4oFactory.Configure().ObjectClass(typeof(Ubicacion)).CascadeOnUpdate(true); Db4oFactory.Configure().ObjectClass(typeof(Ubicacion)).CascadeOnDelete(true); }}

Queries public class UbicacionDAO { public Hashtable ObtenerUbicaciones(Ubicacion filtro) {

db = OpenFileRemote(); list = db.QueryByExample(filtro); Hashtable t = GetDataTable(list); CloseFile(db); return t; } public Ubicacion ObtenerUbicacion(Ubicacion filtro) { return ObtenerUbicacion(filtro,true); } public Ubicacion ObtenerUbicacion(Ubicacion filtro, bool closedb) {

db = OpenFileRemote(); list = db.QueryByExample(filtro); Ubicacion obj2=null; if (list.Count > 0) { obj2 = (Ubicacion)list.Next(); } if (closedb) CloseFile(db); return obj2; }

Grabado public class UbicacionDAO { public void GrabarUbicacion(Ubicacion obj) { UbicacionDAO dao = new UbicacionDAO(); dao.GrabarUbicacion(obj); }

public void GrabarLecturas(Ubicacion obj) { UbicacionDAO dao = new UbicacionDAO();

Ubicacion filtro = new Ubicacion(); Ubicacion obj2; if( obj.IdUbicacion>0) filtro.IdUbicacion = obj.IdUbicacion; obj2 = (Ubicacion)dao.ObtenerUbicacion(filtro,false); // false-> no cierra la conexion para actualizalo if (obj2!= null) { obj2.Estado = obj.Estado; if (obj.Lecturas[0] != null) { obj.Lecturas[0].idLectura = (obj2.Index+1).ToString(); obj2.Lecturas[obj2.Index] = obj.Lecturas[0]; obj2.Index++; } .

Grabado ...

dao.GrabarUbicacion(obj2); } else { obj.Estado = true; dao.GrabarUbicacion(obj); } }

}

Class UbicacionDAO{ public void GrabarUbicacion(Ubicacion obj) { GrabarUbicacion(obj, true); }

public void GrabarUbicacion(Ubicacion obj, bool closedb) { db = OpenFileRemote(); db.Store(obj); if (closedb) CloseFile(db); }}

Borrado de Datospublic class ComunDAO {

.

.

. public void DeleteAll() { IObjectContainer db = OpenFileRemote(); Util.DeleteAll(db); CloseFile(db); }}

public class Util {... public static void DeleteAll(IObjectContainer db) { object obj = new object(); IObjectSet set = db.QueryByExample(obj); foreach (object obj2 in set) { db.Delete(obj2); } }}

Simulación de Lecturaspublic class Lector {

private void startReader() { stop = true; EstablecerEstadoBotones(); int i = 1; int top = int.Parse(ConfigurationManager.AppSettings["MaxLecturas"].Trim()); while (i < top && stop) { double val = ObtenerLectura(); labelLectura.Text = val.ToString() + " °C"; GrabarLectura(val); i++; } }

private static double ObtenerLectura() { return RandomDouble(15,70); }...

Simulación de Lecturas... private void GrabarLectura(double val, bool agregarlectura) { UbicacionOP op = new MonitorTemperatura.Operciones.UbicacionOP(); Ubicacion obj = new Ubicacion(); obj.IdUbicacion = int.Parse(ConfigurationManager.AppSettings["IdUbicacion"].Trim()); obj.Descripcion = ConfigurationManager.AppSettings["Descripcion"].Trim(); obj.Estado = stop; if (agregarlectura) { Lectura l = new Lectura(); l.Tipounidad.IdUnidad = ConfigurationManager.AppSettings["TipoUnidad"].Trim(); l.Valor = val; l.Fecha = System.DateTime.Now; l.Hora = System.DateTime.Now; obj.Lecturas[0] = l; } op.GrabarLecturas(obj);

}}

Configuracion Cliente

<configuration><appSettings>

<add key="IdUbicacion" value="1" /><add key="Descripcion" value="Ubicacion Prueba 1" /><add key="TipoUnidad" value="1" /><add key="MaxLecturas" value="20" /><add key="WebAdmin"

value="http://localhost/MonitorTemperatura.View/Default.aspx" /></appSettings>

</configuration>

top related