This file is indexed.

/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>Τυπική διάρκεια &gt; 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>