summaryrefslogtreecommitdiffstats
path: root/kjsembed/docs/examples/eventhandling/jsboard.js
blob: 91e9a0f2a7b613b4fe05889d9ba3158a720a9054 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
#!/usr/bin/env kjscmd

// Globals
var frame = new QFrame(this);
var labels = new Array();
var startPos = new Point(0,0);
var lastPos = new Point(0,0);

frame.resize(300,300);
frame.paletteBackgroundColor = "blue";

var target = new Target(frame,"Target");
for( var idx = 0; idx < 3; ++idx)
  labels[idx] = new Block(frame, "Label " + idx);

frame.show();
application.exec();

function Target( parent, text)
{
  var x = Math.floor( Math.random() * parent.width );
  var y = Math.floor( Math.random() * parent.height );
  var w = 100;
  var h = 100;

  this.label = new QLabel(parent);
  this.text = text;
  this.label.paletteBackgroundColor = "green";
  this.label.geometry = new Rect(x,y,w,h);

  this.checkInside = function( objectRect )
  {
    return this.label.geometry.contains(objectRect);
  }

}

function Block(parent,text)
{
    this.label = new QLabel(parent);
    var x = Math.floor( Math.random() * parent.width );
    var y = Math.floor( Math.random() * parent.height );
    var w = 25;
    var h = 25;
    this.label.text = text;
    this.label.geometry = new Rect(x,y,w,h);
    this.label.frameShape = QFrame.WinPanel;
    this.label.frameShadow = QFrame.Plain;
    this.label.paletteBackgroundColor = "white";  
    this.label.setMouseTracking(true);
    this.label.adjustSize();
    
    // Event handlers
    this.label.mousePressEvent = function(ev)
    {
      //println("Press: " + this.text);
      startPos = this.pos;
      lastPos = ev.globalPos;
      println("Start: " + startPos.x() + "," + startPos.y());
      
    }
  
    this.label.mouseReleaseEvent = function(ev)
    {
      if( target.checkInside(this.geometry) )
	alert( "You got " + this.text + " on target!" );
      else
      {
	println("Reset: " + startPos.x() + "," + startPos.y());
	this.pos = startPos;
      }
    }
  
    this.label.mouseMoveEvent = function(ev)
    {
	if( ev.state == 1)
	{
	  var xDelta = ev.globalX - lastPos.x();
	  var yDelta = ev.globalY - lastPos.y();
	  this.move( this.x + xDelta, this.y + yDelta );
	  lastPos = ev.globalPos;
	}
    }
}