Unterschiede
Hier werden die Unterschiede zwischen zwei Versionen angezeigt.
| Beide Seiten der vorigen Revision Vorhergehende Überarbeitung Nächste Überarbeitung | Vorhergehende Überarbeitung | ||
|
xojo:objectnotifier:start [2021/04/01 15:53] mz |
xojo:objectnotifier:start [2021/04/06 07:27] (aktuell) mz [Object notification] |
||
|---|---|---|---|
| Zeile 1: | Zeile 1: | ||
| - | ====== Object | + | ====== Object |
| - | /* {{tag> }} */ | + | |
| - | {{indexmenu>.#3|ns tsort hsort nsort}} | + | <fs x-large> |
| + | |||
| + | <WRAP round download 40%> | ||
| + | **{{ : | ||
| + | |||
| + | {{ : | ||
| + | </WRAP> | ||
| + | |||
| + | |||
| + | This works similar to the built-in interfaces // | ||
| + | However the **ObjectChanged** method receives two parameters: an **Object** from the notifier and any **info** from the original subscriber.\\ | ||
| + | |||
| + | The **notifier** may send himself by setting " | ||
| + | The **subscriber** stores any sort of (static) information together with the callback-address when subscribing by // | ||
| + | This info may be a simple index number, but it can also be a whole object (means a reference to an object) so that the receiver can distinguish which subscription called him. | ||
| + | |||
| + | The **// | ||
| + | Simply instantiate this class and call their members like: | ||
| + | |||
| + | Declare: | ||
| + | private property onb as ObjectNotifierBox | ||
| + | in // | ||
| + | onb = new ObjectNotifierBox | ||
| + | Actual implementation of the // | ||
| + | Sub addObjectNotificationReceiver(receiver as objectNotificationReceiver, | ||
| + | | ||
| + | End Sub | ||
| + | |||
| + | Sub removeObjectNotificationReceiver(receiver As objectNotificationReceiver) | ||
| + | | ||
| + | End Sub | ||
| + | |||
| + | For calling all subscribed receivers write somewhere in your class: | ||
| + | |||
| + | onb.callReceivers(me) | ||
| + | |||
| + | Instead of " | ||
| + | |||
| + | <WRAP round important 100%> | ||
| + | Be careful with // | ||
| + | < | ||
| + | xy.addObjectNotificationReceiver(me, | ||
| + | xy.addObjectNotificationReceiver(me, | ||
| + | </ | ||
| + | Because // | ||
| + | It's therefore not possible to delete only the second entry (with //info// 2). | ||
| + | |||
| + | </ | ||
| + | |||
| + | |||
| + | |||
| + | ====== Sourcecode ====== | ||
| + | |||
| + | {{ : | ||
| - | ---- | ||
| ===== Interface objectNotifier ===== | ===== Interface objectNotifier ===== | ||
| Zeile 61: | Zeile 112: | ||
| Properties | Properties | ||
| | | ||
| - | mInfos() As Variant | + | |
| - | mReceivers() As objectNotificationReceiver | + | |
| | | ||
| End Class | End Class | ||