Compare commits
No commits in common. "541b49779617c5384e5e189d40705ab860f428be" and "0e719177275a9bdf5e337cd372b925a60d49e346" have entirely different histories.
541b497796
...
0e71917727
@ -37,6 +37,8 @@ public CommandController(ChatView view, GrafikModel model, GrafikController cont
|
|||||||
|
|
||||||
public void registerEvents(){
|
public void registerEvents(){
|
||||||
view.getBtnConnect().addActionListener(this);
|
view.getBtnConnect().addActionListener(this);
|
||||||
|
//ToDo: muss auf gFrame referenzieren
|
||||||
|
//view.getTfNachricht().addActionListener(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void registerCommands(){
|
public void registerCommands(){
|
||||||
|
|||||||
@ -51,6 +51,7 @@ public class CommandConnect implements CommandInterface
|
|||||||
lg.info("Server ausgewählt");
|
lg.info("Server ausgewählt");
|
||||||
try {
|
try {
|
||||||
commandSend.setTransmitter(new Server(view, model, gView));
|
commandSend.setTransmitter(new Server(view, model, gView));
|
||||||
|
//commandSend.transmitterInterface = new Server(view);
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
lg.info("Die Verbindung zum Server ist Fehlgeschlagen");
|
lg.info("Die Verbindung zum Server ist Fehlgeschlagen");
|
||||||
}
|
}
|
||||||
@ -60,6 +61,7 @@ public class CommandConnect implements CommandInterface
|
|||||||
lg.info("Client ausgewählt");
|
lg.info("Client ausgewählt");
|
||||||
try {
|
try {
|
||||||
commandSend.setTransmitter(new Client(view, model, gView));
|
commandSend.setTransmitter(new Client(view, model, gView));
|
||||||
|
//commandSend.transmitterInterface = new Client(view);
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
lg.info("Die Verbindung zum Client ist Fehlgeschlagen");
|
lg.info("Die Verbindung zum Client ist Fehlgeschlagen");
|
||||||
|
|
||||||
|
|||||||
@ -14,6 +14,7 @@ import ChatProgramm.util.OhmLogger;
|
|||||||
import ChatProgramm.view.ChatView;
|
import ChatProgramm.view.ChatView;
|
||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
import javax.swing.JTextField;
|
import javax.swing.JTextField;
|
||||||
|
import ChatProgramm.model.Nachricht;
|
||||||
import ChatProgramm.view.GrafikView;
|
import ChatProgramm.view.GrafikView;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -23,10 +24,10 @@ import ChatProgramm.view.GrafikView;
|
|||||||
public class CommandSend implements CommandInterface
|
public class CommandSend implements CommandInterface
|
||||||
{
|
{
|
||||||
private static Logger lg = OhmLogger.getLogger();
|
private static Logger lg = OhmLogger.getLogger();
|
||||||
|
private JTextField eingabeFeld;
|
||||||
|
private String nachricht;
|
||||||
private GrafikView view;
|
private GrafikView view;
|
||||||
private GrafikModel model;
|
private GrafikModel model;
|
||||||
|
|
||||||
public TransmitterInterface transmitterInterface;
|
public TransmitterInterface transmitterInterface;
|
||||||
public Server server;
|
public Server server;
|
||||||
public Client client;
|
public Client client;
|
||||||
@ -46,16 +47,21 @@ public class CommandSend implements CommandInterface
|
|||||||
@Override
|
@Override
|
||||||
public void execute()
|
public void execute()
|
||||||
{
|
{
|
||||||
|
lg.info("wir sind drin");
|
||||||
Figur aktuelleFigur = model.getFiguren().getLast();
|
Figur aktuelleFigur = model.getFiguren().getLast();
|
||||||
try
|
if(transmitterInterface != null){
|
||||||
{
|
|
||||||
transmitterInterface.send(aktuelleFigur);
|
transmitterInterface.send(aktuelleFigur);
|
||||||
|
}
|
||||||
|
else{
|
||||||
|
lg.info("Der Transmitter ist immernoch null");
|
||||||
|
}
|
||||||
|
//ToDo in dieser methode muss die Figur serialisiert werden und zum
|
||||||
|
//übermitteln bereitgestellt werden
|
||||||
|
|
||||||
}
|
// if(transmitterInterface != null && !eingabeFeld.getText().isEmpty()){
|
||||||
catch(Exception NullPointerExeption)
|
// transmitterInterface.send(eingabeFeld.getText());
|
||||||
{
|
// eingabeFeld.setText("");
|
||||||
lg.info("Der Transmitter ist null");
|
// }
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@ -4,7 +4,6 @@
|
|||||||
*/
|
*/
|
||||||
package ChatProgramm.model;
|
package ChatProgramm.model;
|
||||||
|
|
||||||
import ChatProgramm.util.OhmLogger;
|
|
||||||
import ChatProgramm.view.ChatView;
|
import ChatProgramm.view.ChatView;
|
||||||
import ChatProgramm.view.GrafikView;
|
import ChatProgramm.view.GrafikView;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@ -18,7 +17,7 @@ import java.util.logging.*;
|
|||||||
*/
|
*/
|
||||||
public class Client extends Transmitter {
|
public class Client extends Transmitter {
|
||||||
|
|
||||||
private static Logger lg = OhmLogger.getLogger();
|
private static Logger lg = Logger.getLogger("netz");
|
||||||
private static final int PORT = 35000; //lt. iana port > 2¹⁵
|
private static final int PORT = 35000; //lt. iana port > 2¹⁵
|
||||||
private static final String IP = "127.0.0.1";
|
private static final String IP = "127.0.0.1";
|
||||||
|
|
||||||
|
|||||||
@ -2,6 +2,7 @@
|
|||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||||
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||||
*/
|
*/
|
||||||
|
|
||||||
package ChatProgramm.model;
|
package ChatProgramm.model;
|
||||||
|
|
||||||
import java.awt.Point;
|
import java.awt.Point;
|
||||||
@ -19,32 +20,30 @@ import java.util.List;
|
|||||||
import java.util.logging.Logger;
|
import java.util.logging.Logger;
|
||||||
import java.util.prefs.Preferences;
|
import java.util.prefs.Preferences;
|
||||||
import ChatProgramm.util.OhmLogger;
|
import ChatProgramm.util.OhmLogger;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author le
|
* @author le
|
||||||
*/
|
*/
|
||||||
public class GrafikModel {
|
public class GrafikModel
|
||||||
|
{
|
||||||
private Figur aktuelleFigur;
|
private Figur aktuelleFigur;
|
||||||
private ArrayList<Figur> figuren;
|
private ArrayList<Figur> figuren;
|
||||||
private Preferences pref;
|
private Preferences pref;
|
||||||
private static Logger lg = OhmLogger.getLogger();
|
private static Logger lg = OhmLogger.getLogger();
|
||||||
|
|
||||||
public GrafikModel() {
|
public GrafikModel()
|
||||||
|
{
|
||||||
aktuelleFigur = new Figur();
|
aktuelleFigur = new Figur();
|
||||||
figuren = new ArrayList<>();
|
figuren = new ArrayList<>();
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addPoint(Point p) {
|
public void addPoint(Point p)
|
||||||
|
{
|
||||||
aktuelleFigur.addPoint(p);
|
aktuelleFigur.addPoint(p);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addFigure(Figur figur) {
|
public List<Point> getPunkte()
|
||||||
figuren.add(figur);
|
{
|
||||||
}
|
|
||||||
|
|
||||||
public List<Point> getPunkte() {
|
|
||||||
return aktuelleFigur.getPunkte();
|
return aktuelleFigur.getPunkte();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -52,9 +51,18 @@ public class GrafikModel {
|
|||||||
return Collections.unmodifiableList(figuren);
|
return Collections.unmodifiableList(figuren);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
public void endShape() {
|
public void endShape() {
|
||||||
figuren.add(aktuelleFigur);
|
figuren.add(aktuelleFigur);
|
||||||
aktuelleFigur = new Figur();
|
aktuelleFigur = new Figur();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void setFigur(Figur figur){
|
||||||
|
//aktuelleFigur = figur;
|
||||||
|
figuren.add(figur);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
31
src/ChatProgramm/model/Nachricht.java
Normal file
31
src/ChatProgramm/model/Nachricht.java
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
/*
|
||||||
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Licenses/license-default.txt to change this license
|
||||||
|
* Click nbfs://nbhost/SystemFileSystem/Templates/Classes/Class.java to edit this template
|
||||||
|
*/
|
||||||
|
|
||||||
|
package ChatProgramm.model;
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @author ahren
|
||||||
|
*/
|
||||||
|
public class Nachricht
|
||||||
|
{
|
||||||
|
private String nachricht;
|
||||||
|
|
||||||
|
public Nachricht(String nachricht)
|
||||||
|
{
|
||||||
|
this.nachricht = nachricht;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @return the nachricht
|
||||||
|
*/
|
||||||
|
public String getNachricht() {
|
||||||
|
return nachricht;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setNachricht(String nachricht) {
|
||||||
|
this.nachricht = nachricht;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -39,10 +39,12 @@ public class ReceiveAdapter implements Subscriber<Figur> {
|
|||||||
}
|
}
|
||||||
|
|
||||||
public void onNext(Figur item) {
|
public void onNext(Figur item) {
|
||||||
model.addFigure(item);
|
|
||||||
gView.drawFigur();
|
|
||||||
|
|
||||||
lg.info("Figur wurde dem Grafikmodel hinzugefügt");
|
lg.info("Figur wurde dem Grafikmodel hinzugefügt");
|
||||||
|
model.setFigur(item);
|
||||||
|
gView.drawFigur();
|
||||||
|
// evtl muss die Figur aber zuerst serialisiert werden
|
||||||
|
//view.getTxtChat().append(item.getNachricht());
|
||||||
this.subscription.request(1);
|
this.subscription.request(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@ -5,7 +5,6 @@
|
|||||||
|
|
||||||
package ChatProgramm.model;
|
package ChatProgramm.model;
|
||||||
|
|
||||||
import ChatProgramm.util.OhmLogger;
|
|
||||||
import ChatProgramm.view.ChatView;
|
import ChatProgramm.view.ChatView;
|
||||||
import ChatProgramm.view.GrafikView;
|
import ChatProgramm.view.GrafikView;
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
@ -18,14 +17,9 @@ import java.util.logging.*;
|
|||||||
*/
|
*/
|
||||||
public class Server extends Transmitter
|
public class Server extends Transmitter
|
||||||
{
|
{
|
||||||
private static Logger lg = OhmLogger.getLogger();
|
private static Logger lg = Logger.getLogger("netz");
|
||||||
private static final int PORT = 35000; //lt. iana port > 2¹⁵
|
private static final int PORT = 35000; //lt. iana port > 2¹⁵
|
||||||
|
|
||||||
public Server(ChatView view, GrafikModel model, GrafikView gView) throws IOException {
|
|
||||||
super(view, model, gView);
|
|
||||||
connect();
|
|
||||||
initIO();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void connect() throws IOException
|
public void connect() throws IOException
|
||||||
{
|
{
|
||||||
@ -41,5 +35,12 @@ public class Server extends Transmitter
|
|||||||
{
|
{
|
||||||
lg.warning("Timeout"+"("+timeout/1000+"s)");
|
lg.warning("Timeout"+"("+timeout/1000+"s)");
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
public Server(ChatView view, GrafikModel model, GrafikView gView) throws IOException {
|
||||||
|
super(view, model, gView);
|
||||||
|
connect();
|
||||||
|
initIO();
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -76,12 +76,17 @@ public abstract class Transmitter implements Runnable, Subscriber<Figur>, Transm
|
|||||||
InputStream is = socket.getInputStream();
|
InputStream is = socket.getInputStream();
|
||||||
OutputStream os = socket.getOutputStream();
|
OutputStream os = socket.getOutputStream();
|
||||||
|
|
||||||
|
|
||||||
|
// Bruh im ernst mann muss zuerst den writer und dann den reader initialisieren
|
||||||
|
// andersrum ist das blockiert weil die Streams von hinten nach vorne gelesen werden
|
||||||
writer = new ObjectOutputStream(os);
|
writer = new ObjectOutputStream(os);
|
||||||
writer.flush();
|
writer.flush();
|
||||||
|
|
||||||
reader = new ObjectInputStream(is);
|
reader = new ObjectInputStream(is);
|
||||||
|
|
||||||
lg.info("Reader / Writer Initialisierung abgeschlossen");
|
lg.info("Reader / Writer Initialisierung abgeschlossen");
|
||||||
startempfangen();
|
startempfangen();
|
||||||
|
lg.info("Warte auf Nachricht");
|
||||||
|
|
||||||
} catch (UnsupportedEncodingException ex) {
|
} catch (UnsupportedEncodingException ex) {
|
||||||
Logger.getLogger(Transmitter.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(Transmitter.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
@ -118,6 +123,7 @@ public abstract class Transmitter implements Runnable, Subscriber<Figur>, Transm
|
|||||||
if (receivedObject instanceof Figur) {
|
if (receivedObject instanceof Figur) {
|
||||||
lg.info("Figur erhalten");
|
lg.info("Figur erhalten");
|
||||||
figur = (Figur) receivedObject;
|
figur = (Figur) receivedObject;
|
||||||
|
// Verarbeiten Sie die empfangene Figur
|
||||||
}
|
}
|
||||||
} catch (IOException ex) {
|
} catch (IOException ex) {
|
||||||
Logger.getLogger(Transmitter.class.getName()).log(Level.SEVERE, null, ex);
|
Logger.getLogger(Transmitter.class.getName()).log(Level.SEVERE, null, ex);
|
||||||
@ -129,7 +135,11 @@ public abstract class Transmitter implements Runnable, Subscriber<Figur>, Transm
|
|||||||
return figur;
|
return figur;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// public void disconnect (){
|
||||||
|
// in.close();
|
||||||
|
// out.close();
|
||||||
|
// s.close();
|
||||||
|
// }
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
|
|||||||
@ -4,6 +4,7 @@
|
|||||||
*/
|
*/
|
||||||
package ChatProgramm.model;
|
package ChatProgramm.model;
|
||||||
|
|
||||||
|
import ChatProgramm.model.Nachricht;
|
||||||
/**
|
/**
|
||||||
*
|
*
|
||||||
* @author ahren
|
* @author ahren
|
||||||
|
|||||||
@ -30,7 +30,7 @@ import ChatProgramm.util.OhmLogger;
|
|||||||
*
|
*
|
||||||
* @author le
|
* @author le
|
||||||
*/
|
*/
|
||||||
public class GrafikView extends JComponent
|
public class GrafikView extends JComponent implements Printable
|
||||||
{
|
{
|
||||||
private static Logger lg = OhmLogger.getLogger();
|
private static Logger lg = OhmLogger.getLogger();
|
||||||
private static Dimension EINS = new Dimension(1, 1); // Dimension ist eine Klasse die width udn height hält
|
private static Dimension EINS = new Dimension(1, 1); // Dimension ist eine Klasse die width udn height hält
|
||||||
@ -109,4 +109,44 @@ public class GrafikView extends JComponent
|
|||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
public void doPrint()
|
||||||
|
{
|
||||||
|
HashPrintRequestAttributeSet printSet =
|
||||||
|
new HashPrintRequestAttributeSet();
|
||||||
|
printSet.add(DialogTypeSelection.NATIVE);
|
||||||
|
PrinterJob pj = PrinterJob.getPrinterJob();
|
||||||
|
pj.setPrintable(this);
|
||||||
|
//Dialog
|
||||||
|
if (pj.printDialog(printSet))
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
pj.print(printSet);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
JOptionPane.showMessageDialog(this, ex.toString());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int print(Graphics gp, PageFormat pf, int pageIndex) throws PrinterException
|
||||||
|
{
|
||||||
|
Graphics2D g2p = (Graphics2D)gp;
|
||||||
|
if (pageIndex == 0)
|
||||||
|
{
|
||||||
|
g2p.translate(pf.getImageableX(), pf.getImageableY());
|
||||||
|
g2p.scale(pf.getImageableWidth() / this.getWidth(),
|
||||||
|
pf.getImageableHeight() / this.getHeight());
|
||||||
|
super.print(g2p);
|
||||||
|
return Printable.PAGE_EXISTS;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
return Printable.NO_SUCH_PAGE; // wichtig sonst Papiervernichtung
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user