/usr/share/help/el/hig-book/hig-ch-feedback.xml is in gnome-devel-docs 3.8.1-1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
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 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 | <?xml version="1.0" encoding="utf-8"?>
<chapter id="feedback" lang="el">
<title>Ανάδραση</title>
<sect1 id="feedback-responsiveness">
<title>Χαρακτηριστικά απαντητικών εφαρμογών</title>
<para>Αν και υψηλά απαντητικές εφαρμογές μπορεί να διαφέρουν πολύ από μία στην άλλη, μοιράζονται τα ακόλουθα χαρακτηριστικά:</para>
<itemizedlist>
<listitem>
<para>Δίνουν άμεση ανάδραση στους χρήστες, ακόμα κι όταν δεν μπορούν να εκπληρώσουν αμέσως τα αιτήματά τους.</para>
</listitem>
<listitem>
<para>Χειρίζονται τα αιτήματα σε ουρά όπως θα περίμεναν οι χρήστες, απορρίπτοντας αιτήματα που δεν είναι πια σχετικά και αναδιατάσσοντας τα αιτήματα σύμφωνα με τις πιθανές προτεραιότητες του χρήστη.</para>
</listitem>
<listitem>
<para>Επιτρέπουν στους χρήστες να κάνουν άλλη εργασία ενώ χρονοβόρες λειτουργίες προχωρούν - ιδιαίτερα λειτουργίες που δεν ζητήθηκαν από τους χρήστες - όπως αυτές που ζητούν αχρησιμοποίητη μνήμη ή άλλες λειτουργίες "τακτοποίησης".</para>
</listitem>
<listitem>
<para>Παρέχουν αρκετή ανάδραση για χρήστες στην κατανόηση της εκτέλεσης την οργάνωση ανάδρασης σύμφωνα με τις δυνατότητες κατανόησης και αντίδρασης των χρηστών.</para>
</listitem>
<listitem>
<para>Αφήνουν τους χρήστες να γνωρίζουν πότε η διαδικασία εξελίσσεται.</para>
</listitem>
<listitem>
<para>Επιτρέπουν την γνώση ή εκτίμηση του απαιτούμενου χρόνου των λειτουργιών από τους χρήστες.</para>
</listitem>
<listitem>
<para>Επιτρέπουν οι χρήστες να ορίσουν τον ρυθμό εργασίας, όταν είναι δυνατό και οι χρήστες μπορούν να σταματήσουν τις ζητούμενες εργασίες που έχουν αρχίσει αλλά δεν έχουν τελειώσει.</para>
</listitem>
</itemizedlist>
<!-- CB-Ed: Collapse some of the items in the list above, they are similar or have lots of overlap. -->
<para>Υψηλά απαντητικές εφαρμογές επιτρέπουν στους χρήστες τον έλεγχο με γρήγορη αναγνώριση κάθε αιτήματος του χρήστη, δίνοντας συνεχή ανάδραση της προόδου εκπλήρωσης κάθε αιτήματος και επιτρέποντας στους χρήστες την ολοκλήρωση εργασιών χωρίς απαράδεκτες καθυστερήσεις.</para>
<para>Ακόμα και σε εφαρμογές με ελκυστικές, διαισθητικές διεπαφές χρήστη μπορεί να λείπει η απαντητικότητα. Τυπικά, μη αποκρινόμενες εφαρμογές έχουν τουλάχιστον ένα από τα ακόλουθα προβλήματα:</para>
<itemizedlist>
<listitem>
<para>Παρέχουν αργή ανάδραση - ή και καθόλου - στα αιτήματα των χρηστών, αφήνοντας τους χρήστες να διερωτώνται τι έχει κάνει ή κάνει τώρα η εφαρμογή.</para>
</listitem>
<listitem>
<para>Όταν εκτελούνται εκτεταμένες λειτουργίες, αποτρέπουν τους χρήστες από την εκτέλεση άλλης εργασίας ή ακυρώνουν την εκτεταμένη λειτουργία.</para>
</listitem>
<listitem>
<para>Αποτυγχάνουν να εμφανίσουν εκτιμήσεις διάρκειας εκτεταμένων λειτουργιών, εξαναγκάζοντας τους χρήστες να περιμένουν απρόβλεπτες περιόδους.</para>
</listitem>
<listitem>
<para>Αγνοούν τα αιτήματα των χρηστών ενώ εκτελούν μη ζητούμενες "τακτοποιήσεις", εξαναγκάζοντας τους χρήστες να περιμένουν απρόβλεπτο χρόνο - συχνά χωρίς ανάδραση.</para>
</listitem>
</itemizedlist>
<para>Μπορείτε μερικές φορές ενδεχομένως να βελτιώσετε την απόκριση μιας εφαρμογής χωρίς να επιταχύνετε τον κώδικα της εφαρμογής. Για συμβουλές εκτέλεσης τέτοιων βελτιώσεων, δείτε <xref linkend="feedback-responding-to-user"/>.</para>
</sect1>
<sect1 id="feedback-response-times">
<title>Αποδεκτοί χρόνοι απόκρισης</title>
<para>Μερικά συμβάντα διεπαφής χρήστη απαιτούν μικρότερες καθυστερήσεις απόκρισης από άλλες. Για παράδειγμα, η απόκριση μιας εφαρμογής στο πάτημα ποντικιού ή το πάτημα πλήκτρου χρειάζονται να είναι πολύ γρηγορότερα από την απόκριση του σε ένα αίτημα αποθήκευσης αρχείου. Ο παρακάτω πίνακας δείχνει τη μέγιστη αποδεκτή καθυστέρηση απάντησης για τυπικά συμβάντα διεπαφής.</para>
<table frame="all">
<title>Μέγιστοι αποδεκτοί χρόνοι απόκρισης για τυπικά συμβάντα</title>
<tgroup align="left" cols="2">
<thead>
<row>
<entry>Συμβάν γραφικής διεπαφής</entry>
<entry>Μέγιστος επιτρεπόμενο χρόνος απόκρισης</entry>
</row>
</thead>
<tbody>
<row>
<entry>Πάτημα ποντικιού, κίνηση δείκτη, κίνηση ή αυξομείωση παραθύρων, πληκτρολόγηση, πάτημα κουμπιού, σχεδίαση πράξης, άλλο γραφικό συμβάν UI που σχετίζεται με τον συντονισμό χεριού-ματιού</entry>
<entry>0.1 δευτερόλεπτο</entry>
</row>
<row>
<entry>Εμφάνιση δεικτών προόδου, ολοκληρώνοντας κοινές εντολές χρήστη (π.χ. κλείσιμο ενός παραθύρου) ή εργασίες παρασκηνίου (π.χ. αναμόρφωση πίνακα)</entry>
<entry>1.0 δευτερόλεπτο</entry>
</row>
<row>
<entry>Εμφάνιση γραφήματος ή οτιδήποτε άλλου που ένας τυπικός χρήστης θα μπορούσε να περιμένει να πάρει χρόνο (π.χ. εμφάνιση μιας νέας λίστας όλων των οικονομικών συναλλαγών μιας εταιρείας για μια λογιστική περίοδο)</entry>
<entry>10.0 δευτερόλεπτα</entry>
</row>
<row>
<entry>Αποδοχή και εκτέλεση όλης των καταχωρίσεων του χρήστη για κάθε εργασία</entry>
<entry>10.0 δευτερόλεπτα</entry>
</row>
</tbody>
</tgroup>
</table>
<para>Κάντε κάθε καθυστέρηση απόκρισης στην εφαρμογή σας όσο το δυνατό πιο σύντομη, εκτός και οι χρήστες χρειάζονται χρόνο να δουν την εμφανιζόμενη πληροφορία πριν σβηστεί. Η αποδεκτή καθυστέρηση απάντησης για κάθε συμβάν βασίζεται στην αίσθηση ενός τυπικού χρήστη ότι το συμβάν είναι ένα λογικό σημείο στο οποίο σταματά ή διακόπτει. Όσο μεγαλύτερη είναι αυτή η αίσθηση, τόσο περισσότερο πρόθυμα θα περιμένει ο χρήστης για μια απόκριση. Επιβεβαιώστε ότι η εφαρμογή σας αποκρίνεται στα αιτήματα του χρήστη μέσα στα καταχωρημένα όρια στον παραπάνω πίνακα. Εάν η εφαρμογή σας δεν μπορεί να αποκριθεί μέσα σε αυτά τα όρια, θα έχει προφανώς ένα ή περισσότερα γενικά προβλήματα που προκαλούνται από ένα συγκεκριμένο αλγόριθμο ή άρθρωμα.</para>
<itemizedlist>
<title>Κατευθυντήριες γραμμές</title>
<listitem>
<para>Επιβεβαιώστε ότι η εφαρμογή σας παρέχει ανάδραση μέσα σε 100 ms (0,1 δεύτερα) μετά από κάθε πάτημα πλήκτρου, κίνηση του ποντικιού, ή άλλη φυσική καταχώριση από τον χρήστη.</para>
</listitem>
<listitem>
<para>Επιβεβαιώστε ότι η εφαρμογή σας παρέχει ανάδραση μέσα σε 100 ms (0,1 δεύτερα) μετά από κάθε αλλαγή στην κατάσταση των ελέγχων που αντιδρούν στην εισαγωγή από τον χρήστη - για παράδειγμα, εμφάνιση μενού ή ένδειξη απόθεσης στόχων.</para>
</listitem>
<listitem>
<para>Επιβεβαιώστε ότι η εφαρμογή σας δεν χρειάζεται πάνω από 1 δεύτερο να εμφανίσει κάθε δείκτη προόδου, να ολοκληρώσει κάθε κοινή εντολή του χρήστη, ή να ολοκληρώσει κάθε εργασία παρασκηνίου.</para>
</listitem>
<listitem>
<para>Επιβεβαιώστε ότι η εφαρμογή σας δεν χρειάζεται πάνω από 10 δευτερόλεπτα να αποδεχθεί και να επεξεργαστεί κάθε καταχώριση του χρήστη σε οποιαδήποτε εργασία - συμπεριλαμβάνοντας την καταχώριση του χρήστη σε κάθε βήμα μιας πολυσταδιακής εργασίας, όπως ενός οδηγού.</para>
</listitem>
</itemizedlist>
</sect1>
<sect1 id="feedback-responding-to-user">
<title>Απόκριση στα αιτήματα του χρήστη</title>
<para>Αν η εφαρμογή σας αργεί αρκετά στην απόκριση, οι χρήστες θα απογοητευθούν. Χρησιμοποιήστε αυτές τις τεχνικές για να βελτιώσετε τις αποκρίσεις της εφαρμογής σας.</para>
<itemizedlist>
<title>Κατευθυντήριες γραμμές</title>
<listitem>
<para>Εμφανίστε την ανάδραση όσο πιο σύντομα γίνεται.</para>
</listitem>
<listitem>
<para>Αν δεν μπορείτε να εμφανίσετε όλες τις πληροφορίες που ο χρήστης έχει ζητήσει, εμφανίστε πρώτα τις πιο σημαντικές από αυτές.</para>
</listitem>
<listitem>
<para>Κερδίστε χρόνο εμφανίζοντας προσεγγιστικά αποτελέσματα κατά τον υπολογισμό των τελικών αποτελεσμάτων.</para>
</listitem>
<listitem>
<para>Εάν οι χρήστες είναι πιθανό να επαναλάβουν μια χρονοβόρα εντολή σε γρήγορη διαδοχή, γλιτώστε χρόνο καλύπτοντας τα αποτελέσματα της εντολής αντί για κατ' επανάληψη επεξεργασία της εντολής. Για παράδειγμα, εάν ο χρήστης προσθέτει αρκετές γραμμές σε έναν αποθηκευμένο πίνακα σε μια βάση δεδομένων, μπορείτε να εμφανίσετε κάθε νέα γραμμή αμέσως αλλά να καθυστερήσετε στην πραγματικότητα τη δημιουργία κάθε νέας γραμμής στη βάση δεδομένων μέχρι ο χρήστης να έχει τελειώσει την προσθήκη όλων των γραμμών.</para>
</listitem>
<listitem>
<para>Προεργασία. Προετοιμάστε την εκτέλεση της εντολής που είναι πιο πιθανό να ακολουθήσει την τρέχουσα εντολή. Δηλαδή, χρησιμοποιήστε αδρανή χρόνο για να προβλέψετε τα πιθανά επόμενα αιτήματα του χρήστη. Για παράδειγμα, καθώς ο χρήστης μιας εφαρμογής μηνύματος διαβάζει το τρέχον εμφανιζόμενο νέο μήνυμα, η εφαρμογή μπορεί να προετοιμάσει την εμφάνιση του επόμενου νέου μηνύματος.</para>
</listitem>
<listitem>
<para>Χρησιμοποιήστε τη διαδικασία στο παρασκήνιο. Εκτελέστε τις λιγότερο σημαντικές εργασίες - όπως οι τακτοποιήσεις - στο παρασκήνιο, δίνοντας τη δυνατότητα στους χρήστες να συνεχίσουν να δουλεύουν.</para>
</listitem>
<listitem>
<para>Καθυστερήστε τις εργασίες που δεν επείγουν. Εκτελέστε τις αργότερα, όταν υπάρχει περισσότερος διαθέσιμος χρόνος.</para>
</listitem>
<listitem>
<para>Απορρίψτε περιττές λειτουργίες. Για παράδειγμα, την οπισθοδρόμηση αρκετών σελίδων σε έναν περιηγητή ιστού, ένας χρήστης μπορεί να πατήσει το κουμπί του περιηγητή <guibutton>πίσω</guibutton> αρκετές φορές σε μια γρήγορη διαδοχή. Για προβολή της τελικής ζητούμενης σελίδας πιο γρήγορα, ο περιηγητής μπορεί να μην εμφανίσει τις διαβασμένες σελίδες μεταξύ της τρέχουσας σελίδας και αυτής της τελικής σελίδας.</para>
</listitem>
<listitem>
<para>Χρησιμοποιήστε δυναμική διαχείριση χρόνου. Στον χρόνο εκτέλεσης, αλλάξτε τις προτεραιότητες καταχώρισης του χρήστη και άλλων διεργασιών, με βάση την τρέχουσα κατάσταση της εφαρμογής. Για παράδειγμα, εάν ο χρήστης πληκτρολογεί κείμενο σε ένα έγγραφο επεξεργασίας κειμένου ενώ εκτυπώνει ένα άλλο, η εφαρμογή επεξεργασίας κειμένου μπορεί να καθυστερήσει την εργασία εκτύπωσης εάν ο χρήστης μετακινηθεί σε μια εργασία επεξεργασίας (όπως αποκοπή και επικόλληση κειμένου) που απαιτεί μεγαλύτερους πόρους.</para>
</listitem>
<listitem>
<para>Στην εφαρμογή σας, εμφανίστε μία εκτίμηση του χρόνου εκτέλεσης κάθε λειτουργίας.</para>
<itemizedlist>
<listitem>
<para>Εάν η εντολή μπορεί να πάρει περισσότερο από 5 δευτερόλεπτα για ολοκλήρωση της εργασία της σε ένα αντικείμενο, επιτρέψτε στους χρήστες να αλληλεπιδράσουν με οποιαδήποτε μέρη του αντικειμένου και της εφαρμογής που δεν επηρεάζονται άμεσα από την εντολή.</para>
</listitem>
<listitem>
<para>Εάν μια εντολή παρέχει μεγάλη έξοδο, εμφανίστε μερικά αποτελέσματα καθώς γίνονται διαθέσιμα. Κυλήστε τα αποτελέσματα (εάν είναι απαραίτητο) μέχρι ο χρήστης να μετακινήσει την εστίαση εισόδου σε ένα συστατικό (π.χ. μια γραμμή κύλισης ή περιοχή κειμένου) που εμπεριέχεται στην κύλιση.</para>
</listitem>
</itemizedlist>
</listitem>
</itemizedlist>
</sect1>
<sect1 id="feedback-types">
<title>Τύποι οπτικής ανάδρασης</title>
<para>Μπορείτε να χρησιμοποιήσετε δύο τύπους οπτικής ανάδρασης για λειτουργίες στην ανάδραση του δείκτη της εφαρμογή σας και κινήσεις προόδου.</para>
<sect2 id="pointer-feedback">
<title>Ανάδραση δείκτη</title>
<para>Η ανάδραση δείκτη αλλάζει το σχήμα του δείκτη. Για παράδειγμα, ένας απασχολημένος δείκτης δείχνει ότι μια λειτουργία εξελίσσεται και ότι ο χρήστης δεν μπορεί να κάνει άλλες εργασίες. Ένας διαδραστικά απασχολημένος δείκτης δείχνει ότι μια λειτουργία εξελίσσεται αλλά το παράθυρο είναι ακόμα διαδραστικό.</para>
<figure>
<title>Απασχολημένος δείκτης (αριστερά) και διαδραστικά απασχολημένος δείκτης (δεξιά)</title>
<mediaobject><imageobject> <imagedata depth="28" fileref="images/feedback-pointers-busy.png" format="PNG" width="58"/> </imageobject> <imageobject> <imagedata fileref="images/feedback-pointers-busy.eps" format="EPS"/> </imageobject> <textobject> <phrase>Απασχολημένος δείκτης (αριστερά) και απασχολημένος διαδραστικός δείκτης (δεξιά)</phrase> </textobject></mediaobject>
</figure>
<!-- CB-Fig: Replace above figure with one that is cleaned up. -->
</sect2>
<sect2 id="progress-animations">
<title>Κινήσεις προόδου</title>
<para>Οι κινήσεις προόδου εμφανίζουν είτε πόση λειτουργία ολοκληρώθηκε, είτε μόνο μια συνεχιζόμενη λειτουργία. Κανονικά, αυτές παίρνουν τη μορφή είτε μιας γραμμής προόδου ή μιας λίστας ελέγχων προόδου.</para>
<itemizedlist>
<title>Κατευθυντήριες γραμμές</title>
<listitem>
<para>Όταν εμφανίζεται μια κίνηση προόδου, ανοίξτε την μόλις είναι δυνατό αφού μάθετε ότι απαιτείται και κλείστε την αυτόματα μόλις η συσχετισμένη λειτουργία ολοκληρωθεί.</para>
</listitem>
<listitem>
<para>Χρησιμοποιήστε μια γραμμή μέτρησης προόδου εάν η εφαρμογή σας μπορεί να εκτιμήσει είτε πόσο θα διαρκέσει η λειτουργία, ή τι αναλογία της λειτουργίας ολοκληρώθηκε.</para>
</listitem>
<listitem>
<para>Εάν η εφαρμογή σας δεν μπορεί να κάνει καμιά εκτίμηση και η λειτουργία έχει μόνο ένα βήμα, χρησιμοποιήστε μια <link linkend="indeterminate-progress">γραμμή αόριστης προόδου</link>. Για λειτουργίες με δύο ή περισσότερα βήματα, χρησιμοποιήστε μια <link linkend="progress-checklists">λίστα ελέγχων προόδου</link> που εμφανίζει δυναμικά ένα σημάδι ελέγχου για κάθε ολοκληρωμένο βήμα.</para>
</listitem>
</itemizedlist>
<sect3 id="progress-bars">
<title>Γραμμές προόδου</title>
<para>Για πληροφορίες σε διαφορετικούς τύπους γραμμών προόδου και πότε να τις χρησιμοποιήσετε δείτε <xref linkend="controls-progress-bars"/>.</para>
<sect4 id="progress-windows-vs-status-bar">
<title>Παράθυρα προόδου - γραμμή κατάστασης</title>
<para>Σε μια εφαρμογή όπου τα <link linkend="windows-primary">πρωτεύοντα παράθυρα</link> περιέχουν μια <link linkend="controls-status-bars">γραμμή κατάστασης</link> (που με τη σειρά της περιέχει μια γραμμή προόδου), θα είναι συχνά η περίπτωση που μια ανάδραση λειτουργίας θα μπορούσε να αναπαρασταθεί είτε στη γραμμή κατάστασης ή σε ένα <link linkend="windows-progress">παράθυρο προόδου</link>. Ένας απλοϊκός κανόνας είναι να χρησιμοποιήσετε τη γραμμή κατάστασης όταν μια λειτουργία αναμένεται να διαρκέσει λιγότερο από δέκα δευτερόλεπτα, αλλιώς ένα παράθυρο προόδου. Όμως, σκεφτείτε τα ακόλουθα όταν επιλέγετε μεταξύ των δύο:</para>
<itemizedlist>
<listitem>
<para>Ανοίγοντας ένα παράθυρο, ιδιαίτερα όταν μια λειτουργία είναι σύντομη, μπορεί ανώφελα να διακόψει τη ροή εργασίας του χρήστη.</para>
</listitem>
<listitem>
<para>Τα παράθυρα προόδου μπορούν να μεταφέρουν περισσότερες πληροφορίες.</para>
</listitem>
<listitem>
<para>Τα παράθυρα πολλαπλής προόδου μπορεί να ανοιχτούν μονομιάς, ενώ μόνο μια μόνη λειτουργία μπορεί να εμφανιστεί σε μια γραμμή κατάστασης.</para>
</listitem>
<listitem>
<para>Τα παράθυρα προόδου παρέχουν ένα κουμπί <guibutton>ακύρωσης</guibutton>.</para>
</listitem>
</itemizedlist>
</sect4>
</sect3>
<sect3 id="progress-checklists">
<title>Παράθυρα λίστας ελέγχου</title>
<para>Ένα παράθυρο λίστας ελέγχων εμφανίζει τη σειρά των σταδίων σε μια λειτουργία. Δείτε <xref linkend="progress-window-checklists"/>. <figure><title>Ένα παράθυρο λίστας ελέγχου</title>
<mediaobject><imageobject><imagedata fileref="images/feedback-checklist-running.png" format="PNG" width="336" depth="220"/></imageobject> <textobject><phrase>Ένα παράθυρο λίστας ελέγχων που εμφανίζει μια σειρά βημάτων</phrase></textobject> <imageobject> <imagedata fileref="images/feedback-checklist-running.eps" format="EPS"/> </imageobject></mediaobject>
</figure></para>
</sect3>
</sect2>
</sect1>
<sect1 id="feedback-choosing">
<title>Επιλογή κατάλληλης ανάδρασης</title>
<para>Για τον προσδιορισμό του τύπου της οπτικής ανάδρασης για μια συγκεκριμένη λειτουργία, σκεφτείτε αυτούς τους συντελεστές:</para>
<itemizedlist>
<listitem>
<para>Εάν η εφαρμογή σας μπορεί να δώσει μια εκτίμηση της προόδου της λειτουργίας.</para>
</listitem>
<listitem>
<para>Εάν η λειτουργία φράσσει τον χρήστη από την παραπέρα εκτέλεση εντολών στην εφαρμογή σας.</para>
</listitem>
<listitem>
<para>Εάν η εφαρμογή σας έχει έναν αποκλειστικό χώρο, όπως μια γραμμή κατάστασης για να δείξει την κατάσταση των λειτουργιών.</para>
</listitem>
</itemizedlist>
<para>Ο παρακάτω πίνακας δείχνει τον παρεχόμενο τύπο ανάδρασης για λειτουργίες που συνήθως διαρκούν τουλάχιστον 1 δεύτερο για να ολοκληρωθούν. Στη στήλη "κατάλληλη ανάδραση", "εσωτερικές κινήσεις προόδου" σημαίνει κινήσεις προόδου που εμφανίζονται σε μια αποκλειστική περιοχή κατάστασης μιας εφαρμογής και "εξωτερικές κινήσεις προόδου" σημαίνει κινήσεις προόδου που εμφανίζονται κάπου αλλού από την αποκλειστική περιοχή κατάστασης - τυπικά, σε ένα πλαίσιο ειδοποίησης.</para>
<table frame="all">
<title>Οπτικοί τύποι ανάδρασης για λειτουργίες που διαρκούν τουλάχιστον 1 δευτερόλεπτο</title>
<tgroup align="left" cols="4">
<thead>
<row>
<entry>Τυπική διάρκεια > 5 δευτερόλεπτα;</entry>
<entry>Να εμποδίζεται ο χρήστης να συντάσσει επιπρόσθετες εντολές;</entry>
<entry>Η εφαρμογή έχει αποκλειστική περιοχή κατάστασης;</entry>
<entry>Κατάλληλη ανάδραση</entry>
</row>
</thead>
<tbody>
<row>
<entry>Ναι</entry>
<entry>Ναι</entry>
<entry>Ναι</entry>
<entry>Εσωτερική κίνηση και ανάδραση δείκτη</entry>
</row>
<row>
<entry>Ναι</entry>
<entry>Ναι</entry>
<entry>Όχι</entry>
<entry>Ανάδραση δείκτη</entry>
</row>
<row>
<entry>Ναι</entry>
<entry>Όχι</entry>
<entry>Ναι</entry>
<entry>Εσωτερική κίνηση</entry>
</row>
<row>
<entry>Όχι</entry>
<entry>Ναι</entry>
<entry>Ναι</entry>
<entry>Εσωτερική κίνηση και ανάδραση δείκτη</entry>
</row>
<row>
<entry>Όχι</entry>
<entry>Ναι</entry>
<entry>Όχι</entry>
<entry>Εξωτερική κίνηση και ανάδραση δείκτη</entry>
</row>
<row>
<entry>Όχι</entry>
<entry>Όχι</entry>
<entry>Ναι</entry>
<entry>Εσωτερική κίνηση</entry>
</row>
<row>
<entry>Όχι</entry>
<entry>Όχι</entry>
<entry>Όχι</entry>
<entry>Εξωτερική κίνηση</entry>
</row>
</tbody>
</tgroup>
</table>
<itemizedlist>
<title>Κατευθυντήριες γραμμές</title>
<listitem>
<para>Χρησιμοποιήστε έναν απασχολημένο δείκτη όποτε οι χρήστες εμποδίζονται από αλληλεπίδραση με την εφαρμογή σας για 1 δευτερόλεπτο ή περισσότερο. Εμφανίστε τον απασχολημένο δείκτη λιγότερο από 1 δευτερόλεπτο μετά την έναρξη της λειτουργίας.</para>
</listitem>
<listitem>
<para>Σε μια εντολή που πιθανόν να διαρκέσει 10 δευτερόλεπτα ή περισσότερο, δώστε ένα κουμπί <guibutton>στάσης</guibutton> ή <guibutton>ακύρωσης</guibutton>, που μπορεί επίσης να ενεργοποιηθεί πατώντας <keycap>Esc</keycap>, που επιτρέπει στους χρήστες να τερματίσουν την διεργασία της εντολής ακόμα κι αν η εφαρμογή σας δεν μπορεί να αναιρέσει τα αποτελέσματα της εντολής. Δείτε <xref linkend="feedback-interrupting"/>.</para>
</listitem>
<listitem>
<para>Όταν χρησιμοποιείτε μια εξωτερική κίνηση, αφήστε το παράθυρο να περιέχει την κίνηση στην οθόνη για τουλάχιστον 1 δευτερόλεπτο μετά την ολοκλήρωση της λειτουργίας, με ένα μήνυμα πετυχημένης ολοκλήρωσης. Αλλάξτε το κουμπί <guibutton>στάσης</guibutton> ή <guibutton>ακύρωσης</guibutton> με ένα κουμπί <guibutton>εντάξει</guibutton> κατά την διάρκεια αυτής της περιόδου - πάτημα αυτού του κουμπιού θα πρέπει να κλείσει το παράθυρο αμέσως.</para>
</listitem>
</itemizedlist>
</sect1>
<sect1 id="feedback-interrupting">
<title>Να επιτρέπονται οι διακοπές</title>
<para>Οι χρήστες μερικές φορές χρειάζεται να σταματήσουν μια εντολή - για παράδειγμα, επειδή διαρκεί πολύ. Η εφαρμογή σας πρέπει να επιτρέπει στους χρήστες να σταματούν τις εκτελούμενες εντολές, ακόμα κι αν σταματούν μια εντολή που δεν μπορεί να αναιρεθεί ή να "επαναφέρει" όλα τα αποτελέσματα της εντολής.</para>
<itemizedlist>
<title>Κατευθυντήριες γραμμές</title>
<listitem>
<para>Τοποθετήστε ένα κουμπί <guibutton>στάσης</guibutton> ή <guibutton>ακύρωσης</guibutton>, που μπορεί επίσης να ενεργοποιηθεί πατώντας <keycap>Esc</keycap>, κοντά στην κίνηση προόδου για την διακοπτόμενη εντολή.</para>
</listitem>
<listitem>
<para>Ονομάστε το κουμπί <guibutton>ακύρωση</guibutton> εάν όλη η λειτουργία μπορ να εγκαταλειφθεί καθαρά χωρίς παρενέργειες, αφήνοντας το σύστημα στην κατάσταση που ήταν πριν το ξεκίνημα της λειτουργίας. Τελειώστε την εντολή αμέσως όταν ο χρήστης πατά αυτό το κουμπί.</para>
</listitem>
<listitem>
<para>Ονομάστε το κουμπί <guibutton>στάση</guibutton> εάν η εντολή μπορεί να διακοπεί, αλλά τα αποτελέσματά της μέχρι αυτό το σημείο δεν μπορούν (ή δεν πρέπει) να αντιστραφούν. Όταν ο χρήστης πατά αυτό το κουμπί, ανοίξτε ένα πλαίσιο ειδοποίησης που προειδοποιεί για τις ενδεχόμενες παρενέργειες παύσης της εντολής. Το πλαίσιο ειδοποίησης πρέπει να έχει μόνο δύο κουμπιά: ένα για συνέχιση της διεργασίας της εντολής και ένα για άμεσο τερματισμό της.</para>
</listitem>
<!-- CB-Fig: Figure here showing example alertbox in context (overlaying the progress animation in a dialog, etc.) with sample alerbox text. JLFDG AT p. 107 shows this. (Fig 66) -->
</itemizedlist>
<para>Εναλλακτικά, μπορείτε να τοποθετήσετε ένα κουμπί <guibutton>παύσης</guibutton> ή <guibutton>ακύρωσης</guibutton> κοντά στον έλεγχο με τον οποίον ο χρήστης έδωσε την εντολή που χρειάζεται να σταματήσει. Τοποθετήστε το κουμπί εδώ μόνο εάν:</para>
<itemizedlist>
<listitem>
<para>Δεν υπάρχει καμιά κίνηση προόδου για την εντολή, ή</para>
</listitem>
<listitem>
<para>Η κίνηση προόδου είναι σε μια περιοχή κατάστασης ενός παραθύρου ή μιας άλλης θέσης που της λείπει χώρος για ένα κουμπί <guibutton>στάσης</guibutton> ή <guibutton>ακύρωσης</guibutton>.</para>
</listitem>
</itemizedlist>
<para>Στο πλαίσιο ειδοποίησης που εμφανίζεται μετά το πάτημα ενός κουμπιού <guibutton>στάσης</guibutton>, βεβαιωθείτε ότι το μήνυμα και οι ετικέτες κουμπιού στο πλαίσιο ειδοποίησης είναι συγκεκριμένες και ακριβείς. Ασαφείς ετικέτες κουμπιών μπορούν να προκαλέσουν τον τερματισμό ή συνέχιση μιας εντολής άθελα του από τον χρήστη. Για παράδειγμα, χρησιμοποιήστε:</para>
<para><screen>Να συνεχιστεί η διαγραφή αρχείων; <guibutton>[Συνέχιση διαγραφής]</guibutton>
<guibutton>[Παύση διαγραφής]</guibutton></screen></para>
<para>αντί για</para>
<para><screen>Η λειτουργία διακόπηκε, να συνεχιστεί; <guibutton>[Ναι]</guibutton>
<guibutton>[Όχι]</guibutton></screen></para>
<para>μιας και στο τελευταίο παράδειγμα, δεν είναι σαφές εάν το πάτημα <guibutton>ναι</guibutton> θα συνεχίσει τη λειτουργία ή θα συνεχίσει τη διακοπή (π.χ. ακύρωση της λειτουργίας).</para>
</sect1>
</chapter>
|