Benutzer:J*/Ka-Mel-Oh/Testgelände/Notizzettel: Unterschied zwischen den Versionen
< Benutzer:J* | Ka-Mel-Oh | Testgelände
Zur Navigation springen
Zur Suche springen
J* (Diskussion | Beiträge) (Die Seite wurde neu angelegt.) |
K (Textersetzung - „http://kamelopedia.mormo.org/“ durch „http://kamelopedia.net/“) |
||
| (8 dazwischenliegende Versionen von einem anderen Benutzer werden nicht angezeigt) | |||
| Zeile 1: | Zeile 1: | ||
| − | / | + | __NOTOC__ |
| + | __NEWSECTIONLINK__ | ||
| + | ==Framework: Array.prototype und Async== | ||
| + | ab jetzt im Verzeichnis [[Kamel:J*/lib|lib]] zu finden! | ||
| + | ==Klassenarchitektur der Karten== | ||
| + | <!-- | ||
| + | function X () | ||
| + | { | ||
| + | this.constructor(1,2,3,4) | ||
| + | } | ||
| + | X.prototype = new Card() | ||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | + | function add(a,b,c,d) | |
| − | + | { | |
| − | + | a = new Function( "this.constructor(" + | |
| − | + | parseInt(a) + "," + | |
| − | + | parseInt(b) + "," + | |
| − | + | parseInt(c) + "," + | |
| + | parseInt(d) + ")" | ||
| + | ); | ||
| + | a.prototype = new Card(); | ||
| + | return a; | ||
| + | } | ||
| + | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | + | fkt1 = add(1,2,3,4); | |
| − | + | fkt2 = add(2,7,8,9); | |
| − | + | fkt2.prototype.hooks.bla = | |
| − | |||
| − | |||
| − | |||
| − | |||
| − | + | c = new fkt2(); | |
| − | + | c instanceof fkt2 | |
| − | + | --> | |
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | + | == Wiki-Klasse == | |
| − | + | Achtung, wichtig: Umstellen auf api.php und JSON: | |
| − | + | http://kamelopedia.net/api.php?format=jsonfm&indexpageids&action=query&prop=revisions&titles=Hauptseite&rvprop=ids|flags|timestamp|user|content|comment | |
| − | + | ... und dann den Timestamp zum Schreiben benutzen (vorher .replace(/[^0-9]/g, "")!) | |
| − | |||
| − | |||
| − | |||
| − | |||
| − | + | Aktuelle version läuft aber schon im lib-Verzeichnis. | |
| − | |||
| − | |||
| − | |||
| − | + | == UI == | |
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | |||
| − | if ( | + | <!-- |
| + | dragger = { | ||
| + | item: null, | ||
| + | const: {pickupPrecision: 10, dropPrecision: 30}, | ||
| + | object: { | ||
| + | original: {x: NaN, y: NaN}, | ||
| + | current: {x: NaN, y:NaN} | ||
| + | }, | ||
| + | pointer: { | ||
| + | original: {x: NaN, y:NaN}, | ||
| + | current: {x: NaN, y:NaN} | ||
| + | }, | ||
| + | handler: { klick: null, drag: null, drop: null }, | ||
| + | dropzones: [ ], | ||
| + | pickup: function (e) { | ||
| + | if (dragger.item != null) | ||
| + | return; | ||
| + | dragger.object.original.x = this.offsetLeft; | ||
| + | dragger.object.original.y = this.offsetTop; | ||
| + | dragger.pointer.original.x = dragger.pointer.current.x; | ||
| + | dragger.pointer.original.y = dragger.pointer.current.y; | ||
| + | dragger.item=this; | ||
| + | return false; | ||
| + | }, | ||
| + | mouseMove: function (e) { | ||
| + | dragger.pointer.current.x = document.all ? window.event.clientX : e.pageX; | ||
| + | dragger.pointer.current.y = document.all ? window.event.clientY : e.pageY; | ||
| + | if (dragger.item != null) | ||
{ | { | ||
| − | + | dragger.drag(); | |
| − | |||
} | } | ||
| − | if ( | + | }, |
| + | drag: function () { | ||
| + | dragger.object.current.y = dragger.object.original.y + dragger.pointer.current.y - dragger.pointer.original.y; | ||
| + | dragger.object.current.x = dragger.object.original.x + dragger.pointer.current.x - dragger.pointer.original.x; | ||
| + | dragger.item.style.top = dragger.object.current.y + "px"; | ||
| + | dragger.item.style.left = dragger.object.current.x + "px"; | ||
| + | }, | ||
| + | drop: function () { | ||
| + | if ( Math.abs(dragger.object.original.x - dragger.object.current.x) < dragger.const.pickupPrecision && | ||
| + | Math.abs(dragger.object.original.y - dragger.object.current.y) < dragger.const.pickupPrecision ) | ||
{ | { | ||
| − | + | dragger.item.style.top = dragger.object.original.y + "px"; | |
| − | + | dragger.item.style.left = dragger.object.original.x + "px"; | |
| + | var d = dragger.item; | ||
| + | dragger.item = null; | ||
| + | if ( dragger.handler.klick != null ) | ||
| + | dragger.handler.klick( d ) | ||
} | } | ||
| − | } | + | dragger.item = null; |
| + | } | ||
| + | } | ||
| + | document.onmousemove = dragger.mouseMove; | ||
| + | document.onmouseup = dragger.drop; | ||
| + | |||
| + | for(c=0;c<(l=document.getElementsByClassName("handcard").length);c++) | ||
| + | { | ||
| + | document.getElementsByClassName("handcard")[c].onmousedown = dragger.pickup; | ||
} | } | ||
| + | --> | ||
| − | + | == Hat nix mit Ka-Mel-Oh zu tun, aber weils so schön ist == | |
| − | // | + | <!-- |
| + | //document.getElementById("bodyContent").innerHTML += "<iframe id='bw'></iframe>"; | ||
| + | //document.getElementById("bw").style.width="100%" | ||
| + | //document.getElementById("bw").style.height="400px" | ||
| + | //document.getElementById("bw").style.border="1px transparent solid" | ||
| − | + | var histTitle= "Hauptseite"; | |
| − | + | var histRevQuery="{{#dpl: titlematch=Hauptseite|skipthispage=no|namespace=|firstrevisionsince=20040101|format=,%REVISION%}}" | |
| − | + | hist = new Async( [ | |
| − | function( | + | function () { return { wiki: {source: histRevQuery, title: histTitle}}; }, |
| − | + | wiki.parse, | |
| − | + | function (e) { a = (parseInt("0"+e.wiki.HTML.replace(/[^0-9]/g,""))); document.getElementById("bw").href=wgServer+wgScript+"/" } | |
| − | + | ]) | |
| − | |||
| − | |||
| − | ] | ||
| − | + | hist.start(); | |
| + | --> | ||
Aktuelle Version vom 3. Januar 2014, 03:43 Uhr
Framework: Array.prototype und Async[<small>bearbeiten</small>]
ab jetzt im Verzeichnis lib zu finden!
Klassenarchitektur der Karten[<small>bearbeiten</small>]
Wiki-Klasse[<small>bearbeiten</small>]
Achtung, wichtig: Umstellen auf api.php und JSON:
http://kamelopedia.net/api.php?format=jsonfm&indexpageids&action=query&prop=revisions&titles=Hauptseite&rvprop=ids%7Cflags%7Ctimestamp%7Cuser%7Ccontent%7Ccomment
... und dann den Timestamp zum Schreiben benutzen (vorher .replace(/[^0-9]/g, "")!)
Aktuelle version läuft aber schon im lib-Verzeichnis.