WindDirection.java 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384
  1. package weerstation1;
  2. import java.util.ArrayList;
  3. public class WindDirection extends Grootheid{
  4. public WindDirection(Measurement measurement1, ArrayList<Measurement> measurement2){
  5. setName("Windrichting");
  6. updateRecent(measurement1);
  7. updatePeriod(measurement2);
  8. }
  9. public void updateRecent(Measurement measurement1){
  10. setCurrent(measurement1.getRawWindDir());
  11. }
  12. public void updatePeriod(ArrayList<Measurement> measurement2){
  13. createList(measurement2);
  14. maxMin();
  15. //modus();
  16. }
  17. public void displayGraph()
  18. {
  19. GUIboard.writePageToMatrix("", "West East", "");
  20. int x,y;
  21. int radius = 15;
  22. double degree= getCurrent();
  23. int x2 = 0;
  24. int y2 = 0;
  25. degree -= 90;
  26. if( degree < 0){
  27. degree += 360;
  28. }
  29. for(double i = 0; i< 360; i+= 1)
  30. {
  31. x = (int)(64 + (radius*Math.cos(i * Math.PI / 180)));
  32. y = (int)(16 + radius*Math.sin(i * Math.PI / 180));
  33. if(i == degree){
  34. x2 = x;
  35. y2 = y;
  36. }
  37. IO.writeShort(0x42, 1 << 12 | x << 5 | y);
  38. }
  39. line(64, 16, x2, y2);
  40. }
  41. public static void line(int x1,int y1,int x2, int y2) {
  42. if(x1 > x2)
  43. {
  44. int x3 = x1;
  45. x1 = x2;
  46. x2 = x3;
  47. int y3 = y1;
  48. y1 = y2;
  49. y2 = y3;
  50. }
  51. int x,y;
  52. int deltax = x2 - x1 ;
  53. int deltay = y2 - y1 ;
  54. for (x=x1; x<=x2; x++) {
  55. y = y1 + deltay * (x - x1) / deltax;
  56. IO.writeShort(0x42, 1 << 12 | x << 5 | y);
  57. }
  58. }
  59. private void createList(ArrayList<Measurement> measurement2)
  60. {
  61. if(!list.isEmpty())
  62. {
  63. list.clear();
  64. }
  65. for(Measurement ms : measurement2)
  66. {
  67. list.add( (double)ms.getRawWindDir());
  68. }
  69. }
  70. }