You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

EierUhrModel.java 1.8KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. /*
  2. * To change this license header, choose License Headers in Project Properties.
  3. * To change this template file, choose Tools | Templates
  4. * and open the template in the editor.
  5. */
  6. package EierUhrKomponente;
  7. import java.util.concurrent.ExecutorService;
  8. import java.util.concurrent.Executors;
  9. import java.util.concurrent.Flow;
  10. import java.util.concurrent.SubmissionPublisher;
  11. import java.util.logging.Level;
  12. import java.util.logging.Logger;
  13. import ohmlogger.OhmLogger;
  14. /**
  15. *
  16. * @author chris
  17. */
  18. public class EierUhrModel implements Runnable
  19. {
  20. private int zahl;
  21. private ExecutorService exe;
  22. private boolean laufend;
  23. private static Logger lg = OhmLogger.getLogger();
  24. private SubmissionPublisher<Integer> ipublisher;
  25. public EierUhrModel()
  26. {
  27. zahl = 100;
  28. exe = Executors.newSingleThreadExecutor();
  29. ipublisher = new SubmissionPublisher<>();
  30. }
  31. void start()
  32. {
  33. exe.submit(this);
  34. laufend = true;
  35. lg.info("Start Model");
  36. }
  37. public void initZahl(int zahl)
  38. {
  39. this.zahl = zahl;
  40. lg.info("Reset Zahl to: " + Integer.toString(zahl));
  41. start();
  42. }
  43. @Override
  44. public void run()
  45. {
  46. while(laufend)
  47. {
  48. lg.info(Integer.toString(zahl));
  49. if(zahl > 0)
  50. {
  51. try
  52. {
  53. Thread.sleep(1000);
  54. zahl -= 1;
  55. ipublisher.submit(zahl);
  56. }
  57. catch (InterruptedException ex)
  58. {
  59. lg.info("error: ");
  60. Logger.getLogger(EierUhrModel.class.getName()).log(Level.SEVERE, null, ex);
  61. }
  62. }
  63. else
  64. {
  65. lg.info("0 erreicht");
  66. stop();
  67. }
  68. }
  69. }
  70. public void addSubscription(Flow.Subscriber<Integer> subscriber)
  71. {
  72. ipublisher.subscribe(subscriber);
  73. }
  74. public void stop()
  75. {
  76. laufend = false;
  77. }
  78. }