sl@56: //
sl@56: // Define a public API for both SharpDisplay client and server to use.
sl@56: //
sl@56:
sl@56: using System;
sl@24: using System.Collections.Generic;
sl@24: using System.Linq;
sl@24: using System.Text;
sl@24: using System.Threading.Tasks;
sl@24: using System.ServiceModel;
sl@24: using System.Collections;
sl@43: using System.Drawing;
sl@43: using System.Runtime.Serialization;
sl@24:
sl@24:
sl@55: namespace SharpDisplay
sl@24: {
sl@56: ///
sl@56: /// TextField can be send to our server to be displayed on the screen.
sl@56: ///
sl@43: [DataContract]
sl@43: public class TextField
sl@43: {
sl@43: public TextField()
sl@43: {
sl@43: Index = 0;
sl@43: Text = "";
sl@43: Alignment = ContentAlignment.MiddleLeft;
sl@43: }
sl@43:
sl@43: public TextField(int aIndex, string aText = "", ContentAlignment aAlignment = ContentAlignment.MiddleLeft)
sl@43: {
sl@43: Index = aIndex;
sl@43: Text = aText;
sl@43: Alignment = aAlignment;
sl@43: }
sl@43:
sl@43: [DataMember]
sl@43: public int Index { get; set; }
sl@43:
sl@43: [DataMember]
sl@43: public string Text { get; set; }
sl@43:
sl@43: [DataMember]
sl@43: public ContentAlignment Alignment { get; set; }
sl@43: }
sl@43:
sl@56: ///
sl@56: /// Define our SharpDisplay service.
sl@56: /// Clients and servers must implement it to communicate with one another.
sl@56: /// Through this service clients can send requests to a server.
sl@56: /// Through this service a server session can receive requests from a client.
sl@56: ///
sl@55: [ServiceContract( CallbackContract = typeof(ICallback), SessionMode = SessionMode.Required)]
sl@55: public interface IService
sl@24: {
sl@32: ///
sl@32: /// Set the name of this client.
sl@32: /// Name is a convenient way to recognize your client.
sl@32: /// Naming you client is not mandatory.
sl@32: /// In the absence of a name the session ID is often used instead.
sl@32: ///
sl@32: ///
sl@24: [OperationContract(IsOneWay = true)]
sl@32: void SetName(string aClientName);
sl@24:
sl@32: ///
sl@32: /// Put the given text in the given field on your display.
sl@32: /// Fields are often just lines of text.
sl@32: ///
sl@43: ///
sl@24: [OperationContract(IsOneWay = true)]
sl@43: void SetText(TextField aTextField);
sl@26:
sl@32: ///
sl@32: /// Allows a client to set multiple text fields at once.
sl@32: ///
sl@32: ///
sl@24: [OperationContract(IsOneWay = true)]
sl@43: void SetTexts(System.Collections.Generic.IList aTextFields);
sl@32:
sl@32: ///
sl@32: /// Provides the number of clients currently connected
sl@32: ///
sl@32: ///
sl@32: [OperationContract()]
sl@32: int ClientCount();
sl@32:
sl@24: }
sl@24:
sl@56: ///
sl@56: /// SharDisplay callback provides a means for a server to notify its clients.
sl@56: ///
sl@55: public interface ICallback
sl@24: {
sl@24: [OperationContract(IsOneWay = true)]
sl@24: void OnConnected();
sl@24:
sl@32: ///
sl@32: /// Tell our client to close its connection.
sl@32: /// Notably sent when the server is shutting down.
sl@32: ///
sl@24: [OperationContract(IsOneWay = true)]
sl@32: void OnCloseOrder();
sl@24: }
sl@24:
sl@24:
sl@24:
sl@24: }