Thu, 04 Jun 2015 14:50:33 +0200
Genesis of lecture sources for Droidcon Berlin 2015 in Postbahnhof.
michael@0 | 1 | <!--- |
michael@0 | 2 | Licensed to the Apache Software Foundation (ASF) under one |
michael@0 | 3 | or more contributor license agreements. See the NOTICE file |
michael@0 | 4 | distributed with this work for additional information |
michael@0 | 5 | regarding copyright ownership. The ASF licenses this file |
michael@0 | 6 | to you under the Apache License, Version 2.0 (the |
michael@0 | 7 | "License"); you may not use this file except in compliance |
michael@0 | 8 | with the License. You may obtain a copy of the License at |
michael@0 | 9 | |
michael@0 | 10 | http://www.apache.org/licenses/LICENSE-2.0 |
michael@0 | 11 | |
michael@0 | 12 | Unless required by applicable law or agreed to in writing, |
michael@0 | 13 | software distributed under the License is distributed on an |
michael@0 | 14 | "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY |
michael@0 | 15 | KIND, either express or implied. See the License for the |
michael@0 | 16 | specific language governing permissions and limitations |
michael@0 | 17 | under the License. |
michael@0 | 18 | --> |
michael@0 | 19 | |
michael@0 | 20 | # org.apache.cordova.dialogs |
michael@0 | 21 | |
michael@0 | 22 | Questo plugin consente di accedere ad alcuni elementi di interfaccia utente nativa del dialogo. |
michael@0 | 23 | |
michael@0 | 24 | ## Installazione |
michael@0 | 25 | |
michael@0 | 26 | cordova plugin add org.apache.cordova.dialogs |
michael@0 | 27 | |
michael@0 | 28 | |
michael@0 | 29 | ## Metodi |
michael@0 | 30 | |
michael@0 | 31 | * `navigator.notification.alert` |
michael@0 | 32 | * `navigator.notification.confirm` |
michael@0 | 33 | * `navigator.notification.prompt` |
michael@0 | 34 | * `navigator.notification.beep` |
michael@0 | 35 | |
michael@0 | 36 | ## navigator.notification.alert |
michael@0 | 37 | |
michael@0 | 38 | Mostra una finestra di avviso o la finestra di dialogo personalizzata. La maggior parte delle implementazioni di Cordova una dialogo nativa per questa caratteristica, ma alcune piattaforme utilizzano il browser `alert` funzione, che è in genere meno personalizzabile. |
michael@0 | 39 | |
michael@0 | 40 | navigator.notification.alert(message, alertCallback, [title], [buttonName]) |
michael@0 | 41 | |
michael@0 | 42 | |
michael@0 | 43 | * **messaggio**: messaggio finestra di dialogo. *(String)* |
michael@0 | 44 | |
michael@0 | 45 | * **alertCallback**: Callback da richiamare quando viene chiusa la finestra di avviso. *(Funzione)* |
michael@0 | 46 | |
michael@0 | 47 | * **titolo**: titolo di dialogo. *(String)* (Opzionale, default è`Alert`) |
michael@0 | 48 | |
michael@0 | 49 | * **buttonName**: nome del pulsante. *(String)* (Opzionale, default è`OK`) |
michael@0 | 50 | |
michael@0 | 51 | ### Esempio |
michael@0 | 52 | |
michael@0 | 53 | function alertDismissed() { |
michael@0 | 54 | // do something |
michael@0 | 55 | } |
michael@0 | 56 | |
michael@0 | 57 | navigator.notification.alert( |
michael@0 | 58 | 'You are the winner!', // message |
michael@0 | 59 | alertDismissed, // callback |
michael@0 | 60 | 'Game Over', // title |
michael@0 | 61 | 'Done' // buttonName |
michael@0 | 62 | ); |
michael@0 | 63 | |
michael@0 | 64 | |
michael@0 | 65 | ### Piattaforme supportate |
michael@0 | 66 | |
michael@0 | 67 | * Amazon fuoco OS |
michael@0 | 68 | * Android |
michael@0 | 69 | * BlackBerry 10 |
michael@0 | 70 | * Firefox OS |
michael@0 | 71 | * iOS |
michael@0 | 72 | * Tizen |
michael@0 | 73 | * Windows Phone 7 e 8 |
michael@0 | 74 | * Windows 8 |
michael@0 | 75 | |
michael@0 | 76 | ### Windows Phone 7 e 8 stranezze |
michael@0 | 77 | |
michael@0 | 78 | * Non non c'è nessun avviso del browser integrato, ma è possibile associare uno come segue per chiamare `alert()` in ambito globale: |
michael@0 | 79 | |
michael@0 | 80 | window.alert = navigator.notification.alert; |
michael@0 | 81 | |
michael@0 | 82 | |
michael@0 | 83 | * Entrambi `alert` e `confirm` sono non di blocco chiamate, risultati di cui sono disponibili solo in modo asincrono. |
michael@0 | 84 | |
michael@0 | 85 | ### Firefox OS Stranezze: |
michael@0 | 86 | |
michael@0 | 87 | Entrambi nativi di blocco `window.alert()` e non bloccante `navigator.notification.alert()` sono disponibili. |
michael@0 | 88 | |
michael@0 | 89 | ## navigator.notification.confirm |
michael@0 | 90 | |
michael@0 | 91 | Visualizza una finestra di dialogo conferma personalizzabile. |
michael@0 | 92 | |
michael@0 | 93 | navigator.notification.confirm(message, confirmCallback, [title], [buttonLabels]) |
michael@0 | 94 | |
michael@0 | 95 | |
michael@0 | 96 | * **messaggio**: messaggio finestra di dialogo. *(String)* |
michael@0 | 97 | |
michael@0 | 98 | * **confirmCallback**: Callback da richiamare con l'indice del pulsante premuto (1, 2 o 3) o quando la finestra di dialogo viene chiusa senza una pressione del pulsante (0). *(Funzione)* |
michael@0 | 99 | |
michael@0 | 100 | * **titolo**: titolo di dialogo. *(String)* (Opzionale, default è`Confirm`) |
michael@0 | 101 | |
michael@0 | 102 | * **buttonLabels**: matrice di stringhe che specificano le etichette dei pulsanti. *(Matrice)* (Opzionale, default è [ `OK,Cancel` ]) |
michael@0 | 103 | |
michael@0 | 104 | ### confirmCallback |
michael@0 | 105 | |
michael@0 | 106 | Il `confirmCallback` viene eseguito quando l'utente preme uno dei pulsanti nella finestra di dialogo conferma. |
michael@0 | 107 | |
michael@0 | 108 | Il callback accetta l'argomento `buttonIndex` *(numero)*, che è l'indice del pulsante premuto. Nota che l'indice utilizza l'indicizzazione base uno, quindi il valore è `1` , `2` , `3` , ecc. |
michael@0 | 109 | |
michael@0 | 110 | ### Esempio |
michael@0 | 111 | |
michael@0 | 112 | function onConfirm(buttonIndex) { |
michael@0 | 113 | alert('You selected button ' + buttonIndex); |
michael@0 | 114 | } |
michael@0 | 115 | |
michael@0 | 116 | navigator.notification.confirm( |
michael@0 | 117 | 'You are the winner!', // message |
michael@0 | 118 | onConfirm, // callback to invoke with index of button pressed |
michael@0 | 119 | 'Game Over', // title |
michael@0 | 120 | ['Restart','Exit'] // buttonLabels |
michael@0 | 121 | ); |
michael@0 | 122 | |
michael@0 | 123 | |
michael@0 | 124 | ### Piattaforme supportate |
michael@0 | 125 | |
michael@0 | 126 | * Amazon fuoco OS |
michael@0 | 127 | * Android |
michael@0 | 128 | * BlackBerry 10 |
michael@0 | 129 | * Firefox OS |
michael@0 | 130 | * iOS |
michael@0 | 131 | * Tizen |
michael@0 | 132 | * Windows Phone 7 e 8 |
michael@0 | 133 | * Windows 8 |
michael@0 | 134 | |
michael@0 | 135 | ### Windows Phone 7 e 8 stranezze |
michael@0 | 136 | |
michael@0 | 137 | * Non non c'è nessuna funzione browser incorporato per `window.confirm` , ma è possibile associare assegnando: |
michael@0 | 138 | |
michael@0 | 139 | window.confirm = navigator.notification.confirm; |
michael@0 | 140 | |
michael@0 | 141 | |
michael@0 | 142 | * Chiama al `alert` e `confirm` sono non bloccante, quindi il risultato è disponibile solo in modo asincrono. |
michael@0 | 143 | |
michael@0 | 144 | ### Firefox OS Stranezze: |
michael@0 | 145 | |
michael@0 | 146 | Entrambi nativi di blocco `window.confirm()` e non bloccante `navigator.notification.confirm()` sono disponibili. |
michael@0 | 147 | |
michael@0 | 148 | ## navigator.notification.prompt |
michael@0 | 149 | |
michael@0 | 150 | Visualizza una finestra di dialogo nativa che è più personalizzabile del browser `prompt` funzione. |
michael@0 | 151 | |
michael@0 | 152 | navigator.notification.prompt(message, promptCallback, [title], [buttonLabels], [defaultText]) |
michael@0 | 153 | |
michael@0 | 154 | |
michael@0 | 155 | * **messaggio**: messaggio finestra di dialogo. *(String)* |
michael@0 | 156 | |
michael@0 | 157 | * **promptCallback**: Callback da richiamare con l'indice del pulsante premuto (1, 2 o 3) o quando la finestra di dialogo viene chiusa senza una pressione del pulsante (0). *(Funzione)* |
michael@0 | 158 | |
michael@0 | 159 | * **titolo**: dialogo titolo *(String)* (opzionale, default è`Prompt`) |
michael@0 | 160 | |
michael@0 | 161 | * **buttonLabels**: matrice di stringhe specificando il pulsante etichette *(Array)* (opzionale, default è`["OK","Cancel"]`) |
michael@0 | 162 | |
michael@0 | 163 | * **defaultText**: valore di input predefinito textbox ( `String` ) (opzionale, Default: stringa vuota) |
michael@0 | 164 | |
michael@0 | 165 | ### promptCallback |
michael@0 | 166 | |
michael@0 | 167 | Il `promptCallback` viene eseguito quando l'utente preme uno dei pulsanti nella finestra di dialogo richiesta. Il `results` oggetto passato al metodo di callback contiene le seguenti proprietà: |
michael@0 | 168 | |
michael@0 | 169 | * **buttonIndex**: l'indice del pulsante premuto. *(Numero)* Nota che l'indice utilizza l'indicizzazione base uno, quindi il valore è `1` , `2` , `3` , ecc. |
michael@0 | 170 | |
michael@0 | 171 | * **INPUT1**: il testo immesso nella finestra di dialogo richiesta. *(String)* |
michael@0 | 172 | |
michael@0 | 173 | ### Esempio |
michael@0 | 174 | |
michael@0 | 175 | function onPrompt(results) { |
michael@0 | 176 | alert("You selected button number " + results.buttonIndex + " and entered " + results.input1); |
michael@0 | 177 | } |
michael@0 | 178 | |
michael@0 | 179 | navigator.notification.prompt( |
michael@0 | 180 | 'Please enter your name', // message |
michael@0 | 181 | onPrompt, // callback to invoke |
michael@0 | 182 | 'Registration', // title |
michael@0 | 183 | ['Ok','Exit'], // buttonLabels |
michael@0 | 184 | 'Jane Doe' // defaultText |
michael@0 | 185 | ); |
michael@0 | 186 | |
michael@0 | 187 | |
michael@0 | 188 | ### Piattaforme supportate |
michael@0 | 189 | |
michael@0 | 190 | * Amazon fuoco OS |
michael@0 | 191 | * Android |
michael@0 | 192 | * Firefox OS |
michael@0 | 193 | * iOS |
michael@0 | 194 | * Windows Phone 7 e 8 |
michael@0 | 195 | |
michael@0 | 196 | ### Stranezze Android |
michael@0 | 197 | |
michael@0 | 198 | * Android supporta un massimo di tre pulsanti e ignora di più di quello. |
michael@0 | 199 | |
michael@0 | 200 | * Su Android 3.0 e versioni successive, i pulsanti vengono visualizzati in ordine inverso per dispositivi che utilizzano il tema Holo. |
michael@0 | 201 | |
michael@0 | 202 | ### Firefox OS Stranezze: |
michael@0 | 203 | |
michael@0 | 204 | Entrambi nativi di blocco `window.prompt()` e non bloccante `navigator.notification.prompt()` sono disponibili. |
michael@0 | 205 | |
michael@0 | 206 | ## navigator.notification.beep |
michael@0 | 207 | |
michael@0 | 208 | Il dispositivo riproduce un bip sonoro. |
michael@0 | 209 | |
michael@0 | 210 | navigator.notification.beep(times); |
michael@0 | 211 | |
michael@0 | 212 | |
michael@0 | 213 | * **volte**: il numero di volte per ripetere il segnale acustico. *(Numero)* |
michael@0 | 214 | |
michael@0 | 215 | ### Esempio |
michael@0 | 216 | |
michael@0 | 217 | // Beep twice! |
michael@0 | 218 | navigator.notification.beep(2); |
michael@0 | 219 | |
michael@0 | 220 | |
michael@0 | 221 | ### Piattaforme supportate |
michael@0 | 222 | |
michael@0 | 223 | * Amazon fuoco OS |
michael@0 | 224 | * Android |
michael@0 | 225 | * BlackBerry 10 |
michael@0 | 226 | * iOS |
michael@0 | 227 | * Tizen |
michael@0 | 228 | * Windows Phone 7 e 8 |
michael@0 | 229 | * Windows 8 |
michael@0 | 230 | |
michael@0 | 231 | ### Amazon fuoco OS stranezze |
michael@0 | 232 | |
michael@0 | 233 | * Amazon fuoco OS riproduce il **Suono di notifica** specificato sotto il pannello **Impostazioni/Display e il suono** predefinito. |
michael@0 | 234 | |
michael@0 | 235 | ### Stranezze Android |
michael@0 | 236 | |
michael@0 | 237 | * Android giochi default **Notification ringtone** specificato sotto il pannello **impostazioni/audio e Display** . |
michael@0 | 238 | |
michael@0 | 239 | ### Windows Phone 7 e 8 stranezze |
michael@0 | 240 | |
michael@0 | 241 | * Si basa su un file generico bip dalla distribuzione di Cordova. |
michael@0 | 242 | |
michael@0 | 243 | ### Tizen stranezze |
michael@0 | 244 | |
michael@0 | 245 | * Tizen implementa bip di riproduzione di un file audio tramite i media API. |
michael@0 | 246 | |
michael@0 | 247 | * Il file beep deve essere breve, deve essere situato un `sounds` sottodirectory della directory radice dell'applicazione e deve essere denominato`beep.wav`. |