diff options
author | David Friedman <dmail@google.com> | 2015-07-02 02:33:03 +0000 |
---|---|---|
committer | Android Git Automerger <android-git-automerger@android.com> | 2015-07-02 02:33:03 +0000 |
commit | 2ebfc3f78483842c789688da47b721f60b4149e4 (patch) | |
tree | 2359f86967c5b769851396e5dde8b6a62881dacf /docs | |
parent | 5adc6ba056de056f73ee484b859b45657da0c1fb (diff) | |
parent | fa8eb1e0d42e7b10447a285d9b2a583d367c3cad (diff) | |
download | frameworks_base-2ebfc3f78483842c789688da47b721f60b4149e4.zip frameworks_base-2ebfc3f78483842c789688da47b721f60b4149e4.tar.gz frameworks_base-2ebfc3f78483842c789688da47b721f60b4149e4.tar.bz2 |
am fa8eb1e0: Merge "Docs: Localization of Design pages on DAC. Bug: 20503708" into mnc-preview-docs
* commit 'fa8eb1e0d42e7b10447a285d9b2a583d367c3cad':
Docs: Localization of Design pages on DAC. Bug: 20503708
Diffstat (limited to 'docs')
36 files changed, 11584 insertions, 5 deletions
diff --git a/docs/html-intl/intl/es/design/get-started/principles.jd b/docs/html-intl/intl/es/design/get-started/principles.jd new file mode 100644 index 0000000..351a4f7 --- /dev/null +++ b/docs/html-intl/intl/es/design/get-started/principles.jd @@ -0,0 +1,307 @@ +page.title=Principios de diseño para Android +@jd:body + +<p>Estos principios de diseño fueron creados por el +equipo de experiencia del usuario de Android para su propio uso, con el fin de tener siempre en cuenta lo mejor para los usuarios. +En cuanto a los desarrolladores y diseñadores de Android, continúan +utilizando las pautas de diseño más detalladas para los diferentes +tipos de dispositivos.</p> + +<p> +Tenga en cuenta estos principios cuando ponga en práctica su propia +creatividad e ideas de diseño. Desvíese de lo tradicional con un propósito. +</p> + +<h2 id="enchant-me">Cautívame</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="delight-me">Deléitame de formas sorprendentes</h4> +<p>Una superficie atractiva, una animación colocada en el lugar correcto o un efecto de sonido bien sincronizado suelen ser experiencias +placenteras. Los efectos sutiles contribuyen a crear un sentimiento de facilidad y la sensación de que se cuenta con una fuerza +poderosa.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_delight.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="real-objects-more-fun">Los objetos reales son más divertidos que los botones y los menús</h4> +<p>Permita que los usuarios toquen y manipulen directamente los objetos de su aplicación. Esto reduce el esfuerzo cognitivo +que se necesita para llevar a cabo una tarea que resulte satisfactoria a nivel emocional.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_real_objects.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-it-mine">Permíteme darle un toque personal</h4> +<p>A los usuarios les gusta agregar toques personales, ya que esto los ayuda a sentirse cómodos y a sentir que tienen el control. Ofrezca +opciones predeterminadas prácticas y atractivas, pero también tenga en cuenta personalizaciones opcionales y divertidas que no entorpezcan las +tareas principales.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_it_mine.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="get-to-know-me">Conóceme</h4> +<p>Con el paso del tiempo, conozca las preferencias de los usuarios. En lugar de pedirles a los usuarios que elijan las mismas cosas una y otra +vez, permita que puedan acceder fácilmente a las opciones que ya eligieron antes.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_get_to_know_me.png"> + + </div> +</div> + +<h2 id="simplify-my-life">Simplifica mi vida</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="keep-it-brief">Sé breve</h4> +<p>Utilice frases cortas con palabras simples. Las personas tienden a omitir las oraciones largas.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_keep_it_brief.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="pictures-faster-than-words">Las imágenes son más prácticas que las palabras</h4> +<p>Considere la idea de utilizar imágenes para explicar las ideas. Las imágenes atraen la atención de las personas y pueden ser mucho más eficientes +que las palabras.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_pictures.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="decide-for-me">Decide por mí, pero permíteme tener la última palabra</h4> +<p>Siga su instinto y actúe sin preguntar primero. Tener que elegir demasiadas veces y tomar muchas decisiones hace que las personas +se sientan molestas. Permita que los usuarios puedan deshacer sus elecciones en caso de que no sean lo que ellos desean.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_decide_for_me.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="only-show-when-i-need-it">Solo muéstrame lo que necesito, cuando lo necesito</h4> +<p>Los usuarios se sienten abrumados cuando se les presenta demasiada información al mismo tiempo. Divida las tareas y la información en fragmentos pequeños +y fáciles de digerir. Oculte las opciones que no son fundamentales en el momento y capacite a los usuarios sobre la marcha.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_information_when_need_it.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="always-know-where-i-am">Siempre debo saber dónde me encuentro</h4> +<p>Haga que los usuarios sientan que conocen el camino de regreso. Para ello, diseñe las distintas partes de su aplicación de modo tal que se vean diferentes y +utilice transiciones para mostrar la relación entre las pantallas. Proporcione comentarios sobre las tareas que están en curso.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_navigation.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="never-lose-my-stuff">Nunca pierdas lo que es mío</h4> +<p>Guarde aquellas cosas que los usuarios crearon y permítales acceder a ellas desde cualquier lugar. Recuerde las configuraciones, +los toques personales y las creaciones en todos los teléfonos, las tablets y las computadoras. Esta es la forma de hacer que las actualizaciones +sean lo más simple del mundo.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_never_lose_stuff.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="looks-same-should-act-same">Si se ve igual, debe funcionar de la misma manera</h4> +<p>Ayude a los usuarios a distinguir las diferencias funcionales al lograr que se vean diferentes en lugar de sutiles. +Evite los modos, que son sitios que lucen similar pero actúan diferente ante la misma entrada.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_looks_same.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="interrupt-only-if-important">Solo interrúmpeme si es importante</h4> +<p>Al igual que un buen asistente personal, evite a los usuarios los pormenores poco importantes. Las personas desean estar +concentradas y, a menos que sea fundamental y esté sujeta a un plazo de tiempo, una interrupción puede resultar agobiante y frustrante.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_important_interruption.png"> + + </div> +</div> + +<h2 id="make-me-amazing">Permíteme ser asombroso</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="give-me-tricks">Ofréceme trucos que funcionen en todos lados</h4> +<p>Las personas se sienten muy bien cuando descubren cosas por sí mismos. Logre que su aplicación sea más simple de utilizar al +aprovechar los patrones visuales y la memoria muscular de otras aplicaciones de Android. Por ejemplo, el gesto de deslizar rápidamente +puede ser un buen acceso directo de navegación.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_tricks.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="its-not-my-fault">No es mi culpa</h4> +<p>Sea sutil cuando les solicite a los usuarios que realicen correcciones. Ellos desean sentirse inteligentes cuando usan la +aplicación que usted creó. Si hacen algo mal, bríndeles instrucciones claras de recuperación, pero evite darles detalles técnicos. +Sería incluso mejor que usted lo solucione en segundo plano.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_error.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="sprinkle-encouragement">Fomenta lo simple</h4> +<p>Desglose las tareas complejas en pasos más pequeños que se puedan cumplir fácilmente. Ofrezca comentarios sobre las acciones, +incluso si es simplemente un halago sutil.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_sprinkle_encouragement.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="do-heavy-lifting-for-me">Haz el trabajo pesado por mí</h4> +<p>Haga que los principiantes se sientan como expertos al permitirles hacer cosas que pensaron que nunca podrían hacer. Por +ejemplo, a través de los accesos directos en los que se combinan múltiples efectos de fotografías, puede lograr que las fotografías de principiantes se vean maravillosas +en solo algunos pasos.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_heavy_lifting.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-important-things-fast">Haz que lo importante sea rápido</h4> +<p>No todas las acciones son iguales. Decida qué es lo más importante en su aplicación y haga +que los usuarios lo puedan encontrar fácilmente y utilizar de forma rápida, como el obturador de una cámara o el botón de pausa de un reproductor de música.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_important_fast.png"> + + </div> +</div> diff --git a/docs/html-intl/intl/es/design/material/index.jd b/docs/html-intl/intl/es/design/material/index.jd new file mode 100644 index 0000000..8cd3428 --- /dev/null +++ b/docs/html-intl/intl/es/design/material/index.jd @@ -0,0 +1,186 @@ +page.title=Material Design +page.tags=Material,design +page.type=design +page.image=design/material/images/MaterialLight.png + +@jd:body + +<!-- developer docs box --> +<a class="notice-developers right" href="{@docRoot}training/material/index.html"> + <div> + <h3>Documentos para desarrolladores</h3> + <p>Creación de aplicaciones con Material Design</p> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=p4gmvHyuZzw"> +<div> + <h3>Video</h3> + <p>Introducción a Material Design</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=YaG_ljfzeUw"> +<div> + <h3>Video</h3> + <p>Papel y tinta: los materiales más importantes</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=XOcCOBe8PTc"> +<div> + <h3>Video</h3> + <p>Material Design en la aplicación Google I/O</p> +</div> +</a> + + + +<p itemprop="description">Material Design es una guía integral para el diseño visual, de movimientos y +de interacción en distintas plataformas y dispositivos. Android ahora es compatible con las aplicaciones de +Material Design. Para usar Material Design en sus aplicaciones de Android, siga las pautas descritas +en la <a href="http://www.google.com/design/spec">especificación de Material Design</a> y use los +nuevos componentes y funcionalidades disponibles en Android 5.0 (nivel de API 21) y versiones posteriores.</p> + +<p>En Android, se proporcionan los siguientes elementos que le permitirán crear aplicaciones en Material Design:</p> + +<ul> + <li>un tema nuevo;</li> + <li>nuevos widgets para vistas complejas;</li> + <li>nuevas API (interfaces de programación de aplicaciones) para sombras y animaciones personalizadas.</li> +</ul> + +<p>Para obtener más información sobre la implementación de Material Design en Android, consulte +<a href="{@docRoot}training/material/index.html">Creación de aplicaciones con Material Design</a>.</p> + + +<h3>Tema Material</h3> + +<p>El tema Material le ofrece un nuevo estilo para su aplicación, widgets del sistema que le permiten configurar +la paleta de colores y animaciones predeterminadas para información táctil y transiciones de actividades.</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/MaterialDark.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">Tema Dark Material</p> + </div> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/MaterialLight.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">Tema Light Material</p> + </div> +</div> +<br style="clear:left"/> +</div> + +<p>Para obtener más información, consulte <a href="{@docRoot}training/material/theme.html">Uso del tema +Material</a>.</p> + + +<h3>Listas y tarjetas</h3> + +<p>Android proporciona dos widgets nuevos para mostrar listas y tarjetas con estilos y +animaciones de Material Design:</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/list_mail.png" width="500" height="426" /> + <p>El nuevo widget <code>RecyclerView</code> es una versión más acoplable de <code>ListView</code> + que admite diferentes tipos de diseños y proporciona mejoras en el rendimiento.</p> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/card_travel.png" width="500" height="426" /> + <p>El nuevo widget <code>CardView</code> le permite mostrar extractos de información importante dentro de + tarjetas que tienen apariencia y estilo coherentes.</p> +</div> +<br style="clear:left"/> +</div> + +<p>Para obtener más información, consulte <a href="{@docRoot}training/material/lists-cards.html">Creación de listas +y tarjetas</a>.</p> + + +<h3>Visualización de sombras</h3> + +<p>Además de las propiedades X e Y, las vistas de Android ahora poseen una +propiedad Z. Esta propiedad nueva representa la elevación de una vista, que determina lo siguiente:</p> + +<ul> +<li>El tamaño de la sombra: las vistas con valores Z más elevados proyectan sombras más grandes.</li> +<li>El orden del dibujo: las vistas con valores Z más elevados aparecen sobre las otras vistas.</li> +</ul> + +<div style="width:290px;margin-left:35px;float:right"> + <div class="framed-nexus5-port-span-5"> + <video class="play-on-hover" autoplay> + <source src="{@docRoot}design/material/videos/ContactsAnim.mp4"/> + <source src="{@docRoot}design/videos/ContactsAnim.webm"/> + <source src="{@docRoot}design/videos/ContactsAnim.ogv"/> + </video> + </div> + <div style="font-size:10pt;margin-left:20px;margin-bottom:30px"> + <em>Para volver a reproducir la película, haga clic en la pantalla del dispositivo.</em> + </div> +</div> + +<p>Para obtener más información, consulte <a href="{@docRoot}training/material/shadows-clipping.html">Definición +de vistas de recorte y sombras</a>.</p> + + +<h3>Animaciones</h3> + +<p>Las nuevas API de animaciones le permiten crear animaciones personalizadas para la información táctil en los controles de IU, +además de realizar cambios en el estado de las vistas y transiciones entre actividades.</p> + +<p>Estas API le permiten hacer lo siguiente:</p> + +<ul> +<li style="margin-bottom:15px"> +responder a los eventos táctiles de sus vistas mediante animaciones de <strong>información táctil</strong>; +</li> +<li style="margin-bottom:15px"> +ocultar y mostrar vistas con animaciones con <strong>efecto circular</strong>; +</li> +<li style="margin-bottom:15px"> +alternar entre actividades con animaciones personalizadas de <strong>transición de actividades</strong>; +</li> +<li style="margin-bottom:15px"> +crear animaciones más naturales con <strong>movimiento curvo</strong>; +</li> +<li style="margin-bottom:15px"> +animar los cambios en una o más propiedades de las vistas con las animaciones de <strong>cambio de estado de la vista</strong>; +</li> +<li style="margin-bottom:15px"> +mostrar animaciones en los <strong>elementos de diseño de la lista de estados</strong> entre los cambios de estado de las vistas. +</li> +</ul> + +<p>Las animaciones de la información táctil se concentran en diferentes vistas estándar, como los botones. Las nuevas API +le permiten personalizar estas animaciones y agregarlas a sus vistas personalizadas.</p> + +<p>Para obtener más información, consulte <a href="{@docRoot}training/material/animations.html">Definición de animaciones +personalizadas</a>.</p> + + +<h3>Elementos de diseño</h3> + +<p>Estas nuevas capacidades para los elementos de diseño le permiten implementar aplicaciones de Material Design:</p> + +<ul> +<li>Los <strong>dibujables en vector</strong> se pueden escalar sin perder definición y son perfectos +para los iconos de las aplicaciones de un solo color.</li> +<li>El <strong>teñido de los dibujables</strong> le permite definir mapas de bits como máscaras alfa y pintarlos con +un color durante el tiempo de ejecución.</li> +<li>La <strong>extracción de color</strong> le permite extraer automáticamente colores prominentes de una +imagen del mapa de bits.</li> +</ul> + +<p>Para obtener más información, consulte <a href="{@docRoot}training/material/drawables.html">Trabajo con +elementos de diseño</a>.</p> diff --git a/docs/html-intl/intl/es/design/patterns/confirming-acknowledging.jd b/docs/html-intl/intl/es/design/patterns/confirming-acknowledging.jd new file mode 100644 index 0000000..fbaa060 --- /dev/null +++ b/docs/html-intl/intl/es/design/patterns/confirming-acknowledging.jd @@ -0,0 +1,70 @@ +page.title=Confirmación y reconocimiento +page.tags=dialog,toast,notification +@jd:body + +<p>En algunos casos, cuando un usuario invoca una acción desde su aplicación, se recomienda <em>confirmar</em> o proporcionar un <em>reconocimiento</em> de dicha acción a través del texto.</p> + +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_confirming.png"> + <p><strong>Confirmación</strong> es solicitarle al usuario que verifique que realmente desea proceder con una acción que acaba de invocar. En algunos casos, la confirmación se presenta junto con una advertencia o mensaje con información importante relacionada con la acción que el usuario debe aprobar.</p> + </div> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_acknowledge.png"> + <p>El <strong>reconocimiento</strong> hace referencia al hecho de mostrar un determinado texto para informarle al usuario que la acción que acaba de invocar ya se completó. De este modo, se elimina la incertidumbre sobre las operaciones implícitas que lleva a cabo el sistema. En algunos casos, el reconocimiento se presenta junto con una opción para deshacer la acción.</p> + </div> +</div> + +<p>Comunicarse con los usuarios de este modo permite reducir la incertidumbre respecto de acciones pasadas o futuras. Mediante la confirmación o el reconocimiento también se puede evitar que los usuarios cometan errores de los que podrían arrepentirse.</p> + +<h2>Cuándo se debe solicitar una confirmación o proporcionar un reconocimiento de las acciones de los usuarios</h2> +<p>No es necesario que se solicite una confirmación o se proporcione un reconocimiento para todas las acciones. Utilice este diagrama de flujo cuando tenga que tomar decisiones relacionadas con el diseño.</p> +<img src="{@docRoot}design/media/confirm_ack_flowchart.png"> + +<h2>Confirmación</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Ejemplo: Google Play Books</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_books.png"> + <p>En este ejemplo, el usuario solicitó eliminar un libro de su biblioteca de Google Play. Aparecerá una <a href="{@docRoot}design/building-blocks/dialogs.html#alerts">alerta</a> para confirmar esta acción porque es importante que el usuario comprenda que el libro ya no estará disponible desde ningún dispositivo.</p> + <p>Cuando diseñe un cuadro de diálogo de confirmación, asegúrese de que el título sea significativo y que incluya la acción solicitada.</p> + </div> + <div class="layout-content-col span-7"> + <h4>Ejemplo: Android Beam</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_beam.png"> + <p>No es necesario que las confirmaciones se presenten en todas las alertas con dos botones. Luego de iniciar Android Beam, se le solicita al usuario que seleccione el contenido que desea compartir (en este ejemplo, se trata de una fotografía). Si el usuario decide no continuar, simplemente se descartará el teléfono de la lista.</p> + </div> +</div> + +<h2>Reconocimiento</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Ejemplo: Borrador de Gmail abandonado y guardado</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_draftsave.png"> + <p>En este ejemplo, si el usuario navega con los botones Back o Up desde la pantalla de redacción de Gmail, posiblemente ocurrirá algo inesperado: el borrador actual se guardará automáticamente. Esto se mostrará a través de un reconocimiento en forma de aviso. Dicho aviso desaparece luego de algunos segundos.</p> + <p>En este caso, no se puede incluir la opción de deshacer porque el almacenamiento fue iniciado por la aplicación, no por el usuario. Gracias a esto, se puede continuar redactando el mensaje de forma rápida y fácil con solo navegar hasta la lista de borradores.</p> + + </div> + <div class="layout-content-col span-6"> + <h4>Ejemplo: Conversación de Gmail eliminada</h4> + <img src="{@docRoot}design/media/confirm_ack_draft_deleted.png"> + <p>Después de que el usuario elimina una conversación de la lista de Gmail, aparece un mensaje de reconocimiento con la opción de deshacer la acción. Dicho reconocimiento seguirá en pantalla hasta que el usuario lleve a cabo una acción no relacionada, como desplazarse por la lista.</p> + </div> +</div> + +<h2>Sin confirmación ni reconocimiento</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Ejemplo: Hacer +1</h4> + <img style="padding: 33px 0 30px;" src="{@docRoot}design/media/confirm_ack_ex_plus1.png"> + <p><strong>No se necesita confirmación</strong>. Si el usuario hizo +1 sin querer, esto no es un problema. Simplemente, puede tocar el botón de nuevo para deshacer la acción.</p> + <p><strong>No se necesita un reconocimiento</strong>. El usuario verá que el botón +1 parpadea y cambia a color rojo. Esa es una señal muy clara.</p> + </div> + <div class="layout-content-col span-7"> + <h4>Ejemplo: Eliminación de una aplicación de la pantalla de inicio</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_removeapp.png"> + <p><strong>No se necesita confirmación</strong>. Esta es una acción intencionada: el usuario debe arrastrar y colocar un elemento en un destino relativamente grande y aislado. Por lo tanto, es poco probable que se cometan errores. No obstante, si el usuario se arrepiente de la decisión que tomó, solo demorará algunos segundos en recuperar lo eliminado.</p> + <p><strong>No se necesita un reconocimiento</strong>. El usuario sabrá que la aplicación ya no aparecerá en la Pantalla de inicio porque él mismo la hizo desaparecer al arrastrarla.</p> + + </div> +</div> diff --git a/docs/html-intl/intl/es/design/patterns/navigation.jd b/docs/html-intl/intl/es/design/patterns/navigation.jd new file mode 100644 index 0000000..6332491 --- /dev/null +++ b/docs/html-intl/intl/es/design/patterns/navigation.jd @@ -0,0 +1,213 @@ +page.title=Navegación con los botones Back y Up +page.tags="navigation","activity","task","up navigation","back navigation" +page.image=/design/media/navigation_between_siblings_gmail.png +@jd:body + +<a class="notice-developers" href="{@docRoot}training/implementing-navigation/index.html"> + <div> + <h3>Documentos para desarrolladores</h3> + <p>Implementación de la navegación eficiente</p> + </div> +</a> + +<p itemprop="description">La navegación coherente es un componente fundamental de la experiencia general del usuario. Pocas situaciones frustran más a los +usuarios que la navegación básica que se comporta de forma irregular e inesperada. En Android 3.0, +se introdujeron cambios significativos en el comportamiento global de la navegación. Si sigue detalladamente +las pautas de navegación con los botones Back y Up, la navegación en su aplicación será predecible y confiable para los usuarios.</p> +<p>En Android 2.3 y versiones anteriores, se confió en el botón <em>Back</em> del sistema para respaldar la navegación dentro de una +aplicación. Con la introducción de las barras de acciones en Android 3.0, apareció un segundo mecanismo de navegación: +el botón <em>Up</em>, que consiste en el icono de la aplicación y una pequeña flecha a la izquierda.</p> + +<img src="{@docRoot}design/media/navigation_with_back_and_up.png"> + +<h2 id="up-vs-back">Up en comparación con Back</h2> + +<p>El botón Up se utiliza para navegar dentro de una aplicación sobre la base de las relaciones jerárquicas +entre pantallas. Por ejemplo, si en la pantalla A se muestra una lista de elementos y, si se selecciona un elemento, se conduce al usuario a la +pantalla B (en la que se presenta ese elemento de forma más detallada), entonces en la pantalla B se debe mostrar el botón Up para regresar +a la pantalla A.</p> +<p>Si una pantalla aparece en la parte superior de una aplicación (es decir, en el inicio de la aplicación), no debe incluir el botón Up +.</p> + +<p>El botón Back del sistema se utiliza para navegar, en orden cronológico inverso, por el historial +de pantallas en las que recientemente trabajó el usuario. Generalmente, se basa en las relaciones temporales +entre pantallas, y no en la jerarquía de la aplicación.</p> + +<p>Cuando la pantalla que se visitó anteriormente es también el componente jerárquico primario de la pantalla actual, si se presiona el botón +Back, se obtendrá el mismo resultado que si se presiona el botón Up, y esto es algo que sucede a +menudo. Sin embargo, a diferencia del botón Up, mediante el cual se garantiza que el usuario permanezca en la aplicación, el botón Back +le permite al usuario regresar a la pantalla de inicio o, incluso, a otra aplicación.</p> + +<img src="{@docRoot}design/media/navigation_up_vs_back_gmail.png"> + +<p>El botón Back también permite diferentes comportamientos que no están vinculados directamente con la navegación entre pantallas: +</p> +<ul> +<li>descartar las ventanas flotantes (cuadros de diálogo o emergentes);</li> +<li>descartar las barras de acción contextuales y eliminar el resaltado de los elementos seleccionados;</li> +<li>ocultar el teclado en la pantalla (IME [Editores de métodos de entrada]).</li> +</ul> +<h2 id="within-app">Navegación dentro de su aplicación</h2> + +<h4>Navegación hacia pantallas con múltiples puntos de entrada</h4> +<p>En algunos casos, las pantallas no tienen una posición fija dentro de la jerarquía de la aplicación, y se puede acceder a ellas +desde múltiples puntos de entrada (como la pantalla Configuración, a la que se puede acceder desde cualquier otra pantalla +de la aplicación). En este caso, el botón Up debe permitir regresar a la pantalla remitente, por lo que se comportaría +de forma idéntica al botón Back.</p> +<h4>Cambio de vista dentro de una pantalla</h4> +<p>Cambiar las opciones de vista de una pantalla no modifica el comportamiento de los botones Up o Back: la pantalla sigue estando +en el mismo lugar dentro de la jerarquía de la aplicación y no se crea ningún historial de navegación nuevo.</p> +<p>Entre los ejemplos de cambios en las vistas, se encuentran los siguientes:</p> +<ul> +<li>cambio de vistas mediante las pestañas o los deslizamientos de izquierda a derecha;</li> +<li>cambio de vistas mediante un menú desplegable (también conocido como pestañas colapsadas);</li> +<li>filtrado de listas;</li> +<li>clasificación de listas;</li> +<li>modificación de las características de la pantalla (como el zoom).</li> +</ul> +<h4>Navegación entre pantallas relacionadas</h4> +<p>Si su aplicación es compatible con la navegación desde una lista de elementos hacia una vista de detalles de alguno de esos elementos, generalmente, +es preferible respaldar la navegación de dirección desde ese elemento a otro anterior +o siguiente en la lista. Por ejemplo, en Gmail, es fácil deslizarse hacia la izquierda o la derecha desde una conversación +para ver una conversación anterior o más nueva en la misma bandeja de entrada. Al igual que cuando se cambia la vista dentro de una pantalla, en este tipo de +navegación no se cambia el comportamiento de los botones Up o Back.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_gmail.png"> + +<p>Sin embargo, una excepción importante a este caso se presenta cuando se explora entre vistas de detalles relacionadas que no están vinculadas +mediante la lista que se está utilizando; por ejemplo, cuando se explora en Play Store entre diferentes aplicaciones +del mismo desarrollador o entre álbumes del mismo artista. En estos casos, si se sigue cada vínculo, esto queda registrado en el +historial, por lo que, a través del botón Back, se regresa a cada pantalla que se visitó anteriormente. El botón Up debe seguir omitiendo +estas pantallas relacionadas y navegar hacia la pantalla del contenedor visitada más recientemente.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market1.png"> + +<p>Usted puede lograr que el comportamiento del botón Up sea incluso más inteligente teniendo en cuenta sus conocimientos de la vista +detallada. Si extendemos el ejemplo de Play Store mencionado antes, imaginemos que el usuario navegó desde el último +libro visto hacia los detalles de la adaptación de la película. En ese caso, mediante el botón Up podrá regresar a un contenedor +(Películas) por el que el usuario no navegó anteriormente.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market2.png"> + +<h2 id="into-your-app">Navegación dentro de la aplicación a través de los widgets y las notificaciones de la pantalla de inicio</h2> + +<p>Podrá utilizar los widgets y las notificaciones de la pantalla de inicio para ayudar a los usuarios a navegar directamente hacia las pantallas +que se encuentran en posiciones más profundas dentro de la jerarquía de su aplicación. Por ejemplo, tanto el widget de la bandeja de entrada de Gmail como las notificaciones de los mensajes nuevos + pueden omitir la pantalla Bandeja de entrada y llevar al usuario directamente hacia una vista de conversación.</p> + +<p>En ambos casos, el botón Up se debe utilizar de la siguiente manera:</p> + +<ul> +<li><em>Si a la pantalla de destino generalmente se llega desde una determinada pantalla dentro de su +aplicación</em>, el botón Up debe permitir la navegación hacia esa pantalla.</li> +<li><em>De lo contrario, </em>el botón Up debe permitir la navegación hacia la pantalla que está en el nivel superior ("Inicio") de su aplicación.</li> +</ul> + +<p>En el caso del botón Back, la navegación debe ser más predecible. Para ello, coloque en la +pila de retroceso de la tarea la ruta completa de la navegación ascendente hacia la pantalla que se encuentra en el nivel superior de la aplicación. De este modo, los usuarios que +no recuerdan cómo ingresaron a su aplicación podrán navegar hacia la pantalla del nivel superior de la aplicación antes de +salir.</p> + +<p>A modo de ejemplo, el widget de la pantalla Inicio de Gmail posee un botón para llevar al usuario directamente a la pantalla de +redacción. Mediante los botones Up o Back de la pantalla de redacción el usuario debería poder dirigirse hacia la Bandeja de entrada y, a partir de allí, continuar hacia la pantalla Inicio +por medio del botón Back.</p> + +<img src="{@docRoot}design/media/navigation_from_outside_back.png"> + +<h4>Notificaciones indirectas</h4> + +<p>Cuando su aplicación necesita presentar información sobre múltiples eventos de forma simultánea, puede utilizar una +sola notificación que dirija al usuario a una pantalla intersticial. En esta pantalla, se resumen dichos +eventos y se proporcionan rutas para que el usuario navegue más profundamente por la aplicación. Las notificaciones de este estilo se +denominan <em>notificaciones indirectas</em>.</p> + +<p>A diferencia de las notificaciones estándar (directas), si se presiona Back desde una pantalla intersticial de una +notificación indirecta, el usuario será dirigido hacia el punto en el que se desencadenó la notificación. No se incluyen +pantallas adicionales en la pila de retroceso. Una vez que el usuario se dirige hacia la aplicación desde la +pantalla intersticial, los botones Up y Back se comportan del mismo modo que lo hacen en las notificaciones estándar, como se describió antes: +navegan dentro de la aplicación en lugar de regresar a la pantalla intersticial.</p> + +<p>Por ejemplo, supongamos que un usuario de Gmail recibe una notificación indirecta del calendario Si se toca +esta notificación, se abrirá la pantalla intersticial, en la que se mostrarán recordatorios de varios +eventos diferentes. Si se toca Back desde la pantalla intersticial, el usuario volverá a Gmail. Si se toca un evento +en particular, el usuario saldrá de la pantalla intersticial e ingresará en la aplicación Calendario, donde se mostrarán detalles del +evento. En la pantalla de detalles del evento, es posible navegar con los botones Up y Back hacia la vista superior del calendario.</p> + +<img src="{@docRoot}design/media/navigation_indirect_notification.png"> + +<h4>Notificaciones emergentes</h4> + +<p><em>Las notificaciones emergentes</em> omiten el panel lateral de notificaciones y aparecen directamente +frente al usuario. Estas casi nunca se utilizan, y se <strong>deben reservar para ocasiones en las que es necesario proporcionar una +respuesta oportuna y es necesario realizar una interrupción en el contexto del usuario</strong>. Por ejemplo, +en Talk se utiliza este estilo para alertar al usuario sobre una invitación de un amigo para participar en una videocharla, ya que esta +invitación caducará automáticamente luego de algunos segundos.</p> + +<p>En términos de comportamiento de la navegación, las notificaciones emergentes siguen, en gran medida, el comportamiento de la pantalla intersticial +de una notificación indirecta. El botón Back le permite al usuario descartar la notificación emergente. Si el usuario navega +desde la ventana emergente hacia la aplicación que genera las notificaciones, los botones Up y Back seguirán las reglas para las notificaciones estándar +mientras se navega por la aplicación.</p> + +<img src="{@docRoot}design/media/navigation_popup_notification.png"> + +<h2 id="between-apps">Navegación entre aplicaciones</h2> + +<p>Una de las principales ventajas del sistema Android es la capacidad de las aplicaciones de activarse +mutuamente, por lo que el usuario puede navegar directamente desde una aplicación hacia otra. Por ejemplo, una +aplicación que debe tomar una fotografía puede activar la aplicación de la cámara, la cual mostrará la fotografía +en la aplicación que la activó. Esto representa una gran ventaja tanto para el desarrollador, quien puede aprovechar fácilmente el +código de otras aplicaciones, y también para el usuario, quien disfruta de una experiencia coherente para acciones +que se realizan comúnmente.</p> + +<p>Para comprender la navegación entre aplicaciones, es importante que entienda el comportamiento del marco de Android, +que se explica a continuación.</p> + +<h4>Actividades, tareas e intentos</h4> + +<p>En Android, una <strong>actividad</strong> es un componente de la aplicación que define una pantalla de +información y todas las acciones relacionadas que el usuario puede llevar a cabo. Su aplicación es un conjunto de +actividades formado por las actividades que usted crea y aquellas que reutiliza de otras aplicaciones.</p> + +<p>Una <strong>tarea</strong> es la secuencia de actividades que un usuario realiza para lograr un objetivo. En +una sola tarea, se pueden utilizar actividades de una sola aplicación o se pueden utilizar actividades de varias +aplicaciones diferentes.</p> + +<p>Un <strong>intento</strong> es un mecanismo mediante el cual una aplicación indica que necesita la ayuda de +otra aplicación para realizar una acción. Las actividades de una aplicación pueden indicar los intentos +a los que pueden dar respuesta. En el caso de los intentos comunes, como "Compartir", es posible que el usuario tenga instaladas varias aplicaciones +que pueden cumplir con esta solicitud.</p> + +<h4>Ejemplo: navegación entre aplicaciones para respaldar el uso compartido</h4> + +<p>Para comprender cómo las actividades, las tareas y los intentos funcionan en conjunto, considere cómo una aplicación les permite a los usuarios +compartir contenido a través de otra aplicación. Por ejemplo, si ejecuta la aplicación Play Store desde la pantalla de inicio, se iniciará +una nueva tarea A (vea la imagen a continuación). Después de navegar por Play Store y de tocar un libro promocionado +para ver la información detallada, el usuario permanece en la misma tarea y la extiende al agregar actividades. Si se desencadena la acción +Compartir, se le mostrará al usuario un cuadro de diálogo con una lista de todas las actividades (provenientes de diferentes aplicaciones) +que se registraron para concretar el intento de compartir.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_inward.png"> + +<p>Si el usuario decide compartir el contenido a través de Gmail, la actividad de redacción de Gmail se agrega como una continuación de la +tarea A; no se crea una tarea nueva. Si Gmail estaba ejecutando su propia tarea en segundo plano, esta +no debería verse afectada.</p> + +<p>Desde la actividad de redacción, si se envía el mensaje o se toca el botón Back, se dirigirá nuevamente al usuario hacia +la actividad de detalles del libro. Si se sigue tocando el botón Back, el usuario seguirá navegando por Play +Store y, finalmente, llegará a la pantalla de inicio.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_back.png"> + +<p>Sin embargo, si el usuario toca el botón Up desde la actividad de redacción, estará indicando su deseo de permanecer dentro de +Gmail. Por consiguiente, aparecerá la actividad de la lista de conversaciones de Gmail y se creará una nueva tarea B para esto. La ruta raíz de las nuevas tareas siempre conduce +a la pantalla Inicio, por lo que, si se toca el botón Back desde la lista de conversaciones, se regresará a dicha pantalla.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_up.png"> + +<p>La tarea A permanece en segundo plano, y el usuario podrá regresar a ella después (por ejemplo, a través de la pantalla +Recientes). Si Gmail ya estaba ejecutando su propia tarea en segundo plano, esta se reemplazará con la +tarea B, y el contexto anterior se abandonará para darle preferencia al nuevo objetivo del usuario.</p> + +<p>Cuando su aplicación se registre para manipular los intentos de una actividad que se encuentra en un nivel profundo dentro de la jerarquía de la aplicación, +consulte <a href="#into-your-app">Navegación dentro de la aplicación a través de los widgets y +las notificaciones de la pantalla de inicio</a> para obtener información sobre cómo especificar la navegación del botón Up.</p> diff --git a/docs/html-intl/intl/es/design/patterns/notifications.jd b/docs/html-intl/intl/es/design/patterns/notifications.jd new file mode 100644 index 0000000..bdbc77b --- /dev/null +++ b/docs/html-intl/intl/es/design/patterns/notifications.jd @@ -0,0 +1,872 @@ +page.title=Notificaciones +page.tags="notifications","design","L" +@jd:body + + <a class="notice-developers" href="{@docRoot}training/notify-user/index.html"> + <div> + <h3>Documentos para desarrolladores</h3> + <p>Cómo notificar al usuario</p> + </div> +</a> + +<a class="notice-designers" href="notifications_k.html"> + <div> + <h3>Notificaciones en Android 4.4 y versiones anteriores</h3> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=Uiq2kZ2JHVY"> +<div> + <h3>Video</h3> + <p>DevBytes: Notificaciones en la vista previa para desarrolladores de Android L</p> +</div> +</a> + +<style> + .col-5, .col-6, .col-7 { + margin-left:0px; + } +</style> + +<p>El sistema de notificaciones les permite a los usuarios mantenerse informados sobre eventos relevantes y +oportunos +de su aplicación, como nuevos mensajes de chat de un amigo o un evento del calendario. +Piense en las notificaciones como un canal de noticias que alerta a los usuarios sobre eventos +importantes +a medida que se producen o como un registro en el que se relatan los eventos mientras el usuario no está prestando +atención y que se sincroniza de forma correspondiente en todos los dispositivos de Android.</p> + +<h4 id="New"><strong>Novedades de Android 5.0</strong></h4> + +<p>En Android 5.0, las notificaciones reciben actualizaciones importantes a nivel estructural, +visual y funcional.</p> + +<ul> + <li>En las notificaciones, se han realizado cambios visuales de forma coherente con el nuevo +tema Material Design.</li> + <li> Las notificaciones ahora están disponibles en la pantalla de bloqueo del dispositivo y +el contenido confidencial se puede seguir + ocultando detrás de dicha pantalla.</li> + <li>En las notificaciones de alta prioridad que se reciben cuando el dispositivo está en uso, ahora se utiliza un nuevo formato llamado + notificaciones emergentes.</li> + <li>Notificaciones sincronizadas en la nube: Si se omite una notificación en un dispositivo +Android, esta se omitirá + también en los demás dispositivos.</li> +</ul> + +<p class="note"><strong>Nota:</strong> El diseño de las notificaciones de esta versión de +Android se diferencia +de manera significativa del diseño de las versiones anteriores. Para obtener información sobre el diseño de las notificaciones en versiones +anteriores, consulte <a href="./notifications_k.html">Notificaciones en Android 4.4 y versiones anteriores</a>.</p> + +<h2 id="Anatomy">Anatomía de una notificación</h2> + +<p>En esta sección, se repasan las partes básicas de una notificación y cómo se pueden mostrar en +diferentes tipos de dispositivos.</p> + +<h3 id="BaseLayout">Diseño básico</h3> + +<p>Como mínimo, todas las notificaciones poseen un diseño básico que incluye lo siguiente:</p> + +<ul> + <li> El <strong>icono</strong> de la notificación. El icono simboliza la +aplicación que lo origina. También puede + indicar el tipo de notificación si la aplicación genera más de un +tipo.</li> + <li> <strong>Título</strong> de la notificación y +<strong>texto</strong> adicional.</li> + <li> Una <strong>marca de tiempo</strong>.</li> +</ul> + +<p>Las notificaciones creadas con {@link android.app.Notification.Builder Notification.Builder} +para versiones anteriores de la plataforma lucen y funcionan igual en Android +5.0; solo presentan algunos cambios de estilo que el sistema realiza +por usted. Para obtener más información sobre las notificaciones en versiones anteriores de +Android, consulte +<a href="./notifications_k.html">Notificaciones en Android 4.4 y versiones anteriores</a>.</p></p> + + + <img style="margin:20px 0 0 0" src="{@docRoot}images/android-5.0/notifications/basic_combo.png" alt="" width="700px" /> + + +<div style="clear:both;margin-top:20px"> + <p class="img-caption"> + Diseño básico de una notificación para dispositivos portátiles (izquierda) y la misma notificación en Wear (derecha), + con una fotografía del usuario y un icono de la notificación + </p> + </div> + +<h3 id="ExpandedLayouts">Diseños expandidos</h3> + + +<p>Usted puede decidir cuántos detalles mostrarán las notificaciones +de su aplicación. Las notificaciones pueden mostrar las primeras +líneas de un mensaje o la vista previa de una imagen más grande. A través de la +información adicional, se proporciona más +contexto al usuario y, en algunos casos, se puede permitir que el usuario lea todo el +mensaje. El usuario +puede acercar o alejar la imagen, o deslizar la imagen con un solo dedo para alternar entre los diseños compacto +y expandido. + En el caso de las notificaciones de un solo evento, Android proporciona tres plantillas de +diseños expandidos (texto, bandeja de entrada e + imagen) para que usted utilice en su aplicación. En las siguientes imágenes, se muestra cómo +se ven las notificaciones de un solo evento en los + dispositivos portátiles (izquierda) y los dispositivos con Wear (derecha).</p> + +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/expandedtext_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/stack_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/ExpandedImage.png" + alt="" width="311px" height;="450px" /> + +<h3 id="actions" style="clear:both; margin-top:40px">Acciones</h3> + +<p>Android es compatible con acciones opcionales que se muestran en la parte inferior +de la notificación. +A través de las acciones, los usuarios pueden administrar las tareas más comunes para una determinada +notificación desde el interior del panel de notificaciones, sin tener que abrir la +aplicación que la originó. +Esto acelera la interacción y, junto con la función deslizar para descartar, ayuda a los usuarios a enfocarse en las +notificaciones que les parecen importantes.</p> + + + <img src="{@docRoot}images/android-5.0/notifications/action_combo.png" alt="" width="700px" /> + + + +<p style="clear:both">Sea moderado con la cantidad de acciones que incluye en una +notificación. Mientras más +acciones incluya, mayor complejidad cognitiva generará. Limítese a +la menor cantidad posible +de acciones al incluir solo las acciones más importantes +y significativas.</p> + +<p>Las acciones recomendadas para las notificaciones son aquellas que:</p> + +<ul> + <li> Son fundamentales, frecuentes y típicas para el tipo de contenido que está +mostrando. + <li> Les permiten a los usuarios realizar las tareas rápidamente. +</ul> + +<p>Evite acciones que sean:</p> + +<ul> + <li> ambiguas; + <li> iguales que la acción predeterminada de la notificación (tales como "Leer" o +"Abrir"). +</ul> + + + +<p>Puede especificar un máximo de tres acciones, cada una de ellas formada por un icono +de la acción y un nombre. + Al agregarle acciones a un diseño básico simple, la notificación será expandible, +incluso si no + cuenta con un diseño expandido. Como las acciones solo se muestran en las notificaciones +expandidas + y, de lo contrario, se ocultan, asegúrese de que cualquier acción que el +usuario invoque desde + una notificación esté disponible también desde la aplicación +asociada.</p> + +<h2 style="clear:left">Notificación emergente</h2> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/hun-example.png" alt="" width="311px" /> + <p class="img-caption"> + Ejemplo de una notificación emergente (llamada telefónica entrante, alta prioridad) +que aparece en la parte superior de una + aplicación inmersiva + </p> +</div> + +<p>Cuando llega una notificación de alta prioridad (ver a la derecha), esta se presenta +a los usuarios +durante un período breve, con un diseño expandido que expone las posibles acciones.</p> +<p> Luego de este período, la notificación se retira hacia el +panel de notificaciones. Si la <a href="#correctly_set_and_manage_notification_priority">prioridad</a> de una notificación +se marca como Alta, Máxima o Pantalla completa, se obtiene una notificación emergente.</p> + +<p><b>Buenos ejemplos de notificaciones emergentes</b></p> + +<ul> + <li> Llamada telefónica entrante cuando se utiliza un dispositivo</li> + <li> Alarma cuando se utiliza un dispositivo</li> + <li> Nuevo mensaje SMS</li> + <li> Batería baja</li> +</ul> + +<h2 style="clear:both" id="guidelines">Pautas</h2> + + +<h3 id="MakeItPersonal">Personalización</h3> + +<p>En el caso de las notificaciones de los elementos que envía otra persona (como un mensaje o una +actualización de estado), utilice +{@link android.app.Notification.Builder#setLargeIcon setLargeIcon()} para incluir la imagen de esa persona. Además, adjunte información sobre +la persona en los metadatos de la notificación (consulte {@link android.app.Notification#EXTRA_PEOPLE}).</p> + +<p>El icono principal de su notificación seguirá estando visible, de modo que el usuario pueda asociarlo +con el icono +que se muestra en la barra de estado.</p> + + +<img src="{@docRoot}images/android-5.0/notifications/Triggered.png" alt="" width="311px" /> +<p style="margin-top:10px" class="img-caption"> + Notificación en la que se muestra la persona que la generó y el contenido que envió. +</p> + + +<h3 id="navigate_to_the_right_place">Navegación hacia el lugar correcto</h3> + +<p>Cuando el usuario toca el cuerpo de una notificación (fuera de los botones de acción +), esta se abre +en el lugar en el que el usuario puede visualizarla y utilizar los datos que se mencionan en la +notificación. En la mayoría de los casos, se tratará de la vista detallada de un solo elemento de datos como un mensaje, +pero también se podría tratar de una +vista resumida si la notificación está apilada. Si la aplicación dirige al +usuario a cualquier sitio que se encuentre debajo del nivel superior, incorpore la navegación en la pila de retroceso de la aplicación para que el +usuario pueda presionar el botón Back del sistema y regresar al nivel superior. Para obtener más información, consulte +<em>Navegación dentro de la aplicación a través de los widgets y las notificaciones de la pantalla de Inicio</em> en el patrón de +diseño <a href="{@docRoot}design/patterns/navigation.html#into-your-app">Navegación</a>.</p> + +<h3 id="correctly_set_and_manage_notification_priority">Configuración y administración +correctas de la prioridad +de las notificaciones</h3> + +<p>Android admite el uso de una marca de prioridad en las notificaciones. Esta marca +le permite influir en el lugar donde aparecerá la notificación, en relación con otras notificaciones, y +lo ayuda a asegurarse de +que los usuarios vean siempre primero las notificaciones más importantes. Cuando publica una notificación, puede elegir +entre los +siguientes niveles de prioridad:</p> +<table> + <tr> + <td class="tab0"> +<p><strong>Prioridad</strong></p> +</td> + <td class="tab0"> +<p><strong>Uso</strong></p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MAX</code></p> +</td> + <td class="tab1"> +<p>Utilícelo para las notificaciones críticas y urgentes en las que se le informa al usuario sobre una condición +que es +crítica en el tiempo o que se debe resolver antes de que el usuario continúe con una +tarea específica.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>HIGH</code></p> +</td> + <td class="tab1"> +<p>Utilícelo, principalmente, para comunicaciones importantes, como eventos de mensajes o +chats con contenido que sea particularmente interesante para el usuario. +Las notificaciones de alta prioridad activan la pantalla de notificaciones emergentes.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>DEFAULT</code></p> +</td> + <td class="tab1"> +<p>Utilícelo para todas las notificaciones que no pertenecen a ninguno de los otros tipos de prioridades que se describen aquí.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>LOW</code></p> +</td> + <td class="tab1"> +<p>Utilícelo para las notificaciones que desea que el usuario reciba, pero +que son menos urgentes. Las notificaciones de baja prioridad tienden a aparecer en la parte inferior de la lista, +por lo que son ideales para +eventos como actualizaciones sociales públicas o indirectas: El usuario solicitó que se le notifiquen +estas +actualizaciones, pero estas notificaciones nunca tendrán prioridad sobre las comunicaciones +urgentes o directas.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MIN</code></p> +</td> + <td class="tab1"> +<p>Utilícelo para la información contextual o de segundo plano, como información sobre el clima o la +ubicación contextual. +Las notificaciones cuya prioridad es mínima no aparecen en la barra de estado. El usuario +las descubre al expandir el panel de notificaciones.</p> +</td> + </tr> +</table> + + +<h4 id="how_to_choose_an_appropriate_priority"><strong>Cómo elegir la +prioridad +adecuada</strong></h4> + +<p><code>DEFAULT</code>, <code>HIGH</code> y <code>MAX</code> son niveles de prioridad interruptiva, y se corre el riesgo de +interrumpir al usuario +en el medio de su actividad. Para evitar incomodar a los usuarios de su aplicación, reserve los niveles de prioridad interruptiva para +las notificaciones:</p> + +<ul> + <li> en las que participe otra persona;</li> + <li> en las que el tiempo sea importante;</li> + <li> que puedan modificar inmediatamente el comportamiento del usuario en el mundo real.</li> +</ul> + +<p>Las notificaciones que se configuran en <code>LOW</code> y <code>MIN</code> pueden seguir siendo +valiosas para el usuario: muchas, tal vez la mayoría, de las notificaciones simplemente no le piden al usuario que actúe de inmediato +ni llaman su atención mediante una vibración, pero poseen información que será valiosa para el +usuario +cuando este decida ver las notificaciones. Entre los criterios de las notificaciones con prioridad <code>LOW</code> y <code>MIN</code>, +se incluyen los siguientes:</p> + +<ul> + <li> No participan otras personas.</li> + <li> El tiempo no es importante.</li> + <li> Incluyen contenido que podría interesarle al usuario, pero que tal vez desee +buscarlo cuando lo necesite.</li> +</ul> + + + <img src="{@docRoot}images/android-5.0/notifications/notifications_pattern_priority.png" alt="" width="700" /> + + +<h3 style="clear:both" id="set_a_notification_category">Configuración de una +categoría de notificaciones</h3> + +<p>Si su notificación se puede clasificar dentro de alguna de las categorías predefinidas (consulte +a continuación), asígnela +según corresponda. Esta información se puede utilizar en determinados aspectos de la IU del sistema, como el panel de notificaciones (o cualquier +otro +agente de escucha de la notificación), para realizar una clasificación y filtrar las decisiones.</p> +<table> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_CALL">CATEGORY_CALL</a></code></p> +</td> + <td> +<p>Llamada entrante (voz o video) o una solicitud de comunicación +sincrónica similar</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_MESSAGE">CATEGORY_MESSAGE</a></code></p> +</td> + <td> +<p>Mensaje entrante directo (SMS, mensaje instantáneo, etc.)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EMAIL">CATEGORY_EMAIL</a></code></p> +</td> + <td> +<p>Mensaje en bloque asíncrono (correo electrónico)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EVENT">CATEGORY_EVENT</a></code></p> +</td> + <td> +<p>Evento del calendario</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROMO">CATEGORY_PROMO</a></code></p> +</td> + <td> +<p>Promoción o anuncio</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ALARM">CATEGORY_ALARM</a></code></p> +</td> + <td> +<p>Alarma o temporizador</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROGRESS">CATEGORY_PROGRESS</a></code></p> +</td> + <td> +<p>Progreso de una operación en segundo plano de larga ejecución</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SOCIAL">CATEGORY_SOCIAL</a></code></p> +</td> + <td> +<p>Actualización de red social o uso compartido de datos</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ERROR">CATEGORY_ERROR</a></code></p> +</td> + <td> +<p>Error en una operación en segundo plano o un estado de autenticación</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_TRANSPORT">CATEGORY_TRANSPORT</a></code></p> +</td> + <td> +<p>Control de transporte de medios para la reproducción</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SYSTEM">CATEGORY_SYSTEM</a></code></p> +</td> + <td> +<p>Actualización del estado del dispositivo o el sistema. Reservado para ser utilizado por el sistema</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SERVICE">CATEGORY_SERVICE</a></code></p> +</td> + <td> +<p>Indicación de ejecución de servicio en segundo plano</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_RECOMMENDATION">CATEGORY_RECOMMENDATION</a></code></p> +</td> + <td> +<p>Una recomendación específica y oportuna para un solo evento. Por ejemplo, en una +aplicación de noticias tal vez se desee +recomendar una historia que se considere que el usuario deseará leer luego</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_STATUS">CATEGORY_STATUS</a></code></p> +</td> + <td> +<p>Información constante sobre el estado contextual o del dispositivo</p> +</td> + </tr> +</table> + +<h3 id="summarize_your_notifications">Resumen de las notificaciones</h3> + +<p>Si una notificación de un determinado tipo ya está pendiente cuando su aplicación intenta enviar una nueva +notificación del mismo tipo, combínelas en una misma notificación resumida para la aplicación. No +cree un objeto nuevo.</p> + +<p>Las notificaciones resumidas incluirán una descripción resumida y le permitirán al usuario +conocer cuántas +notificaciones de un determinado tipo están pendientes.</p> + +<div class="col-6"> + +<p><strong>Lo que no debe hacer</strong></p> + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Dont.png" alt="" width="311px" /> +</div> + +<div> +<p><strong>Lo que debe hacer</strong></p> + + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Do.png" alt="" width="311px" /> +</div> + +<p style="clear:left; padding-top:30px; padding-bottom:20px">Puede proporcionar +información más detallada sobre cada una de las notificaciones que conforman un + resumen al utilizar el diseño resumido expandido. Este enfoque les permite a los usuarios tener +una idea más clara de las + notificaciones pendientes y determinar si están lo suficientemente interesados como para leer +los detalles en la + aplicación asociada.</p> +<div class="col-6"> + <img src="{@docRoot}images/android-5.0/notifications/Stack.png" style="margin-bottom:20px" alt="" width="311px" /> + <p class="img-caption"> + Notificación contraída y expandida que es un resumen (mediante el uso de <code>InboxStyle</code>) + </p> +</div> + +<h3 style="clear:both" id="make_notifications_optional">Uso de notificaciones +opcionales</h3> + +<p>Los usuarios deben tener siempre el control sobre las notificaciones. Permítale al usuario +deshabilitar las notificaciones +de su aplicación o cambiar las propiedades de las alertas, como el sonido de una alerta y si desea +utilizar la vibración, +mediante la incorporación de un elemento de configuración de notificaciones en las configuraciones de la aplicación.</p> + +<h3 id="use_distinct_icons">Uso de iconos diferentes</h3> +<p>Al mirar el área de notificaciones, el usuario debe poder diferenciar +los tipos de +notificaciones que están pendientes actualmente.</p> + +<div class="figure"> + <img src="{@docRoot}images/android-5.0/notifications/ProductIcons.png" alt="" width="420" /> +</div> + + <div><p><strong>Lo que debe hacer</strong></p> + <p>Mirar los iconos de notificaciones que ya se proporcionan en las aplicaciones de Android y crear +iconos de notificaciones para + su aplicación que tengan una apariencia bastante diferente.</p> + + <p><strong>Lo que debe hacer</strong></p> + <p>Utilizar el <a href="/design/style/iconography.html#notification">estilo de icono de notificación</a> + adecuado para los iconos pequeños y el +<a href="/design/style/iconography.html#action-bar">estilo +de icono de barra de acción</a> del diseño Material Light para los iconos + de acciones.</p> +<p ><strong>Lo que debe hacer</strong></p> +<p >Hacer que los iconos sean simples y evitar incluir una cantidad excesiva de detalles difíciles de +distinguir.</p> + + <div><p><strong>Lo que no debe hacer</strong></p> + <p>Colocar valores alfa adicionales (que se oscurezcan o aclaren) en los +iconos pequeños y los + iconos de acciones. Estos pueden tener bordes alisados, pero como en Android estos iconos se utilizan +como máscaras (es decir, solo se + utiliza el canal alfa), por lo general, la imagen se debe dibujar con +opacidad completa.</p> + +</div> +<p style="clear:both"><strong>Lo que no debe hacer</strong></p> + +<p>Utilizar colores para diferenciar su aplicación de las demás. Los iconos de las notificaciones simplemente +deben ser una imagen sobre un fondo blanco o transparente.</p> + + +<h3 id="pulse_the_notification_led_appropriately">Pulsación adecuada del +LED de notificaciones</h3> + +<p>Muchos dispositivos con Android incluyen un LED de notificaciones, que se utiliza para mantener al +usuario informado sobre los +eventos cuando la pantalla está apagada. Las notificaciones con un nivel de prioridad <code>MAX</code>, +<code>HIGH</code> o <code>DEFAULT</code> deben +hacer que se encienda el LED, mientras que las de menor prioridad (<code>LOW</code> y +<code>MIN</code>) no deben activar esta función.</p> + +<p>El control del usuario sobre las notificaciones debe extenderse al LED. Cuando se utilice +DEFAULT_LIGHTS, el +LED se iluminará en color blanco. Sus notificaciones no deberían utilizar un color +diferente, a menos que el +usuario lo haya personalizado explícitamente.</p> + +<h2 id="building_notifications_that_users_care_about">Creación de notificaciones +importantes para los usuarios</h2> + +<p>Para crear una aplicación que les guste a los usuarios, es importante diseñar las notificaciones +cuidadosamente. +Las notificaciones son la voz de su aplicación y ayudan a definir su +personalidad. Las notificaciones no deseadas +o que no son importantes pueden hacer que el usuario se moleste o no se sienta cómodo con la cantidad de +atención que le demanda la +aplicación, por eso debe utilizarlas de forma moderada.</p> + +<h3 id="when_to_display_a_notification">Cuándo se deben mostrar las notificaciones</h3> + +<p>Para crear una aplicación que los usuarios disfruten, es importante +reconocer que la atención +y el enfoque del usuario son recursos que se deben proteger. Aunque el sistema de notificaciones de Android +se diseñó +para minimizar el impacto de las notificaciones en la atención del usuario, +es +importante tener en cuenta que las notificaciones interrumpen el +flujo de tareas del usuario. +Cuando planifique sus notificaciones, pregúntese si son lo suficiente importantes como para +realizar una interrupción. Si no está seguro, permítale al usuario que elija las +notificaciones mediante la configuración de notificaciones de su aplicación o que ajuste +la marca de prioridad de las notificaciones en <code>LOW</code> o <code>MIN</code> para +evitar distraer al usuario cuando realiza +alguna otra tarea.</p> + + <img src="{@docRoot}images/android-5.0/notifications/TimeSensitive.png" alt="" width="311px" /> + <p style="margin-top:10px" class="img-caption"> + Ejemplos de notificaciones sujetas a limitación temporal + </p> + +<p>Aunque las aplicaciones más eficientes para el usuario solo proporcionan una respuesta cuando se la solicita, en algunos casos, +vale la pena que una aplicación interrumpa al usuario con una notificación no solicitada.</p> + +<p>Utilice las notificaciones principalmente para <strong>eventos sujetos a limitaciones temporales</strong>, en especial + si estos eventos sincrónicos <strong>involucran a otras personas</strong>. Por +ejemplo, un chat entrante + es una forma de comunicación sincrónica y en tiempo real: otro usuario +está esperando de forma activa su respuesta. Los eventos del calendario son otros buenos ejemplos de cuándo se debe utilizar una +notificación y llamar la atención del usuario, + ya que los eventos son inminentes y, generalmente, +involucran a otras personas.</p> + +<h3 style="clear:both" id="when_not_to_display_a_notification">Cuándo no se debe +mostrar una notificación</h3> + +<div class="figure" style="margin-top:60px"> + <img src="{@docRoot}images/android-5.0/notifications/AntiSample1.png" alt="" width="311px" /> +</div> + +<p>En muchos otros casos, no es apropiado enviar notificaciones:</p> + +<ul> + <li> Evite notificarle al usuario acerca de información que no le enviaron +específicamente a él o +información que no está verdaderamente sujeta a una limitación temporal. Por ejemplo, las actualizaciones asíncronas +e indirectas + que circulan por las redes sociales generalmente no justifican una interrupción en +tiempo real. En el caso de los usuarios + interesados en dichas notificaciones, permítales elegir.</li> + <li> No cree una notificación si la información nueva y relevante se muestra actualmente +en la pantalla. En su lugar, + utilice la IU de la aplicación para notificarle al usuario sobre la nueva información +directamente en contexto. + Por ejemplo, una aplicación de chat no debe crear notificaciones del sistema mientras +el usuario está chateando de forma activa con otro usuario.</li> + <li> No interrumpa al usuario para que ejecute operaciones técnicas de bajo nivel, como guardar +o sincronizar información, o actualizar una aplicación si dicha aplicación o el sistema pueden resolver el problema +sin la participación del usuario.</li> + <li> No interrumpa al usuario para informarle sobre un error si la +aplicación puede solucionar el error por sus propios medios, sin que el usuario +realice ninguna acción.</li> + <li> No cree notificaciones que no incluyan contenidos reales de notificación y que +simplemente promocionen + su aplicación. Una notificación debe proporcionar información nueva, útil y oportuna, y +no debe utilizarse + solo para lanzar una aplicación.</li> + <li> No cree notificaciones superfluas solo para mostrar su marca +a los usuarios. + Dichas notificaciones frustran y aíslan a su público. La +mejor forma de proporcionar + pequeñas cantidades de información actualizada y de mantener a los usuarios interesados +en su + aplicación es desarrollar un widget que puedan colocar en la +pantalla de inicio, si así lo desean.</li> +</ul> + +<h2 style="clear:left" id="interacting_with_notifications">Interacción con +las notificaciones</h2> + +<p>Las notificaciones se indican mediante iconos en la barra de estado, y se puede acceder a ellas +al abrir el +panel lateral de notificaciones.</p> + +<p>Al tocar una notificación, se abre la aplicación asociada con el contenido detallado +que coincide con el de la notificación. +Si dicha notificación se desplaza hacia la izquierda o la derecha, esta se eliminará del panel lateral.</p> + +<h3 id="ongoing_notifications">Notificaciones constantes</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/MusicPlayback.png" alt="" width="311px" /> + <p class="img-caption"> + Notificaciones constantes relacionadas con la reproducción de música + </p> +</div> +<p>Mediante las notificaciones constantes, se mantiene a los usuarios informados sobre un proceso en curso en +segundo plano. +Por ejemplo, los reproductores de música anuncian la pista que se está reproduciendo actualmente en el +sistema de notificaciones y +siguen haciéndolo hasta que el usuario detiene la reproducción. Mediante las notificaciones constantes también se le pueden +mostrar al usuario +comentarios sobre tareas más extensas, como descargar un archivo o codificar un video. Los usuarios no podrán +eliminar las notificaciones constantes del panel lateral de notificaciones.</p> + +<h3 id="ongoing_notifications">Reproducción de medios</h3> +<p>En Android 5.0, la pantalla de bloqueo no muestra los controles de transporte para la clase +{@link android.media.RemoteControlClient} obsoleta. Sin embargo, <em>sí</em> muestra las notificaciones, de modo que las notificaciones de reproducción de cada +aplicación ahora son la forma principal +en la que los usuarios controlan la reproducción desde el estado bloqueado. A través de este comportamiento, se le otorga más control +a la aplicación sobre los +botones que se deben mostrar, y la forma en que debe mostrarlos, al mismo tiempo que se proporciona +al usuario una experiencia coherente, independientemente de si la pantalla está bloqueada o no.</p> + +<h3 style="clear:both" +id="dialogs_and_toasts_are_for_feedback_not_notification">Diálogos +y avisos</h3> + +<p>Su aplicación no debe crear un diálogo o un aviso si actualmente no se muestra en la +pantalla. Los diálogos o los avisos se deben + mostrar únicamente como una respuesta inmediata a una acción que realiza el usuario +dentro de su aplicación. +Para obtener más información sobre cómo utilizar los diálogos y los avisos, consulte +<a href="/design/patterns/confirming-acknowledging.html">Confirmación y reconocimiento</a>.</p> + +<h3>Orden y clasificación</h3> + +<p>Las notificaciones son noticias que, como tales, se muestran, básicamente, en +orden cronológico inverso, prestando +especial atención a la +<a href="#correctly_set_and_manage_notification_priority">prioridad</a> de la notificación especificada en la aplicación.</p> + +<p>Las notificaciones son una parte clave de la pantalla de bloqueo y se muestran de forma prominente +cada vez +que se enciende la pantalla del dispositivo. El espacio en la pantalla de bloqueo es reducido, por lo que +es sumamente importante +que se identifiquen las notificaciones más urgentes o relevantes. Por este +motivo, Android cuenta +con un algoritmo de clasificación más sofisticado para las notificaciones, que tiene en cuenta lo siguiente:</p> + +<ul> + <li> La marca de tiempo y la prioridad especificada en la aplicación.</li> + <li> Si la notificación interrumpió al usuario recientemente con un sonido o una +vibración. (Es decir, + si el teléfono emitió un sonido y el usuario desea saber "¿Qué +pasó?", en la pantalla de bloqueo se debe + proporcionar una respuesta a simple vista).</li> + <li> Todas aquellas personas involucradas en la notificación mediante{@link android.app.Notification#EXTRA_PEOPLE} + y, especialmente, si son contactos preferidos.</li> +</ul> + +<p>Para aprovechar aún más esta función de clasificación, enfóquese en la +experiencia del usuario que desea +crear, en lugar de centrarse en algún punto importante de la lista.</p> + + <img src="{@docRoot}images/android-5.0/notifications/AntiSample3.png" alt="" width="700px" /> + + <p class="img-caption" style="margin-top:10px">Las notificaciones de Gmail +poseen una prioridad predeterminada, por lo que + normalmente clasifican los mensajes de una aplicación de mensajería instantánea como Hangouts, pero +realizan + un cambio de prioridad temporal cuando ingresan nuevos mensajes. + </p> + + +<h3>En la pantalla de bloqueo</h3> + +<p>Como las notificaciones son visibles en la pantalla de bloqueo, la privacidad del usuario es un aspecto +especialmente +importante. Por lo general, las notificaciones contienen información confidencial y +no necesariamente deben ser visibles +para cualquier persona que agarre el dispositivo y encienda la pantalla.</p> + +<ul> + <li> En el caso de los dispositivos que posean una pantalla de bloqueo segura (PIN, patrón o contraseña), la interface está formada por + partes públicas y privadas. La interfaz pública se puede mostrar en una pantalla de bloqueo segura y, + por ende, cualquier persona puede verla. La interfaz privada es el mundo detrás de esa pantalla de bloqueo y + solo se revela cuando el usuario se registra en el dispositivo.</li> +</ul> + +<h3>Control del usuario sobre la información que se muestra en la pantalla de bloqueo segura</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/LockScreen@2x.png" srcset="{@docRoot}images/android-5.0/notifications/LockScreen.png 1x" alt="" width="311px" /> + <p class="img-caption"> + Notificaciones en la pantalla de bloqueo, en la que el contenido se revela luego de que el usuario desbloquea el dispositivo + </p> +</div> + +<p>Cuando se configura una pantalla de bloqueo segura, el usuario puede decidir ocultar los +detalles confidenciales de dicha pantalla. En este caso, la IU del sistema +analiza el <em>nivel de visibilidad</em> de la notificación para decidir +qué información se puede mostrar de forma segura.</p> +<p> Para controlar el nivel de visibilidad, realice una llamada a +<code><a +href="/reference/android/app/Notification.Builder.html#setVisibility(int)">Notification.Builder.setVisibility()</a></code> + y especifique uno de los siguientes valores:</p> + +<ul> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PUBLIC">VISIBILITY_PUBLIC</a></code>. +Se muestra todo el contenido de la notificación. + Esta es la opción predeterminada del sistema si no se especificó el grado de visibilidad.</li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PRIVATE">VISIBILITY_PRIVATE</a></code>. +En la pantalla de bloqueo se muestra la información básica sobre la existencia de esta notificación, incluido +el icono y el nombre de la aplicación a través de la cual se publicó. No se muestra el resto de los detalles de la notificación. +A continuación, especificamos algunos puntos que se deben tener en cuenta: + <ul> + <li> Si desea proporcionar una versión pública diferente de su notificación +para que el sistema la muestre en una pantalla de bloqueo segura, suministre un +objeto de notificación de reemplazo en el campo <code><a +href="/reference/android/app/Notification.html#publicVersion">Notification.publicVersion</a></code> +. + <li> Mediante esta configuración, su aplicación puede crear una versión resumida del +contenido que sigue siendo útil, pero que no revela información personal. Considere el ejemplo de una +aplicación de SMS cuyas notificaciones incluyen el texto del SMS, el nombre del remitente y el icono del contacto. +Esta notificación debe ser <code>VISIBILITY_PRIVATE</code>, pero <code>publicVersion</code> podría +seguir conteniendo información útil como "3 mensajes nuevos", sin que se muestren otros detalles +de identificación. + </ul> + </li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_SECRET">Notification.VISIBILITY_SECRET</a></code>. Se muestra solo la menor cantidad de información posible; se excluye incluso +el icono de la notificación.</li> +</ul> +<h2 style="clear:both" id="notifications_on_android_wear">Notificaciones en +Android Wear</h2> + +<p>Las notificaciones y sus <em>acciones</em> se conectan de forma predeterminada con los dispositivos con Wear. +Los desarrolladores pueden controlar qué notificaciones se conectan desde el +teléfono hacia el reloj +y viceversa. Los desarrolladores también pueden controlar qué acciones se conectan. Si +en su aplicación se incluyen +acciones que no se pueden realizar con una sola pulsación, oculte dichas acciones +en su notificación para Wear +o considere anclarlas a una aplicación de Wear. De este modo, el usuario podrá +finalizar con la acción desde el +reloj.</p> + +<h4>Conexión entre notificaciones y acciones</h4> + +<p>Mediante un dispositivo conectado, como un teléfono, es posible conectar las notificaciones con un dispositivo con Wear, para que las +notificaciones se muestren allí. De modo similar, también es posible conectar acciones para que el usuario pueda ejecutarlas +directamente desde las notificaciones en los dispositivos con Wear.</p> + +<p><strong>Conexión</strong></p> + +<ul> + <li> Nuevos mensajes instantáneos</li> + <li> Acciones de una sola pulsación como Hacer +1, Me gusta o Favorito</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/WearBasic.png" width="156px" height="156px" alt="" /> + +<p><strong>Sin conexión</strong></p> + +<ul> + <li> Notificaciones de podcasts que llegaron recientemente</li> + <li> Acciones que se asignan a funciones que no se pueden ejecutar desde el reloj</li> +</ul> + + + +<p><h4>Acciones únicas diseñadas para Wear</h4></p> + +<p>Existen algunas acciones que solo puede realizar en Wear. Entre estas, se incluyen las siguientes:</p> + +<ul> + <li> listas rápidas de respuestas predeterminadas como "Vuelvo enseguida";</li> + <li> acciones que se abren desde el teléfono;</li> + <li> un "Comentario" o una acción de "Respuesta" que activa la pantalla de entrada de voz;</li> + <li> acciones que lanzan aplicaciones específicas de Wear.</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/ReplyAction.png" width="156px" height="156px" alt="" /> diff --git a/docs/html-intl/intl/ja/design/get-started/principles.jd b/docs/html-intl/intl/ja/design/get-started/principles.jd new file mode 100644 index 0000000..8e4149d --- /dev/null +++ b/docs/html-intl/intl/ja/design/get-started/principles.jd @@ -0,0 +1,307 @@ +page.title=Android デザイン指針 +@jd:body + +<p>このデザイン指針は、ユーザーがもっとも知りたいと思われることを中心に、Android User Experience Team により、またその活動を統一的なものにするために作成されたものです。Android デベロッパーとデザイナーに対しては各種端末向けのより詳細なデザイン ガイドラインがあります。 + + + +</p> + +<p> +ご自身の創造性やデザインについて考える際、この指針を考慮に入れてください。 +何を当てはめるかは目的に応じて調整してください。 +</p> + +<h2 id="enchant-me">ユーザーを引きつける</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="delight-me">サプライズで楽しませる</h4> +<p>美しい画面、考え抜かれて配置されたアニメーション、タイミングの良いサウンド エフェクトは、使っていて楽しくなります。 +わずかな効果でも、ユーザーを楽しませ、力を得たように感じてもらえます。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_delight.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="real-objects-more-fun">ボタンやメニューよりもリアルなオブジェクトでさらに楽しく</h4> +<p>ユーザーがアプリでオブジェクトを直接タップしたり操作したりできるようになります。タスクを実行するために必要な認知の労力が軽減され、感覚的な満足度も上がります。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_real_objects.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-it-mine">自分らしさを加える</h4> +<p>ユーザーは自分でカスタマイズすることを好みます。これにより、くつろいだ気分や自分の思いのままできる自由な気分を味わうことができます。デフォルトで実用的で美しいものを取りそろえ、それに加えてメイン タスクの妨げにならない、楽しいカスタマイズも任意で加えられます。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_it_mine.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="get-to-know-me">ユーザーについて知る</h4> +<p>徐々にユーザーの好みを学習していきます。同じ選択を繰り返す手間をかけず、前に選択したものをすぐに選べるようになります。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_get_to_know_me.png"> + + </div> +</div> + +<h2 id="simplify-my-life">よりシンプルに</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="keep-it-brief">常に簡潔に</h4> +<p>シンプルな言葉を並べた短いフレーズを用います。長い文章は好まれません。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_keep_it_brief.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="pictures-faster-than-words">画像は言葉よりもわかりやすい</h4> +<p>画像を使ってアイデアを説明してみましょう。ユーザーの興味を引くことができ、言葉よりも効率的です。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_pictures.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="decide-for-me">選択は最小限に、最終決定はユーザーに</h4> +<p>最初からユーザーにすべて尋ねるのではなく、もっとも適切と思われる項目を提示します。選択肢や決定事項が多すぎると面倒に感じます。 +推測が間違っていた場合に備え、「やり直し」も可能にします。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_decide_for_me.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="only-show-when-i-need-it">必要なものを必要なときにだけ表示する</h4> +<p>一度に表示される内容が多すぎると疲れてしまいます。タスクや情報はいくつかに小さくまとめてわかりやすくします。 +その時点で必要のないオプションは非表示にして、必要なときだけ表示します。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_information_when_need_it.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="always-know-where-i-am">全体像から現在の位置を示す</h4> +<p>ユーザーがはっきりと自分の現在の場所を把握できるようにします。アプリのどの場所にいるかを明示し、遷移して画面の関係を認識できるようにします。 +実行しているタスクに対して応答し続けます。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_navigation.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="never-lose-my-stuff">作成したものは失くさない</h4> +<p>ユーザーが時間をかけて作ったものは保存して、どこからでもアクセスできるようにします。設定、独自のカスタマイズ、電話、タブレット、コンピュータで作成したものを記録します。 +アップグレードも簡単になります。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_never_lose_stuff.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="looks-same-should-act-same">見た目が同じ場合は機能も同じにする</h4> +<p>視覚的な違いを際立たせ、ユーザーが機能の違いをはっきり区別できるようにします。同じような外観、同じ入力で機能が異なるようなモードは避けます。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_looks_same.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="interrupt-only-if-important">割り込みは重要なときにだけ行う</h4> +<p>優秀な個人秘書のように、重要ではない些細なことでユーザーをわずらわせることのないよう配慮します。集中したいユーザーにとって、重要で一刻を争うようなものでない限り、割り込まれると面倒で不快に感じる可能性があります。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_important_interruption.png"> + + </div> +</div> + +<h2 id="make-me-amazing">操作を楽しく</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="give-me-tricks">あらゆる場所に工夫を仕込む</h4> +<p>自分で理解すると嬉しく感じられます。Android アプリで広く使われている視覚や操作のパターンを生かし、アプリの操作をわかりやすいものにします。 +たとえばスワイプ操作は便利なナビゲーションのショートカットとして使えます。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_tricks.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="its-not-my-fault">解決は簡単に</h4> +<p>ユーザーに修正を促す場合はその方法に注意します。アプリではスマートに問題を解決できるようにします。うまくいかなかったときは解決方法を明確に示し、技術的な詳細を表示する必要はありません。自動的に修正できる問題はユーザーに通知する必要すらありません。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_error.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="sprinkle-encouragement">操作を促すしかけを散りばめる</h4> +<p>複雑なタスクは分割し、それぞれ簡単に達成できるようにします。1 つ 1 つにフィードバックすることで、ユーザーの満足度は高まります。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_sprinkle_encouragement.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="do-heavy-lifting-for-me">作業の手間はかけない</h4> +<p>できると思っていなかったことをできるようにすることで、知識がなくても専門家のような気分を味わってもらえます。たとえば複数の写真効果を組み合わせたショートカットを使うことで、わずかな手順でプロのような写真に仕上げられます。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_heavy_lifting.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-important-things-fast">重要なことはすみやかに</h4> +<p>すべてのアクションが同じ優先度とは限りません。アプリのアクションには優先度を設定し、重要なものはたとえばカメラのシャッター ボタンや音楽プレイヤーの一時停止ボタンのように、簡単に見つけられすぐに使えるようにします。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_important_fast.png"> + + </div> +</div> diff --git a/docs/html-intl/intl/ja/design/material/index.jd b/docs/html-intl/intl/ja/design/material/index.jd new file mode 100644 index 0000000..3acd423 --- /dev/null +++ b/docs/html-intl/intl/ja/design/material/index.jd @@ -0,0 +1,186 @@ +page.title=マテリアル デザイン +page.tags=Material, design +page.type=design +page.image=design/material/images/MaterialLight.png + +@jd:body + +<!-- developer docs box --> +<a class="notice-developers right" href="{@docRoot}training/material/index.html"> + <div> + <h3>デベロッパー文書</h3> + <p>マテリアル デザインを使ったアプリの作成</p> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=p4gmvHyuZzw"> +<div> + <h3>ビデオ</h3> + <p>マテリアル デザインについて</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=YaG_ljfzeUw"> +<div> + <h3>ビデオ</h3> + <p>紙とインク:重要なマテリアル</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=XOcCOBe8PTc"> +<div> + <h3>ビデオ</h3> + <p>Google I/O アプリのマテリアル デザイン</p> +</div> +</a> + + + +<p itemprop="description">マテリアル デザインは、視覚や動作と、複数のプラットフォームや端末間でのインタラクション デザインに関する包括的な指針です。 +Android はマテリアル デザイン アプリに対応するようになりました。 +Android アプリでマテリアル デザインを使うには、<a href="http://www.google.com/design/spec">マテリアル デザインの仕様</a>で説明されているガイドラインに従い、Android 5.0(API レベル 21)以降の新しいコンポーネントや機能を使用します。 + +</p> + +<p>Android にはマテリアル デザインの作成に使うことができる次の要素が用意されています。</p> + +<ul> + <li>新しいテーマ</li> + <li>複雑なビュー用の新しいウィジェット</li> + <li>カスタムのシャドウとアニメーション用の新しい API</li> +</ul> + +<p>Android でのマテリアル デザインの実装については、<a href="{@docRoot}training/material/index.html">マテリアル デザインを使ったアプリの作成</a>をご覧ください。 +</p> + + +<h3>マテリアル テーマ</h3> + +<p>マテリアル テーマはアプリの新しいスタイルである、システム ウィジェットを提供します。システム ウィジェットを使ってカラーパレット、タッチ フィードバックやアクティビティ遷移のためのデフォルトのアニメーションを指定できます。 +</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/MaterialDark.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">暗色マテリアル テーマ</p> + </div> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/MaterialLight.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">明色マテリアル テーマ</p> + </div> +</div> +<br style="clear:left"/> +</div> + +<p>詳細については、<a href="{@docRoot}training/material/theme.html">マテリアル テーマの使用</a>をご覧ください。 +</p> + + +<h3>リストとカード</h3> + +<p>Android はマテリアル デザインのスタイルとアニメーションを含むカードとリストを表示する新しい 2 つのウィジェットを提供しています。 +</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/list_mail.png" width="500" height="426" /> + <p><code>RecyclerView</code> ウィジェットは <code>ListView</code> のさらに柔軟なバージョンで、さまざまなレイアウト タイプをサポートしてパフォーマンスを向上します。 +</p> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/card_travel.png" width="500" height="426" /> + <p>新しい <code>CardView</code> ウィジェットでは、外観や使用感が一貫しているカード内に重要な情報を表示できます。 +</p> +</div> +<br style="clear:left"/> +</div> + +<p>詳細については、<a href="{@docRoot}training/material/lists-cards.html">リストとカードの作成</a>をご覧ください。 +</p> + + +<h3>シャドウの表示</h3> + +<p>X と Y プロパティに加え、Android のビューに Z プロパティが追加されました。 +この新しいプロパティはビューのエレベーションを表し、次を指定します。</p> + +<ul> +<li>シャドウのサイズ: Z 値が高いビューほどキャストするシャドウのサイズが大きくなります。</li> +<li>表示される順序: Z 値が高いビューほど他のビューより上位に表示されます。</li> +</ul> + +<div style="width:290px;margin-left:35px;float:right"> + <div class="framed-nexus5-port-span-5"> + <video class="play-on-hover" autoplay> + <source src="{@docRoot}design/material/videos/ContactsAnim.mp4"/> + <source src="{@docRoot}design/videos/ContactsAnim.webm"/> + <source src="{@docRoot}design/videos/ContactsAnim.ogv"/> + </video> + </div> + <div style="font-size:10pt;margin-left:20px;margin-bottom:30px"> + <em>端末の画像をクリックすると動画を再生できます</em> + </div> +</div> + +<p>詳細については、<a href="{@docRoot}training/material/shadows-clipping.html">シャドウとクリッピング ビューの定義</a>をご覧ください。 +</p> + + +<h3>アニメーション</h3> + +<p>新しいアニメーション API を使って UI コントロールのタッチ フィードバック、ビューの状態遷移、アクティビティ遷移のカスタム アニメーションを作成できます。 +</p> + +<p>これらの API で次の操作を実行できます。</p> + +<ul> +<li style="margin-bottom:15px"> +<strong>タッチ フィードバック</strong> アニメーションを使ってビューのタップイベントに応答します。 +</li> +<li style="margin-bottom:15px"> +<strong>円形状の出現</strong>アニメーションを使ってビューを表示 / 非表示にします。 +</li> +<li style="margin-bottom:15px"> +カスタムの<strong>アクティビティ遷移</strong>アニメーションを使ってアクティビティを切り替えます。 +</li> +<li style="margin-bottom:15px"> +<strong>曲線モーション</strong>を使ってより自然なアニメーションを作成します。 +</li> +<li style="margin-bottom:15px"> +<strong>ビューの状態遷移</strong>アニメーションを使って 1 つ以上のビュー プロパティの遷移を表現します。 +</li> +<li style="margin-bottom:15px"> +ビューの状態遷移間のアニメーションを<strong>状態リスト ドローアブル</strong>で表示します。 +</li> +</ul> + +<p>タッチ フィードバック アニメーションはボタンなどの複数の標準ビューに組み込まれます。新しい API を使ってこれらのアニメーションをカスタマイズし、それらをカスタム ビューに追加できます。 +</p> + +<p>詳細については、<a href="{@docRoot}training/material/animations.html">カスタム アニメーションの定義</a>をご覧ください。 +</p> + + +<h3>ドローアブル</h3> + +<p>次の新しいドローアブル機能を使ってマテリアル デザイン アプリを実装できます。</p> + +<ul> +<li><strong>ベクター型ドローアブル</strong>は鮮明度を失わずに拡張でき、単色のアプリ内アイコンに最適です。 +</li> +<li><strong>ドローアブルによる着色</strong>を使ってビットマップをアルファマスクとして定義し、実行時にそれらのビットマップに色付けすることができます。 +</li> +<li><strong>色の抽出</strong>を使ってビットマップ画像から代表色を自動的に抽出できます。 +</li> +</ul> + +<p>詳細については、<a href="{@docRoot}training/material/drawables.html">ドローアブルの使用</a>をご覧ください。 +</p> diff --git a/docs/html-intl/intl/ja/design/patterns/confirming-acknowledging.jd b/docs/html-intl/intl/ja/design/patterns/confirming-acknowledging.jd new file mode 100644 index 0000000..35ba821 --- /dev/null +++ b/docs/html-intl/intl/ja/design/patterns/confirming-acknowledging.jd @@ -0,0 +1,70 @@ +page.title=確認と通知 +page.tags=dialog,toast,notification +@jd:body + +<p>状況に応じて、ユーザーがアプリでアクションを呼び出したときに、テキストを使ってそのアクションを<em>確認</em>したり<em>通知</em>したりするのは良い方法です。</p> + +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_confirming.png"> + <p><strong>確認</strong>とは、呼び出したアクションを続けるかどうかをユーザーに確認してもらうことです。場合によって、確認は考慮する必要があるアクションに関連する警告や重要情報とともに表示されることがあります。</p> + </div> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_acknowledge.png"> + <p><strong>通知</strong>とは、呼び出したアクションが完了したことをユーザーにお知らせするテキストを表示することです。これによって、システムが実行している暗黙的な処理の不明瞭さをなくすことができます。場合によって、通知はアクションを元に戻すオプションとともに表示されることがあります。</p> + </div> +</div> + +<p>このような方法でユーザーに情報を伝えると、実行された処理やこれから実行される処理についての不明瞭さを軽減できます。確認や通知によって、後悔するような間違いをするのを防ぐこともできます。</p> + +<h2>ユーザーのアクションを確認または通知する場合</h2> +<p>すべてのアクションに確認または通知が必要なわけではありません。デザインを決定する際の指針として次のチャートを使用してください。</p> +<img src="{@docRoot}design/media/confirm_ack_flowchart.png"> + +<h2>確認</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>例: Google Play ブックス</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_books.png"> + <p>この例では、ユーザーが Google Play ライブラリから書籍を削除することを要求しています。その書籍が今後端末で使えなくなることを知ってもらうことが重要であるため、このアクションを確認する<a href="{@docRoot}design/building-blocks/dialogs.html#alerts">アラート</a>が表示されます。</p> + <p>確認のダイアログを作成するときは、要求されたアクションがすぐわかるようなタイトルにします。</p> + </div> + <div class="layout-content-col span-7"> + <h4>例: Android Beam</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_beam.png"> + <p>確認は、必ずしも 2 つのボタンの付いたアラートで示す必要はありません。Android Beam を開始した後に、ユーザーには共有するコンテンツ(この例では写真)にタップするように求めるメッセージが表示されます。共有を続行しない場合は、電話を離すだけです。</p> + </div> +</div> + +<h2>通知</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>例: 放置した Gmail 下書きの保存</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_draftsave.png"> + <p>この例では、ユーザーが Gmail 作成画面から前の画面に戻ったり、上位画面に移動したりするときに、予測しないことが起こる可能性があるため、現在の下書きが自動的に保存されます。トースト形式の通知によってその状態が明らかになります。この通知は数秒後にフェードします。</p> + <p>この場合、保存操作はユーザーではなくアプリによって行われるため、元に戻す操作は適切ではありません。また、下書きのリストに移動するだけでメッセージの作成をすぐに再開できます。</p> + + </div> + <div class="layout-content-col span-6"> + <h4>例: Gmail スレッドの削除</h4> + <img src="{@docRoot}design/media/confirm_ack_draft_deleted.png"> + <p>ユーザーが Gmail のリストからスレッドを削除した後に、元に戻すオプションとともに通知が表示されます。ユーザーがリストのスクロールなど関連しないアクションを実行するまで通知は表示されたままになります。</p> + </div> +</div> + +<h2>確認または通知を行わない場合</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>例: +1 操作</h4> + <img style="padding: 33px 0 30px;" src="{@docRoot}design/media/confirm_ack_ex_plus1.png"> + <p><strong>確認は不要</strong>。ユーザーが誤って +1 ボタンをタップしても、大きな問題にはなりません。ボタンをもう一度タップすればアクションを元に戻すことができます。</p> + <p><strong>通知は不要</strong>。+1 ボタンがバウンスし、赤に変わります。これは非常にわかりやすいシグナルです。</p> + </div> + <div class="layout-content-col span-7"> + <h4>例: ホームスクリーンからアプリを削除</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_removeapp.png"> + <p><strong>確認は不要</strong>。これは意図的なアクションです。ユーザーはアイテムを比較的大きな分離されたターゲットにドラッグ アンド ドロップする必要があります。そのため、不測の問題が発生することはほとんどありません。ユーザーがこの決定を元に戻したい場合は、ほんの数秒で元に戻すことができます。</p> + <p><strong>通知は不要</strong>。ユーザーは自分でアプリをドラッグして削除するため、アプリがホームスクリーンから消えることがわかっています。</p> + + </div> +</div> diff --git a/docs/html-intl/intl/ja/design/patterns/navigation.jd b/docs/html-intl/intl/ja/design/patterns/navigation.jd new file mode 100644 index 0000000..dbb6b04 --- /dev/null +++ b/docs/html-intl/intl/ja/design/patterns/navigation.jd @@ -0,0 +1,213 @@ +page.title=Back と Up を使用したナビゲーション +page.tags="navigation","activity","task","up navigation","back navigation" +page.image=/design/media/navigation_between_siblings_gmail.png +@jd:body + +<a class="notice-developers" href="{@docRoot}training/implementing-navigation/index.html"> + <div> + <h3>デベロッパー文書</h3> + <p>効果的なナビゲーションを実装する</p> + </div> +</a> + +<p itemprop="description">一貫したナビゲーションは全体的なユーザーの操作性を向上するために欠かせない重要な要素です。一貫性がなく予測できない動作ほどユーザーにとって不快なものはありません。 +Android 3.0 では、全体的なナビゲーション動作が大きく変更されました。 +注意深く Back と Up のガイドラインに従うことで、アプリのナビゲーションをユーザーにとって予測可能で信頼できるものにすることができます。 +</p> +<p>Android 2.3 以前のアプリ内でのナビゲーションはシステムの <em>Back</em> ボタンを使って行われてきました。Android 3.0 よりアクションバーが導入され、第 2 のナビゲーション メカニズムとして <em>Up</em> ボタンが登場しました。このボタンはアプリアイコンと左向きのキャラットで構成されています。 + +</p> + +<img src="{@docRoot}design/media/navigation_with_back_and_up.png"> + +<h2 id="up-vs-back">Up と Back</h2> + +<p>Up ボタンは、画面間の階層関係に基づいてアプリ内を移動するために使います。 +たとえば、画面 A がアイテムのリストを表示し、アイテムを選択すると(そのアイテムの詳細を表示する)画面 B に移動する場合、画面 B には画面 A に戻るための Up ボタンを用意する必要があります。 + +</p> +<p>画面がアプリの最上位(つまり、アプリのホーム)であれば、Up ボタンを表示すべきではありません。 +</p> + +<p>システムの Back ボタンはユーザーが最近使用した画面を、さかのぼって順番に移動する場合に使用されます。 +通常このナビゲーションはアプリの階層ではなく、画面を表示した順番に基づいています。 +</p> + +<p>前に表示していた画面が現在の画面の親階層となる場合は、Back ボタンを押すとUp ボタンを押したときと同じ結果になります — これはよくある動作です。 + +ただし、Up ボタンではユーザーが確実にアプリ内に留まるのに対して、Back ボタンを使えばホームスクリーンに、さらには別のアプリに戻ることさえできます。 +</p> + +<img src="{@docRoot}design/media/navigation_up_vs_back_gmail.png"> + +<p>Back ボタンは、画面間を直接ナビゲーションするだけでなく、次のような動作もサポートします。 +</p> +<ul> +<li>フローティング ウィンドウ(ダイアログ、ポップアップ)を閉じる</li> +<li>コンテキスト アクションバーを閉じて、選択したアイテムのハイライト表示を解除する</li> +<li>オンスクリーン キーボード(IME)を非表示にする</li> +</ul> +<h2 id="within-app">アプリ内でのナビゲーション</h2> + +<h4>複数のエントリ ポイントのある画面のナビゲーション</h4> +<p>画面にアプリ階層内の正確な位置がなく、アプリ内の他のどの画面からでもアクセスできる設定画面などのように複数のエントリ ポイントからアクセスできる場合があります。この場合、Up ボタンは参照元の画面に戻ることを選択する必要があります。これは Back も同様です。 +— + +</p> +<h4>画面内でビューを変更する</h4> +<p>画面のビュー オプションを変更しても Up と Back の動作は変わりません。画面はアプリの階層内の同じ位置に留まり、新しいナビゲーション履歴は作成されません。 +</p> +<p>このようなビューの変更には次のようなものがあります。</p> +<ul> +<li>タブや左右のスワイプを使ってビューを切り替える</li> +<li>ドロップダウン(折りたたみタブ)を使ってビューを切り替える</li> +<li>リストにフィルタをかける</li> +<li>リストをソートする</li> +<li>表示の方法を変える(ズームなど)</li> +</ul> +<h4>兄弟画面間のナビゲーション</h4> +<p>アプリでアイテムのリストから 1 つのアイテム詳細画面に移動するとき、そのアイテムからリスト内の前後にある別のアイテムへのナビゲーションをサポートするのが望ましいことがよくあります。 + +たとえば、Gmail では、スワイプすることで、ある会話から同じ受信トレイの新しいまたは古い会話へ左右に簡単に移動できます。 +画面内でビューを変更する場合と同じように、このようなナビゲーションによって Up または Back の動作は変わりません。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_gmail.png"> + +<p>しかし、参照リストで結び付けられていない関連詳細ビュー間をブラウジングする場合 — たとえば Play ストアで同じデベロッパーのアプリや同じアーティストのアルバム間をブラウジング場合、その動作はこれとは明らかに異なります。 + +この場合、各リンクをたどると履歴が作成され、Back ボタンで以前に表示した各画面に戻ることになります。 +Up では常にこれらの関連画面をバイパスして、直前に表示したコンテナ画面に移動します。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market1.png"> + +<p>Up の動作を詳細ビューの知識に基づいてより使いやすくすることができます。 +前述の Play ストアの例で、ユーザーが直前に表示した書籍から映画版の詳細に移動したとします。 +その場合、Up でユーザーが前に表示していないコンテナ(映画)に戻ることができます。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market2.png"> + +<h2 id="into-your-app">ホームスクリーンのウィジェットと通知によるアプリへのナビゲーション</h2> + +<p>ホームスクリーンのウィジェットや通知を使ってユーザーがアプリ階層内の深い階層にある画面に直接移動できるようにします。 +たとえば、Gmail の受信ボックスのウィジェットと新しいメッセージ通知はどちらも受信トレイ画面をバイパスし、会話ビューを直接表示できます。 +</p> + +<p>この両方の機能で、Up ボタンを次のように処理します。</p> + +<ul> +<li><em>通常アプリ内の特定の画面から移動先画面に移動する場合</em>、Up でその画面に移動します。 +</li> +<li><em>それ以外の場合は</em>、Up でアプリの最上位(「ホーム」)画面に移動します。</li> +</ul> + +<p>Back ボタンの場合は、アプリの最上位画面への完全な上向きナビゲーション パスをタスクのバックスタックに挿入してナビゲーションをより予測可能なものにする必要があります。 +この設定によって、アプリにどのように入ったか忘れたユーザーは、終了前のアプリの最上位画面に移動できます。 + +</p> + +<p>たとえば Gmail のホームスクリーンのウィジェットには、その作成画面に直接移動するボタンがあります。 +作成画面の Up または Back で受信トレイが表示され、そこから Back ボタンでホームに移動します。 +</p> + +<img src="{@docRoot}design/media/navigation_from_outside_back.png"> + +<h4>間接通知</h4> + +<p>アプリで複数のイベントに関する情報を同時に表示する必要がある場合、1 つの通知を使ってユーザーをインタースティシャル画面に導くことができます。 +この画面にはこれらのイベントがまとめてあり、アプリのさらに深い階層に移動するためのパスが示されます。このスタイルの通知を<em>間接通知</em>と呼びます。 + +</p> + +<p>標準(直接)通知とは異なり、間接通知のインタースティシャル画面から Back を押すとユーザーは通知がトリガーされた地点に戻ります — バックスタックには追加の画面は挿入されません。 + +ユーザーがインタースティシャル画面からアプリに移動すると、Up および Back は前述した標準通知の場合と同様に動作します。つまりインタースティシャル画面に戻るのではなくアプリ内でナビゲーションします。 + +</p> + +<p>たとえば Gmail のユーザーがカレンダーから間接通知を受け取ったとします。この通知をタップするとインタースティシャル画面が開き、複数の異なるイベントに関するリマインダーが表示されます。 + +インタースティシャル画面で Back をタップすると Gmail に戻ります。特定のイベントをタップすると、インタースティシャル画面から完全なカレンダー アプリに移動し、そのイベントの詳細が表示されます。 + +イベントの詳細から、Up および Back を使うとカレンダーの最上位ビューが表示されます。</p> + +<img src="{@docRoot}design/media/navigation_indirect_notification.png"> + +<h4>ポップアップ通知</h4> + +<p><em>ポップアップ通知</em>は通知ドロワーをバイパスしてユーザーの前に直接表示されます。 +ポップアップ通知はめったに使われません。<strong>タイムリーな応答が要求され、ユーザーのコンテキストの中断が必要な場合に使われます</strong>。 +たとえばトークでは、このスタイルを使って友人からのビデオチャットへの参加に関する招待状についてユーザーに通知します。というのも、この招待状は数秒後に自動的に期限切れになるからです。 + +</p> + +<p>ナビゲーション動作の点から、ポップアップ通知は間接通知のインタースティシャル画面の動作に厳密に従います。 +Back でポップアップ通知は閉じます。ユーザーがポップアップから通知元のアプリに移動すると、Up と Back は標準通知のルールに従い、アプリ内でナビゲーションします。 + +</p> + +<img src="{@docRoot}design/media/navigation_popup_notification.png"> + +<h2 id="between-apps">アプリ間のナビゲーション</h2> + +<p>Android システムの基本的な利点の 1 つにアプリ同士がそれぞれをアクティブにできる機能があります。これによりユーザーは特定のアプリから別のアプリへ直接移動できます。 +たとえば写真を撮影する必要があるアプリでは、カメラアプリをアクティブにすることができます。カメラアプリは写真を参照元のアプリに戻します。これはデベロッパーにとっては他のアプリのコードを簡単に利用できるという点で、またユーザーにとっては通常実行するアクションに対して一貫した操作を実行できるという点で大きなメリットです。 + + + +</p> + +<p>アプリ間のナビゲーションを理解するには、次に説明する Android フレームワークの動作を理解することが重要です。 +</p> + +<h4>アクティビティ、タスク、インテント</h4> + +<p>Android における<strong>アクティビティ</strong>とは情報の画面と、ユーザーが実行できるすべての関連アクションを定義するアプリケーション コンポーネントです。 +アプリはアクティビティのコレクションで、作成したアクティビティと他のアプリから再利用するアクティビティの両方で構成されています。 +</p> + +<p><strong>タスク</strong>とは目標を実現するためにユーザーが従う一連のアクティビティです。1 つのタスクで 1 つのアプリだけのアクティビティを利用することも、複数のアプリのアクティビティを利用することもできます。 + +</p> + +<p><strong>インテント</strong>とは、あるアプリがアクションの実行に関して別のアプリのサポートが必要であることを示すメカニズムです。 +アプリのアクティビティでそれらのアプリが対応できるインテントを示すことができます。 +「共有」などの一般的なインテントの場合、ユーザーはその要求を実現できる多くのアプリをインストールしている場合があります。 +</p> + +<h4>例: 共有をサポートするアプリ間のナビゲーション</h4> + +<p>アクティビティ、タスク、インテントの連携を理解するには、1 つのアプリが別のアプリを使ってユーザーによるコンテンツの共有を可能にする仕組みを知る必要があります。たとえばホームから Play ストアのアプリを起動すると、新しいタスク A が開始されるとします(以下の図を参照)。 + +Play ストア内をナビゲートし、プロンプトで表示された書籍をタップしてその詳細を表示した後もユーザーは同じタスク内に留まり、アクティビティを追加するとタスクは拡張されます。 +「共有」アクションをトリガーすると、共有インテントを処理するよう登録されている(さまざまなアプリの)各アクティビティを示すダイアログがユーザー表示されます。 + +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_inward.png"> + +<p>ユーザーが Gmail 経由で共有することを選択すると、Gmail の作成アクティビティがタスク A の続きとして追加されます — 新しいタスクは作成されません。 +Gmail にバックグラウンドで実行中の独自のタスクがある場合、そのタスクは影響を受けません。 +</p> + +<p>作成アクティビティからメッセージを送信するか、Back ボタンをタップするとユーザーは書籍の詳細アクティビティに戻ります。 +Back を連続してタップすると Play ストアに戻り、最終的にはホームが表示されます。 +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_back.png"> + +<p>ただし、作成アクティビティから Up をタップすると、ユーザーは Gmail 内に留まる意思を示すことになります。 +Gmail の会話リストのアクティビティが表示され、新しいタスク B が作成されます。新しいタスクは常にホームをルートとしているため、会話リストからBack をタップするとホームに戻ります。 +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_up.png"> + +<p>タスク A はバックグラウンドで維持され、ユーザー後から(たとえば [最近使ったアプリ] 画面経由で)このタスクに戻ることができます。 +Gmail にバックグラウンドで実行中の独自のタスクが既にある場合、そのタスクはタスク B に置き換えられます — 前のコンテキストはユーザーの新しい目標の導入より破棄されます。 +</p> + +<p>アプリがアプリ階層内の深い階層にあるアクティビティでインテントを処理するように登録されている場合は、Up ナビゲーションの指定方法について<a href="#into-your-app">ホームスクリーンのウィジェットと通知によるアプリへのナビゲーション</a>をご覧ください。 + +</p> diff --git a/docs/html-intl/intl/ja/design/patterns/notifications.jd b/docs/html-intl/intl/ja/design/patterns/notifications.jd new file mode 100644 index 0000000..8c5b6ba --- /dev/null +++ b/docs/html-intl/intl/ja/design/patterns/notifications.jd @@ -0,0 +1,872 @@ +page.title=通知 +page.tags="notifications","design","L" +@jd:body + + <a class="notice-developers" href="{@docRoot}training/notify-user/index.html"> + <div> + <h3>デベロッパー文書</h3> + <p>ユーザーに通知する</p> + </div> +</a> + +<a class="notice-designers" href="notifications_k.html"> + <div> + <h3>Android 4.4 以前での通知</h3> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=Uiq2kZ2JHVY"> +<div> + <h3>ビデオ</h3> + <p>DevBytes:Notifications in the Android L Developer Preview</p> +</div> +</a> + +<style> + .col-5, .col-6, .col-7 { + margin-left:0px; + } +</style> + +<p>通知システムを使用すると、ユーザーは友人からの新しいチャット メッセージやカレンダー イベントなど、自分に関係のあるタイムリーなイベントについてアプリで常に通知を受けることができます。通知は、重要な出来事が起こるとすぐに知らせてくれるニュース チャンネルであり、ユーザーが意識していない間に出来事を時系列的に記録するログであると捉えることができます — さらに、すべての Android 端末で適宜同期されます。 + + + + + +</p> + +<h4 id="New"><strong>Android 5.0 での新機能</strong></h4> + +<p>Android 5.0 において、通知は構造的に、視覚的に、機能的に重要なアップデートを受信します。 +</p> + +<ul> + <li>通知は、新しいマテリアル デザインのテーマにあわせて外観が変更されているところす。 +</li> + <li> 端末のロック画面で通知を利用できるようになりましたが、機密性の高いコンテンツはこれからも非表示にできます。 + +</li> + <li>端末の使用中に受信した高優先度の通知において、ヘッドアップ通知と呼ばれる新しい形式が使用されるようになりました。 +</li> + <li>クラウド同期通知: 所有する Android 端末のどれかで通知を却下すると、他でも却下されます。 + +</li> +</ul> + +<p class="note"><strong>注</strong>: このバージョンの Android での通知設計は、従来のバージョンから大きく変わっています。 + +これまでのバージョンの通知設計について詳しくは、<a href="./notifications_k.html">Android 4.4 以前での通知</a>をご覧ください。 +</p> + +<h2 id="Anatomy">通知の仕組み</h2> + +<p>このセクションでは、通知の基本パーツと各種端末における通知の表示について詳しく説明します。 +</p> + +<h3 id="BaseLayout">基本レイアウト</h3> + +<p>あらゆる通知の最低限の基本レイアウトは次のようになっています。</p> + +<ul> + <li> 通知の<strong>アイコン</strong>。このアイコンは通知元のアプリを示します。複数タイプの通知を生成するアプリでは、通知のタイプを示すことがあります。 + + +</li> + <li> 通知の<strong>タイトル</strong>と追加<strong>テキストメッセージ</strong>。 +</li> + <li> <strong>タイムスタンプ</strong>。</li> +</ul> + +<p>従来のプラットフォーム バージョンの {@link android.app.Notification.Builder Notification.Builder} で作成された通知は、Android 5.0 でも同じように表示され、機能します。スタイルにいくらかの違いがありますが、システムが対処します。 + + +従来のバージョンの Android での通知について詳しくは、<a href="./notifications_k.html">Android 4.4 以前での通知</a>をご覧ください。 + +</p></p> + + + <img style="margin:20px 0 0 0" src="{@docRoot}images/android-5.0/notifications/basic_combo.png" alt="" width="700px" /> + + +<div style="clear:both;margin-top:20px"> + <p class="img-caption"> + ユーザー フォトと通知アイコンを使用した、携帯端末での通知(左)と Wear での同じ通知(右) + + </p> + </div> + +<h3 id="ExpandedLayouts">展開レイアウト</h3> + + +<p>通知にどこまでの詳細を表示するかを選択できます。 +メッセージの最初の数行を表示したり、大きな画像プレビューを表示したりできます。 +追加情報はユーザーにより多くのコンテキストを提供し、—場合によっては—メッセージ全体が表示されることもあります。 + + +ユーザーは、ピンチ ズームまたは 1 本指のスワイプで、コンパクトなレイアウトと展開されたレイアウトを切り替えることができます。 + + + 1 つのイベントに関する通知に対し、Android では 3 種類の展開レイアウト(テキスト、受信トレイ、画像)をアプリケーションで使用できるようにしています。 + +次の図に、1 つのイベントに関する通知が携帯端末(左)とウェアラブル(右)でどのように見えるかを示します。 + +</p> + +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/expandedtext_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/stack_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/ExpandedImage.png" + alt="" width="311px" height;="450px" /> + +<h3 id="actions" style="clear:both; margin-top:40px">アクション</h3> + +<p>Android では、通知の最下部に表示されるオプションのアクションをサポートしています。ここに示されるアクションを使用することで、ユーザーは特定の通知に対するほとんどの一般的なタスクを通知シェードで処理でき、通知元のアプリケーションを開く必要はありません。これによりやり取りがスピードアップし、スワイプで却下もできることから、ユーザーは自分に関係のある通知に集中しやすくなります。 + + + + + +</p> + + + <img src="{@docRoot}images/android-5.0/notifications/action_combo.png" alt="" width="700px" /> + + + +<p style="clear:both">通知に含めるアクションの数はほどほどに抑えることをお勧めします。 +含めるアクションを増やすほど、わかりにくくなるからです。 +もっとも差し迫った意味のある重要なアクションだけにして、アクションの数を最小限に抑えてください。 + + +</p> + +<p>通知に対するアクションとして好ましい候補は次のとおりです。</p> + +<ul> + <li> 表示するコンテンツ タイプに欠かせず、よく使われ、典型的である + + <li> ユーザーがタスクを手早く完了できる +</ul> + +<p>次のようなアクションは避けてください。</p> + +<ul> + <li> あいまいである + <li> 通知のデフォルト アクションと同じである(「読む」や「開く」など) + +</ul> + + + +<p>アクションは 3 つまで指定でき、それぞれにアクションのアイコンと名前が付きます。 + + シンプルな基本レイアウトにアクションを追加すると、展開レイアウトがない場合でも、通知は展開可能になります。 + +アクションは展開可能な通知にのみ表示され、それ以外では非表示になることから、ユーザーが通知から起動できるどのアクションについても、関連アプリケーションからも利用できるようにしてください。 + + + + +</p> + +<h2 style="clear:left">ヘッドアップ通知</h2> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/hun-example.png" alt="" width="311px" /> + <p class="img-caption"> + イマーシブ アプリの最上部に表示されたヘッドアップ通知の例(電話の着信、高優先度) + + + </p> +</div> + +<p>優先度の高い通知が作成されると(右図)、その展開レイアウトが可能なアクションとともに短時間表示されます。 + +</p> +<p> この時間が過ぎると、通知は通知シェードに戻ります。 +通知の<a href="#correctly_set_and_manage_notification_priority">優先度</a>を示すフラグが高、最大、全画面の場合は、ヘッドアップ通知になります。 +</p> + +<p><b>ヘッドアップ通知にふさわしい例</b></p> + +<ul> + <li> 端末使用中の電話の着信</li> + <li> 端末使用中のアラーム</li> + <li> 新しい SMS メッセージ</li> + <li> 低バッテリ残量</li> +</ul> + +<h2 style="clear:both" id="guidelines">ガイドライン</h2> + + +<h3 id="MakeItPersonal">パーソナルにする</h3> + +<p>他人から送信されたアイテム(メッセージ、ステータス アップデートなど)の通知には、{@link android.app.Notification.Builder#setLargeIcon setLargeIcon()} を使用して相手の画像を含めます。 + +また、通知のメタデータに相手に関する情報を添付します({@link android.app.Notification#EXTRA_PEOPLE} を参照)。 +</p> + +<p>通知のメインアイコンは表示され続けるため、ユーザーはそれをステータスバーに表示されるアイコンと関連付けることができます。 + +</p> + + +<img src="{@docRoot}images/android-5.0/notifications/Triggered.png" alt="" width="311px" /> +<p style="margin-top:10px" class="img-caption"> + 通知をトリガーした人と送信内容が表示された通知。 +</p> + + +<h3 id="navigate_to_the_right_place">適切な画面へのナビゲーション</h3> + +<p>ユーザーが通知の本体(アクション ボタン以外)をタップしたら、アプリが開き、通知に表示されているデータの表示や操作ができる画面へ移動するようにします。 + + +ほとんどの場合、移動先はメッセージのような 1 つのデータアイテムの詳細表示になりますが、通知がスタックされている場合は概要ビューにすることも考えられます。 + +アプリがユーザーをアプリの最上位レベルより下のどこかに移動する場合は、アプリのバックスタックにナビゲーションを挿入して、ユーザーがシステムの Back ボタンを押すと最上位レベルに戻れるようにします。 + +詳しくは、<a href="{@docRoot}design/patterns/navigation.html#into-your-app">ナビゲーション</a>デザイン パターンの<em>ホーム画面ウィジェットと通知を経由するアプリへのナビゲーション</em>をご覧ください。 + +</p> + +<h3 id="correctly_set_and_manage_notification_priority">通知優先度の適切な設定と管理 + +</h3> + +<p>Android では、通知用の優先度フラグをサポートしています。このフラグを使用すると、通知の表示位置に他の通知との相対関係として影響を及ぼして、ユーザーが常に最重要の通知を真っ先に目にするようにできます。 + + +通知を投稿する際には、優先度を次の中から選べます。 + +</p> +<table> + <tr> + <td class="tab0"> +<p><strong>優先度</strong></p> +</td> + <td class="tab0"> +<p><strong>用途</strong></p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MAX</code></p> +</td> + <td class="tab1"> +<p>重大で切迫した通知に対して使用します。緊急を要する状況、または特定のタスクを続ける前に解決する必要がある状況であることをユーザーに通告します。 + + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>HIGH</code></p> +</td> + <td class="tab1"> +<p>主に重要な情報に対して使用します。ユーザーが特に関心を持ちそうなメッセージ イベントやチャット イベントなどが該当します。通知の優先度を高く設定すると、ヘッドアップ通知を表示できます。 + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>DEFAULT</code></p> +</td> + <td class="tab1"> +<p>ここで説明している他の優先度のどれにも該当しないすべての通知に対して使用します。</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>LOW</code></p> +</td> + <td class="tab1"> +<p>ユーザーに知らせたいがそれほど緊急ではない通知に対して使用します。 +低優先度の通知は一般にリストの末尾に表示され、公の、または間接的なソーシャル アップデートなどに適しています。 + +ユーザーがこうした通知の設定をしていても、急を要するコミュニケーションや直接的なコミュニケーションより優先されないようにする必要があります。 + + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MIN</code></p> +</td> + <td class="tab1"> +<p>天気予報や周辺位置情報のようなコンテキスト的またはバックグラウンド的な情報に対して使用します。最小優先度の通知はステータスバーに表示されません。 + +ユーザーは通知シェードを展開したときにその存在に気づきます。 +</p> +</td> + </tr> +</table> + + +<h4 id="how_to_choose_an_appropriate_priority"><strong>適切な優先度の選び方</strong> + +</h4> + +<p><code>DEFAULT</code>、<code>HIGH</code>、<code>MAX</code> は中断を伴う優先度レベルで、ユーザーによるアクティビティに割り込むリスクがあります。 + +アプリのユーザーに不快に思われないようにするため、割り込みを伴う優先度レベルの通知は次のような場合に限定してください。 +</p> + +<ul> + <li> 他人が絡む</li> + <li> 急を要する</li> + <li> 実世界におけるユーザーの行動が直ちに変わりうる</li> +</ul> + +<p><code>LOW</code> や <code>MIN</code> に設定されている通知も、ユーザーにとって価値がある可能性はあります。 +ほとんどとは言わないまでも、多くの通知は、ユーザーの注意を直ちに引く、またはユーザーの手首に振動を与える必要はありませんが、ユーザーがその通知を見ることにしたときに価値があると気づくような情報が含まれている必要があります。 + + +優先度が <code>LOW</code> や <code>MIN</code> の通知の条件は以下のとおりです。 +</p> + +<ul> + <li> 他人が絡まない</li> + <li> 急を要さない</li> + <li> ユーザーが興味を持ちうる内容が含まれているが、手が空いたときに参照することにして問題ない +</li> +</ul> + + + <img src="{@docRoot}images/android-5.0/notifications/notifications_pattern_priority.png" alt="" width="700" /> + + +<h3 style="clear:both" id="set_a_notification_category">通知カテゴリの設定 +</h3> + +<p>通知が、あらかじめ定義されているカテゴリ(下を参照)のどれかに該当する場合は、それに沿って割り当てます。 + +通知シェード(やその他の通知リスナー)などの各種システム UI は、評価やフィルタリングの判断にこの情報を使用することがあります。 + +</p> +<table> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_CALL">CATEGORY_CALL</a></code></p> +</td> + <td> +<p>電話(ビデオまたは音声)の着信またはそれに類する同期通信の要求 +</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_MESSAGE">CATEGORY_MESSAGE</a></code></p> +</td> + <td> +<p>直接メッセージ(SMS、インスタントメッセージなど)の受信</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EMAIL">CATEGORY_EMAIL</a></code></p> +</td> + <td> +<p>非同期バルク メッセージ(メール)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EVENT">CATEGORY_EVENT</a></code></p> +</td> + <td> +<p>カレンダー イベント</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROMO">CATEGORY_PROMO</a></code></p> +</td> + <td> +<p>販促または広告</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ALARM">CATEGORY_ALARM</a></code></p> +</td> + <td> +<p>アラームまたはタイマー</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROGRESS">CATEGORY_PROGRESS</a></code></p> +</td> + <td> +<p>長時間実行のバックグラウンド処理の進捗</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SOCIAL">CATEGORY_SOCIAL</a></code></p> +</td> + <td> +<p>ソーシャル ネットワークまたは共有アップデート</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ERROR">CATEGORY_ERROR</a></code></p> +</td> + <td> +<p>バックグラウンド処理または認証ステータスにおけるエラー</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_TRANSPORT">CATEGORY_TRANSPORT</a></code></p> +</td> + <td> +<p>再生のためのメディア転送コントロール</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SYSTEM">CATEGORY_SYSTEM</a></code></p> +</td> + <td> +<p>システムまたは端末のステータス アップデート。システム用に予約済み。</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SERVICE">CATEGORY_SERVICE</a></code></p> +</td> + <td> +<p>バックグラウンド サービス実行中の表示。</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_RECOMMENDATION">CATEGORY_RECOMMENDATION</a></code></p> +</td> + <td> +<p>1 つの事項に対する具体的でタイムリーな推奨。たとえば、ニュースアプリがユーザーが次に読みたいのではないかと予想した記事を推奨するなど。 + +</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_STATUS">CATEGORY_STATUS</a></code></p> +</td> + <td> +<p>端末やコンテキスト ステータスに関する進行中情報。</p> +</td> + </tr> +</table> + +<h3 id="summarize_your_notifications">通知の概要</h3> + +<p>アプリで特定の新しい通知を送信しようとしたときに同じタイプの通知が既に保留されていた場合は、それらを統合してそのアプリに対する 1 つの概要通知にします。新しいオブジェクトは作成しないでください。 + +</p> + +<p>概要通知は概要説明を作成し、特定タイプの通知がいくつ保留になっているのかがユーザーにわかるようにします。 + +</p> + +<div class="col-6"> + +<p><strong>非推奨</strong></p> + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Dont.png" alt="" width="311px" /> +</div> + +<div> +<p><strong>推奨</strong></p> + + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Do.png" alt="" width="311px" /> +</div> + +<p style="clear:left; padding-top:30px; padding-bottom:20px">概要を構成している個々の通知に関する詳細は、展開ダイジェスト レイアウトを使用して提示できます。 + +このアプローチにより、ユーザーはどの通知が保留中か、そして関連アプリで詳しく読もうと思うほどそれらに興味があるかを把握しやすくなります。 + + + +</p> +<div class="col-6"> + <img src="{@docRoot}images/android-5.0/notifications/Stack.png" style="margin-bottom:20px" alt="" width="311px" /> + <p class="img-caption"> + 通知の展開された概要と折りたたまれた概要(<code>InboxStyle</code> を使用) + </p> +</div> + +<h3 style="clear:both" id="make_notifications_optional">通知をオプションにする +</h3> + +<p>ユーザーは常に通知を制御できる必要があります。アプリケーションの設定に通知設定アイテムを追加して、ユーザーがアプリの通知を無効にしたり、警告音や振動を使用するかどうかなどのアラート設定を変更したりできるようにしてください。 + + + +</p> + +<h3 id="use_distinct_icons">見分けやすいアイコンにする</h3> +<p>現在保留になっているのがどのタイプの通知なのか、ユーザーが通知エリアを一目で見分けられることが必要です。 + +</p> + +<div class="figure"> + <img src="{@docRoot}images/android-5.0/notifications/ProductIcons.png" alt="" width="420" /> +</div> + + <div><p><strong>推奨</strong></p> + <p>Android アプリが既に提供している通知アイコンを見ながら、独自アプリ用に見かけの十分異なるアイコンを作成する。 + +</p> + + <p><strong>推奨</strong></p> + <p>小さなアイコン用の適切な<a href="/design/style/iconography.html#notification">通知アイコン スタイル</a>と、アクション アイコン用の Material Light <a href="/design/style/iconography.html#action-bar">アクションバー アイコンスタイル</a>を使う。 + + + +</p> +<p ><strong>推奨</strong></p> +<p >アイコンの見た目はシンプルに保ち、細かくしすぎて見にくくならないようにする。 +</p> + + <div><p><strong>非推奨</strong></p> + <p>なんらかの追加アルファ(暗転やフェード)を小さなアイコンやアクション アイコンに配置する。エッジはアンチ エイリアス処理できますが、Android ではこれらのアイコンをマークとして使用するため(つまり、アルファ チャンネルのみ使用)、画像は概して完全不透明で描画されます。 + + + + +</p> + +</div> +<p style="clear:both"><strong>非推奨</strong></p> + +<p>アプリを他と色で区別する。通知アイコンは、背景が透明な白に限定してください。 +</p> + + +<h3 id="pulse_the_notification_led_appropriately">通知 LED を適切に点灯させる +</h3> + +<p>多くの Android 端末には通知 LED が用意されており、スクリーンがオフのときでもユーザーに引き続きイベントを通知するために使用されます。 + +優先度が <code>MAX</code>、<code>HIGH</code>、<code>DEFAULT</code> の通知を LED 点灯するようにし、優先度の低い通知(<code>LOW</code> と <code>MIN</code>)は点灯しないようにしてください。 + + +</p> + +<p>ユーザーによる通知の制御が LED にも及ぶようにしてください。DEFAULT_LIGHTS を使用すると、LED が白く点灯します。 + +ユーザーが明示的にカスタマイズしない限り、通知では別の色を使用しないでください。 + +</p> + +<h2 id="building_notifications_that_users_care_about">ユーザーが気にする通知の作成 +</h2> + +<p>ユーザーに愛されるアプリを開発するためには、通知を入念にデザインすることが重要です。通知はアプリの声を体現するものであり、アプリの個性の一部です。 + + +望まれない通知や重要ではない通知がユーザーの邪魔になったり、アプリへの注目を集める意図が逆にユーザーに不快に思われたりしかねませんので、通知は適切に使用してください。 + + +</p> + +<h3 id="when_to_display_a_notification">通知を表示すべきケース</h3> + +<p>ユーザーが楽しんで使えるアプリケーションを開発するには、ユーザーの注目や関心は保護すべきリソースであるという認識が重要です。 + +Android の通知システムは、ユーザーの注意に対する通知のインパクトを最小限に抑える設計になっていますが、通知がユーザーのタスクフローに割り込むという事実を意識することがやはり重要です。通知を盛り込む予定の場合は、それが割り込みに値するほど重要かどうかを自問してください。 + + + + + + +確信が持てない場合は、ユーザーがアプリの通知設定を使用して通知をコントロールできるようにするか、通知のフラグを <code>LOW</code> か <code>MIN</code> に設定してユーザーがしている別のことを邪魔しないようにします。 + + + +</p> + + <img src="{@docRoot}images/android-5.0/notifications/TimeSensitive.png" alt="" width="311px" /> + <p style="margin-top:10px" class="img-caption"> + 急を要する通知の例 + </p> + +<p>概して、適切に振る舞うアプリは話しかけられたときだけ口を開きますが、求められていない通知でユーザーの作業に割り込むことにメリットがあるケースもいくつか存在します。 +</p> + +<p>通知は主に<strong>急を要するイベント</strong>で、特に<strong>他人が絡む</strong>同期イベントで使用します。 +たとえば、受信チャットはリアルタイムの同期コミュニケーションです。 + +他人が応答を能動的に待っています。 +カレンダー イベントも、通知でユーザーの注目を引くタイミングに関する好例です。なぜなら、そうしたイベントは差し迫っており、往々にして他人が絡みます。 + + +</p> + +<h3 style="clear:both" id="when_not_to_display_a_notification">通知を表示すべきでないケース +</h3> + +<div class="figure" style="margin-top:60px"> + <img src="{@docRoot}images/android-5.0/notifications/AntiSample1.png" alt="" width="311px" /> +</div> + +<p>以上を除く多くの場合、通知の使用は適切ではありません。</p> + +<ul> + <li> 明示的にユーザー宛てではない情報や、それほど急を要さない情報は、ユーザーへの通知を避けます。 + +たとえば、ソーシャル ネットワーク経由で流れてくる非同期の間接的なアップデートは、概してリアルタイムの割り込みにふさわしくありません。 + + +それらに本当に関心のあるユーザーが選択できるようにします。 +</li> + <li> 関連する新しい情報が現在画面に表示されている場合は、通知を作成しないようにします。 +その代わり、アプリケーションそのものの UI を使用して、ユーザーに情報をコンテキスト内で直接通知します。 + + + たとえば、チャット アプリケーションは、ユーザーが他のユーザーとチャットしている最中にシステム通知を作成しないようにします。 +</li> + <li> 情報の保存や同期、アプリケーションのアップデートなど、低レベルの技術的な通知については、アプリやシステムがユーザーの介入なしに問題を解決できる場合は割り込まないようにします。 + +</li> + <li> アプリケーションがユーザーの介入なしにエラーから復旧できる場合は、そのようなエラーの通知で割り込まないでください。 + +</li> + <li> 通知にふさわしい内容がなく、アプリを宣伝するだけの通知は、作成しないようにします。通知は、有益でタイムリーな新しい情報を提供するものであり、アプリを起動するためだけには使用しないでください。 + + + +</li> + <li> ブランドをユーザーの目の前に提示するだけの表面的な通知を作成しないようにします。 + + そうした通知はユーザーにフラストレーションを与え、アプリが使われなくなります。アップデートされた情報を少しだけ提供し、ユーザーをアプリにつなぎ止める最適な方法は、ホームスクリーンに配置できるウィジェットを開発することです。 + + + + +</li> +</ul> + +<h2 style="clear:left" id="interacting_with_notifications">通知の操作 +</h2> + +<p>通知はステータスバーにアイコンとして示され、通知ドロワーを開いてアクセスできます。 + +</p> + +<p>通知をタップすると関連アプリが開き、その通知に対応する詳細なコンテンツに移動します。通知上で左か右にスワイプされた通知は、ドロワーから削除されます。 + +</p> + +<h3 id="ongoing_notifications">進行中通知</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/MusicPlayback.png" alt="" width="311px" /> + <p class="img-caption"> + 音楽再生の進行中通知 + </p> +</div> +<p>進行中通知は、バックグラウンドで進行中の処理に関する情報をユーザーに伝えます。たとえば、音楽プレイヤーは通知システムで現在再生中のトラックを示し、ユーザーが再生を停止するまで通知を継続します。 + + + +進行中通知には、ファイルのダウンロードやビデオのエンコードなど、時間のかかるタスクに対するフィードバックをユーザーに示すこともできます。 + +ユーザーは、進行中通知を通知ドロワーから手動では削除できません。 +</p> + +<h3 id="ongoing_notifications">メディア再生</h3> +<p>Android 5.0 では、廃止された {@link android.media.RemoteControlClient} クラスの転送コントロールがロック画面に表示されません。 +ただし、通知が表示されるため、<em></em>ユーザーがロック状態から再生をコントロールするための主な手段は、現状では各アプリの再生通知です。 + +この動作により、アプリは表示するボタンとその表示形態についてより多くをコントロールでき、画面がロックされているかどうかによらない一貫した操作感をユーザーに提供できます。 + + +</p> + +<h3 style="clear:both" +id="dialogs_and_toasts_are_for_feedback_not_notification">ダイアログとトースト +</h3> + +<p>アプリが画面上に表示されていないときにダイアログやトーストを作成しないようにしてください。 +ダイアログやトーストの表示は、アプリでのアクションに対するユーザーへの即座の応答のみにします。ダイアログやトーストの使用の目安については、<a href="/design/patterns/confirming-acknowledging.html">確認と通知</a>をご覧ください。 + + + +</p> + +<h3>評価と並べ替え</h3> + +<p>通知はニュースであるため、基本的には新しい順に表示され、アプリが通知に指定した<a href="#correctly_set_and_manage_notification_priority">優先度</a>に基づき特別な配慮がなされます。 + + +</p> + +<p>通知はロック画面の重要な一部であり、端末のディスプレイがオンになるたび前面に出ます。 + +ロック画面のスペースは限られているため、もっとも緊急か重要な通知を識別することが何より重要になります。 + +この理由から、Android では洗練された通知並べ替えアルゴリズムを採用しており、その中で以下を考慮しています。 + +</p> + +<ul> + <li> タイムスタンプと、アプリが指定した優先度。</li> + <li> その通知が最近ユーザーに音または振動で配信されたかどうか。 +(つまり、電話が音を立てるだけの場合、ユーザーが「何が起こったのか」を知りたくなったら、ロック画面はそれに一目でわかる答えを示すべきです)。 + + +</li> + <li> {@link android.app.Notification#EXTRA_PEOPLE} を使用して通知に添付された人、特にその人が「お気に入り」の連絡先かどうか。 +</li> +</ul> + +<p>この並べ替え機能を最大限に生かすには、リストにおける特定の位置付けを狙うのではなく、ユーザーの操作感に注目します。 + +</p> + + <img src="{@docRoot}images/android-5.0/notifications/AntiSample3.png" alt="" width="700px" /> + + <p class="img-caption" style="margin-top:10px">Gmail 通知の優先度はデフォルトであり、そのため Hangouts などのインスタントメッセージ アプリからのメッセージの下に並びますが、新しいメッセージが来たときは一時的にそれより先に表示されます。 + + + + + </p> + + +<h3>ロック画面上</h3> + +<p>通知はロック画面に表示されるため、ユーザーのプライバシーはとりわけ重要な考慮対象です。 + +通知には機密性の高い情報が含まれることが多く、端末を手に取ってディスプレイをオンにした誰にでも見られるようにすべきではありません。 + +</p> + +<ul> + <li> セキュリティ保護されたロック画面(PIN、パターン、パスワードなど)を持つ端末の場合、インターフェースには公開部分と秘密部分があります。 +公開インターフェースはセキュリティ保護されたロック画面に表示でき、誰でも見られます。 +秘密インターフェースはロック画面の背後にある世界で、ユーザーが端末にサインインして初めて表示されます。 +</li> +</ul> + +<h3>セキュリティ保護されたロック画面に表示される情報のユーザー コントロール</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/LockScreen@2x.png" srcset="{@docRoot}images/android-5.0/notifications/LockScreen.png 1x" alt="" width="311px" /> + <p class="img-caption"> + ロック画面上の通知。コンテンツはユーザーが端末をロック解除した後に表示されます。 + </p> +</div> + +<p>セキュリティ保護されたロック画面をセットアップする際、ユーザーはセキュリティ保護されたロック画面には表示しない機密性の高い情報を選ぶことができます。 +その場合、システム UI は通知の<em>可視性レベル</em>を考慮して、表示しても問題ない情報を識別します。 + +</p> +<p> 可視性レベルをコントロールするには、<code><a +href="/reference/android/app/Notification.Builder.html#setVisibility(int)">Notification.Builder.setVisibility()</a></code> を呼び出し、次の値のどれかを指定します。 + +</p> + +<ul> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PUBLIC">VISIBILITY_PUBLIC</a></code>。通知の内容がすべて表示されます。 + + 可視性レベルが指定されていない場合は、これがシステム デフォルトです。</li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PRIVATE">VISIBILITY_PRIVATE</a></code>。ロック画面に、その通知の存在に関する基本情報、たとえば通知のアイコンやそれを提示したアプリ名などを表示します。 + +通知のその他の詳細は表示されません。いくつか留意すべき点があります。 + + <ul> + <li> システムがセキュリティ保護されたロック画面に表示するためとして公開バージョンの通知を別に提供する場合は、<code><a +href="/reference/android/app/Notification.html#publicVersion">Notification.publicVersion</a></code> フィールドに代替 Notification オブジェクトを用意します。 + + + + <li> この設定により、アプリは利便性はあるが個人情報は明かさない編集されたバージョンのコンテンツを作成できるようになります。 +SMS アプリを例に考えて見ましょう。通知には SMS のテキストメッセージ、送信者の名前、連絡先アイコンが含まれています。この通知は <code>VISIBILITY_PRIVATE</code> であるべきですが、<code>publicVersion</code> にも "3 件の新しいメッセージ" のような個人を特定する詳細なしでも利便性のある情報を盛り込めます。 + + + + + </ul> + </li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_SECRET">Notification.VISIBILITY_SECRET</a></code>。必要最小限の情報のみ表示し、通知のアイコンさえありません。 +</li> +</ul> +<h2 style="clear:both" id="notifications_on_android_wear">Android Wear での通知 +</h2> + +<p>通知とそのアクション<em></em>は、デフォルトで Wear 端末にブリッジされます。デベロッパーは、どの通知が電話から腕時計へ、またはその逆へブリッジするかを制御できます。 + + +また、どのアクションがブリッジするかも制御できます。タップ 1 回では完了しないアクションがアプリに含まれている場合は、そうしたアクションを Wear 通知では隠すか Wear アプリに接続することを検討してください。いずれにしても、ユーザーがアクションを腕時計で完了できるようにします。 + + + + + +</p> + +<h4>通知とアクションのブリッジ</h4> + +<p>電話のような接続状態の端末は、通知を Wear 端末にブリッジして、通知が腕時計に表示されるようにできます。 +同様に、アクションもブリッジして、ユーザーが通知に Wear 端末で直接対処できるようにできます。 +</p> + +<p><strong>ブリッジする</strong></p> + +<ul> + <li> 新しいインスタントメッセージ</li> + <li> +1、いいね、心拍数のようなタップ 1 回のアクション</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/WearBasic.png" width="156px" height="156px" alt="" /> + +<p><strong>ブリッジしない</strong></p> + +<ul> + <li> 新着ポッドキャストの通知</li> + <li> 腕時計ではできない機能にマップされたアクション</li> +</ul> + + + +<p><h4>Wear 専用に定義されたアクション</h4></p> + +<p>Wear でのみできるアクションがいくつかあります。次に例を挙げます。</p> + +<ul> + <li> 「Be right back」 のような定形応答のクイックリスト</li> + <li> 携帯電話で開く</li> + <li> 音声入力画面を起動する 「Comment」 アクションや 「Reply」 アクション</li> + <li> Wear 専用アプリを起動するアクション</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/ReplyAction.png" width="156px" height="156px" alt="" /> diff --git a/docs/html-intl/intl/ko/design/get-started/principles.jd b/docs/html-intl/intl/ko/design/get-started/principles.jd new file mode 100644 index 0000000..aba8a9b --- /dev/null +++ b/docs/html-intl/intl/ko/design/get-started/principles.jd @@ -0,0 +1,307 @@ +page.title=Android 디자인 원칙 +@jd:body + +<p>이러한 디자인 원칙은 사용자의 이익을 가장 염두에 두고 Android +사용자 환경 팀(User Experience Team)에 의해서와 이 팀을 위해 개발되었습니다. Android 개발자 및 디자이너를 +위해 Android 사용자 환경 팀은 계속해서 여러 +유형의 기기를 위한 상세한 디자인 가이드라인의 +기저를 이루고 있습니다.</p> + +<p> +본인의 +창의성과 디자인 사고를 적용할 때 이러한 원칙을 고려해 보시기 바랍니다. 목적을 가지고 여러 가지 참신한 발상을 실현해 보세요. +</p> + +<h2 id="enchant-me">황홀하게 만들기</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="delight-me">놀라운 방식으로 기쁨을 주기</h4> +<p>아름다운 표면, 신중하게 위치한 애니메이션 또는 시간적으로 잘 짜여진 소리 효과는 사람들에게 즐거운 +경험을 줍니다. 잔잔한 효과는 자연스러움을 느끼게 해주며, 강력한 +힘을 가지고 있다고 느끼게 해줍니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_delight.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="real-objects-more-fun">버튼 및 메뉴보다 더 흥미로운 실제 사물</h4> +<p>사람들이 직접 앱 내 사물을 터치하고 조작할 수 있게 해보세요. 이는 태스크를 수행할 때 +필요한 인지 노력을 줄이는 동시에 정서적인 만족을 가져다 줍니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_real_objects.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-it-mine">내 것으로 만들게 하기</h4> +<p>사람들은 개인적인 취향을 더하고 싶어 하는데, 그렇게 하면 마음이 편안해지고 통제할 수 있다고 느끼게 되기 때문입니다. 합리적이고 +아름다운 기본 설정을 제공하는 동시에 +주요 태스크를 저해하지 않는 범위에서 재미있고, 선택 가능한 맞춤 기능을 제공할 것을 고려해 보십시오.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_it_mine.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="get-to-know-me">사용자에 대해 파악하기</h4> +<p>시간이 지남에 따라 사람들이 선호하는 것을 알아보세요. 똑같은 선택을 매번 +하도록 요구하기 보다는 이전 선택을 쉽게 접근할 수 있는 곳에 둡니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_get_to_know_me.png"> + + </div> +</div> + +<h2 id="simplify-my-life">사용자의 생활을 단순하게 만들기</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="keep-it-brief">간결하게 만들기</h4> +<p>간단한 단어로 이루어진 짧은 문구를 사용하세요. 문장이 길면 사람들이 보지 않고 넘길 가능성이 커집니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_keep_it_brief.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="pictures-faster-than-words">말보다 빠른 사진</h4> +<p>생각을 전달하는 데 사진을 이용할 것을 고려해 보세요. 사람들의 시선을 끌고 말보다 +더 효과적일 수 있습니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_pictures.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="decide-for-me">사용자를 대신해서 결정해 주되 최종 결정권은 사용자에게 주기</h4> +<p>먼저 물어보기 보다는 최선의 추측을 하고 조치를 취해 보세요. 선택하고 결정해야 하는 사항이 너무 많으면 사람들이 +짜증을 내게 됩니다. 만약을 대비해 '실행 취소' 기능을 제공합니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_decide_for_me.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="only-show-when-i-need-it">사용자가 필요로 할 때 필요한 사항만 보여주기</h4> +<p>사람들은 한 번에 너무 많은 것을 보면 버거워합니다. 태스크 및 정보를 소화 가능한 +작은 크기로 나누세요. 현재 필요하지 않은 옵션은 숨기고 사람들의 작업 진행에 맞게 옵션을 표시하세요.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_information_when_need_it.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="always-know-where-i-am">사용자 자신이 현재 어디에 있는지 항상 알도록 하기</h4> +<p>사람들에게 현재 자신이 어디에 있는지에 대한 확신을 주어야 합니다. 앱에서 장소가 명확하게 표시되게 하고, +전환을 사용하여 화면 간 관계를 보여줍니다. 현재 작업 중인 태스크에 대한 피드백을 제공합니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_navigation.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="never-lose-my-stuff">사용자가 가지고 있는 것들을 절대 잃어버리지 않도록 하기</h4> +<p>사람들이 공들여 만든 것을 저장하고 어디서든지 액세스할 수 있게 합니다. 휴대폰, 태블릿 및 컴퓨터에 걸쳐 설정, +개인적 특색, 그리고 만든 것들이 저장되도록 합니다. 그렇게 하면 업그레이드가 세상에서 +가장 쉬워집니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_never_lose_stuff.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="looks-same-should-act-same">똑같이 보이면 똑같이 동작되도록 하기</h4> +<p>기능을 시각적으로 단순하게 만들기 보다는 눈에 띄게 만들어 사람들이 기능적 차이를 알아볼 수 있게 합니다. +비슷하게 보이는 장소지만 같은 입력에 대해 다르게 실행되는 모드는 피하도록 합니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_looks_same.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="interrupt-only-if-important">중요할 때만 작업을 중단하기</h4> +<p>유능한 개인 비서와 같이 중요하지 않은 일로 사람들의 작업을 중단하지 않도록 합니다. 사람들은 +작업에 계속 집중하기를 바라며, 중요하고 시간을 다투는 일을 제외하고는 작업이 중단되면 부담스럽고 짜증이 날 수 있습니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_important_interruption.png"> + + </div> +</div> + +<h2 id="make-me-amazing">사용자를 놀래킬 수 있는 환경 만들기</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="give-me-tricks">어디서든 적용될 수 있는 팁 제공하기</h4> +<p>사람들은 스스로 알아내는 것을 좋아합니다. 다른 Android 앱의 시각적 패턴과 머슬 메모리(muscle memory)를 활용하여 +앱을 쉽게 배울 수 있게 만드세요. 예를 들어 스와이프 제스처는 +좋은 탐색 지름길이 될 수 있습니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_tricks.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="its-not-my-fault">사용자가 자기 탓으로 느끼지 않게 하기</h4> +<p>사람들의 실수를 바로잡아 줄 때는 부드럽게 합니다. 사람들은 +앱을 사용할 때 스마트하게 느끼고 싶어 합니다. 뭔가 잘못될 경우, 명확한 복구 지침을 제공하되, 기술적인 세부 사항은 제공하지 않습니다. +사람들 모르게 복구할 수 있으면 더 좋습니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_error.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="sprinkle-encouragement">격려하기</h4> +<p>복잡한 태스크를 쉽게 완료할 수 있도록 여러 단계로 나눕니다. 미묘한 반짝임일지라도 +작업에 대해서 피드백을 줍니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_sprinkle_encouragement.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="do-heavy-lifting-for-me">힘든 건 대신해주기</h4> +<p>초보자들이 할 수 있을 것이라 생각하지 못한 일들을 해서 전문가처럼 느낄 수 있게 합니다. 예를 +들어, 여러 사진 효과를 결합한 단축키 기능은 아마추어 사진이 +겨우 몇 단계를 거치는 것만으로 멋진 사진으로 보이게 할 수 있습니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_heavy_lifting.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-important-things-fast">중요한 일은 빨리 해결되도록 하기</h4> +<p>모든 작업이 같지는 않습니다. 앱에서 가장 중요한 것이 무엇인지 결정한 후 쉽게 찾을 수 있고 +빨리 사용할 수 있도록 합니다. 일례로 카메라의 셔터 버튼이나 음악 플레이어의 일시정지 버튼이 이에 해당됩니다.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_important_fast.png"> + + </div> +</div> diff --git a/docs/html-intl/intl/ko/design/material/index.jd b/docs/html-intl/intl/ko/design/material/index.jd new file mode 100644 index 0000000..31992fa --- /dev/null +++ b/docs/html-intl/intl/ko/design/material/index.jd @@ -0,0 +1,186 @@ +page.title=머티어리얼 디자인 +page.tags=Material,design +page.type=design +page.image=design/material/images/MaterialLight.png + +@jd:body + +<!-- developer docs box --> +<a class="notice-developers right" href="{@docRoot}training/material/index.html"> + <div> + <h3>개발자 문서</h3> + <p>머티어리얼 디자인으로 앱 생성</p> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=p4gmvHyuZzw"> +<div> + <h3>비디오</h3> + <p>머티어리얼 디자인 소개</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=YaG_ljfzeUw"> +<div> + <h3>비디오</h3> + <p>종이와 잉크: 중요한 머티어리얼</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=XOcCOBe8PTc"> +<div> + <h3>비디오</h3> + <p>Google I/O 앱 내 머티어리얼 디자인</p> +</div> +</a> + + + +<p itemprop="description">머티어리얼 디자인은 플랫폼 및 기기 전반의 표현 방식, 모션 및 +상호 작용 디자인에 대한 종합적인 지침입니다. Android에는 이제 +머티어리얼 디자인 앱에 대한 지원이 포함되었습니다. Android 앱에서 머티어리얼 디자인을 사용하려면 <a href="http://www.google.com/design/spec">머티어리얼 디자인 사양</a>에 +규정되어 있는 지침을 따르세요. 또한 Android 5.0(API 레벨 21) 이상에서 제공하는 +새 구성 요소 및 기능을 사용하세요.</p> + +<p>Android는 머티어리얼 디자인 앱을 구축하는 데 사용할 수 있는 다음 요소를 제공합니다.</p> + +<ul> + <li>새로운 테마</li> + <li>복잡한 뷰를 위한 새로운 위젯</li> + <li>사용자 지정 그림자 및 애니메이션을 위한 새로운 API</li> +</ul> + +<p>Android에서 머티어리얼 디자인을 구현하는 방법에 대한 자세한 내용은 +<a href="{@docRoot}training/material/index.html">머티어리얼 디자인으로 앱 생성</a>을 참조하세요.</p> + + +<h3>머티어리얼 테마</h3> + +<p>머티어리얼 테마는 앱에 사용할 수 있는 새로운 스타일, 색상표를 +설정할 수 있는 시스템 위젯, 그리고 터치 피드백 및 액티비티 전환을 위한 기본 애니메이션을 제공합니다.</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/MaterialDark.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">어두운 머티어리얼 테마</p> + </div> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/MaterialLight.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">밝은 머티어리얼 테마</p> + </div> +</div> +<br style="clear:left"/> +</div> + +<p>자세한 내용은 <a href="{@docRoot}training/material/theme.html">머티어리얼 +테마 사용</a>을 참조하세요.</p> + + +<h3>목록 및 카드</h3> + +<p>Android는 머티어리얼 디자인 스타일 +및 애니메이션으로 카드 및 목록을 표시하는 데 사용할 수 있는 두 개의 새로운 위젯을 제공합니다.</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/list_mail.png" width="500" height="426" /> + <p>새로운 <code>RecyclerView</code> 위젯은 <code>ListView</code>의 +플러그 기능이 개선된 버전으로, 다양한 레이아웃 유형을 지원하고 향상된 성능을 제공합니다.</p> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/card_travel.png" width="500" height="426" /> + <p>새로운 <code>CardView</code> 위젯은 일관적인 모양 및 느낌이 있는 +카드 내 정보의 중요한 부분을 표시할 수 있게 해줍니다.</p> +</div> +<br style="clear:left"/> +</div> + +<p>자세한 내용은 <a href="{@docRoot}training/material/lists-cards.html">목록 +및 카드 생성</a>을 참조하세요.</p> + + +<h3>뷰 그림자</h3> + +<p>X 및 Y 속성과 더불어 이제 Android의 뷰에는 Z +속성이 추가되었습니다. 이 새로운 속성은 다음을 결정하는 뷰의 엘리베이션을 나타냅니다.</p> + +<ul> +<li>그림자 크기: 뷰의 Z 값이 클수록 표시되는 그림자도 커집니다.</li> +<li>그리기 순서: 뷰의 Z 값이 클수록 다른 뷰의 위에 표시됩니다.</li> +</ul> + +<div style="width:290px;margin-left:35px;float:right"> + <div class="framed-nexus5-port-span-5"> + <video class="play-on-hover" autoplay> + <source src="{@docRoot}design/material/videos/ContactsAnim.mp4"/> + <source src="{@docRoot}design/videos/ContactsAnim.webm"/> + <source src="{@docRoot}design/videos/ContactsAnim.ogv"/> + </video> + </div> + <div style="font-size:10pt;margin-left:20px;margin-bottom:30px"> + <em>영화를 재생하려면 기기 화면을 클릭합니다.</em> + </div> +</div> + +<p>자세한 내용은 <a href="{@docRoot}training/material/shadows-clipping.html">그림자 +정의 및 뷰 클리핑</a>을 참조하세요.</p> + + +<h3>애니메이션</h3> + +<p>새 애니메이션 API는 UI 컨트롤 내의 터치 피드백, 뷰 상태 +변화, 그리고 액티비티 전환을 위한 사용자 지정 애니메이션을 생성할 수 있게 해줍니다.</p> + +<p>이 API를 사용하면 다음 작업을 수행할 수 있습니다.</p> + +<ul> +<li style="margin-bottom:15px"> +<strong>터치 피드백</strong> 애니메이션으로 뷰 내 터치 이벤트에 응답하기. +</li> +<li style="margin-bottom:15px"> +<strong>회전하며 나타나기</strong> 애니메이션으로 뷰 감추기 및 표시하기. +</li> +<li style="margin-bottom:15px"> +사용자 지정 <strong>액티비티 전환</strong> 애니메이션으로 액티비티 간 전환하기. +</li> +<li style="margin-bottom:15px"> +<strong>커브 모션</strong>으로 더 자연스러운 애니메이션 생성하기. +</li> +<li style="margin-bottom:15px"> +<strong>뷰 상태 변경</strong> 애니메이션으로 하나 이상의 뷰 속성 변경 사항 애니메이션화하기. +</li> +<li style="margin-bottom:15px"> +뷰 상태 변경 간에 <strong>상태 목록 드로어블</strong>에서 애니메이션 표시하기. +</li> +</ul> + +<p>터치 피드백 애니메이션은 버튼과 같은 여러 기본 뷰에 내장되어 있습니다. 새 API를 사용하면 이러한 애니메이션을 사용자 지정하고 사용자 지정 뷰에 추가할 수 +있습니다.</p> + +<p>자세한 내용은 <a href="{@docRoot}training/material/animations.html">사용자지정 +애니메이션 정의</a>를 참조하세요.</p> + + +<h3>드로어블</h3> + +<p>드로어블에 대한 다음과 같은 새 기능을 통해 머티어리얼 디자인 앱을 쉽게 구현할 수 있습니다.</p> + +<ul> +<li><strong>벡터 드로어블</strong>은 단색 인앱 아이콘에 +적합하며, 정의 손실 없이 확장 가능합니다.</li> +<li><strong>드로어블 색조</strong>를 사용하면 비트맵을 알파 마스크로 정의할 수 있으며, 런타임에 +색을 입힐 수 있습니다.</li> +<li><strong>색상 추출</strong>은 +비트맵 이미지에서 주요 색상을 자동으로 추출할 수 있게 해줍니다.</li> +</ul> + +<p>자세한 내용은 <a href="{@docRoot}training/material/drawables.html">Drawable +사용</a>을 참조하세요.</p> diff --git a/docs/html-intl/intl/ko/design/patterns/confirming-acknowledging.jd b/docs/html-intl/intl/ko/design/patterns/confirming-acknowledging.jd new file mode 100644 index 0000000..2444b0e --- /dev/null +++ b/docs/html-intl/intl/ko/design/patterns/confirming-acknowledging.jd @@ -0,0 +1,70 @@ +page.title=확인 및 승인하기 +page.tags=dialog,toast,notification +@jd:body + +<p>사용자가 앱에서 작업을 호출할 때와 같은 몇몇 상황에서는 텍스트를 통해 해당 작업을 <em>확인</em>하거나 <em>승인</em>하는 것이 좋습니다.</p> + +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_confirming.png"> + <p><strong>확인하기</strong>란, 사용자에게 방금 호출한 작업을 정말로 진행할 것인지 묻는 것입니다. 경우에 따라 확인은 고려해야 할 작업과 관련된 경고 또는 중요한 정보와 함께 표시됩니다.</p> + </div> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_acknowledge.png"> + <p><strong>승인하기</strong>란, 사용자에게 방금 호출한 작업이 완료되었음을 알리는 텍스트를 표시하는 것입니다. 이는 시스템이 수행하는 암시적인 작업에 대한 불확실성을 제거해 줍니다. 경우에 따라 승인은 작업의 실행을 취소하는 옵션과 함께 표시됩니다.</p> + </div> +</div> + +<p>이런 방식의 사용자와의 소통은 이미 일어난 일이나 일어날 일에 대한 불확실성을 완화시키는 데 도움이 될 수 있습니다. 또한, 확인하기 또는 승인하기는 사용자가 후회할지도 모르는 실수를 미연에 방지합니다.</p> + +<h2>사용자 작업을 확인 또는 승인하기 적절한 경우</h2> +<p>모든 작업에 확인 또는 승인이 적합한 것은 아닙니다. 다음 순서도를 참고하여 디자인을 결정하는 데 도움을 받으세요.</p> +<img src="{@docRoot}design/media/confirm_ack_flowchart.png"> + +<h2>확인하기</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>예: Google Play 도서</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_books.png"> + <p>이 예에서는 사용자가 Google Play 라이브러리에서 도서 삭제를 요청했습니다. 이 작업을 확인하기 위해 <a href="{@docRoot}design/building-blocks/dialogs.html#alerts">경고</a>가 나타납니다. 왜냐하면 해당 도서를 더 이상 어떠한 기기에서도 이용할 수 없다는 것을 알려야 하기 때문입니다.</p> + <p>확인 대화 상자를 작성할 때, 요청된 작업을 반향하여 제목을 의미 있게 만듭니다.</p> + </div> + <div class="layout-content-col span-7"> + <h4>예: Android Beam</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_beam.png"> + <p>확인을 두 개의 버튼을 포함한 경고로 표시할 필요는 없습니다. Android Beam을 시작하면 사용자에게 공유할 콘텐츠를 터치하라는 메시지가 표시됩니다(이 예의 경우 사진). 진행하지 않기로 결정한 경우에는 휴대폰에서 벗어나면 됩니다.</p> + </div> +</div> + +<h2>승인하기</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>예: 방치된 Gmail 초안 저장</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_draftsave.png"> + <p>이 예에서는 사용자가 Gmail의 메일 작성 화면에서 뒤로 또는 위로 탐색을 수행하면 예상치 못한 일이 일어나는데, 그건 바로 현재 초안이 자동으로 저장되는 것입니다. 승인은 알림 메시지 형식으로 나타납니다. 그리고 몇 초 후 사라집니다.</p> + <p>이때, 저장이 사용자가 아닌 앱에 의해 이뤄졌기 때문에 실행 취소는 적합하지 않습니다. 그리고 초안 목록으로 이동하면 쉽고 빠르게 메일 작성을 재개할 수 있습니다.</p> + + </div> + <div class="layout-content-col span-6"> + <h4>예: Gmail 대화 삭제</h4> + <img src="{@docRoot}design/media/confirm_ack_draft_deleted.png"> + <p>사용자가 Gmail 목록에서 대화를 삭제하면, 승인이 실행 취소 옵션과 함께 표시됩니다. 승인은 사용자가 목록을 스크롤하는 등의 관련 없는 작업을 수행하기 전까지 그대로 남아 있습니다.</p> + </div> +</div> + +<h2>확인 또는 승인이 필요 없는 경우</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>예: +1 누르기</h4> + <img style="padding: 33px 0 30px;" src="{@docRoot}design/media/confirm_ack_ex_plus1.png"> + <p><strong>확인이 필요 없습니다</strong>. 사용자가 실수로 +1을 누른 경우, 별문제가 되지 않습니다. 버튼을 다시 터치하여 해당 작업의 실행을 취소하면 됩니다.</p> + <p><strong>승인이 필요 없습니다</strong>. 사용자는 +1 버튼이 바운스되고 빨간색으로 바뀌는 것을 볼 수 있습니다. 이는 매우 분명한 신호입니다.</p> + </div> + <div class="layout-content-col span-7"> + <h4>예: 홈 화면에서 앱 제거하기</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_removeapp.png"> + <p><strong>확인이 필요 없습니다</strong>. 이는 의도적인 작업으로, 사용자는 상대적으로 크고 고립된 대상으로 항목을 끌어다 놓을 것입니다. 따라서 실수가 발생할 가능성이 매우 낮습니다. 하지만 사용자가 이 결정을 후회하는 경우, 다시 복구하는 데는 몇 초면 됩니다.</p> + <p><strong>승인이 필요 없습니다</strong>. 사용자는 앱이 홈 화면에서 사라진 것을 알게 되는데, 이는 앱을 외부로 끌어서 화면에서 사라지게 했기 때문입니다.</p> + + </div> +</div> diff --git a/docs/html-intl/intl/ko/design/patterns/navigation.jd b/docs/html-intl/intl/ko/design/patterns/navigation.jd new file mode 100644 index 0000000..8e5c30b --- /dev/null +++ b/docs/html-intl/intl/ko/design/patterns/navigation.jd @@ -0,0 +1,213 @@ +page.title=뒤로 및 위로 탐색 기능이 포함된 탐색 +page.tags="navigation","activity","task","up navigation","back navigation" +page.image=/design/media/navigation_between_siblings_gmail.png +@jd:body + +<a class="notice-developers" href="{@docRoot}training/implementing-navigation/index.html"> + <div> + <h3>개발자 문서</h3> + <p>효과적인 탐색 구현하기</p> + </div> +</a> + +<p itemprop="description">일관적인 탐색 기능은 전반적인 사용자 환경에 필수적인 요소입니다. 일관성 없고 예상대로 진행되지 않는 기본 탐색은 +사용자에게 많은 실망을 줍니다. Android 3.0에서는 +글로벌 탐색 동작에 중요한 변경 사항을 도입했습니다. 뒤로 및 위로 탐색에 대한 +가이드라인을 꼼꼼히 따르면 사용자가 예상 가능하고 신뢰할 수 있는 탐색 기능이 탑재된 앱을 만들 수 있습니다.</p> +<p>Android 2.3 이하 버전에서는 +앱 내 탐색 기능을 지원하기 위해 시스템의 <em>뒤로</em> 버튼에 의존했습니다. Android 3.0에서는 작업 모음을 도입함으로써 앱 아이콘 및 왼쪽 방향 캐럿으로 이루어진 2차 탐색 메커니즘인 +<em>위로</em> 버튼이 추가되었습니다.</p> + +<img src="{@docRoot}design/media/navigation_with_back_and_up.png"> + +<h2 id="up-vs-back">위로 및 뒤로 비교</h2> + +<p>위로 버튼은 화면 +간의 계층적 관계를 기반으로 앱 내에서 탐색할 때 사용됩니다. 예를 들어, 화면 A에 표시된 항목 목록에서 항목을 선택하면 항목에 대한 세부 정보를 표시하는 화면 B로 이동하게 되는데, 이때 +화면 B는 화면 A로 +돌아가는 위로 버튼을 제공해야 합니다.</p> +<p>화면이 앱의 최상단에 있는 경우(즉, 앱의 홈인 경우), 위로 +버튼이 표시되지 않아야 합니다.</p> + +<p>시스템의 뒤로 버튼은 사용자가 최근에 작업한 화면 +기록을 역순으로 탐색할 때 사용됩니다. 일반적으로 이 버튼은 앱의 계층 구조가 아닌 화면 +간의 일시적인 관계를 기반으로 합니다.</p> + +<p>또한, 앞서 본 화면이 현재 화면의 계층적 상위 화면일 경우 +뒤로 버튼을 누르는 것과 위로 버튼을 누르는 것의 결과가 동일하며, 이는 흔하게 +발생하는 동작입니다. 하지만 사용자가 앱 내에 머무는 위로 버튼과 달리, 뒤로 +버튼을 누르면 홈 화면 또는 다른 앱으로 돌아갈 수 있습니다.</p> + +<img src="{@docRoot}design/media/navigation_up_vs_back_gmail.png"> + +<p>뒤로 버튼은 화면 간 탐색과 직접적으로 관련 없는 몇 가지 동작도 지원합니다. +</p> +<ul> +<li>부동 창 해제(대화 상자, 팝업)</li> +<li>상황에 맞는 작업 모음 해제 및 선택한 항목에서 강조 표시 제거</li> +<li>화상 키보드(IME) 감추기</li> +</ul> +<h2 id="within-app">앱 내 탐색</h2> + +<h4>진입 지점이 여러 개인 화면으로 이동하기</h4> +<p>일부 화면은 앱의 계층 구조 내에서 엄격한 위치를 가지고 있지 않는 경우가 있으며, 이 경우 여러 진입 지점을 +통해서 접근할 수 있습니다. 예를 들어 설정 화면은 앱 +내의 다른 어떤 화면에서도 접근이 가능합니다. 이러한 경우, 위로 버튼을 누르면 뒤로 버튼과 +동일하게 참조하는 화면으로 돌아가게 됩니다.</p> +<h4>화면 내에서 뷰 변경하기</h4> +<p>화면의 뷰 옵션 변경은 위로 또는 뒤로 버튼의 동작을 변경하지 않습니다. 이는 화면이 앱 계층 구조 내에서 여전히 동일한 위치에 +있고, 어떠한 탐색 기록도 새로 생성되지 않기 때문입니다.</p> +<p>이러한 뷰 변경의 예는 다음과 같습니다.</p> +<ul> +<li>탭 및/또는 좌우 스와이프를 사용하여 뷰 전환하기</li> +<li>드롭다운(겹쳐진 탭이라고도 함)을 사용하여 뷰 전환하기</li> +<li>목록 필터링하기</li> +<li>목록 정렬하기</li> +<li>표시 문자 변경하기(예: 확대/축소)</li> +</ul> +<h4>형제 화면 간 탐색하기</h4> +<p>항목 목록에서 개별 항목의 상세 뷰로의 이동을 앱에서 지원하는 경우, 해당 항목에서 목록의 이전/이후 +항목으로 직접 이동할 수 있도록 지원하는 것이 바람직한 +경우도 있습니다. 예를 들어 Gmail의 대화에서 왼쪽 또는 오른쪽으로 간단하게 스와이프하여 동일한 받은 편지함에 있는 신규 또는 이전 메일을 +볼 수 있습니다. 화면 내에서 뷰를 변경하는 것과 마찬가지로, +탐색은 위로 또는 뒤로 버튼의 동작을 바꾸지 않습니다.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_gmail.png"> + +<p>하지만 참조 목록으로 같이 +묶여 있지 않은 연관된 상세 뷰 사이를 탐색할 때는 주목할 만한 예외적인 상황이 발생합니다. 예를 들어, Play Store에서 +동일한 개발자가 만든 여러 앱 또는 동일한 아티스트의 여러 앨범을 탐색하는 경우가 그렇습니다. 이러한 경우, 링크를 따라갈 때마다 +기록이 생성되므로, 뒤로 버튼을 누르면 이전에 본 화면으로 이동합니다. 위로 버튼을 누르면 계속해서 이러한 연관된 화면을 +거치지 않고 가장 최근에 본 컨테이너 화면으로 이동합니다.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market1.png"> + +<p>상세 +뷰에 대한 지식을 바탕으로 더욱 스마트한 위로 버튼 동작을 구현할 수 있습니다. 위에서 설명한 Play Store 예를 확장하여 사용자가 +마지막으로 본 도서에서 해당 도서를 각색한 영화의 세부 정보 화면으로 이동했다고 가정해 봅니다. 그러한 경우, 위로 버튼을 누르면 사용자가 이전에 탐색한 적이 없는 +컨테이너(영화)로 이동할 수 있습니다.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market2.png"> + +<h2 id="into-your-app">홈 화면 위젯 및 알림을 통한 앱 탐색</h2> + +<p>홈 화면 위젯이나 알림을 사용하여 사용자가 앱 계층 구조 내에 +있는 화면으로 바로 이동할 수 있게 할 수 있습니다. 예를 들어, Gmail의 받은 편지함 위젯과 새 메시지 알림은 +모두 받은 편지함 화면을 건너뛰고 사용자가 해당 메일로 바로 이동할 수 있게 해줍니다.</p> + +<p>이러한 두 경우 모두 위로 버튼을 다음과 같이 처리합니다.</p> + +<ul> +<li><em>일반적으로 목적지 화면이 +앱 내의 특정 화면에서 출발한 경우</em>, 위로 버튼은 해당 화면으로 이동해야 합니다.</li> +<li><em>그 외의 경우</em>, 위로 버튼은 앱의 최상위("홈") 화면으로 이동해야 합니다.</li> +</ul> + +<p>뒤로 버튼의 경우, +앱의 최상위 화면으로 이동하는 완전한 상위 탐색 경로를 태스크의 백 스택에 삽입하여 탐색을 더욱 예측 가능하게 만들어야 합니다. 이는 앱에 어떻게 진입했는지 잊어버린 +사용자가 앱에서 나가기 +전에 앱의 최상위 화면으로 이동할 수 있게 해줍니다.</p> + +<p>예를 들어 Gmail의 홈 화면 위젯은 메일 작성 +화면으로 바로 진입할 수 있는 버튼을 제공합니다. 메일 작성 화면에서 위로 또는 +뒤로 버튼을 누르면 받은 편지함으로 이동하게 되고, 받은 편지함에서 뒤로 버튼을 누르면 홈으로 돌아가게 됩니다.</p> + +<img src="{@docRoot}design/media/navigation_from_outside_back.png"> + +<h4>간접 알림</h4> + +<p>앱이 동시에 다양한 이벤트 정보를 제공해야 하는 경우, 사용자를 틈새 화면(interstitial screen)으로 이동하게 하는 +단일 알림을 사용할 수 있습니다. 이 화면은 +이러한 이벤트를 요약하고, 사용자가 앱을 세부적으로 탐색할 수 있는 경로를 제공합니다. 이러한 스타일의 알림을 <em>간접 알림</em>이라고 +합니다.</p> + +<p>기본(직접) 알림과 달리, 간접 알림의 +틈새 화면에서 뒤로 버튼을 누르면 백 스택에 다른 화면이 +추가되지 않고 알림이 트리거된 지점으로 사용자를 이동시킵니다. 사용자가 +틈새 화면에서 앱으로 들어가면, 위로 버튼 및 뒤로 버튼은 위에서 설명한 바와 같이 틈새 화면으로 돌아가지 않고, 기본 알림과 마찬가지로 앱 내에서 +탐색을 수행합니다.</p> + +<p>예를 들어 Gmail을 사용 중인 사용자가 캘린더로부터 간접 알림을 받았다고 가정해 봅니다. 해당 +알림을 터치하면 틈새 화면이 열립니다. 이 화면에는 다른 +여러 이벤트에 대한 알림도 표시됩니다. 틈새 화면에서 뒤로 버튼을 터치하면 Gmail로 돌아갑니다. 특정 +이벤트를 터치하면 사용자를 틈새 화면에서 나오게 하여 +해당 이벤트의 세부 정보를 보여주는 완전한 캘린더 앱으로 이동하게 됩니다. 이벤트 세부 정보 화면에서 위로 버튼과 뒤로 버튼을 누르면 캘린더의 최상위 뷰로 이동하게 됩니다.</p> + +<img src="{@docRoot}design/media/navigation_indirect_notification.png"> + +<h4>팝업 알림</h4> + +<p><em>팝업 알림</em>은 알림 창을 거치지 않고 바로 사용자에게 +표시되는 알림입니다. <strong>팝업 알림은 시기적절한 +응답이 요구되는 경우와 사용자의 컨텍스트를 중단하는 것이 필요한 경우에 한하여</strong> 드물게 사용됩니다. 예를 들어 +Talk는 친구가 화상 채팅에 참여하도록 보낸 +초대를 사용자에게 알리기 위해 이러한 스타일의 알림을 사용하며, 이 초대는 몇 초 후에 자동으로 만료됩니다.</p> + +<p>탐색 동작 측면에서, 팝업 알림은 간접 +알림의 틈새 화면 동작을 상당히 많이 따릅니다. 뒤로 버튼을 누르면 팝업 알림이 해제됩니다. 사용자가 팝업을 +통해 앱으로 이동하면, 위로 및 뒤로 버튼은 기본 알림의 규칙에 따라 앱 내에서 +탐색합니다.</p> + +<img src="{@docRoot}design/media/navigation_popup_notification.png"> + +<h2 id="between-apps">앱 간 탐색</h2> + +<p>Android 시스템의 기본이 되는 강점 중 하나는 앱이 +다른 앱을 실행할 수 있다는 점이며, 이로 인해 사용자는 한 앱에서 다른 앱으로 직접 이동할 수 있습니다. 예를 들어, 사진을 캡처해야 하는 +앱은 카메라 앱을 작동시킬 수 있으며, 카메라 앱은 사진을 해당 앱으로 +돌려줍니다. 이러한 기능은 개발자와 사용자 모두에게 매우 유용합니다. 왜냐하면 개발자는 쉽게 다른 앱의 +코드를 활용할 수 있고, 사용자는 흔히 수행하는 +작업을 일관된 환경으로 즐길 수 있기 때문입니다.</p> + +<p>앱 간 탐색을 이해하려면 아래에서 +설명하는 Android 프레임워크 동작을 알아야 합니다.</p> + +<h4>액티비티, 태스크 및 인텐트</h4> + +<p>Android에서 <strong>액티비티</strong>는 +정보 및 사용자가 수행할 수 있는 모든 관련 작업이 포함된 화면을 정의하는 애플리케이션 구성 요소입니다. 앱은 본인이 직접 생성하는 +액티비티와 다른 앱에서 재활용하는 액티비티로 구성되어 있는 액티비티 컬렉션입니다.</p> + +<p><strong>태스크</strong>는 사용자가 목적을 달성하기 위해서 따르는 일련의 액티비티입니다. 단일 +태스크는 단 한 가지 앱의 액티비티만 사용할 수도 있고, +여러 앱의 액티비티를 사용할 수도 있습니다.</p> + +<p><strong>인텐트</strong>는 어떤 앱이 작업을 수행하는 데 다른 +앱의 도움을 받고자 한다는 신호를 보내는 메커니즘입니다. 앱의 액티비티는 +어떠한 인텐트에 응답을 보낼 수 있는지 알려줄 수 있습니다. "공유하기"와 같이 일반적인 인텐트의 경우, 사용자는 해당 요청을 수행할 수 있는 여러 앱을 +설치했을 수도 있습니다.</p> + +<h4>예: "공유하기"를 지원하는 앱 간에 탐색하기</h4> + +<p>액티비티, 태스크, 인텐트가 어떻게 같이 동작하는지 이해하려면 한 앱이 다른 앱을 사용하여 콘텐츠 +공유를 어떻게 가능하게 하는지 생각해 보세요. 예를 들어, 홈에서 Play Store 앱을 실행하면 +새로운 태스크 A가 시작됩니다(아래 그림 참조). Play Store에서 탐색하다가 홍보 도서의 세부 정보를 +보기 위해 터치하면, 다른 액티비티를 추가하여 태스크를 연장하는 방식으로 사용자는 동일한 태스크에 머물게 됩니다. 공유하기 +작업을 트리거하면 공유하기 인텐트를 처리하도록 +등록된 액티비티(다양한 앱에서 제공)가 나열된 목록을 보여주는 대화 상자가 표시됩니다.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_inward.png"> + +<p>사용자가 Gmail을 통해 공유하기를 선택할 경우, 새로운 태스크가 생성되는 것이 아니라 +태스크 A의 연장으로 Gmail의 메일 작성 액티비티가 추가됩니다. Gmail의 백그라운드에서 실행되는 자체적인 태스크가 있을 경우, 해당 태스크는 아무런 +영향도 받지 않습니다.</p> + +<p>메일 작성 액티비티에서 메시지를 보내거나 뒤로 버튼을 터치하면, 사용자는 +도서 세부 정보 액티비티로 돌아가게 됩니다. 뒤로 버튼을 연이어 터치하면 Play +Store에서 탐색한 페이지로 되돌아가게 되어 결국에는 홈 화면에 이르게 됩니다.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_back.png"> + +<p>하지만 사용자가 메일 작성 액티비티에서 위로 버튼을 터치하는 것은 +Gmail에 남아 있고자 하는 의지를 보이는 것입니다. 따라서, 이 경우 Gmail의 대화 목록 액티비티가 표시되고, 새로운 태스크 B가 생성됩니다. 새로운 태스크는 +항상 홈에 기반을 두고 있기 때문에, 대화 목록에서 뒤로 버튼을 터치하면 홈으로 되돌아가게 됩니다.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_up.png"> + +<p>태스크 A는 백그라운드에 남아 있기 때문에 나중에 돌아올 수 있습니다(예를 들어, +최근 앱 화면을 통해). Gmail에 이미 백그라운드에서 실행 중인 자체적인 태스크가 있을 경우, +해당 태스크는 태스크 B로 대체됩니다. 이전 컨텍스트는 사용자의 새로운 목적에 따라 제거됩니다.</p> + +<p>앱 계층 구조 내의 액티비티에서 인텐트를 처리하도록 앱에서 등록하는 경우, 위로 탐색을 지정하는 방법에 대한 지침을 확인하려면 +<a href="#into-your-app">홈 화면 위젯 및 +알림을 통한 앱 탐색</a>을 참조하세요.</p> diff --git a/docs/html-intl/intl/ko/design/patterns/notifications.jd b/docs/html-intl/intl/ko/design/patterns/notifications.jd new file mode 100644 index 0000000..aab5eac --- /dev/null +++ b/docs/html-intl/intl/ko/design/patterns/notifications.jd @@ -0,0 +1,872 @@ +page.title=알림 +page.tags="notifications","design","L" +@jd:body + + <a class="notice-developers" href="{@docRoot}training/notify-user/index.html"> + <div> + <h3>개발자 문서</h3> + <p>사용자에게 알리기</p> + </div> +</a> + +<a class="notice-designers" href="notifications_k.html"> + <div> + <h3>Android 4.4 이하 버전의 알림</h3> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=Uiq2kZ2JHVY"> +<div> + <h3>비디오</h3> + <p>DevBytes: Android L Developer Preview의 알림</p> +</div> +</a> + +<style> + .col-5, .col-6, .col-7 { + margin-left:0px; + } +</style> + +<p>알림 시스템을 사용하면 친구로부터 받은 새 채팅 메시지나 캘린더 이벤트와 같이 앱에서 관련된 +시기 적절한 +이벤트에 대한 알림을 사용자에게 표시할 수 있습니다. +알림을 중요한 +이벤트가 +발생한 경우 사용자에게 이에 대해 알리는 뉴스 채널이나 사용자가 앱에 집중하고 +있지 않은 동안에 이벤트를 시간순으로 기록하는 로그라고 생각하세요. 또한, 적절한 경우 모든 Android 기기에 걸쳐 동기화될 수도 있습니다.</p> + +<h4 id="New"><strong>Android 5.0의 새로운 기능</strong></h4> + +<p>Android 5.0에서는 구조적, +시각적, 그리고 기능적으로 중요한 업데이트를 알림을 통해 받을 수 있습니다.</p> + +<ul> + <li>새로운 +머티어리얼 디자인 테마와 일치하도록 알림이 시각적으로 바뀌었습니다.</li> + <li> 알림이 이제 기기 잠금 화면에 표시되나, +민감한 콘텐츠는 여전히 +숨길 수 있습니다.</li> + <li>기기가 사용 중일 때 수신되는 최우선 순위의 알림은 이제 +헤드업 알림이라는 새로운 형식을 사용합니다.</li> + <li>클라우드와 동기화되는 알림: Android +기기 중 하나에서 알림을 해지하면 +다른 기기에서도 해지됩니다.</li> +</ul> + +<p class="note"><strong>참고:</strong> 이 +Android 버전의 알림 디자인은 이전 버전과 많이 +다릅니다. 이전 +버전의 알림 디자인에 대한 자세한 내용은 <a href="./notifications_k.html">Android 4.4 이하 버전의 알림</a>을 참조하세요.</p> + +<h2 id="Anatomy">알림의 해부학적 구조</h2> + +<p>이 섹션에서는 알림의 기본적인 부분과 다양한 유형의 기기에서 알림이 어떻게 +표시될 수 있는지에 대해 살펴봅니다.</p> + +<h3 id="BaseLayout">기본 레이아웃</h3> + +<p>모든 알림은 기본적으로 다음을 포함하는 기본 레이아웃으로 구성됩니다.</p> + +<ul> + <li> 알림 <strong>아이콘</strong>. 알림 아이콘은 +알림을 발생시킨 앱을 나타냅니다. 또한, +앱이 두 가지 이상의 +유형을 생성하는 경우 알림 유형을 나타낼 수도 있습니다.</li> + <li> 알림 <strong>제목</strong> 및 추가 +<strong>텍스트</strong>.</li> + <li> <strong>타임스탬프</strong>.</li> +</ul> + +<p>이전 플랫폼 버전의 +{@link android.app.Notification.Builder Notification.Builder}로 생성된 알림은 시스템이 대신 +처리하는 사소한 스타일 변화를 제외하면 Android +5.0에서 똑같이 표시되고 동작합니다. 이전 +Android 버전의 알림에 대한 자세한 내용은 +<a href="./notifications_k.html">Android 4.4 이하 버전의 알림</a>을 참조하세요.</p></p> + + + <img style="margin:20px 0 0 0" src="{@docRoot}images/android-5.0/notifications/basic_combo.png" alt="" width="700px" /> + + +<div style="clear:both;margin-top:20px"> + <p class="img-caption"> + 핸드헬드 알림(왼쪽) 및 Wear에서 표시되는 동일한 알림(오른쪽)의 기본 레이아웃 +- 사용자 사진 및 알림 아이콘 포함 + </p> + </div> + +<h3 id="ExpandedLayouts">확장 레이아웃</h3> + + +<p>앱 알림이 얼마나 자세한 정보를 +제공하도록 할지는 직접 선택할 수 있습니다. 메시지의 처음 +몇 줄을 보여주거나 더 큰 이미지 미리보기를 보여줄 수 있습니다. 이러한 추가 +정보는 사용자에게 더 많은 +컨텍스트를 제공하며, 경우에 따라 이를 통해 사용자는 메시지 +전체를 읽을 수도 있습니다. 사용자는 +핀치-줌(pinch-zoom) 또는 한 손가락으로 밀기를 이용하여 축소 레이아웃과 +확장 레이아웃 간을 전환할 수 있습니다. + Android는 단일 이벤트 알림에 대해 세 개의 확장 레이아웃 +템플릿(텍스트, 받은 편지함, +이미지)을 애플리케이션에 사용할 수 있도록 제공합니다. 다음 이미지는 +단일 이벤트 알림이 +핸드헬드(왼쪽) 및 웨어러블(오른쪽)에서 어떻게 표시되는지 보여줍니다.</p> + +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/expandedtext_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/stack_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/ExpandedImage.png" + alt="" width="311px" height;="450px" /> + +<h3 id="actions" style="clear:both; margin-top:40px">작업</h3> + +<p>Android는 알림의 +맨 아래 부분에 표시되는 선택적인 작업을 지원합니다. +이러한 작업을 통해 사용자는 알림을 발생시킨 +애플리케이션을 열 필요 없이 알림 창에서 특정 +알림에 대한 가장 일반적인 태스크를 처리할 수 있습니다. +이 기능은 밀어서 해제하기와 함께 작용하여 상호 작용의 속도를 향상시키며, 사용자가 자신에게 중요한 알림에 +집중하는 데 도움이 됩니다.</p> + + + <img src="{@docRoot}images/android-5.0/notifications/action_combo.png" alt="" width="700px" /> + + + +<p style="clear:both">알림에 +포함할 작업의 수는 신중하게 결정해야 합니다. 더 많은 +작업을 포함할수록 인지적 복합성이 가중됩니다. 당장에 중요하며 의미 +있는 작업만 포함하여 작업 +수를 최소한으로 +제한해야 합니다.</p> + +<p>알림에 포함하기에 적합한 작업은 다음과 같습니다.</p> + +<ul> + <li> 표시하려는 +콘텐츠 유형과 관련하여 필수적이고, 자주 사용되며 전형적인 작업 + <li> 사용자가 신속하게 태스크를 완료할 수 있게 하는 작업 +</ul> + +<p>다음과 같은 작업은 피합니다.</p> + +<ul> + <li> 애매모호한 작업 + <li> "읽기" 또는 +"열기"와 같이 알림의 기본 작업과 동일한 작업 +</ul> + + + +<p>작업 +아이콘 및 이름으로 각각 구성된, 최대 세 개의 작업을 지정할 수 있습니다. + 단순한 기본 레이아웃에 작업을 추가하면 알림이 확장 가능하게 되며, +알림에 +확장 레이아웃이 없는 경우에도 이러한 사항이 적용됩니다. 작업은 +확장된 +알림에서만 표시되고 그 외에는 숨겨져 있으므로 +사용자가 알림에서 +호출할 수 있는 모든 작업을 관련 애플리케이션 내에서도 +사용할 수 있는지 확인해야 합니다.</p> + +<h2 style="clear:left">헤드업 알림</h2> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/hun-example.png" alt="" width="311px" /> + <p class="img-caption"> + 몰입형 앱의 +최상위에 +표시되는 헤드업 알림의 예(걸려오는 전화, 최우선 순위) + </p> +</div> + +<p>최우선 순위의 알림을 수신하면(오른쪽), 가능한 작업을 보여주는 확장된 레이아웃 형태로 +잠시 동안 사용자에게 +표시됩니다.</p> +<p> 그런 다음, 알림이 알림 +창으로 돌아갑니다. 알림에 대한 <a href="#correctly_set_and_manage_notification_priority">우선 순위</a> 플래그가 HIGH, MAX 또는 전체 화면으로 +지정된 경우 헤드업 알림이 표시됩니다.</p> + +<p><b>헤드업 알림의 좋은 예</b></p> + +<ul> + <li> 기기 사용 시 걸려오는 전화</li> + <li> 기기 사용 시 알람</li> + <li> 새 SMS 메시지</li> + <li> 배터리 부족</li> +</ul> + +<h2 style="clear:both" id="guidelines">가이드라인</h2> + + +<h3 id="MakeItPersonal">개인에 맞게 만들기</h3> + +<p>다른 사람이 보낸 항목(메시지 또는 +상태 업데이트)에 대한 알림의 경우 +{@link android.app.Notification.Builder#setLargeIcon setLargeIcon()}을 사용하여 그 사람의 이미지를 포함합니다. 또한 +그 사람에 대한 정보를 알림의 메타데이터에 추가합니다({@link android.app.Notification#EXTRA_PEOPLE} 참조).</p> + +<p>알림의 기본 아이콘이 여전히 표시됩니다. 따라서 사용자는 +해당 아이콘을 상태 표시줄에 +보이는 아이콘과 관련시킬 수 있습니다.</p> + + +<img src="{@docRoot}images/android-5.0/notifications/Triggered.png" alt="" width="311px" /> +<p style="margin-top:10px" class="img-caption"> + 누가 트리거했는지와 보낸 내용을 보여주는 알림입니다. +</p> + + +<h3 id="navigate_to_the_right_place">적합한 곳으로 이동하기</h3> + +<p>사용자가 작업 +버튼 외부에서 알림을 터치하면, 사용자가 알림에서 +참조되는 데이터를 확인하고 처리할 수 있는 곳에서 +앱이 열리도록 합니다. 대부분의 경우, 메시지와 같은 단일 데이터 항목을 표시하는 상세 뷰가 이에 해당합니다. +하지만 알림이 중첩되어 있을 경우에는 +요약 뷰일 수도 있습니다. 앱이 +최상위 레벨 아래의 위치에서 열린 경우 +사용자가 시스템의 뒤로 버튼을 눌러 최상위 레벨로 돌아갈 수 있도록 앱의 백 스택에 탐색 경로를 삽입합니다. 자세한 내용은 +<a href="{@docRoot}design/patterns/navigation.html#into-your-app">탐색</a> +디자인 패턴의 <em>홈 화면 위젯 및 알림을 통한 앱 탐색</em>을 참조하세요.</p> + +<h3 id="correctly_set_and_manage_notification_priority">알림의 +우선 순위를 정확하게 설정하고 +관리하기</h3> + +<p>Android는 알림 우선 순위 플래그를 지원합니다. 이 플래그를 통해 다른 알림에 상대적으로 알림이 표시되는 위치가 +결정되도록 할 수 있습니다. 또한 +사용자가 가장 중요한 알림을 항상 가장 먼저 볼 수 있게 +할 수 있습니다. 알림을 게시할 때 +다음 우선 순위 중에서 +선택할 수 있습니다.</p> +<table> + <tr> + <td class="tab0"> +<p><strong>우선 순위</strong></p> +</td> + <td class="tab0"> +<p><strong>용도</strong></p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MAX</code></p> +</td> + <td class="tab1"> +<p>시간에 민감한 +또는 +특정 태스크를 계속 진행하기 전에 처리해야 할 +상황을 사용자에게 알리는 중요하고 긴급한 알림에 사용합니다.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>HIGH</code></p> +</td> + <td class="tab1"> +<p>중요한 대화에 주로 사용합니다. 일례로 사용자에게 특별히 흥미로운 내용이 포함된 메시지 또는 채팅 +이벤트가 이에 해당합니다. +최우선 순위의 알림은 헤드업 알림이 표시되도록 합니다.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>DEFAULT</code></p> +</td> + <td class="tab1"> +<p>여기서 설명하지 않은 기타 모든 우선 순위의 알림에 사용합니다.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>LOW</code></p> +</td> + <td class="tab1"> +<p>사용자에게 알려야 하지만 긴급하지 않은 +알림에 사용합니다. 우선 순위가 낮은 알림은 보통 목록의 맨 아래에 표시되며, +공개 또는 대상이 불특정한 소셜 업데이트에 사용하기 +좋습니다. 사용자가 +요구한 +알림이지만, 이러한 알림은 긴급하거나 직접적인 +대화를 우선할 수 없습니다.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MIN</code></p> +</td> + <td class="tab1"> +<p>날씨 정보 또는 상황에 맞는 +위치 정보와 같은 상황별 또는 배경 정보에 사용합니다. +최소 우선 순위 알림은 상태 표시줄에 표시되지 않습니다. 이러한 알림은 사용자가 알림 창을 확대하면 +볼 수 있습니다.</p> +</td> + </tr> +</table> + + +<h4 id="how_to_choose_an_appropriate_priority"><strong> +적절한 +우선 순위를 선택하는 방법</strong></h4> + +<p><code>DEFAULT</code>, <code>HIGH</code> 및 <code>MAX</code>는 작업을 중단시키는 우선 순위이며, 사용자의 액티비티를 +중단시키는 +위험 요소입니다. 앱 사용자를 성가시게 하지 않으려면 다음과 같은 +알림에만 작업을 중단시키는 우선 순위를 지정해야 합니다.</p> + +<ul> + <li> 다른 사람이 관련된 알림</li> + <li> 시간에 민감한 알림</li> + <li> 실제 환경에서의 사용자 행동을 즉시 바꿀 수 있는 알림</li> +</ul> + +<p><code>LOW</code> 및 <code>MIN</code>으로 설정된 알림도 사용자에게 +중요할 수 있습니다. 대부분은 아니지만 많은 알림이 사용자의 +즉각적인 주의를 필요로 하지 않거나 사용자의 손목에 진동을 줄 필요가 없지만, 사용자가 알림을 확인하고자 +했을 때 유용하다고 +여길 정보를 포함합니다. <code>LOW</code> 및 <code>MIN</code> +우선 순위 알림에 대한 조건은 다음과 같습니다.</p> + +<ul> + <li> 다른 사람이 관련되지 않음</li> + <li> 시간에 민감하지 않음</li> + <li> 사용자가 흥미를 가질 만하지만 시간이 있을 때 +보기를 원할 수 있는 내용을 포함함</li> +</ul> + + + <img src="{@docRoot}images/android-5.0/notifications/notifications_pattern_priority.png" alt="" width="700" /> + + +<h3 style="clear:both" id="set_a_notification_category">알림 +범주 설정하기</h3> + +<p>알림이 미리 정의된 범주에 포함될 경우(아래 +참조), +그에 따라 할당합니다. 알림 창(또는 +다른 알림 +수신자)과 같은 시스템 UI의 기능은 순위 및 필터링 결정을 내리는 데 이 정보를 활용할 수 있습니다.</p> +<table> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_CALL">CATEGORY_CALL</a></code></p> +</td> + <td> +<p>수신 전화(음성 또는 화상) 또는 이와 유사한 동기적 대화 +요청</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_MESSAGE">CATEGORY_MESSAGE</a></code></p> +</td> + <td> +<p>수신되는 직접 메시지(SMS, 인스턴트 메시지 등)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EMAIL">CATEGORY_EMAIL</a></code></p> +</td> + <td> +<p>비동기적 대량 메시지(이메일)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EVENT">CATEGORY_EVENT</a></code></p> +</td> + <td> +<p>캘린더 이벤트</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROMO">CATEGORY_PROMO</a></code></p> +</td> + <td> +<p>홍보 또는 광고</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ALARM">CATEGORY_ALARM</a></code></p> +</td> + <td> +<p>알람 또는 타이머</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROGRESS">CATEGORY_PROGRESS</a></code></p> +</td> + <td> +<p>장기간 실행 중인 백그라운드 작업의 진행 상황</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SOCIAL">CATEGORY_SOCIAL</a></code></p> +</td> + <td> +<p>소셜 네트워크 또는 공유 업데이트</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ERROR">CATEGORY_ERROR</a></code></p> +</td> + <td> +<p>백그라운드 작업 또는 인증 상태 오류</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_TRANSPORT">CATEGORY_TRANSPORT</a></code></p> +</td> + <td> +<p>재생에 대한 미디어 전송 제어</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SYSTEM">CATEGORY_SYSTEM</a></code></p> +</td> + <td> +<p>시스템 또는 기기 상태 업데이트. 시스템용으로 예약됨</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SERVICE">CATEGORY_SERVICE</a></code></p> +</td> + <td> +<p>실행 중인 백그라운드 서비스에 대한 표시</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_RECOMMENDATION">CATEGORY_RECOMMENDATION</a></code></p> +</td> + <td> +<p>한 가지 특정 항목에 대한 구체적이고 시기적절한 권장 사항. 예를 들어, 뉴스 +앱이 사용자가 다음으로 읽기 원할 것이라고 생각하는 뉴스를 +권하고자 하는 경우</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_STATUS">CATEGORY_STATUS</a></code></p> +</td> + <td> +<p>기기 또는 상황별 상태에 대한 지속적인 정보</p> +</td> + </tr> +</table> + +<h3 id="summarize_your_notifications">알림 요약하기</h3> + +<p>특정 유형의 알림이 이미 보류 중일 때 앱에서 같은 유형의 새 +알림을 보내려고 하는 경우, 이 앱에 대해 두 알림을 하나의 요약 알림으로 결합합니다. 새로운 개체는 +생성하지 않아야 합니다.</p> + +<p>요약 알림은 사용자가 특정 종류의 알림이 +몇 개나 보류 중인지 +파악할 수 있도록 간단한 개요를 표시합니다.</p> + +<div class="col-6"> + +<p><strong>잘못된 사용</strong></p> + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Dont.png" alt="" width="311px" /> +</div> + +<div> +<p><strong>올바른 사용</strong></p> + + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Do.png" alt="" width="311px" /> +</div> + +<p style="clear:left; padding-top:30px; padding-bottom:20px">확장된 다이제스트 레이아웃을 사용하여 +요약에 포함된 각각의 알림에 대한 +더 자세한 정보를 제공할 수 있습니다. 이 방식을 통해 사용자는 +어떠한 알림이 보류 중이고, +관련된 앱에서 +상세 정보를 읽고 싶을 정도로 알림이 흥미로운지를 +판단할 수 있습니다.</p> +<div class="col-6"> + <img src="{@docRoot}images/android-5.0/notifications/Stack.png" style="margin-bottom:20px" alt="" width="311px" /> + <p class="img-caption"> + 확장된 알림 및 축소된 요약 알림(<code>InboxStyle</code> 사용) + </p> +</div> + +<h3 style="clear:both" id="make_notifications_optional">알림을 +선택 항목으로 만들기</h3> + +<p>사용자는 항상 알림을 통제할 수 있어야 합니다. 애플리케이션 설정에 알림 설정 항목을 추가하여 +사용자가 앱의 +알림을 +해제하거나 경고 속성(예: 경고음 및 진동 사용 +여부)을 변경할 수 있도록 허용합니다.</p> + +<h3 id="use_distinct_icons">뚜렷한 아이콘 사용</h3> +<p>알림 영역을 봄으로써 사용자는 현재 +어떠한 종류의 +알림이 보류 중인지 파악할 수 있어야 합니다.</p> + +<div class="figure"> + <img src="{@docRoot}images/android-5.0/notifications/ProductIcons.png" alt="" width="420" /> +</div> + + <div><p><strong>올바른 사용</strong></p> + <p>Android 앱이 이미 제공하는 알림 아이콘을 살펴본 후 본인의 앱에서 +뚜렷히 나타날 수 있는 +알림 아이콘을 만듭니다.</p> + + <p><strong>올바른 사용</strong></p> + <p>작은 아이콘에 +적절한 <a href="/design/style/iconography.html#notification">알림 아이콘 스타일</a>을 사용하며, 작업 +아이콘에는 머티어리얼 라이트 +<a href="/design/style/iconography.html#action-bar">작업 모음 아이콘 +스타일</a>을 사용합니다.</p> +<p ><strong>올바른 사용</strong></p> +<p >아이콘은 시각적으로 단순하게 유지하고, +알아차리기 힘들 정도로 과도하게 세부적인 디자인은 피합니다.</p> + + <div><p><strong>잘못된 사용</strong></p> + <p>작은 +아이콘 및 작업 +아이콘에 알파(어둡게 설정 또는 페이드 효과)를 추가합니다. 아이콘의 가장자리를 안티-앨리어싱할 수는 있지만, Android가 이러한 +아이콘을 마스크(즉, +알파 채널만 사용됨)로 사용하기 때문에 일반적으로 이미지는 최대 수준의 +불투명도로 그려집니다.</p> + +</div> +<p style="clear:both"><strong>잘못된 사용</strong></p> + +<p>다른 앱과의 차별화를 위해 색상을 사용합니다. 알림 아이콘은 투명한 배경 이미지에 흰색 아이콘이어야만 +합니다.</p> + + +<h3 id="pulse_the_notification_led_appropriately">알림 LED를 +적절하게 사용하기</h3> + +<p>많은 Android 기기에는 알림 LED가 내장되어 있으며, 이러한 알림 LED는 화면이 꺼져 있을 때 +사용자에게 +이벤트에 대해 알리기 위해 사용됩니다. 우선 순위가 <code>MAX</code>, +<code>HIGH</code> 또는 <code>DEFAULT</code>인 알림의 경우 +LED가 켜지며, 낮은 우선 순위(<code>LOW</code> 및 +<code>MIN</code>)의 알림의 경우 LED가 켜지지 않습니다.</p> + +<p>알림과 관련하여 사용자는 LED도 제어할 수 있어야 합니다. +DEFAULT_LIGHTS를 사용하는 경우 +LED는 흰색으로 켜집니다. 사용자가 +명시적으로 지정한 경우 외에는 다른 알림 +색상을 사용할 수 없습니다.</p> + +<h2 id="building_notifications_that_users_care_about">사용자가 관심을 가질 만한 +알림 만들기</h2> + +<p>사용자의 사랑을 받는 앱을 만들기 위해서는 +알림을 신중하게 디자인해야 합니다. +알림은 앱의 목소리를 대변하며, 앱의 +개성에 큰 영향을 미칩니다. 원하지 않거나 +중요하지 않은 알림은 사용자를 성가시게 하거나 앱에서 +많은 신경을 +쓰게 하는 것에 대해 짜증이 나게 합니다. 따라서 알림을 사용할 때는 현명하게 판단해야 합니다.</p> + +<h3 id="when_to_display_a_notification">알림을 표시해야 하는 경우</h3> + +<p>사람들이 즐겨 사용하는 애플리케이션을 만들려면 사용자의 +주의와 집중을 흐트러뜨리지 않고 보호해야 하는 리소스임을 +인지하는 것이 중요합니다. Android의 +알림 시스템은 알림이 사용자의 주의를 최대한 방해하지 않도록 +디자인되었습니다. +하지만 +알림이 +사용자의 태스크 흐름을 방해한다는 사실을 계속해서 인지해야 합니다. +알림을 계획할 때 알림이 사용자의 작업을 중단할 만큼 +중요한지 곰곰히 생각해 보시기 바랍니다. 잘 모르겠는 경우, 사용자가 앱의 알림 설정을 사용하여 알림에 대한 수신 동의를 +선택할 수 있도록 허용하거나 알림 우선 순위 플래그를 <code>LOW</code> 또는 <code>MIN</code>으로 +조정하여 사용자 작업을 +방해하지 +않도록 합니다.</p> + + <img src="{@docRoot}images/android-5.0/notifications/TimeSensitive.png" alt="" width="311px" /> + <p style="margin-top:10px" class="img-caption"> + 시간에 민감한 알림의 예 + </p> + +<p>일반적으로 잘 만들어진 앱은 사용자의 요청이 있을 때에만 정보를 알리고 +요청하지 않은 알림은 꼭 필요한 경우에만 표시하도록 합니다.</p> + +<p>알림은 <strong>시간에 민감한 이벤트</strong>에 주로 사용하며, 특히 +이러한 동기적 이벤트에 <strong>다른 사람이 관련된 경우</strong>에 사용합니다. 예를 +들어 수신되는 채팅 메시지는 +실시간으로 진행되는 동기적 대화 형식이며, 이때 다른 사람은 +적극적으로 응답을 기다립니다. 캘린더 이벤트는 언제 +알림을 사용하고 +사용자의 주의를 끌어야 하는지에 대해 알 수 있는 또 다른 좋은 예입니다. 왜냐하면 이는 임박한 이벤트이며, 캘린더 이벤트에는 종종 다른 사람이 +관련되기 때문입니다.</p> + +<h3 style="clear:both" id="when_not_to_display_a_notification">알림을 +표시하지 않아야 하는 경우</h3> + +<div class="figure" style="margin-top:60px"> + <img src="{@docRoot}images/android-5.0/notifications/AntiSample1.png" alt="" width="311px" /> +</div> + +<p>다른 대부분의 경우 알림은 적합하지 않습니다.</p> + +<ul> + <li> 사용자와 +직접 관련이 없는 정보나 시간에 민감하지 않은 +정보는 알리지 않도록 합니다. 예를 들어 소셜 네트워크를 통한 비동기적이며 +대상이 불특정한 업데이트는 +일반적으로 실시간으로 +사용자를 방해할 수 없습니다. 그러한 업데이트를 원하는 사용자의 +경우에는 사전에 수신 동의를 설정할 수 있게 하면 됩니다.</li> + <li> 관련된 새 정보가 현재 +화면에 표시된 경우에는 알림을 생성하지 않아야 합니다. 대신 애플리케이션 UI를 +사용하여 컨텍스트 내에 새로운 정보가 있음을 사용자에게 +직접 알립니다. + 예를 들어 채팅 애플리케이션은 +사용자가 다른 사용자와 대화 중일 때는 시스템 알림을 생성하지 않아야 합니다.</li> + <li> 정보 저장 +또는 동기화, 애플리케이션 업데이트와 같은 낮은 수준의 기술 정보의 경우 사용자가 개입하지 +않아도 앱이나 시스템에서 스스로 알아서 처리할 수 있다면 사용자를 방해하지 않도록 합니다.</li> + <li> 사용자가 아무런 조치를 +취하지 않아도 애플리케이션 스스로 오류를 복구할 +수 있는 경우, 이러한 오류에 대해 사용자에게 알리지 않도록 합니다.</li> + <li> 알리는 내용은 없고 +단순히 앱을 +홍보하는 알림은 만들지 않습니다. 알림은 유용하고, 시기적절하며 새로운 정보를 제공해야 하며, 단지 앱 출시를 위한 용도로는 +사용하지 +않습니다.</li> + <li> 단지 +사용자에게 브랜드를 알리기 위한 불필요한 알림은 만들지 않도록 합니다. + 그러한 알림은 사용자를 짜증 나게 만들어 앱에 대한 관심을 멀어지게 합니다. 소량의 +업데이트된 정보를 제공하면서 사용자가 지속적으로 +앱에 관심을 +갖게 만드는 최고의 +방법은 +홈 화면에 추가할 수 있는 위젯을 개발하는 것입니다.</li> +</ul> + +<h2 style="clear:left" id="interacting_with_notifications">알림과 +상호 작용하기</h2> + +<p>알림은 상태 표시줄에 아이콘으로 표시되며, +알림 창을 열어서 +확인할 수 있습니다.</p> + +<p>알림을 터치하면 관련 앱이 열리고 알림에 +해당되는 세부 내용이 표시됩니다. 알림을 왼쪽이나 오른쪽으로 +스와이프하면 알림 창에서 제거됩니다.</p> + +<h3 id="ongoing_notifications">지속적인 알림</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/MusicPlayback.png" alt="" width="311px" /> + <p class="img-caption"> + 음악 재생으로 인한 지속적인 알림 + </p> +</div> +<p>지속적인 알림은 +백그라운드에서 진행 중인 프로세스에 대해 사용자에게 알립니다. +예를 들어 음악 플레이어는 사용자가 재생을 멈출 때까지 +알림 시스템 내에 현재 재생 중인 트랙을 +계속 표시합니다. 또한 지속적인 알림은 파일을 다운로드하거나 비디오를 인코딩하는 등의 장기 태스크에 대한 +피드백을 사용자에게 +표시할 수도 있습니다. 지속적인 알림은 사용자가 알림 창에서 직접 +제거할 수 없습니다.</p> + +<h3 id="ongoing_notifications">미디어 재생</h3> +<p>Android 5.0에서는 잠금 화면에 사용이 중단된 +{@link android.media.RemoteControlClient} 클래스에 대한 전송 제어가 표시되지 않습니다. 하지만 알림은 <em>표시되며</em>, 각 +앱의 재생 알림이 현재 사용자가 잠금 상태에서 재생을 제어하는 기본 +방법입니다. 이 동작은 화면의 잠금 여부와 상관없이 사용자에게 +일관된 환경을 제공하면서, 어떠한 버튼을 +어떻게 표시할지에 대해 앱이 더 세부적으로 제어할 수 있도록 +지원합니다.</p> + +<h3 style="clear:both" +id="dialogs_and_toasts_are_for_feedback_not_notification">대화 상자 +및 알림 메시지</h3> + +<p>현재 +화면에 표시되어 있는 경우가 아니라면 앱은 대화 상자나 알림 메시지를 생성해서는 안 됩니다. 대화 상자나 알림 메시지는 +앱 내에서 +사용자가 어떠한 행동을 취했을 때 이에 대한 즉각적인 응답으로만 표시되어야 합니다. +대화 상자 및 알림 메시지 사용에 대한 자세한 지침은 +<a href="/design/patterns/confirming-acknowledging.html">확인 및 승인하기</a>를 참조하세요.</p> + +<h3>순위 및 순서</h3> + +<p>알림은 뉴스이므로, 기본적으로 발생한 순서의 역순으로 +표시되며, 특히 +앱에서 명시된 알림 +<a href="#correctly_set_and_manage_notification_priority">우선 순위</a>에 따라 순서가 결정됩니다.</p> + +<p>알림은 잠금 화면에서 중요한 부분이며, 기기의 화면이 켜질 +때마다 +표시됩니다. 잠금 화면의 공간은 협소하기 때문에 가장 긴급하고 관련 있는 알림을 식별하는 것이 +가장 +중요합니다. 이러한 +이유 때문에 Android에는 다음을 고려한 +더욱 정교한 정렬 알고리즘이 있습니다.</p> + +<ul> + <li> 타임스탬프 및 애플리케이션에 명시된 우선 순위.</li> + <li> 알림이 최근에 소리 또는 +진동으로 사용자를 방해했는지에 대한 여부. (즉, +휴대폰에서 방금 소리가 났을 때 사용자가 "방금 무슨 +일이 있었지?"에 대해 알고 싶어하는 경우 잠금 화면을 +보면 한 눈에 알 수 있어야 합니다.)</li> + <li> {@link android.app.Notification#EXTRA_PEOPLE}을 사용하여 알림에 첨부된 사람, +그리고 특히 즐겨찾기에 추가된 연락처인지에 대한 여부.</li> +</ul> + +<p>이러한 정렬 알고리즘을 잘 이용하기 위해서는 목록의 특정 부분에 초점을 두기 보다는 생성하고자 +하는 사용자 +환경에 초점을 둡니다.</p> + + <img src="{@docRoot}images/android-5.0/notifications/AntiSample3.png" alt="" width="700px" /> + + <p class="img-caption" style="margin-top:10px">Gmail 알림은 +기본 우선 순위이기 때문에 +보통은 행아웃과 같은 인스턴트 메시징 앱에서 온 메시지보다 하위에 정렬됩니다. 하지만 +새 메시지가 들어오면 +일시적으로 순위가 올라갑니다. + </p> + + +<h3>잠금 화면</h3> + +<p>알림은 잠금 화면에 표시되기 때문에 사용자의 개인 정보 보호가 +특히 +중요하게 고려해야 할 사항입니다. 알림은 종종 민감한 정보를 포함하기 때문에, 아무나 +기기의 화면을 켰을 때 볼 수 있게 할 필요는 +없습니다.</p> + +<ul> + <li> 보안 잠금 화면(PIN, 패턴 또는 암호)이 있는 기기의 인터페이스에는 +공개 및 비공개 부분이 있습니다. 공개 인터페이스는 보안 잠금 화면에 표시될 수 있기 때문에 +누구나 볼 수 있습니다. 비공개 인터페이스는 잠금 화면 뒤에 있기 때문에 +기기의 잠금 화면을 푼 사람만 볼 수 있습니다.</li> +</ul> + +<h3>보안 잠금 화면에 표시된 정보에 대한 사용자 제어</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/LockScreen@2x.png" srcset="{@docRoot}images/android-5.0/notifications/LockScreen.png 1x" alt="" width="311px" /> + <p class="img-caption"> + 사용자가 기기의 잠금을 푼 후 보이는 콘텐츠와 함께 잠금 화면에 표시된 알림 + </p> +</div> + +<p>보안 잠금 화면을 설정할 때 사용자는 +민감한 세부 정보를 보안 잠금 화면에서 숨기도록 선택할 수 있습니다. 이러한 경우 시스템 UI는 알림의 <em>정보 공개 수준</em>을 +고려하여 +안전하게 표시할 수 있는 정보를 파악합니다.</p> +<p> 정보 공개 수준을 제어하려면 +<code><a +href="/reference/android/app/Notification.Builder.html#setVisibility(int)">Notification.Builder.setVisibility()</a></code>를 호출한 후 +다음 값 중 하나를 지정합니다.</p> + +<ul> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PUBLIC">VISIBILITY_PUBLIC</a></code>. 알림의 전체 내용을 +표시합니다. + 정보 공개 수준을 지정하지 않을 경우 시스템 기본값입니다.</li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PRIVATE">VISIBILITY_PRIVATE</a></code>. +잠금 화면에 알림의 +아이콘과 알림을 게시한 앱의 이름을 포함하여 해당 알림의 존재에 대한 기본 정보를 표시합니다. 알림의 나머지 세부 사항은 표시되지 않습니다. +다음과 같은 몇 가지 유용한 사항을 염두해야 합니다. + <ul> + <li> 시스템이 보안 잠금 화면에 다른 공개 버전의 알림을 +표시하도록 제공하려는 경우, <code><a +href="/reference/android/app/Notification.html#publicVersion">Notification.publicVersion</a></code> +필드에 대체 +알림 개체를 제공해야 합니다. + <li> 이렇게 설정하면 앱에서 여전히 유용하지만 개인 정보를 노출하지 않는 편집된 버전의 +내용을 생성할 수 있습니다. 예를 들어, 알림에 SMS 텍스트, 발신자 이름 및 연락처 아이콘을 포함하는 +SMS 앱이 있다고 가정합니다. +이 알림은 <code>VISIBILITY_PRIVATE</code>여야 하지만, <code>publicVersion</code>은 다른 식별 +정보 없이 "3개의 새 메시지"와 같이 여전히 유용한 정보를 +포함할 수 있습니다. + </ul> + </li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_SECRET">Notification.VISIBILITY_SECRET</a></code>. 최소한의 정보만 표시하며, 알림의 아이콘마저 +표시하지 않습니다.</li> +</ul> +<h2 style="clear:both" id="notifications_on_android_wear">Android Wear에 +표시되는 알림</h2> + +<p>Android Wear에 표시되는 알림과 해당 <em>작업</em>은 기본적으로 Wear 기기에 연결되어 있습니다. +개발자는 어떠한 알림을 +휴대폰에서 워치로, +그리고 그 반대로 연결할지 제어할 수 있습니다. 또한 개발자는 어떠한 작업을 연결할지도 제어할 수 있습니다. 앱이 +단일 탭으로 실행할 수 없는 +작업을 포함하는 경우, 이러한 작업을 +Wear +알림에 표시되지 않도록 숨기거나 Wear 앱에 연결하여 사용자가 +워치에서 작업을 +끝낼 수 있도록 합니다.</p> + +<h4>알림과 작업 연결하기</h4> + +<p>휴대폰과 같이 연결된 기기는 알림을 Wear 기기에 연결하여 해당 기기에서 +알림이 표시될 수 있게 합니다. 마찬가지로 작업도 연결할 수 있기 때문에 사용자는 Wear 기기에서 +알림을 바로 처리할 수 있습니다.</p> + +<p><strong>연결해야 할 사항</strong></p> + +<ul> + <li> 새 인스턴트 메시지</li> + <li> +1, Like, Heart와 같은 단일 탭 작업</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/WearBasic.png" width="156px" height="156px" alt="" /> + +<p><strong>연결하지 않아야 할 사항</strong></p> + +<ul> + <li> 새로 도착한 팟캐스트의 알림</li> + <li> 워치에서 수행할 수 없는 기능에 매핑되는 작업</li> +</ul> + + + +<p><h4>Wear에 대해서만 정의할 수 있는 고유한 작업</h4></p> + +<p>Wear에서만 수행할 수 있는 작업이 몇 가지 있으며, 이러한 작업은 다음과 같습니다.</p> + +<ul> + <li> "금방 올게"와 같은 미리 준비된 대답으로 구성된 빠른 목록</li> + <li> 휴대폰에서 열기</li> + <li> 음성 입력 화면을 불러오는 "댓글 달기" 또는 "응답" 작업</li> + <li> Wear에 특화된 앱을 실행하는 작업</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/ReplyAction.png" width="156px" height="156px" alt="" /> diff --git a/docs/html-intl/intl/pt-br/design/get-started/principles.jd b/docs/html-intl/intl/pt-br/design/get-started/principles.jd new file mode 100644 index 0000000..46af758 --- /dev/null +++ b/docs/html-intl/intl/pt-br/design/get-started/principles.jd @@ -0,0 +1,307 @@ +page.title=Princípios de projeto para Android +@jd:body + +<p>Estes princípios de projeto foram desenvolvidos pela e para a Equipe de Experiência do Usuário do Android +para manter os interesses dos usuários em mente. +Para desenvolvedores e projetistas do Android, eles continuam a +definir as diretrizes de projeto mais detalhadas para diferentes +tipos de dispositivo.</p> + +<p> +Considere estes princípios ao aplicar +suas próprias criatividade e mentalidade de projeto. Desvie-se de forma objetiva. +</p> + +<h2 id="enchant-me">Encante-me</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="delight-me">Agrade-me de formas surpreendentes</h4> +<p>Uma bela superfície, uma animação cuidadosamente posicionada ou um efeito sonoro no momento certo + contribui para a boa experiência. Efeitos sutis contribuem para uma sensação de facilidade e de que algo +poderoso está à mão.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_delight.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="real-objects-more-fun">Objetos reais são mais divertidos que botões e menus</h4> +<p>Deixe que as pessoas manipulem e toquem diretamente em objetos no seu aplicativo. Isso reduz o esforço cognitivo +necessário para realizar uma tarefa e torna o aplicativo mais emocionalmente satisfatório.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_real_objects.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-it-mine">Deixe-me torná-lo meu</h4> +<p>As pessoas adoram adicionar toques pessoais, pois isso as ajuda a se sentirem à vontade e em controle. Forneça +padrões sensatos e belos, mas também considere personalizações divertidas e opcionais que não +prejudiquem as tarefas principais.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_it_mine.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="get-to-know-me">Conheça-me</h4> +<p>Conheça as preferências das pessoas no decorrer do tempo. Em vez de pedir que façam as mesmas escolhas repetidamente, +coloque escolhas anteriores em alcance fácil.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_get_to_know_me.png"> + + </div> +</div> + +<h2 id="simplify-my-life">Simplifique minha vida</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="keep-it-brief">Seja breve</h4> +<p>Use frases curtas com palavras simples. As pessoas provavelmente ignorarão frases longas.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_keep_it_brief.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="pictures-faster-than-words">Imagens são mais rápidas que palavras</h4> +<p>Considere usar imagens para explicar ideias. Elas chamam a atenção das pessoas e podem ser muito mais eficientes +que palavras.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_pictures.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="decide-for-me">Decida por mim, mas deixe que eu tenha a palavra final</h4> +<p>Faça a melhor suposição e tome uma ação, em vez de primeiro perguntar. Escolhas e decisões demais deixam as pessoas +incomodadas. Caso suponha errado, permita "desfazer".</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_decide_for_me.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="only-show-when-i-need-it">Mostre só o que preciso, quando eu precisar</h4> +<p>As pessoas se sentem oprimidas quando veem coisas demais de uma vez. Detalhe tarefas e informações em partes +pequenas e digeríveis. Oculte opções que não sejam essenciais no momento e ensine as pessoas à medida que avançam.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_information_when_need_it.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="always-know-where-i-am">Eu sempre devo saber onde estou</h4> +<p>Dê às pessoas a confiança de saberem o que fazer. Faça com que os locais no seu aplicativo pareçam distintos +e use transições para mostrar relacionamentos entre telas. Forneça feedback sobre tarefas em andamento.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_navigation.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="never-lose-my-stuff">Nunca perca as minhas coisas</h4> +<p>Salve o que as pessoas criaram e deixe que elas acessem de qualquer lugar. Lembre-se de configurações, +toques pessoais e criações entre celulares, tablets e computadores. Isso torna a atualização a +coisa mais fácil do mundo.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_never_lose_stuff.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="looks-same-should-act-same">Se parece igual, deve agir da mesma forma</h4> +<p>Ajude as pessoas a discernir diferenças funcionais tornando-as visualmente distintas, em vez de sutis. +Evite que modos locais que agem de forma diferente sobre a mesma entrada se pareçam.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_looks_same.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="interrupt-only-if-important">Só me interrompa se for importante</h4> +<p>Como um bom assistente pessoal, proteja as pessoas de informações não importantes. As pessoas querem ficar +concentradas e, a não ser que seja crítica e dependente de tempo, uma interrupção pode ser irritante e frustrante.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_important_interruption.png"> + + </div> +</div> + +<h2 id="make-me-amazing">Faça com que eu seja incrível</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="give-me-tricks">Dê-me truques que funcionem em qualquer lugar</h4> +<p>As pessoas se sentem ótimas quando descobrem coisas sozinhas. Torne seu aplicativo mais inteligível ao +aproveitar padrões visuais e memórias de outros aplicativos do Android. Por exemplo, o gesto de deslizar +pode ser um bom atalho de navegação.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_tricks.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="its-not-my-fault">Não é culpa minha</h4> +<p>Seja gentil sobre como solicita correções a pessoas. Elas querem se sentir inteligentes ao usar o seu +aplicativo. Se alguma coisa der errada, dê instruções de recuperação claras, mas evite os detalhes técnicos. +Se for possível corrigir em segundo plano, melhor ainda.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_error.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="sprinkle-encouragement">Espalhe motivação</h4> +<p>Divida tarefas complexas em passos menores que possam ser realizados facilmente. Dê feedback sobre ações, +mesmo que seja um brilho sutil.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_sprinkle_encouragement.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="do-heavy-lifting-for-me">Faça o trabalho pesado por mim</h4> +<p>Faça com que novatos se sintam peritos possibilitando que façam coisas que nunca acharam possíveis. Por +exemplo, atalhos que combinem vários efeitos de fotos podem fazer com que fotografias amadoras pareçam incríveis +com apenas alguns passos.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_heavy_lifting.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-important-things-fast">Torne coisas importantes rápidas</h4> +<p>Nem todas as ações são iguais. Decida o que é mais importante em seu aplicativo e torne fácil de encontrar e +rápido de usar, como o botão do obturador em uma câmera ou o botão de pausa em um reprodutor de música.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_important_fast.png"> + + </div> +</div> diff --git a/docs/html-intl/intl/pt-br/design/material/index.jd b/docs/html-intl/intl/pt-br/design/material/index.jd new file mode 100644 index 0000000..60289a3 --- /dev/null +++ b/docs/html-intl/intl/pt-br/design/material/index.jd @@ -0,0 +1,186 @@ +page.title=Material Design +page.tags=Material,design +page.type=design +page.image=design/material/images/MaterialLight.png + +@jd:body + +<!-- developer docs box --> +<a class="notice-developers right" href="{@docRoot}training/material/index.html"> + <div> + <h3>Documentos do desenvolvedor</h3> + <p>Criação de aplicativos com o Material Design</p> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=p4gmvHyuZzw"> +<div> + <h3>Vídeo</h3> + <p>Introdução ao Material Design</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=YaG_ljfzeUw"> +<div> + <h3>Vídeo</h3> + <p>Papel e tinta: Os materiais que importam</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=XOcCOBe8PTc"> +<div> + <h3>Vídeo</h3> + <p>Material Design no aplicativo Google I/O</p> +</div> +</a> + + + +<p itemprop="description">O Material Design é um guia abrangente para design visual, de movimento e de +interação para diversas plataformas e dispositivos. O Android agora é compatível com +aplicativos do Material Design. Para usar o Material Design nos aplicativos Android, siga as orientações definidas +nas <a href="http://www.google.com/design/spec">especificações do Material Design</a> e use os novos +componentes e funcionalidades disponíveis no Android 5.0 (API de nível 21) e em posteriores.</p> + +<p>O Android fornece os seguintes elementos para criar aplicativos do Material Design:</p> + +<ul> + <li>Um novo tema</li> + <li>Novos widgets para vistas complexas</li> + <li>Novas APIs para sombras e animações personalizadas</li> +</ul> + +<p>Para obter mais informações sobre a implementação do Material Design no Android, consulte +<a href="{@docRoot}training/material/index.html">Criação de aplicativos com o Material Design</a>.</p> + + +<h3>Tema do Material</h3> + +<p>O tema do Material fornece um novo estilo para o seu aplicativo, widgets de sistema que permitem +definir a paleta de cores e as animações padrão para feedback de toque e transições de atividades.</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/MaterialDark.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">Tema escuro do Material</p> + </div> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/MaterialLight.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">Tema claro do Material</p> + </div> +</div> +<br style="clear:left"/> +</div> + +<p>Para obter mais informações, consulte <a href="{@docRoot}training/material/theme.html">Como usar o tema +do Material</a>.</p> + + +<h3>Listas e cartões</h3> + +<p>O Android fornece dois novos widgets para exibir cartões e listas com estilos e animações do +Material Design:</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/list_mail.png" width="500" height="426" /> + <p>O novo widget <code>RecyclerView</code> é uma versão mais completa de <code>ListView</code> + com suporte para diferentes tipos de layout e melhorias no desempenho.</p> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/card_travel.png" width="500" height="426" /> + <p>O novo widget <code>CardView</code> permite exibir informações importantes dentro de + cartões que têm aparência consistente.</p> +</div> +<br style="clear:left"/> +</div> + +<p>Para obter mais informações, consulte <a href="{@docRoot}training/material/lists-cards.html">Como criar +listas e cartões</a>.</p> + + +<h3>Sombras de vistas</h3> + +<p>Além das propriedades X e Y, vistas no Android agora têm uma propriedade +Z. Essa nova propriedade representa a elevação de uma vista, que determina:</p> + +<ul> +<li>O tamanho da sombra: vistas com valores maiores de Z lançam sombras maiores.</li> +<li>A ordem de desenho: vistas com valores maiores de Z aparecem sobre outras vistas.</li> +</ul> + +<div style="width:290px;margin-left:35px;float:right"> + <div class="framed-nexus5-port-span-5"> + <video class="play-on-hover" autoplay> + <source src="{@docRoot}design/material/videos/ContactsAnim.mp4"/> + <source src="{@docRoot}design/videos/ContactsAnim.webm"/> + <source src="{@docRoot}design/videos/ContactsAnim.ogv"/> + </video> + </div> + <div style="font-size:10pt;margin-left:20px;margin-bottom:30px"> + <em>Para reproduzir o filme, clique na tela do dispositivo</em> + </div> +</div> + +<p>Para obter mais informações, consulte <a href="{@docRoot}training/material/shadows-clipping.html">Como +definir sombras e recortar visualizações</a>.</p> + + +<h3>Animações</h3> + +<p>As novas APIs de animação permitem criar animações personalizadas para feedback de toque em controles de IU, +mudanças no estado da vista e transições de atividades.</p> + +<p>Essas APIs permitem:</p> + +<ul> +<li style="margin-bottom:15px"> +Responder a eventos de toque nas vistas com animações de <strong>feedback de toque</strong>. +</li> +<li style="margin-bottom:15px"> +Ocultar e exibir vistas com animações de <strong>revelação circular</strong>. +</li> +<li style="margin-bottom:15px"> +Alternar entre atividades com animações de <strong>transição de atividades</strong>. +</li> +<li style="margin-bottom:15px"> +Criar animações mais naturais com <strong>movimento curvado</strong>. +</li> +<li style="margin-bottom:15px"> +Animar mudanças em uma ou mais propriedades da vista com animações de <strong>mudança de estado da vista</strong>. +</li> +<li style="margin-bottom:15px"> +Exibir animações em <strong>desenháveis da lista de estado</strong> entre mudanças de estado da vista. +</li> +</ul> + +<p>Animações de feedback de toque são integradas em várias vistas padrões, como botões. As novas APIs +permitem personalizar essas animações e adicioná-las às vistas personalizadas.</p> + +<p>Para obter mais informações, consulte <a href="{@docRoot}training/material/animations.html">Como definir +animações personalizadas</a>.</p> + + +<h3>Desenháveis</h3> + +<p>Essas novas capacidades dos desenháveis ajudam na implementação de aplicativos do Material Design:</p> + +<ul> +<li><strong>Desenháveis de vetor</strong> são dimensionáveis sem perder definição e são perfeitos +para ícones de uma cor dentro do aplicativo.</li> +<li><strong>Tingimento desenhável</strong> permite definir mapas de bits como uma máscara alfa e tingi-los com +uma cor em tempo de execução.</li> +<li><strong>Extração de cor</strong> permite extrair automaticamente cores proeminentes de uma +imagem de mapa de bits.</li> +</ul> + +<p>Para obter mais informações, consulte <a href="{@docRoot}training/material/drawables.html">Como trabalhar +com desenháveis</a>.</p> diff --git a/docs/html-intl/intl/pt-br/design/patterns/confirming-acknowledging.jd b/docs/html-intl/intl/pt-br/design/patterns/confirming-acknowledging.jd new file mode 100644 index 0000000..934dbdd --- /dev/null +++ b/docs/html-intl/intl/pt-br/design/patterns/confirming-acknowledging.jd @@ -0,0 +1,70 @@ +page.title=Confirmação e reconhecimento +page.tags=dialog,toast,notification +@jd:body + +<p>Em algumas situações, quando um usuário invoca uma ação em seu aplicativo, é uma boa ideia <em>confirmar</em> ou <em>reconhecer</em> essa ação com texto.</p> + +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_confirming.png"> + <p><strong>Confirmar</strong> é pedir ao usuário que verifique se realmente quer prosseguir com a ação que acabou de invocar. Em alguns casos, a confirmação é apresentada com uma advertência ou informações críticas relacionadas à ação que ele precisa considerar.</p> + </div> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_acknowledge.png"> + <p><strong>Reconhecer</strong> é exibir texto para avisar ao usuário que a ação que acabou de ser invocada foi concluída. Isso remove a incerteza sobre operações implícitas que o sistema adota. Em alguns casos, o reconhecimento é apresentado com uma opção para desfazer a ação.</p> + </div> +</div> + +<p>Comunicar-se com os usuários dessas formas pode ajudar a reduzir a incerteza sobre o que aconteceu ou o que acontecerá. Confirmar ou reconhecer também pode evitar que os usuários cometam erros dos quais possam se arrepender.</p> + +<h2>Quando confirmar ou reconhecer ações do usuário</h2> +<p>Nem todas as ações precisam de uma confirmação ou um reconhecimento. Use este fluxograma para orientar as decisões de projeto.</p> +<img src="{@docRoot}design/media/confirm_ack_flowchart.png"> + +<h2>Confirmação</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Exemplo: livros do Google Play</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_books.png"> + <p>Nesse exemplo, o usuário solicitou a exclusão de um livro da biblioteca do Google Play. Um <a href="{@docRoot}design/building-blocks/dialogs.html#alerts">alerta</a> aparece para confirmar essa ação porque é importante entender que o livro não estará mais disponível em nenhum dispositivo.</p> + <p>Ao montar uma caixa de diálogo de confirmação, use um título significativo que ecoe a ação solicitada.</p> + </div> + <div class="layout-content-col span-7"> + <h4>Exemplo: Android Beam</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_beam.png"> + <p>As confirmações não necessariamente precisam ser apresentadas em um alerta com dois botões. Depois de iniciar o Android Beam, o usuário é solicitado a tocar no conteúdo a ser compartilhado (nesse exemplo, uma foto). Se ele decidir não prosseguir, simplesmente afastará o celular.</p> + </div> +</div> + +<h2>Reconhecimento</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Exemplo: abandonar rascunho salvo do Gmail</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_draftsave.png"> + <p>Nesse exemplo, se o usuário navegar para trás ou para cima na tela de composição do Gmail, alguma coisa possivelmente inesperada acontecerá: o rascunho atual será salvo automaticamente. Um reconhecimento na forma de aviso torna isso aparente. Ele desaparece depois de alguns segundos.</p> + <p>Desfazer não é adequado aqui, pois o ato de salvar foi iniciado pelo aplicativo, não pelo usuário, Além de ser rápido e fácil retomar a composição da mensagem navegando para a lista de rascunhos.</p> + + </div> + <div class="layout-content-col span-6"> + <h4>Exemplo: conversa do Gmail excluída</h4> + <img src="{@docRoot}design/media/confirm_ack_draft_deleted.png"> + <p>Depois que o usuário exclui uma conversa da lista no Gmail, um reconhecimento aparece com a opção de desfazer. O reconhecimento permanece até que o usuário tome uma ação não relacionada, como rolar a lista.</p> + </div> +</div> + +<h2>Sem confirmação nem reconhecimento</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Exemplo: +1</h4> + <img style="padding: 33px 0 30px;" src="{@docRoot}design/media/confirm_ack_ex_plus1.png"> + <p><strong>A confirmação é desnecessária.</strong> Se o usuário usar +1 por acidente, não é um problema. Poderá simplesmente tocar no botão novamente para desfazer a ação.</p> + <p><strong>O reconhecimento é desnecessário.</strong> O usuário verá o botão +1 oscilar e ficar vermelho. Esse é um sinal muito claro.</p> + </div> + <div class="layout-content-col span-7"> + <h4>Exemplo: Remover um aplicativo da tela inicial</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_removeapp.png"> + <p><strong>A confirmação é desnecessária.</strong> Essa é uma ação deliberada: o usuário precisa arrastar e soltar um item em um alvo relativamente grande e isolado. Portanto, acidentes são altamente improváveis. Mas, se o usuário se arrepender da decisão, levará apenas alguns segundos para trazê-lo de volta.</p> + <p><strong>O reconhecimento é desnecessário.</strong> O usuário saberá que o aplicativo saiu da tela inicial porque fez com que ele desaparecesse arrastando-o para longe.</p> + + </div> +</div> diff --git a/docs/html-intl/intl/pt-br/design/patterns/navigation.jd b/docs/html-intl/intl/pt-br/design/patterns/navigation.jd new file mode 100644 index 0000000..920ccec --- /dev/null +++ b/docs/html-intl/intl/pt-br/design/patterns/navigation.jd @@ -0,0 +1,213 @@ +page.title=Navegação com Voltar e Para cima +page.tags="navigation","activity","task","up navigation","back navigation" +page.image=/design/media/navigation_between_siblings_gmail.png +@jd:body + +<a class="notice-developers" href="{@docRoot}training/implementing-navigation/index.html"> + <div> + <h3>Documentos do desenvolvedor</h3> + <p>Implementação de navegação efetiva</p> + </div> +</a> + +<p itemprop="description">A navegação consistente é um componente essencial da experiência geral do usuário. Poucas coisas deixam os +usuários mais frustrados do que uma navegação básica que se comporta de forma inconsistente ou inesperada. O Android 3.0 +introduziu mudanças significativas no comportamento global da navegação. Seguir cuidadosamente as +diretrizes de Voltar e Para Cima tornará a navegação em seu aplicativo previsível e confiável para os usuários.</p> +<p>O Android 2.3 e anteriores se baseavam no botão <em>Voltar</em> do sistema para dar suporte à navegação dentro de um +aplicativo. Com a introdução de barras de ação no Android 3.0, um segundo mecanismo de navegação apareceu: +o botão <em>Para Cima</em>, consistindo no ícone do aplicativo e em um cursor para a esquerda.</p> + +<img src="{@docRoot}design/media/navigation_with_back_and_up.png"> + +<h2 id="up-vs-back">Para Cima vs. Voltar</h2> + +<p>O botão Para Cima é usado para navegar dentro de um aplicativo com base nos relacionamentos hierárquicos +entre telas. Por exemplo, se a tela A exibe uma lista de itens e, selecionar um item leva à +tela B (que apresenta aquele item em mais detalhes), então a tela B deve oferecer um botão Para Cima que +volte à tela A.</p> +<p>Se determinada tela é a superior na hierarquia de um aplicativo (ou seja, a página inicial do aplicativo), ela não deve apresentar um botão +Para Cima.</p> + +<p>O botão Voltar do sistema é usado para navegar, em ordem cronológica inversa, pelo histórico +de telas em que o usuário esteve recentemente. Ele é geralmente baseado em relacionamentos temporais +entre telas, em vez de na hierarquia do aplicativo.</p> + +<p>Quando a tela visualizada anteriormente também for a superior hierárquica imediata da tela atual, pressionar +o botão Voltar tem o mesmo resultado que pressionar um botão Para Cima — essa é uma ocorrência +comum. No entanto, diferentemente do botão Para Cima, que garante que o usuário permaneça dentro do aplicativo, o botão +Voltar pode retornar o usuário à tela inicial ou até mesmo a um aplicativo diferente.</p> + +<img src="{@docRoot}design/media/navigation_up_vs_back_gmail.png"> + +<p>O botão Voltar também suporta alguns comportamentos não vinculados diretamente à navegação entre telas: +</p> +<ul> +<li>Descarta janelas flutuantes (caixas de diálogo, pop-ups)</li> +<li>Descarta barras de ação contextuais e remove o destaque dos itens selecionados</li> +<li>Oculta o teclado da tela (IME)</li> +</ul> +<h2 id="within-app">Navegação dentro do seu aplicativo</h2> + +<h4>Navegação para telas com vários pontos de entrada</h4> +<p>Algumas vezes, uma tela não tem uma posição estrita dentro da hierarquia do aplicativo e pode ser atingida +de vários pontos de entrada — como uma tela de configurações que pode ser atingida de qualquer outra tela +do aplicativo. Nesse caso, o botão Para Cima deve escolher voltar para a tela anterior, comportando-se +de forma idêntica a Voltar.</p> +<h4>Mudança de vista dentro de uma tela</h4> +<p>Mudar opções de vista de uma tela não muda o comportamento de Para Cima nem de Voltar: a tela ainda +estará no mesmo lugar dentro da hierarquia do aplicativo e nenhum histórico de navegação será criado.</p> +<p>Exemplos de tais mudanças de vista são:</p> +<ul> +<li>Alternar vistas usando guias e/ou deslizando para a esquerda e para a direita</li> +<li>Alternar vistas usando um menu suspenso (também chamados de abas recolhidas)</li> +<li>Filtrar uma lista</li> +<li>Classificar uma lista</li> +<li>Mudar características de exibição (como mudar o zoom)</li> +</ul> +<h4>Navegação entre telas de mesmo nível</h4> +<p>Quando o aplicativo suporta navegação de uma lista de itens para uma vista de detalhes de um desses itens, +frequentemente é desejável dar suporte à navegação de direção daquele item para outro anterior ou +posterior a ele na lista. Por exemplo, no Gmail, é fácil deslizar para a esquerda ou para a direita em uma +conversa para visualizar uma mais nova ou mais antiga na mesma Caixa de entrada. Assim como ao mudar a vista dentro de uma tela, tal +navegação não muda o comportamento de Para Cima ou Voltar.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_gmail.png"> + +<p>No entanto, uma exceção notável a isso ocorre ao navegar entre vistas de detalhes relacionadas não +vinculadas pela lista de referência — por exemplo, ao navegar na Play Store entre aplicativos +do mesmo desenvolvedor ou álbuns do mesmo artista. Nesses casos, seguir cada link cria +um histórico, fazendo com que o botão Voltar passe por cada tela visualizada anteriormente. Para Cima deve continuar a +ignorar essas relacionadas e navegar para a tela do contêiner visualizada mais recentemente.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market1.png"> + +<p>Você tem a capacidade de deixar o comportamento de Para Cima ainda mais inteligente com base em seu conhecimento da +vista de detalhe. Estendendo o exemplo da Play Store acima, imagine que o usuário navegou do último +Livro visualizado para os detalhes da adaptação do Filme. Nesse caso, Para Cima pode retornar a um contêiner +(filmes) pelo qual o usuário não navegou anteriormente.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market2.png"> + +<h2 id="into-your-app">Navegação para o seu aplicativo pelos widgets de página inicial e notificações</h2> + +<p>Você pode usar widget de página inicial ou notificações para ajudar seus usuários a navegar diretamente para telas +profundas na hierarquia do seu aplicativo. Por exemplo, o widget Caixa de Entrada do Gmail e a notificação de nova mensagem podem +ignorar a tela Caixa de Entrada, levando o usuário diretamente a uma vista de conversa.</p> + +<p>Para esses dois casos, trate o botão Para Cima da seguinte forma:</p> + +<ul> +<li><em>Se a tela de destino é normalmente acessada de uma determinada tela dentro do +aplicativo</em>, Para Cima deve navegar para essa tela.</li> +<li><em>Caso contrário</em>, Para Cima deve navegar para a tela superior ("Página inicial") do aplicativo.</li> +</ul> + +<p>No caso do botão Voltar, você deve tornar a navegação mais previsível inserindo o caminho de navegação para cima +completo na pilha de retorno da tarefa, até a tela superior do aplicativo. Isso permite que usuários +que se esqueceram de como entraram no aplicativo naveguem para a tela superior do aplicativo +antes de saírem.</p> + +<p>Como exemplo, o widget da Página inicial do Gmail tem um botão para mergulhar diretamente para a tela +de composição. Para Cima ou Voltar na tela de composição deve levar o usuário à Caixa de Entrada e, de lá, o +botão Voltar continua até a Página inicial.</p> + +<img src="{@docRoot}design/media/navigation_from_outside_back.png"> + +<h4>Notificações indiretas</h4> + +<p>Quando o aplicativo precisa apresentar simultaneamente informações sobre vários eventos, ele pode usar +uma única notificação que direcione o usuário a uma tela intersticial. Essa tela resume esses +eventos e fornece caminhos para que o usuário mergulhe profundamente no aplicativo. Notificações desse estilo são +chamadas de <em>notificações indiretas</em>.</p> + +<p>Diferentemente de em notificações padrão (diretas), pressionar Voltar em uma tela intersticial da +notificação indireta retorna o usuário ao ponto em que a notificação foi acionada — nenhuma +tela adicional é inserida na pilha de retorno. Quando o usuário prossegue para o aplicativo a partir da +tela intersticial, Para Cima e Voltar se comportam como em notificações padrão, como descrito acima: +navegando dentro do aplicativo em vez de voltar à tela intersticial.</p> + +<p>Por exemplo, suponha que um usuário no Gmail receba uma notificação indireta do Agenda. Tocar nessa +notificação abrirá a tela intersticial, que exibirá lembretes para vários +eventos. Tocar em Voltar na tela intersticial retornará o usuário ao Gmail. Tocar em um determinado evento +levará o usuário da tela intersticial ao aplicativo completo do Agenda para exibir detalhes do +evento. Dos detalhes do evento, Para Cima e Voltar navegam para a vista de nível superior do Agenda.</p> + +<img src="{@docRoot}design/media/navigation_indirect_notification.png"> + +<h4>Notificações pop-up</h4> + +<p><em>Notificações pop-up</em> ignoram a gaveta de notificações, aparecendo diretamente na +frente do usuário. Elas são usadas raramente e <strong>devem ser reservadas para ocasiões em que uma resposta +rápida e a interrupção do contexto do usuário sejam necessárias</strong>. Por exemplo, +o Talk usa esse estilo para alertar o usuário sobre um convite de um amigo para participar de uma conversa com vídeo, já que este +convite expirará automaticamente depois de alguns segundos.</p> + +<p>Em termos do comportamento da navegação, notificações pop-up seguem de perto o comportamento da tela intersticial +de uma notificação indireta. Voltar descarta a notificação pop-up. Se o usuário navegar +da janela pop-up para o aplicativo que realizou a notificação, Para Cima e Voltar seguem as regras de notificações padrão, +navegando dentro do aplicativo.</p> + +<img src="{@docRoot}design/media/navigation_popup_notification.png"> + +<h2 id="between-apps">Navegação entre aplicativos</h2> + +<p>Um dos pontos fortes fundamentais do sistema Android é a capacidade dos aplicativos de ativar +uns aos outros, dando ao usuário a capacidade de navegar diretamente de um aplicativo para outro. Por exemplo, um +aplicativo que precisa capturar uma foto pode ativar o aplicativo Câmera, que devolverá a foto +ao aplicativo que o chamou. Esse é um imenso benefício para o desenvolvedor, que pode aproveitar +facilmente código de outros aplicativos, e para o usuário, que tem uma experiência consistente para ações +comumente realizadas.</p> + +<p>Para entender a navegação entre aplicativos, é importante entender o comportamento da estrutura de trabalho do Android +discutida abaixo.</p> + +<h4>Atividades, tarefas e intenções</h4> + +<p>No Android, uma <strong>atividade</strong> é um componente do aplicativo que define uma tela de +informações e todas as ações associadas que o usuário pode executar. Seu aplicativo é uma coleção de +atividades, consistindo em atividades que você cria e aquelas que reutiliza de outros aplicativos.</p> + +<p>Uma <strong>tarefa</strong> é a sequência de atividades que um usuário segue para atingir um objetivo. Uma +única tarefa pode usar atividades apenas de um aplicativo ou pode retirar atividades de uma série +de outros aplicativos.</p> + +<p>Uma <strong>intenção</strong> é um mecanismo para que um aplicativo sinalize que gostaria da assistência de outro +aplicativo para realizar uma ação. As atividades de um aplicativo podem indicar a que intenções +ele responde. Para intenções comuns, como "Compartilhar", o usuário pode ter vários aplicativos +instalados que atendam a essa solicitação.</p> + +<h4>Exemplo: navegação entre aplicativos para suporte a compartilhamento</h4> + +<p>Para entender como atividades, tarefas e intenções funcionam juntas, entenda como um aplicativo permite que usuários +compartilhem conteúdo usando outro aplicativo. Por exemplo, executar o aplicativo Play Store na tela inicial inicia +uma nova Tarefa A (veja a figura baixo). Depois de navegar pela Play Store e tocar em um livro em promoção +para ver os detalhes, o usuário permanecerá na mesma tarefa, estendendo-a ao adicionar atividades. Acionar +a ação Compartilhar exibe ao usuário uma caixa de diálogo listando cada uma das atividades (de diferentes aplicativos) +que foram registradas para tratar a intenção Compartilhar.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_inward.png"> + +<p>Quando o usuário seleciona o compartilhamento via Gmail, a atividade de composição do Gmail é adicionada como uma continuação da +Tarefa A — nenhuma tarefa nova é criada. Se o Gmail tivesse a própria tarefa em execução em segundo plano, ela não +seria afetada.</p> + +<p>Da atividade de composição, enviar a mensagem ou tocar no botão Voltar retornará o usuário à +atividade de detalhes do livro. Toques subsequentes em Voltar continuarão a navegar para trás pela Play +Store até chegar à Página inicial.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_back.png"> + +<p>No entanto, tocando em Para Cima na atividade de composição, o usuário indica que deseja permanecer no +Gmail. A atividade da lista de conversas do Gmail é exibida e uma nova Tarefa B é criada para ela. Novas tarefas +são sempre vinculadas à Página inicial, portanto, tocar em Voltar na lista de conversas retorna a ela.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_up.png"> + +<p>A Tarefa A persiste no segundo plano e o usuário pode voltar a ela mais tarde (por exemplo, via tela +Recentes). Se o Gmail já tivesse a própria tarefa em execução em segundo plano, ela seria substituída +pela Tarefa B — o contexto anterior é abandonado em favor do novo objetivo do usuário.</p> + +<p>Quando o aplicativo é registrado para tratar intenções com uma atividade em um ponto profundo da hierarquia do aplicativo, +consulte <a href="#into-your-app">Navegação para o seu aplicativo pelos widgets de página +inicial e notificações</a> para ver orientações sobre como especificar a navegação Para Cima.</p> diff --git a/docs/html-intl/intl/pt-br/design/patterns/notifications.jd b/docs/html-intl/intl/pt-br/design/patterns/notifications.jd new file mode 100644 index 0000000..efea610 --- /dev/null +++ b/docs/html-intl/intl/pt-br/design/patterns/notifications.jd @@ -0,0 +1,872 @@ +page.title=Notificações +page.tags="notifications","design","L" +@jd:body + + <a class="notice-developers" href="{@docRoot}training/notify-user/index.html"> + <div> + <h3>Documentos do desenvolvedor</h3> + <p>Notificação ao usuário</p> + </div> +</a> + +<a class="notice-designers" href="notifications_k.html"> + <div> + <h3>Notificações no Android 4.4 e em anteriores</h3> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=Uiq2kZ2JHVY"> +<div> + <h3>Vídeo</h3> + <p>DevBytes: Notificações na pré-visualização do desenvolvedor do Android L</p> +</div> +</a> + +<style> + .col-5, .col-6, .col-7 { + margin-left:0px; + } +</style> + +<p>O sistema de notificações permite que os usuários se mantenham informados sobre eventos relevantes e +imediatos +no aplicativo, como novas mensagens de bate-papo de um amigo ou um evento de calendário. +Pense nas notificações como um canal de notícias que alerta o usuário sobre eventos +importantes à +medida que acontecem ou sobre um registro que grava eventos enquanto o usuário não está prestando +atenção — e que é sincronizado conforme apropriado em todos os dispositivos Android dele.</p> + +<h4 id="New"><strong>Novo no Android 5.0</strong></h4> + +<p>No Android 5.0, as notificações recebem atualizações importantes: em termos estruturais, visuais e +funcionais:</p> + +<ul> + <li>As notificações passaram por mudanças visuais consistentes com o novo +tema do Material Design.</li> + <li> As notificações agora estão disponíveis na tela de bloqueio do dispositivo, enquanto que +o conteúdo sensível ainda pode +ficar oculto atrás dela.</li> + <li>Notificações de alta prioridade recebidas enquanto o dispositivo está em uso agora usam um novo formato, chamado de +notificações heads-up.</li> + <li>Notificações sincronizadas na nuvem: descartar uma notificação em um dos +dispositivos Android a descarta +também nos outros.</li> +</ul> + +<p class="note"><strong>Observação:</strong> o projeto de notificação nesta versão do +Android é uma mudança +significativa em relação às versões anteriores. Para obter informações sobre o projeto de notificação em versões +anteriores, consulte <a href="./notifications_k.html">Notificações no Android 4.4 ou em anteriores</a>.</p> + +<h2 id="Anatomy">Anatomia de uma notificação</h2> + +<p>Esta seção aborda as partes básicas de uma notificação e como elas +podem aparecer em diferentes tipos de dispositivos.</p> + +<h3 id="BaseLayout">Layout básico</h3> + +<p>No mínimo, todas as notificações consistem em um layout básico, incluindo:</p> + +<ul> + <li> O <strong>ícone</strong> da notificação. O ícone simboliza o +aplicativo de origem. Ele também + pode indicar o tipo de notificação, caso o aplicativo gere mais de um +tipo.</li> + <li> Um <strong>título</strong> da notificação e +<strong>texto</strong> adicional.</li> + <li> Uma <strong>marcação de data e hora</strong>.</li> +</ul> + +<p>Notificações criadas com {@link android.app.Notification.Builder Notification.Builder} +para versões anteriores da plataforma têm a mesma aparência e o mesmo funcionamento no Android +5.0, com apenas mudanças menores de estilo que o sistema +entrega a você. Para obter mais informações sobre notificações em versões +anteriores do Android, consulte +<a href="./notifications_k.html">Notificações no Android 4.4 ou em anteriores</a>.</p></p> + + + <img style="margin:20px 0 0 0" src="{@docRoot}images/android-5.0/notifications/basic_combo.png" alt="" width="700px" /> + + +<div style="clear:both;margin-top:20px"> + <p class="img-caption"> + Layout básico de uma notificação em dispositivo portátil (à esquerda) e a mesma notificação em Wear (à direita), +com uma foto do usuário e um ícone de notificação + </p> + </div> + +<h3 id="ExpandedLayouts">Layouts expandidos</h3> + + +<p>Você pode escolher o nível de detalhe que as notificações de seu aplicativo +devem fornecer. Elas podem mostrar as primeiras +linhas de uma mensagem ou exibir uma visualização de imagem maior. As informações +adicionais fornecem ao usuário mais +contexto e — em alguns casos — podem permitir que o usuário leia uma mensagem +em sua totalidade. O usuário pode +pinçar para aproximar ou afastar a vista ou realizar deslizamento de um dedo para alternar entre os layouts +compacto e expandido. + Para notificações de um evento, o Android fornece três modelos de layout +expandido (texto, caixa de entrada e + imagem) para usar em seu aplicativo. As imagens a seguir mostram como +se parecem notificações de um evento em + dispositivos portáteis (à esquerda) e usados junto ao corpo (à direita).</p> + +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/expandedtext_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/stack_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/ExpandedImage.png" + alt="" width="311px" height;="450px" /> + +<h3 id="actions" style="clear:both; margin-top:40px">Ações</h3> + +<p>O Android tem suporte para ações opcionais que são exibidas na parte inferior +da notificação. +Com ações, os usuários podem tratar as tarefas mais comuns para +determinada notificação de dentro da sombra da notificação sem precisar abrir o +aplicativo de origem. +Isso acelera a interação e, em conjunto com deslizar-para-descartar, ajuda os usuários a +se concentrarem em notificações que sejam importantes.</p> + + + <img src="{@docRoot}images/android-5.0/notifications/action_combo.png" alt="" width="700px" /> + + + +<p style="clear:both">Tenha cuidado com o número de ações que inclui em uma +notificação. Quanto mais +ações incluir, maior será a complexidade cognitiva criada. Limite-se +ao menor número possível +de ações, incluindo apenas as ações efetivamente mais importantes e +significativas.</p> + +<p>Boas candidatas a ações em notificações são ações que:</p> + +<ul> + <li> Sejam essenciais, frequentes e típicas para o tipo de conteúdo +exibido + <li> Permitam que o usuário realize tarefas rapidamente +</ul> + +<p>Evite ações que sejam:</p> + +<ul> + <li> Ambíguas + <li> Idênticas à ação padrão da notificação (como "Ler" ou +"Abrir") +</ul> + + + +<p>Você pode especificar no máximo três ações, cada uma consistindo em um ícone +e um nome de ação. + Adicionar ações a um layout básico simples torna a notificação expansível, +mesmo se a +notificação não tiver um layout expandido. Como as ações são exibidas apenas para notificações +expandidas + e que ficam de outra forma ocultas, certifique-se de que qualquer ação que um +usuário possa invocar de dentro de uma + notificação esteja disponível também dentro do aplicativo +associado.</p> + +<h2 style="clear:left">Notificação heads-up</h2> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/hun-example.png" alt="" width="311px" /> + <p class="img-caption"> + Exemplo de uma notificação heads-up (chamada telefônica recebida, alta prioridade) +que aparece sobre um +aplicativo imersivo + </p> +</div> + +<p>Quando uma notificação de alta prioridade chega (veja à direita), ela é apresentada +aos usuários por +um período curto com um layout expandido mostrando possíveis ações.</p> +<p> Depois desse período, a notificação recua para a sombra +de notificação. Se a <a href="#correctly_set_and_manage_notification_priority">prioridade</a> de uma notificação for +marcada como Alta, Máxima ou tela cheia, ela receberá uma notificação heads-up.</p> + +<p><b>Bons exemplos de notificações heads-up</b></p> + +<ul> + <li> Chamada telefônica recebida durante o uso do dispositivo</li> + <li> Alarme durante o uso do dispositivo</li> + <li> Nova mensagem SMS</li> + <li> Bateria fraca</li> +</ul> + +<h2 style="clear:both" id="guidelines">Diretrizes</h2> + + +<h3 id="MakeItPersonal">Torne-a pessoal</h3> + +<p>Para notificações de itens enviados por outra pessoa (como uma mensagem ou +atualização de status), inclua a imagem da pessoa usando +{@link android.app.Notification.Builder#setLargeIcon setLargeIcon()}. Anexe também informações sobre +a pessoa nos metadados da notificação (consulte {@link android.app.Notification#EXTRA_PEOPLE}).</p> + +<p>O ícone principal de sua notificação ainda é mostrado, portanto, o usuário pode associá-lo +ao ícone +visível na barra de status.</p> + + +<img src="{@docRoot}images/android-5.0/notifications/Triggered.png" alt="" width="311px" /> +<p style="margin-top:10px" class="img-caption"> + Notificação que mostra a pessoa que a ativou e o conteúdo enviado. +</p> + + +<h3 id="navigate_to_the_right_place">Navegação para o lugar certo</h3> + +<p>Quando o usuário toca no corpo de uma notificação (fora dos botões +de ação), abra o aplicativo +no lugar em que o usuário possa visualizar e agir sobre os dados referenciados na +notificação. Na maioria dos casos, será a exibição detalhada de um único item de dado, como uma mensagem, +mas também poderá ser uma +vista resumida se a notificação estiver empilhada. Se o aplicativo +levar o usuário a qualquer lugar abaixo do nível superior do aplicativo, insira a navegação na pilha de retorno do aplicativo para que +o usuário possa pressionar o botão Voltar do sistema para voltar ao nível superior. Para obter mais informações, consulte +<em>Navegação para o seu aplicativo pelos widgets de página inicial e notificações</em> no padrão de projeto de <a href="{@docRoot}design/patterns/navigation.html#into-your-app">Navegação</a>. +</p> + +<h3 id="correctly_set_and_manage_notification_priority">Definição e gerenciamento +corretos da prioridade das +notificações</h3> + +<p>O Android tem suporte para um sinalizador de prioridade para notificações. Esse sinalizador permite +influenciar o local em que a notificação é exibida em relação a outras notificações e +ajuda a garantir +que os usuários sempre vejam primeiro as notificações mais importantes. Você pode escolher entre +os seguintes +níveis de prioridade ao publicar uma notificação:</p> +<table> + <tr> + <td class="tab0"> +<p><strong>Prioridade</strong></p> +</td> + <td class="tab0"> +<p><strong>Uso</strong></p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MAX</code></p> +</td> + <td class="tab1"> +<p>Use para notificações críticas e urgentes que alertam o usuário sobre uma condição +que depende +do tempo ou que precisa ser resolvida antes que o usuário possa continuar +com uma determinada tarefa.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>HIGH</code></p> +</td> + <td class="tab1"> +<p>Use principalmente para comunicações importantes, como uma mensagem ou +eventos de bate-papo com conteúdo particularmente interessante para o usuário. +Notificações de alta prioridade acionam a exibição de uma notificação heads-up.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>DEFAULT</code></p> +</td> + <td class="tab1"> +<p>Use para todas as notificações que não recaiam em nenhuma das outras prioridades descritas aqui.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>LOW</code></p> +</td> + <td class="tab1"> +<p>Use para notificações sobre as quais deseja que o usuário seja informado, mas +que sejam menos urgentes. Notificações de baixa prioridade tendem a ser exibidas na parte inferior da lista, +o que as torna uma boa +opção para coisas como atualizações públicas ou sociais não direcionadas: o usuário pediu para +ser notificado sobre +elas, mas essas notificações nunca devem ter precedência sobre comunicações +urgentes ou diretas.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MIN</code></p> +</td> + <td class="tab1"> +<p>Use para informações contextuais ou de histórico, como informações sobre clima ou +informações contextuais de localização. +Notificações de prioridade mínima não aparecem na barra de status. O usuário +as descobre expandindo a sombra da notificação.</p> +</td> + </tr> +</table> + + +<h4 id="how_to_choose_an_appropriate_priority"><strong>Como escolher uma prioridade +adequada +</strong></h4> + +<p><code>DEFAULT</code>, <code>HIGH</code> e <code>MAX</code> são níveis de prioridade de interrupção e arriscam +interromper a atividade +do usuário. Para evitar irritar os usuários de seu aplicativo, reserve níveis de prioridade de interrupção para +notificações que:</p> + +<ul> + <li> Envolvam outra pessoa</li> + <li> Dependam do tempo</li> + <li> Possam mudar imediatamente o comportamento do usuário no mundo real</li> +</ul> + +<p>Notificações definidas como <code>LOW</code> e <code>MIN</code> ainda podem +ser valiosas para o usuário: muitas, se não a maioria, das notificações não precisam demandar a atenção +imediata do usuário, ou vibrar o pulso do usuário, mas ainda contêm informações que o usuário +achará valiosas ao decidir procurar +notificações. Os critérios para notificações de prioridade <code>LOW</code> e <code>MIN</code> +incluem:</p> + +<ul> + <li> Não envolver outras pessoas</li> + <li> Não depender de tempo</li> + <li> Ter conteúdo no qual o usuário pode estar interessado, mas que pode decidir +verificar no momento em que desejar</li> +</ul> + + + <img src="{@docRoot}images/android-5.0/notifications/notifications_pattern_priority.png" alt="" width="700" /> + + +<h3 style="clear:both" id="set_a_notification_category">Definição de uma categoria +de notificação</h3> + +<p>Se a sua notificação recair em uma das categorias predefinidas (veja +abaixo), atribua-a +adequadamente. Aspectos da IU do sistema, como a sombra da notificação (ou qualquer +outra escuta +de notificação), podem usar essas informações para tomar decisões de classificação e filtragem.</p> +<table> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_CALL">CATEGORY_CALL</a></code></p> +</td> + <td> +<p>Chamada recebida (voz ou vídeo) ou solicitação similar de +comunicação síncrona</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_MESSAGE">CATEGORY_MESSAGE</a></code></p> +</td> + <td> +<p>Mensagem direta recebida (SMS, mensagem instantânea etc.)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EMAIL">CATEGORY_EMAIL</a></code></p> +</td> + <td> +<p>Mensagens assíncronas em lote (e-mail)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EVENT">CATEGORY_EVENT</a></code></p> +</td> + <td> +<p>Evento de calendário</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROMO">CATEGORY_PROMO</a></code></p> +</td> + <td> +<p>Promoção ou publicidade</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ALARM">CATEGORY_ALARM</a></code></p> +</td> + <td> +<p>Alarme ou cronômetro</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROGRESS">CATEGORY_PROGRESS</a></code></p> +</td> + <td> +<p>Andamento de uma operação de execução longa em segundo plano</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SOCIAL">CATEGORY_SOCIAL</a></code></p> +</td> + <td> +<p>Atualização de rede social ou de compartilhamento</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ERROR">CATEGORY_ERROR</a></code></p> +</td> + <td> +<p>Erro em operação de segundo plano ou no status de autenticação</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_TRANSPORT">CATEGORY_TRANSPORT</a></code></p> +</td> + <td> +<p>Controle de transporte de mídia para reprodução</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SYSTEM">CATEGORY_SYSTEM</a></code></p> +</td> + <td> +<p>Atualização do sistema ou do status do dispositivo. Reservado para uso do sistema.</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SERVICE">CATEGORY_SERVICE</a></code></p> +</td> + <td> +<p>Indicação de serviço de segundo plano em execução</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_RECOMMENDATION">CATEGORY_RECOMMENDATION</a></code></p> +</td> + <td> +<p>Uma recomendação específica e oportuna para uma única coisa. Por exemplo, um aplicativo +de notícias pode querer +recomendar uma notícia que acredita que o usuário desejará ler em seguida.</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_STATUS">CATEGORY_STATUS</a></code></p> +</td> + <td> +<p>Informações contínuas sobre o dispositivo ou o status contextual</p> +</td> + </tr> +</table> + +<h3 id="summarize_your_notifications">Resuma as notificações</h3> + +<p>Se uma notificação de um certo tipo já estiver pendente quando o aplicativo tentar enviar uma nova +notificação do mesmo tipo, combine-as em uma única notificação de resumo para o aplicativo. Não +crie um novo objeto.</p> + +<p>Uma notificação de resumo cria uma descrição resumida e permite que o +usuário entenda quantas notificações +de um determinado tipo estão pendentes.</p> + +<div class="col-6"> + +<p><strong>O que não fazer</strong></p> + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Dont.png" alt="" width="311px" /> +</div> + +<div> +<p><strong>O que fazer</strong></p> + + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Do.png" alt="" width="311px" /> +</div> + +<p style="clear:left; padding-top:30px; padding-bottom:20px">Você pode fornecer +mais detalhes sobre as notificações individuais que compõem um +resumo usando o layout resumido expandido. Essa abordagem permite que os usuários +entendam melhor quais +notificações estão pendentes e decidam se estão interessados o suficiente para lê-las +em detalhes dentro +do aplicativo associado.</p> +<div class="col-6"> + <img src="{@docRoot}images/android-5.0/notifications/Stack.png" style="margin-bottom:20px" alt="" width="311px" /> + <p class="img-caption"> + Notificação expandida e contraída que é um resumo (usando <code>InboxStyle</code>) + </p> +</div> + +<h3 style="clear:both" id="make_notifications_optional">Torne as notificações +opcionais</h3> + +<p>Os usuários devem sempre controlar as notificações. Permita que o usuário +desative as notificações +de seu aplicativo ou altere as propriedades de alerta, como som de alerta e +se a vibração será usada, +adicionando um item de configuração da notificação nas configurações do aplicativo.</p> + +<h3 id="use_distinct_icons">Use ícones distintos</h3> +<p>Ao olhar para a área de notificação, o usuário deverá ser capaz de discernir +que tipos de +notificações estão atualmente pendentes.</p> + +<div class="figure"> + <img src="{@docRoot}images/android-5.0/notifications/ProductIcons.png" alt="" width="420" /> +</div> + + <div><p><strong>O que fazer</strong></p> + <p>Verifique os ícones de notificação que os aplicativos do Android já fornecem e crie +ícones de notificação para o seu +aplicativo que tenham aparência suficientemente distinta.</p> + + <p><strong>O que fazer</strong></p> + <p>Use o <a href="/design/style/iconography.html#notification">estilo de ícone de notificação</a> apropriado + para ícones pequenos e o + <a href="/design/style/iconography.html#action-bar">estilo de ícone de barra +de ação</a> da luminosidade do Material para os ícones + de ação.</p> +<p ><strong>O que fazer</strong></p> +<p >Mantenha os ícones visualmente simples, evitando detalhes excessivos que sejam +difíceis de discernir.</p> + + <div><p><strong>O que não fazer</strong></p> + <p>Coloque um alfa adicional (esmaecimento ou redução de intensidade) nos ícones pequenos +e nos ícones de + ação; eles podem ter bordas suavizadas, mas, como o Android usa esses +ícones como máscaras (ou seja, somente + o canal alfa é usado), a imagem normalmente deve ser desenhada com +opacidade total.</p> + +</div> +<p style="clear:both"><strong>O que não fazer</strong></p> + +<p>Use cores para distinguir o seu aplicativo dos outros. Ícones de notificação devem +somente ser uma imagem com fundo branco sobre transparente.</p> + + +<h3 id="pulse_the_notification_led_appropriately">Pisque o LED de notificação +adequadamente</h3> + +<p>Muitos dispositivos Android contêm um LED de notificação, que é usado para manter o +usuário informado sobre +eventos enquanto a tela está desligada. Notificações com um nível de prioridade de <code>MAX</code>, +<code>HIGH</code> ou <code>DEFAULT</code> devem +fazer com que o LED brilhe, enquanto que os de prioridade mais baixa (<code>LOW</code> e +<code>MIN</code>) não devem.</p> + +<p>O controle do usuário sobre as notificações deve se estender ao LED. Ao usar +DEFAULT_LIGHTS, o +LED brilhará na cor branca. Suas notificações não devem usar uma cor +diferente, a não ser que o +usuário as tenha explicitamente personalizado.</p> + +<h2 id="building_notifications_that_users_care_about">Criação de notificações +que agradam aos usuários</h2> + +<p>Para criar um aplicativo que os usuários amem, é importante projetar as +notificações cuidadosamente. +As notificações personificam a voz do seu aplicativo e contribuem para +a personalidade dele. Notificações indesejadas ou +irrelevantes podem irritar o usuário ou fazer com que ele reprove a +quantidade de atenção que o +aplicativo exige. Portanto, use notificações de forma cuidadosa.</p> + +<h3 id="when_to_display_a_notification">Quando exibir uma notificação</h3> + +<p>Para criar um aplicativo que as pessoas gostem de usar, é importante +reconhecer que a atenção e o foco +do usuário são recursos que devem ser protegidos. Apesar de o sistema de +notificação do Android ter +sido projetado para minimizar o impacto das notificações na atenção do usuário, +ainda é +importante ter ciência do fato de que as notificações interrompem o +fluxo de tarefas do usuário. +Ao planejar as notificações, pergunte-se se elas são importantes o suficiente para +justificar uma interrupção. Se não tiver certeza, permita que o usuário decida se quer +uma notificação usando as configurações de notificação do seu aplicativo ou ajuste +o sinalizador de prioridade das notificações para <code>LOW</code> ou <code>MIN</code> para +evitar distrair o usuário enquanto ele faz +alguma outra coisa.</p> + + <img src="{@docRoot}images/android-5.0/notifications/TimeSensitive.png" alt="" width="311px" /> + <p style="margin-top:10px" class="img-caption"> + Exemplos de notificação que depende de tempo + </p> + +<p>Apesar de aplicativos bem comportados geralmente se manifestarem apenas quando ocorre interação com eles, alguns +casos justificam que o aplicativo interrompa o usuário com uma notificação não solicitada.</p> + +<p>Use notificações principalmente para <strong>eventos que dependam de tempo</strong>, especialmente + se esses eventos síncronos <strong>envolverem outras pessoas</strong>. Por +exemplo, um bate-papo recebido +é uma forma síncrona em tempo real de comunicação: outro usuário +espera ativamente a resposta. Eventos de calendário são outro exemplo bom de quando usar uma +notificação e atrair a +atenção do usuário, pois o evento é iminente e eventos de calendário frequentemente +envolvem outras pessoas.</p> + +<h3 style="clear:both" id="when_not_to_display_a_notification">Quando não exibir +uma notificação</h3> + +<div class="figure" style="margin-top:60px"> + <img src="{@docRoot}images/android-5.0/notifications/AntiSample1.png" alt="" width="311px" /> +</div> + +<p>Em muitos outros casos, notificações não são adequadas:</p> + +<ul> + <li> Evite notificar o usuário sobre informações que não são especificamente +direcionadas a ele ou +que não dependam realmente de tempo. Por exemplo, as atualizações +assíncronas e não direcionadas +que fluem por uma rede social geralmente não justificam uma interrupção +em tempo real. Para os usuários que se importam +com elas, deixe que decidam recebê-las.</li> + <li> Não crie uma notificação se as informações novas relevantes estiverem +atualmente na tela. Em vez disso, +use a IU do próprio aplicativo para notificar o usuário das novas informações +diretamente no contexto. + Por exemplo, um aplicativo de bate-papo não deve criar notificações de sistema enquanto o +usuário estiver conversando ativamente com outro usuário.</li> + <li> Não interrompa o usuário para realizar operações técnicas de baixo nível, como salvar +ou sincronizar informações, nem atualize um aplicativo se o aplicativo ou o sistema puder resolver +o problema sem envolver o usuário.</li> + <li> Não interrompa o usuário para informar um erro se o aplicativo +puder se recuperar dele por conta própria, sem que o usuário +tome qualquer ação.</li> + <li> Não crie notificações que não tenham conteúdo real de notificação e +que meramente anunciem o seu +aplicativo. Uma notificação deve fornecer informações úteis, oportunas e novas e +não deve ser usada +meramente para executar um aplicativo.</li> + <li> Não crie notificações supérfluas apenas para colocar sua marca na frente +dos usuários. + Tais notificações frustram e provavelmente alienam seu público-alvo. A +melhor forma de fornecer + pequenas quantidades de informações atualizadas e manter o usuário envolvido +com o seu + aplicativo é desenvolver um widget que ele possa colocar na +tela inicial.</li> +</ul> + +<h2 style="clear:left" id="interacting_with_notifications">Interação com +notificações</h2> + +<p>Notificações são indicadas por ícones na barra de status e podem ser acessadas +abrindo a +gaveta de notificações.</p> + +<p>Tocar em uma notificação abre o aplicativo associado com o conteúdo +detalhado que corresponde à notificação. +Deslizar à esquerda ou à direita em uma notificação a remove da gaveta.</p> + +<h3 id="ongoing_notifications">Notificações contínuas</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/MusicPlayback.png" alt="" width="311px" /> + <p class="img-caption"> + Notificação contínua devido à reprodução de música + </p> +</div> +<p>Notificações contínuas mantêm os usuários informados sobre um processo em andamento em +segundo plano. +Por exemplo, reprodutores de música anunciam a faixa em reprodução no +sistema de notificação e +continuam a fazer isso até que o usuário interrompa a reprodução. Notificações contínuas também podem +mostrar ao usuário +feedback sobre tarefas mais longas, como o download de um arquivo ou a codificação de um vídeo. Um usuário não pode remover +manualmente uma notificação contínua da gaveta de notificações.</p> + +<h3 id="ongoing_notifications">Reprodução de mídia</h3> +<p>No Android 5.0, a tela de bloqueio não mostra controles de transporte por causa da classe +{@link android.media.RemoteControlClient} obsoleta. Mas ela <em>mostra</em> notificações, portanto, a notificação de reprodução +de cada aplicativo agora é a forma +principal para que os usuários controlem a reprodução em um estado bloqueado. Esse comportamento dá aos aplicativos mais +controle sobre quais +botões exibir e de que forma, ao mesmo tempo em que fornece uma experiência consistente +para o usuário, com a tela bloqueada ou não.</p> + +<h3 style="clear:both" +id="dialogs_and_toasts_are_for_feedback_not_notification">Diálogos +e avisos</h3> + +<p>O seu aplicativo não deve criar uma caixa de diálogo ou um aviso se não estiver +atualmente na tela. Uma caixa de diálogo ou um aviso + deve ser exibido somente como uma resposta imediata ao usuário tomando uma ação +dentro do seu aplicativo. +Para obter orientação adicional sobre o uso de caixas de diálogo e avisos, consulte +<a href="/design/patterns/confirming-acknowledging.html">Confirmação e reconhecimento</a>.</p> + +<h3>Avaliação e classificação</h3> + +<p>Notificações são notícias e, portanto, são essencialmente exibidas +em ordem cronológica inversa, com +consideração especial para a +<a href="#correctly_set_and_manage_notification_priority">prioridade</a> da notificação declarada no aplicativo.</p> + +<p>Notificações são uma parte importante da tela de bloqueio e são exibidas proeminentemente +sempre +que a tela do dispositivo é exibida. O espaço na tela de bloqueio é restrito, portanto, +é mais importante +do que nunca identificar as notificações mais urgentes ou relevantes. Por esse +motivo, o Android tem um +algoritmo de classificação mais sofisticado para notificações, levando em conta:</p> + +<ul> + <li> A marcação de data e hora e a prioridade declarada no aplicativo.</li> + <li> Se a notificação incomodou recentemente o usuário com som ou +vibração (ou seja, + se o celular acabou de fazer um ruído e o usuário deseja saber "O que acabou de +acontecer?", a tela de bloqueio + deve responder com um olhar rápido).</li> + <li> Qualquer pessoa anexada à notificação usando {@link android.app.Notification#EXTRA_PEOPLE} + e, em particular, se é contato especial (com estrelas).</li> +</ul> + +<p>Para aproveitar ao máximo essa classificação, concentre-se na experiência +do usuário que deseja +criar, e não em um determinado local na lista.</p> + + <img src="{@docRoot}images/android-5.0/notifications/AntiSample3.png" alt="" width="700px" /> + + <p class="img-caption" style="margin-top:10px">Notificações do Gmail têm +prioridade padrão e normalmente + são classificadas abaixo de mensagens de um aplicativo de mensagem instantânea, como o Hangouts, mas +recebem + uma promoção temporária quando novas mensagens chegam. + </p> + + +<h3>Na tela de bloqueio</h3> + +<p>Como as notificações são visíveis na tela de bloqueio, a privacidade do usuário é uma consideração +especialmente + importante. Notificações frequentemente contêm informações sensíveis e +não devem necessariamente estar visíveis +para qualquer pessoa que ligar a tela do dispositivo.</p> + +<ul> + <li> Para dispositivos que têm uma tela de bloqueio segura (PIN, padrão ou senha), a interface tem +partes públicas e privadas. A interface pública pode ser exibida em uma tela de bloqueio segura e, +portanto, vista por qualquer pessoa. A interface privada é o mundo atrás da tela de bloqueio e +só é revelada depois que o usuário faz login no dispositivo.</li> +</ul> + +<h3>Controle do usuário sobre as informações exibidas na tela de bloqueio segura</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/LockScreen@2x.png" srcset="{@docRoot}images/android-5.0/notifications/LockScreen.png 1x" alt="" width="311px" /> + <p class="img-caption"> + Notificações na tela de bloqueio com conteúdo revelado depois que o usuário desbloqueia o dispositivo. + </p> +</div> + +<p>Ao definir uma tela de bloqueio segura, o usuário poderá escolher ocultar +detalhes sensíveis da tela de bloqueio segura. Nesse caso, a IU do sistema +considerará o <em>nível de visibilidade</em> da notificação para descobrir o que pode +ser exibido com segurança.</p> +<p> Para controlar o nível de visibilidade, chame +<code><a +href="/reference/android/app/Notification.Builder.html#setVisibility(int)">Notification.Builder.setVisibility()</a></code> +e especifique um destes valores:</p> + +<ul> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PUBLIC">VISIBILITY_PUBLIC</a></code>. +Exibe o conteúdo inteiro da notificação. + Esse é o padrão do sistema se a visibilidade não for especificada.</li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PRIVATE">VISIBILITY_PRIVATE</a></code>. +Na tela de bloqueio, exibe informações básicas sobre essa notificação, incluindo o +ícone e o nome do aplicativo que a publicou. O restante dos detalhes da notificação não é exibido. +Alguns pontos a ter em mente são: + <ul> + <li> Se você quer fornecer uma versão pública diferente da sua notificação +para que o sistema a exiba em uma tela de bloqueio segura, forneça um objeto +Notificação substituto no campo <code><a +href="/reference/android/app/Notification.html#publicVersion">Notification.publicVersion</a></code>. + + <li> Essa configuração dá ao aplicativo uma oportunidade de criar uma versão alternativa do +conteúdo que ainda é útil, mas não revela informações pessoais. Considere o exemplo de um +aplicativo de SMS cujas notificações incluem o texto da mensagem SMS, o nome do remetente e o ícone do contato. +Essa notificação deve ser <code>VISIBILITY_PRIVATE</code>, mas <code>publicVersion</code> ainda pode +conter informações úteis, como "3 novas mensagens", sem outros detalhes +de identificação. + </ul> + </li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_SECRET">Notification.VISIBILITY_SECRET</a></code>. Mostra apenas as informações mínimas, excluindo até mesmo +o ícone da notificação.</li> +</ul> +<h2 style="clear:both" id="notifications_on_android_wear">Notificações no +Android Wear</h2> + +<p>Notificações e suas <em>ações</em> são enviadas a dispositivos Wear por padrão. +Os desenvolvedores podem controlar que notificações são enviadas do +celular ao relógio +e vice-versa. Os desenvolvedores também podem controlar quais ações são transmitidas. Se o +seu aplicativo inclui +ações que não podem ser executadas com um toque, oculte essas ações +na sua notificação do Wear +ou considere colocá-las em um aplicativo do Wear, permitindo que o usuário +termine a ação +no relógio.</p> + +<h4>Transmissão de notificações e ações</h4> + +<p>Um dispositivo conectado, como um celular, pode transmitir notificações para um dispositivo Wear para que as +notificações sejam exibidas nele. De forma similar, ele pode transmitir ações para que o usuário possa agir +sobre as notificações diretamente do dispositivo Wear.</p> + +<p><strong>Transmitir</strong></p> + +<ul> + <li> Novas mensagens instantâneas</li> + <li> Ações de um toque, como +1, Curtir, Coração</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/WearBasic.png" width="156px" height="156px" alt="" /> + +<p><strong>Não transmitir</strong></p> + +<ul> + <li> Notificações de podcasts recém-chegados</li> + <li> Ações que mapeiem para recursos que não são possíveis no relógio</li> +</ul> + + + +<p><h4>Ações exclusivas a definir para Wear</h4></p> + +<p>Há algumas ações que só podem ser realizadas em Wear. Elas incluem:</p> + +<ul> + <li> Listas rápidas de respostas prontas, como "Volto logo"</li> + <li> Abrir no celular</li> + <li> Uma ação "Comentar" ou "Responder" que abre a tela de entrada de voz</li> + <li> Ações que executam aplicativos específicos de Wear</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/ReplyAction.png" width="156px" height="156px" alt="" /> diff --git a/docs/html-intl/intl/ru/design/get-started/principles.jd b/docs/html-intl/intl/ru/design/get-started/principles.jd new file mode 100644 index 0000000..7f4977c --- /dev/null +++ b/docs/html-intl/intl/ru/design/get-started/principles.jd @@ -0,0 +1,307 @@ +page.title=Принципы проектирования Android +@jd:body + +<p>Эти принципы проектирования были разработаны группой Android +по взаимодействию приложений с пользователями с целью соблюдения интересов пользователей. +Для создателей приложений под Android они лежат в +основе более подробных рекомендаций по проектированию для конкретных +типов устройств.</p> + +<p> +Учитывайте эти принципы, используя собственный +творческий потенциал и мышление разработчика. Впрочем, при наличии веских оснований допустимо некоторое отклонение от них. +</p> + +<h2 id="enchant-me">Постарайтесь понравиться пользователю</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="delight-me">Вызовите у пользователя восхищение неожиданными решениями</h4> +<p>Красивые экраны, тщательно продуманная анимация или своевременные звуковые сигналы создают у пользователя +хорошее настроение. Утонченные эффекты вызывают у пользователя ощущение, +что его возможности не ограничены.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_delight.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="real-objects-more-fun">Реальные объекты доставляют больше удовольствия, чем кнопки и меню</h4> +<p>Позвольте пользователю касаться объектов приложения и манипулировать ими. Это сокращает когнитивные усилия, +необходимые для выполнения задачи, повышая эмоциональное удовлетворение.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_real_objects.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-it-mine">Позвольте пользователю сделать интерфейс индивидуальным</h4> +<p>Люди любят вносить в интерфейс что-то личное, чтобы чувствовать себя более комфортно и считать, что всё под контролем. Предоставьте +продуманные и эстетичные настройки по умолчанию и предусмотрите дополнительные настройки, забавные, но не препятствующие +выполнению основных задач.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_it_mine.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="get-to-know-me">Изучите пользователя</h4> +<p>Постепенно выясняйте предпочтения пользователя Вместо того, чтобы снова и снова заставлять его выбирать одно и то же, + сделайте непосредственно доступными ранее выбранные варианты.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_get_to_know_me.png"> + + </div> +</div> + +<h2 id="simplify-my-life">Упростите жизнь пользователю</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="keep-it-brief">Будьте лаконичны</h4> +<p>Используйте короткие фразы с простыми словами. Люди, скорее всего, пропустят длинные предложения.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_keep_it_brief.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="pictures-faster-than-words">Картинки воспринимаются быстрее чем слова</h4> +<p>Используйте картинки в своих объяснениях. Они завладевают вниманием и действуют гораздо эффективнее +слов.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_pictures.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="decide-for-me">Принимайте решения за пользователя, но оставляйте последнее слово за ним</h4> +<p>Не задавайте пользователю лишних вопросов и действуйте наиболее разумным образом. Слишком широкий выбор вызывает чувство +растерянности. Если существует вероятность, что ваш выбор не устроит пользователя, предоставьте ему возможность отмены.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_decide_for_me.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="only-show-when-i-need-it">Показывайте только самое необходимое и в нужный момент времени</h4> +<p>Люди не в состоянии справиться сразу с большим количеством информации. Разбивайте задачи и информацию на небольшие легко +воспринимаемые части. Скройте несущественные на данный момент опции и обучайте пользователя по ходу дела.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_information_when_need_it.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="always-know-where-i-am">Пользователь всегда должен знать, в каком месте приложения он находится</h4> +<p>Придайте пользователю уверенность, что он не заблудился. Сделайте так, чтобы экраны в вашем приложении отличались друг от друга, и +используйте переходы, чтобы показать связь между экранами. Обеспечивайте обратную связь от выполняемых задач.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_navigation.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="never-lose-my-stuff">Ни в коем случае не теряйте данные пользователей</h4> +<p>Сохраняйте данные, на создание которых пользователь потратил свое время, и обеспечьте ему доступ к этой информации из любого места. Запоминайте настройки + и предпочтения на телефонах, планшетах и компьютерах. Это позволит значительно упростить +обновление приложения.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_never_lose_stuff.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="looks-same-should-act-same">Внешне похожие элементы должны вести себя одинаково</h4> +<p>Помогите людям распознать функциональные различия, сделав их визуально отличимыми. +Избегайте ситуаций, в которых разные места приложения выглядят похоже, но работают по-разному при одних тех же исходных данных.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_looks_same.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="interrupt-only-if-important">Прерывайте пользователя только в действительно важных ситуациях</h4> +<p>Подобно хорошему секретарю, приложение должно оградить пользователя от несущественных мелочей. Люди не любят отвлекаться, +и беспокоить их следует только в исключительно серьезных или не терпящих отлагательства ситуациях.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_important_interruption.png"> + + </div> +</div> + +<h2 id="make-me-amazing">Постарайтесь приятно удивить пользователя</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="give-me-tricks">Предоставьте пользователю привычные приемы</h4> +<p>У людей повышается самооценка, когда они могут разобраться в чем-либо самостоятельно. Сделайте ваше приложение простым в освоении +за счет использования визуальных моделей и мышечной памяти из других приложений Android. Например, жест скольжения +является хорошим навигационным приемом.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_tricks.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="its-not-my-fault">Пользователь ни в чем не виноват</h4> +<p>Будьте корректны, подсказывая пользователю, как выйти из сложного положения. Никто не хочет чувствовать себя бестолковым, имея дело с вашим +приложением. При возникновении проблем дайте четкие указания по восстановлению, но избавьте пользователя от технических деталей. +В идеальном варианте приложение способно самостоятельно исправить ситуацию.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_error.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="sprinkle-encouragement">Не скупитесь на поддержку пользователя</h4> +<p>Разбейте сложные задачи на более мелкие, легко выполнимые этапы. Обеспечьте обратную связь, +даже при незначительных операциях.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_sprinkle_encouragement.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="do-heavy-lifting-for-me">Выполняйте за пользователя черную работу</h4> +<p>Дайте новичкам возможность почувствовать себя экспертами, реализовав операции о которых они и не подозревали. Например, +ярлыки, объединяющие несколько фотоэффектов, позволят превратить любительские фотографии в шедевры всего за +несколько шагов.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_heavy_lifting.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-important-things-fast">Важные действия должны происходить быстро</h4> +<p>Не все действия равноценны. Решите, какие функции вашего приложения являются самыми важными, и обеспечьте возможность +быстро найти и использовать их. Например, это может быть кнопка спуска затвора в фотокамере или кнопка паузы в музыкальном плеере.</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_important_fast.png"> + + </div> +</div> diff --git a/docs/html-intl/intl/ru/design/material/index.jd b/docs/html-intl/intl/ru/design/material/index.jd new file mode 100644 index 0000000..2cfd91e --- /dev/null +++ b/docs/html-intl/intl/ru/design/material/index.jd @@ -0,0 +1,186 @@ +page.title=Material Design +page.tags=Material Design +page.type=design +page.image=design/material/images/MaterialLight.png + +@jd:body + +<!-- developer docs box --> +<a class="notice-developers right" href="{@docRoot}training/material/index.html"> + <div> + <h3>Документация для разработчиков</h3> + <p>Создание приложений с помощью Material Design</p> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=p4gmvHyuZzw"> +<div> + <h3>Видеоролик</h3> + <p>Введение в Material Design</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=YaG_ljfzeUw"> +<div> + <h3>Видеоролик</h3> + <p>Бумага и чернила: материалы, имеющие первостепенное значение</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=XOcCOBe8PTc"> +<div> + <h3>Видеоролик</h3> + <p>Material Design в приложениях для конференции Google I/O</p> +</div> +</a> + + + +<p itemprop="description">Material Design представляет собой комплексную концепцию создания визуальных, движущихся и + интерактивных элементов для различных платформ и устройств. Теперь Android включает в себя поддержку +приложений с элементами Material Design. Чтобы использовать элементы Material Design в своих приложениях под Android, руководствуйтесь инструкциями +в <a href="http://www.google.com/design/spec">спецификации Material Design</a>, а также воспользуйтесь +новыми компонентами и функциями, доступными в Android 5.0 (уровень API 21) и выше.</p> + +<p>Android предоставляет следующие элементы для построения приложений в соответствии с концепцией Material Design:</p> + +<ul> + <li>новую тему;</li> + <li>новые виджеты для сложных представлений;</li> + <li>новые API-интерфейсы для нестандартных теней и анимаций.</li> +</ul> + +<p>Дополнительные сведения о реализации Material Design в Android см. в разделе +<a href="{@docRoot}training/material/index.html">Создание приложений с помощью Material Design</a>.</p> + + +<h3>Тема Material Design</h3> + +<p>Тема Material Design предоставляет новый стиль для ваших приложений, системные виджеты, для которых можно настраивать +цветовую палитру, и анимации, выполняемые по умолчанию в качестве реакции на касание и при переходах между действиями.</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/MaterialDark.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">Тема Material Design в темных тонах</p> + </div> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/MaterialLight.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">Тема Material Design в светлых тонах</p> + </div> +</div> +<br style="clear:left"/> +</div> + +<p>Дополнительные сведения см. в разделе <a href="{@docRoot}training/material/theme.html">Использование темы +Material Design</a>.</p> + + +<h3>Списки и подсказки</h3> + +<p>Android предоставляет два новых виджета для отображения подсказок и списков с использованием стилей +и анимаций Material Design:</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/list_mail.png" width="500" height="426" /> + <p>Виджет <code>RecyclerView</code> Представляет собой более гибкую версию <code>ListView</code>, +которая поддерживает различные типы макетов и способствует повышению производительности.</p> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/card_travel.png" width="500" height="426" /> + <p>Виджет <code>CardView</code> позволяет отображать важные элементы информации внутри + подсказок, имеющие согласованный внешний вид и поведение.</p> +</div> +<br style="clear:left"/> +</div> + +<p>Дополнительные сведения см. в разделе <a href="{@docRoot}training/material/lists-cards.html">Создание списков +и подсказок</a>.</p> + + +<h3>Тени представлений</h3> + +<p>Теперь, помимо свойств X и Y, представления в Android имеют свойство +Z. Это новое свойство показывает, насколько представление "приподнято", иными словами, определяет</p> + +<ul> +<li>размер тени: чем больше Z, тем больше тени, отбрасываемые представлением;</li> +<li>порядок рисования: представления с более высокими значениями Z отображаются поверх других.</li> +</ul> + +<div style="width:290px;margin-left:35px;float:right"> + <div class="framed-nexus5-port-span-5"> + <video class="play-on-hover" autoplay> + <source src="{@docRoot}design/material/videos/ContactsAnim.mp4"/> + <source src="{@docRoot}design/videos/ContactsAnim.webm"/> + <source src="{@docRoot}design/videos/ContactsAnim.ogv"/> + </video> + </div> + <div style="font-size:10pt;margin-left:20px;margin-bottom:30px"> + <em>Для воспроизведения фильма нажмите на экран устройства</em> + </div> +</div> + +<p>Дополнительные сведения см. в разделе <a href="{@docRoot}training/material/shadows-clipping.html">Определение +теней и обрезка представлений</a>.</p> + + +<h3>Анимация</h3> + +<p>Новые API-интерфейсы анимации позволяют создавать нестандартную анимацию для реакции на касание в элементах пользовательского интерфейса, +изменения состояниия представления и переходов между действиями.</p> + +<p>Эти API-интерфейсы позволяют</p> + +<ul> +<li style="margin-bottom:15px"> +реагировать на касание в представлениях, используя анимацию для <strong>реакции на касание</strong>; +</li> +<li style="margin-bottom:15px"> +скрывать и отображать представление с помощью анимации для <strong>кругового появления</strong>; +</li> +<li style="margin-bottom:15px"> +переключаться меду действиями с помощью настраиваемой анимации для <strong>переходов между действиями</strong>; +</li> +<li style="margin-bottom:15px"> +создавать более естественное движение с помощью анимации для <strong>перемещения по кривой</strong>; +</li> +<li style="margin-bottom:15px"> +анимировать изменение одного или нескольких свойств представления с помощью анимации для <strong>изменения состояния представления</strong>; +</li> +<li style="margin-bottom:15px"> +отображать анимацию в <strong>графических элементах списков состояний</strong> в помежутке между изменением состояний представления. +</li> +</ul> + +<p>Анимация для реакции на касание встроена а некоторые стандартные представления, например, кнопки. Новые API-интерфейсы +позволяют разработчику настраивать эти анимации и добавлять их в свои нестандартные представления.</p> + +<p>Дополнительные сведения, см. в разделе <a href="{@docRoot}training/material/animations.html">Определение настраиваемой +анимации</a>.</p> + + +<h3>Графические объекты</h3> + +<p>Следующие возможности по работе с графическими объектами облегчают реализацию приложений с элементами Material Design:</p> + +<ul> +<li><strong>векторные объекты</strong> можно масштабировать без ущерба для четкости, и они отлично подходят +в качестве одноцветных значков приложения;</li> +<li><strong>тонирование графических объектов</strong> позволяет определять растровые изображения как альфа-маску и тонировать их +нужным цветом во время выполнения;</li> +<li><strong>извлечение цвета</strong> позволяет автоматически извлекать главные цвета из +растровых изображений.</li> +</ul> + +<p>Дополнительные сведения см. в разделе <a href="{@docRoot}training/material/drawables.html">Работа с +элементами дизайна</a>.</p> diff --git a/docs/html-intl/intl/ru/design/patterns/confirming-acknowledging.jd b/docs/html-intl/intl/ru/design/patterns/confirming-acknowledging.jd new file mode 100644 index 0000000..99a0d17 --- /dev/null +++ b/docs/html-intl/intl/ru/design/patterns/confirming-acknowledging.jd @@ -0,0 +1,70 @@ +page.title=Подтверждение и уведомление +page.tags=dialog,toast,notification +@jd:body + +<p>В некоторых ситуациях, когда пользователь выполняет действие в вашем приложении, полезно в текстовом виде <em>запросить подтверждение</em> этого действия или <em>отобразить уведомление</em> о его выполнении.</p> + +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_confirming.png"> + <p><strong>Подтверждение</strong> — это просьба к пользователю подтвердить, что он действительно хочет, чтобы запущенное действие было выполнено. Иногда подтверждение отображается вместе с предупреждением или важной информацией относительно действия, которую пользователь должен принять во внимание.</p> + </div> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_acknowledge.png"> + <p><strong>Уведомление</strong> отображает текст, позволяющий пользователю узнать о завершении действия. Это устраняет неопределенность в отношении неявных операций, которые выполняет система. В некоторых случаях уведомления отображаются вместе с возможностью отменить действие.</p> + </div> +</div> + +<p>Взаимодействие с пользователями такими способами позволяет снять неопределенность относительно событий, которые произошли или произойдут. Кроме того, подтверждение или уведомление позволяют удержать пользователя от ошибок, о которых он, возможно, будет сожалеть.</p> + +<h2>Ситуации, в которых следует запрашивать подтверждение и/или отображать уведомление</h2> +<p>Не все действия требуют подтверждения или уведомления. При принятии решений во время разработки приложений руководствуйтесь следующей блок-схемой.</p> +<img src="{@docRoot}design/media/confirm_ack_flowchart.png"> + +<h2>Подтверждение</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Пример: Google Play Books</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_books.png"> + <p>В этом примере пользователь пытается удалить книгу из своей библиотеки Play Google. Для подтверждения этого действия отображается <a href="{@docRoot}design/building-blocks/dialogs.html#alerts">оповещение</a>, поскольку пользователь должен понимать, что книга больше не будет доступна ни с одного устройства.</p> + <p>При разработке диалогового окна подтверждения следует создать осмысленный заголовок, отражающий запрошенное действие.</p> + </div> + <div class="layout-content-col span-7"> + <h4>Пример: Android Beam</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_beam.png"> + <p>Подтверждения не обязательно должны быть представлены в виде оповещения с двумя кнопками. После старта Android Beam пользователю предлагается прикоснуться к содержимому (в данном примере, к фотографии) для обмена данными. Если пользователь решит не продолжать, он просто ничего не предпримет.</p> + </div> +</div> + +<h2>Уведомление</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Пример: Сохранение оставленного черновика Gmail</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_draftsave.png"> + <p>В этом примере, если пользователь переходит назад или вверх от экрана составления писем Gmail (возможно, вследствие неожиданного события), текущий черновик автоматически сохраняется. Всплывающее уведомление обращает внимание пользователя на этот факт. Через несколько секунд оно исчезает.</p> + <p>Отмена здесь неуместна, поскольку сохранение было инициировано приложением, а не пользователем. Кроме того, пользователь сможет без труда вернуться к написанию сообщения, перейдя к списку черновиков.</p> + + </div> + <div class="layout-content-col span-6"> + <h4>Пример: Удаление переписки Gmail</h4> + <img src="{@docRoot}design/media/confirm_ack_draft_deleted.png"> + <p>После того, как пользователь удалит переписку из Gmail, появляется уведомление с возможностью отмены действия. Оно остается, пока пользователь не предпримет постороннее действие, например, прокрутит список писем.</p> + </div> +</div> + +<h2>Отсутствие подтверждения или уведомления</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>Пример: +1</h4> + <img style="padding: 33px 0 30px;" src="{@docRoot}design/media/confirm_ack_ex_plus1.png"> + <p><strong>Подтверждение не требуется</strong>. Если пользователь нажал +1 случайно, это не имеет большого значения. Он может просто нажать кнопку еще раз, чтобы отменить действие.</p> + <p><strong>Уведомление не требуется</strong>. Пользователь увидит, что кнопка +1 поменяла состояние и стала красной. Это достаточно ясный сигнал.</p> + </div> + <div class="layout-content-col span-7"> + <h4>Пример: Удаление приложения с главного экрана</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_removeapp.png"> + <p><strong>Подтверждение не требуется</strong>. Это преднамеренное действие: пользователь должен перетащить элемент на относительно крупную отдельно расположенную цель. Поэтому случайности здесь практически невероятны. К тому же, если пользователь пожалеет о своем решении, ему потребуется всего несколько секунд, чтобы вернуть приложение.</p> + <p><strong>Уведомление не требуется</strong>. Пользователь будет знать, что приложение удалено с главного экрана, потому что сам заставил его исчезнуть в результате перетаскивания.</p> + + </div> +</div> diff --git a/docs/html-intl/intl/ru/design/patterns/navigation.jd b/docs/html-intl/intl/ru/design/patterns/navigation.jd new file mode 100644 index 0000000..a65a8f6 --- /dev/null +++ b/docs/html-intl/intl/ru/design/patterns/navigation.jd @@ -0,0 +1,213 @@ +page.title=Навигация с помощью кнопок "Назад" и "Вверх" +page.tags="navigation","activity","task","up navigation","back navigation" +page.image=/design/media/navigation_between_siblings_gmail.png +@jd:body + +<a class="notice-developers" href="{@docRoot}training/implementing-navigation/index.html"> + <div> + <h3>Документация для разработчиков</h3> + <p>Обеспечение эффективной навигации</p> + </div> +</a> + +<p itemprop="description">Внутренне непротиворечивая навигация является важнейшей составляющей пользовательского интерфейса. Мало что так раздражает +пользователей, как несогласованное или непредсказуемое поведение элементов навигации. В Android 3.0 +глобальное поведение навигации претерпело значительные изменения. Тщательное следование +инструкциям по применению кнопок "Назад" и "Вверх" сделает навигацию в вашем приложении предсказуемой и надежной с точки зрения пользователей.</p> +<p>В Android 2.3 и в более ранних версиях для навигации внутри приложения использовалась системная кнопка <em>Назад</em>. + С появлением панели действий в Android 3.0 стал доступен второй механизм +навигации, — кнопка <em>Вверх</em>, содержащая значок приложения и левую угловую скобку.</p> + +<img src="{@docRoot}design/media/navigation_with_back_and_up.png"> + +<h2 id="up-vs-back">Кнопки "Вверх" и "Назад"</h2> + +<p>Кнопка "Вверх" используется для навигации внутри приложения по иерархической структуре его +экранов. Например, если на экране A отображается некоторый список, и при выборе какого-либо элемента открывается +экран B (с подробной информацией об этом элементе), то на экране B должна присутствовать кнопка "Вверх" + для возврата к экрану A.</p> +<p>Если экран является самым верхним в приложении (то есть главным), он не должен содержать кнопку +"Вверх".</p> + +<p>Системная кнопка "Назад" используется для навигации в обратном хронологическом порядке среди +экранов, недавно открытых пользователем. Такая навигация основана на порядке появления +экранов, а не на иерархии приложения.</p> + +<p>Если предыдущий экран одновременно является иерархическим родителем текущего, +кнопка "Назад" имеет то же действие, что и кнопка "Вверх"—, и это случается довольно +часто. Однако, в отличие от кнопки "Вверх", гарантирующей, что пользователь остается в приложении, кнопка "Назад" +может перевести его на главный экран или даже в другое приложение.</p> + +<img src="{@docRoot}design/media/navigation_up_vs_back_gmail.png"> + +<p>Кроме того, кнопка "Назад" проявляет поведение, не связанное напрямую с навигацией между экранами. Она +</p> +<ul> +<li>закрывает перемещаемые окна (диалоговые, всплывающие);</li> +<li>закрывает контекстные панели действий и снимает выделение с выделенных элементов;</li> +<li>скрывает экранную клавиатуру (IME).</li> +</ul> +<h2 id="within-app">Навигация внутри приложения</h2> + +<h4>Переход на экраны с несколькими точками входа</h4> +<p>Некоторые экраны не имеют строгой позиции в иерархии приложения, и на них можно перейти +из нескольких точек. Например, на экран настроек можно попасть из любого другого экрана +приложения. В таком случае кнопка "Вверх" должна осуществлять возврат на вызвавший экран, т. е. вести себя +идентично кнопке "Назад".</p> +<h4>Изменение представления содержимого на экране</h4> +<p>Изменение параметров представления содержимого на экране не сказывается на поведении кнопок "Вверх" и "Назад", — экран остается +на прежнем месте в иерархии приложения, а история навигации не меняется.</p> +<p>Примерами изменения представления являются</p> +<ul> +<li>переключение представлений с помощью вкладок или жестов прокрутки вправо/влево;</li> +<li>переключение представлений с помощью раскрывающихся (или свернутых) вкладок;</li> +<li>фильтрация списка;</li> +<li>сортировка списка;</li> +<li>изменение характеристик отображения (например, масштаба).</li> +</ul> +<h4>Навигация между экранами одного уровня</h4> +<p>Когда приложение поддерживает навигацию от списка к подробному представлению одного из его элементов, нередко +имеет смысл поддержать навигацию от этого элемента к другому, идущему в списке до или +после него. Например, в Gmail можно провести пальцем влево или вправо по переписке, +чтобы просмотреть предыдущие или последующие входящие сообщения. Как и в случае изменения представления на экране, такая +навигация не меняет поведение кнопок "Вверх" и "Назад".</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_gmail.png"> + +<p>Однако существует важное исключение из этого правила во время просмотра подробных представлений элементов, не связанных +вместе ссылающимся списком, например—, приложений +одного разработчика или альбомов одного исполнителя в Play Store. В этих случаях переход по каждой ссылке создает +историю навигации, что заставляет кнопку "Назад" перебирать все ранее просмотренные экраны. Кнопка "Вверх" должна по-прежнему +игнорировать эти связанные по смыслу экраны и осуществлять переход на последний просмотренный контейнерный экран.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market1.png"> + +<p>Разработчик может сделать поведение кнопки "Вверх" еще более интеллектуальным, исходя из своих знаний о структуре подробного +представления. Вернемся к примеру с просмотром Play Store. Представьте, что пользователь перешел от информации о +книге к информации о ее экранизации. Тогда кнопка "Вверх" могла бы переводить пользователя в контейнер +(Фильмы), в котором он еще не был.</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market2.png"> + +<h2 id="into-your-app">Навигация внутрь приложения с помощью уведомлений и виджетов главного экрана</h2> + +<p>У разработчика также есть возможность использовать уведомления или виджеты главного экрана, чтобы помочь пользователю переходить к экранам, +расположенным глубоко в иерархической структуре приложения. Например, виджет Inbox приложения Gmail и уведомление о новом сообщении могут + перевести пользователя непосредственно к переписке, в обход экрана с входящими сообщениями.</p> + +<p>В обоих этих случаях реализуйте следующее поведение кнопки "Вверх":</p> + +<ul> +<li><em>Если целевой экран, как правило, достигается из одного конкретного экрана +приложения</em>, кнопка "Вверх" должна осуществлять переход на этот экран.</li> +<li><em>В противном случае</em> кнопка "Вверх" должна осуществлять переход на самый верхний (главный) экран приложения.</li> +</ul> + +<p>Что касается кнопки "Назад", необходимо обеспечить более предсказуемую навигацию, вставив в +в стек переходов назад полный путь навигации вверх к самому верхнему экрану приложения. Это позволит пользователям, +забывшим, как они вошли в приложение, перейти к его главному экрану перед выходом из +приложения.</p> + +<p>Например, виджет главного экрана Gmail имеет кнопку, переводящую пользователя прямо на экран +создания сообщений. Кнопки "Вверх" или "Назад" переведут пользователя с этого экрана на экран входящих писем, а оттуда +кнопка "Назад" переведет его на главную страницу.</p> + +<img src="{@docRoot}design/media/navigation_from_outside_back.png"> + +<h4>Косвенные уведомления</h4> + +<p>Когда приложению нужно вывести информацию сразу о нескольких событиях, оно может выдать +одно уведомление, направляющее пользователя на промежуточный экран. Этот экран содержит сводку +событий и предоставляет пользователю возможность перейти вглубь приложения. Такие уведомления +называются <em>косвенными</em>.</p> + +<p>Кнопка "Назад" действует не так, как в случае со стандартными (прямыми) уведомлениями. Нажав ее на промежуточном экране косвенного уведомления, +пользователь вернется в точку, где было сгенерировано уведомление, —поскольку +в стеке переходов назад не появились никакие дополнительные экраны. Если пользователь перейдет в приложение с +промежуточного экрана, поведение кнопок "Вверх" и "Назад" будет таким же, как и при стандартных уведомлениях: +навигация внутри приложения, а не возврат к промежуточному экрану.</p> + +<p>Например, предположим, что пользователь получил косвенное уведомление от приложения Calendar при открытом приложении Gmail. Если он коснется +этого уведомления, откроется промежуточный экран с напоминаниями о нескольких +событиях. Касание кнопки "Назад" на промежуточном экране возвратит пользователя в Gmail. Если пользователь коснется конкретного +события, он перейдет с промежуточного экрана в приложение Calendar к подробной информации о +событии. Оттуда кнопки "Вверх" и "Назад" переведут его на верхний уровень приложения Calendar.</p> + +<img src="{@docRoot}design/media/navigation_indirect_notification.png"> + +<h4>Всплывающие уведомления</h4> + +<p><em>Всплывающие уведомления</em> появляются непосредственно перед пользователем, +в обход панели уведомлений. Они используются редко и <strong>должны быть зарезервированы для ситуаций, в которых требуется немедленная +реакция пользователя, и прерывание его действий оправдано</strong>. Например, +приложение Talk с помощью таких уведомлений извещает пользователя о поступившем от друга приглашении присоединиться к видеочату, поскольку срок действия этого +приглашения истекает через несколько секунд.</p> + +<p>В отношении навигации всплывающие уведомления ведут себя во многом аналогично промежуточному экрану +косвенного уведомления. Кнопка "Назад" удаляет всплывающее уведомление. Если пользователь переходит +от всплывающего уведомления к уведомляющему приложению, кнопки "Вверх" и "Назад" действуют, как при стандартных уведомлениях, +выполняя навигацию внутри приложения.</p> + +<img src="{@docRoot}design/media/navigation_popup_notification.png"> + +<h2 id="between-apps">Навигация между приложениями</h2> + +<p>Одним из фундаментальных достоинств системы Android является способность приложений активировать друг +друга, что дает пользователю возможность переходить непосредственно из одного приложения в другое. Например, +приложение, которому нужно сделать снимок, может активировать приложение Camera, которое передаст фотографию +вызвавшему приложению. Это огромное преимущество, как для разработчика, имеющего возможность без проблем воспользоваться +кодом других приложений, так и для пользователя, получающего согласованный интерфейс для часто выполняемых +действий.</p> + +<p>Чтобы разобраться в навигации между приложениями, необходимо разобраться в поведении платформы Android, +которое обсуждается ниже.</p> + +<h4>Действия, задачи и намерения</h4> + +<p><strong>Действие</strong> в Android — это компонент приложения, определяющий экран с +информацией и все действия, которые при этом может выполнить пользователь. Приложение представляет собой набор +действий, состоящий как из действий, созданных разработчиком, так и из тех, которые выполняются с помощью других приложений.</p> + +<p><strong>Задача</strong> — последовательность действий, выполняемых пользователем для достижения цели. Отдельная +задача может использовать действия, заимствованные у одного или у нескольких +различных приложений.</p> + +<p><strong>Намерение</strong> — механизм, позволяющий приложению сигнализировать, что ему требуется помощь +другого приложения в выполнении некоторого действия. Действия, выполняемые приложением, могут указывать, на какие намерения +они готовы отвечать. Для осуществления достаточно распространенных намерений, например, "Поделиться", у пользователя может быть установлено несколько приложений, + способных выполнить соответствующий запрос.</p> + +<h4>Пример: навигация между приложениями для поддержки совместного использования ресурсов</h4> + +<p>Чтобы понять, как действия, задачи и намерения взаимодействуют друг с другом, разберемся, как одно приложение позволяет пользователям +поделиться содержимым с помощью другого приложения. Например, запуск приложения Play Store из главного экрана создает +новую задачу, Task A (см. рисунок ниже). Когда пользователь выполнит навигацию по Play Store и коснется интересующей его книги, +чтобы просмотреть информацию о ней, он останется в том же приложении, расширив его возможности с помощью добавленных действий. Запуск +действия "Поделиться" выводит перед пользователем диалоговое окно со списком действий (из разных приложений), +зарегистрированных для выполнения намерения "Поделиться".</p> + +<img src="{@docRoot}design/media/navigation_between_apps_inward.png"> + +<p>Если пользователь предпочтет поделиться информацией через Gmail, действие "Написать" приложения Gmail добавляется как продолжение задачи +Task A—, и никакая новая задача не создается. Если в фоновом режиме работает собственная задача Gmail, на нее это никак +не повлияет.</p> + +<p>Если во время действия "Составление сообщения" пользователь отправит сообщение или коснется кнопки "Назад", он вернется к + действию "Просмотр информации о книге". Продолжая нажимать на "Назад", пользователь будет совершать переходы назад в Play +Store, пока, наконец, не вернется на главный экран.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_back.png"> + +<p>Однако, коснувшись кнопки "Вверх" во время действия "Составление сообщения", пользователь выскажет пожелание остаться в приложении +Gmail. Откроется экран действия "Переписка" приложения Gmail, и для него будет создано новая задача Task B. Новые задачи +всегда имеют корень на главном экране, поэтому касание кнопки "Назад" на экране переписки возвращает пользователя именно туда.</p> + +<img src="{@docRoot}design/media/navigation_between_apps_up.png"> + +<p>Задача Task A остается в фоновом режиме, и пользователь может вернуться к ней впоследствии (например, с помощью +экрана с последними приложениями). Если в фоновом режиме уже работает собственная задача Gmail, она будет замещена +задачей Task B. Произойдет отказ от предыдущего контекста ради новой цели пользователя.</p> + +<p>Если для обработки намерений ваше приложение зарегистрирует действие, расположенное в глубине своей иерархии, +следуйте инструкциям по реализации навигации с помощью кнопки "Вверх", изложенным в разделе <a href="#into-your-app">Навигация внутрь приложения с помощью виджетов и +уведомлений главного экрана</a>.</p> diff --git a/docs/html-intl/intl/ru/design/patterns/notifications.jd b/docs/html-intl/intl/ru/design/patterns/notifications.jd new file mode 100644 index 0000000..db46ad5 --- /dev/null +++ b/docs/html-intl/intl/ru/design/patterns/notifications.jd @@ -0,0 +1,872 @@ +page.title=Уведомления +page.tags="notifications","design","L" +@jd:body + + <a class="notice-developers" href="{@docRoot}training/notify-user/index.html"> + <div> + <h3>Документация для разработчиков</h3> + <p>Уведомление пользователя</p> + </div> +</a> + +<a class="notice-designers" href="notifications_k.html"> + <div> + <h3>Уведомления в Android версии 4.4 и ниже</h3> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=Uiq2kZ2JHVY"> +<div> + <h3>Видеоролик</h3> + <p>DevBytes: Уведомления в Android L Developer Preview</p> +</div> +</a> + +<style> + .col-5, .col-6, .col-7 { + margin-left:0px; + } +</style> + +<p>Уведомления позволяют извещать пользователя о релевантных и +периодически возникающих +событиях в приложении, таких как новые сообщения в чате или события в календаре. +Систему уведомлений можно рассматривать как канал новостей, извещающий пользователя о важных +событиях по мере +их возникновения, или как журнал, ведущий хронику событий, пока пользователь не обращает на них +внимания, и синхронизируемый должным образом на всех устройствах Android этого пользователя.</p> + +<h4 id="New"><strong>Новые возможности Android 5.0</strong></h4> + +<p>В Android 5.0 уведомления были существенно обновлены структурно, +визуально, и функционально:</p> + +<ul> + <li>был изменен внешний вид уведомлений в соответствии с новой +темой Material Design;</li> + <li> теперь уведомления доступны на экране блокировки, в то время как +конфиденциальная информация по-прежнему + может быть скрыта;</li> + <li>уведомления с высоким приоритетом, полученные при включенном устройстве, теперь имеют новый формат и называются + уведомлениями Heads-up;</li> + <li>уведомления синхронизируются с облаком: если удалить уведомление на одном из устройств +Android, оно будет удалено + и на остальных устройствах.</li> +</ul> + +<p class="note"><strong>Примечание.</strong> Разработка уведомлений в этой версии +Android значительно +отличается от их разработки в предыдущих версиях. Информацию о разработке уведомлений в предыдущих +версиях можно найти в разделе <a href="./notifications_k.html">Уведомления в Android версии 4.4 и ниже</a>.</p> + +<h2 id="Anatomy">Структура уведомления</h2> + +<p>В этом разделе описываются основные компоненты уведомления и их +отображение на устройствах различных типов.</p> + +<h3 id="BaseLayout">Базовая компоновка</h3> + +<p>Все уведомления имеют, как минимум, базовую компоновку, которую составляют следующие элементы.</p> + +<ul> + <li> <strong>Значок</strong> уведомления. Значок символизирует +инициирующее приложение. Он также может + указывать на тип уведомления, если приложение генерирует уведомления нескольких +типов.</li> + <li> <strong>Заголовок</strong> уведомления и дополнительный +<strong>текст</strong>.</li> + <li> <strong>Временная метка</strong>.</li> +</ul> + +<p>Уведомления, созданные с помощью {@link android.app.Notification.Builder Notification.Builder} +для предыдущих версий платформы, выглядят и функционируют в Android +5.0 так же, как и прежде, за исключением незначительных стилистических отличий, вносимых +системой. Дополнительную информацию о внешнем виде и функциональности уведомлений в предыдущих версиях +Android можно найти в разделе +<a href="./notifications_k.html">Уведомления в Android версии 4.4 и ниже</a>.</p></p> + + + <img style="margin:20px 0 0 0" src="{@docRoot}images/android-5.0/notifications/basic_combo.png" alt="" width="700px" /> + + +<div style="clear:both;margin-top:20px"> + <p class="img-caption"> + Уведомление в базовой компоновке на мобильном устройстве (слева) и то же уведомление на носимом устройстве (справа) + с фотографией пользователя и значком уведомления + </p> + </div> + +<h3 id="ExpandedLayouts">Расширенная компоновка</h3> + + +<p>Разработчик может выбрать степень подробности уведомлений, генерируемых его +приложением. Уведомление может содержать первые +несколько строк сообщения или миниатюру изображения. В качестве дополнительной +информации можно предоставлять пользователю +контекст и, —в некоторых случаях, —давать ему возможность прочитать сообщение +целиком. Чтобы переключаться + между компактной и расширенной компоновкой, пользователь может применить жест сжатия/масштабирования или +провести пальцем по экрану. + Для уведомлений о единичных событиях Android предоставляет + разработчику приложения три шаблона расширенной компоновки +(текст, входящая почта и изображения). Ниже приведены скриншоты уведомлений о единичных +событиях на мобильных устройствах (слева) + и на носимых устройствах (справа).</p> + +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/expandedtext_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/stack_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/ExpandedImage.png" + alt="" width="311px" height;="450px" /> + +<h3 id="actions" style="clear:both; margin-top:40px">Действия</h3> + +<p>Android поддерживает дополнительные действия, отображаемые в нижней части +уведомления. +Благодаря этому пользователи могут выполнять операции, типичные для данного +уведомления, непосредственно из него, не открывая +само приложение. +Это ускоряет взаимодействие и, вместе с операцией "провести пальцем, чтобы удалить", позволяет пользователю сосредоточиться на +важных для него уведомлениях.</p> + + + <img src="{@docRoot}images/android-5.0/notifications/action_combo.png" alt="" width="700px" /> + + + +<p style="clear:both">При определении количества действий в уведомлении следует проявлять +благоразумие. Чем больше +действий предоставлено пользователю, тем выше когнитивная сложность приложения. Ограничьтесь +минимальным количеством +действий, предоставив пользователю наиболее важные и +значимые.</p> + +<p>В уведомлениях отдавайте предпочтение действиям</p> + +<ul> + <li> важным, выполняемым наиболее часто и типичным для отображаемого +содержимого; + <li> позволяющим пользователю быстрее решить задачу. +</ul> + +<p>Избегайте действий</p> + +<ul> + <li> неоднозначных; + <li> совпадающих с действиями, выполняемыми для данного уведомления по умолчанию (например, "Прочитать" или +"Открыть"). +</ul> + + + +<p>Следует предоставлять не более трех действий, указав для каждого +значок и название. + Добавление действий в базовую компоновку делает уведомление расширяемым, +даже если + оно не имеет расширенной компоновки. Поскольку действия отображаются только у +расширенных + уведомлений, необходимо, чтобы любое действие, +которое пользователь может выполнить из + уведомления, было доступно и в соответствующем +приложении.</p> + +<h2 style="clear:left">Уведомления heads-up</h2> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/hun-example.png" alt="" width="311px" /> + <p class="img-caption"> + Пример уведомления heads-up (входящий телефонный звонок, высокий приоритет), +появляющегося поверх + приложения с эффектом присутствия + </p> +</div> + +<p>Когда поступает уведомление с высоким приоритетом (см. изображение справа), оно в течение короткого времени +отображается +в расширенной компоновке, позволяя выполнить допустимые действия.</p> +<p> Затем уведомление принимает обычный +вид. Если для уведомления установлен высокий, максимальный или полноэкранный <a href="#correctly_set_and_manage_notification_priority">приоритет</a> +, оно становится уведомлением heads-up.</p> + +<p><b>Хорошими примерами событий для уведомлений heads-up являются</b></p> + +<ul> + <li> входящий телефонный звонок, во время использования устройства;</li> + <li> сигнал будильника во время использования устройства;</li> + <li> новое SMS-сообщение;</li> + <li> низкий уровень заряда аккумулятора.</li> +</ul> + +<h2 style="clear:both" id="guidelines">Основные рекомендации</h2> + + +<h3 id="MakeItPersonal">Персонализируете уведомление</h3> + +<p>Уведомление о событии, инициированном другим пользователем (например, сообщение или +обновление статуса), должно содержать изображение пользователя, добавленное с помощью +{@link android.app.Notification.Builder#setLargeIcon setLargeIcon()}. Кроме того, в метаданные уведомления необходимо включить информацию о +пользователе (см. {@link android.app.Notification#EXTRA_PEOPLE}).</p> + +<p>Главный значок уведомления будет по-прежнему отображаться, чтобы пользователь мог связать +его со значком +на строке состояния.</p> + + +<img src="{@docRoot}images/android-5.0/notifications/Triggered.png" alt="" width="311px" /> +<p style="margin-top:10px" class="img-caption"> + Уведомление, идентифицирующее пользователя-инициатора, и отображающее отправленное содержимое. +</p> + + +<h3 id="navigate_to_the_right_place">Выполняйте переход в нужное место</h3> + +<p>Когда пользователь касается тела уведомления (за пределами кнопок +с действиями), должен осуществляться переход в то место приложения, +где пользователь сможет просмотреть информацию, о которой извещает уведомление, и действовать в соответствии +с нею. В большинстве случаев там будет находиться подробное представление одного элемента данных, например, сообщения, +но возможно и +сокращенное представление, если накопилось несколько уведомлений. Если приложение переводит +пользователя на какой-либо уровень, отличный от верхнего, реализуйте навигацию в стеке переходов назад в приложении, чтобы +пользователь мог нажать системную кнопку "Назад" и вернуться на верхний уровень. Дополнительную информацию можно найти в разделе +<em>Навигация внутрь приложения с помощью виджетов и уведомлений главного экрана</em> в шаблоне проектирования +<a href="{@docRoot}design/patterns/navigation.html#into-your-app">Навигация</a>.</p> + +<h3 id="correctly_set_and_manage_notification_priority">Правильно выполняйте расстановку приоритетов уведомлений и +управление ими +</h3> + +<p>Android поддерживает флаг приоритета для уведомлений. Это флаг позволяет +влиять на позицию уведомления среди других уведомлений и +гарантировать, +что пользователь в первую очередь увидит самые важные уведомления. При отправке уведомления можно выбрать один +из +следующих уровней приоритета:</p> +<table> + <tr> + <td class="tab0"> +<p><strong>Приоритет</strong></p> +</td> + <td class="tab0"> +<p><strong>Использование</strong></p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MAX</code></p> +</td> + <td class="tab1"> +<p>Применяйте для наиболее важных и неотложных уведомлений, извещающих пользователя +о ситуации, +критичной по времени или такой, на которую необходимо отреагировать, чтобы продолжить +выполнение задачи.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>HIGH</code></p> +</td> + <td class="tab1"> +<p>Применяйте, в основном, для передачи важной информации, например, о сообщениях или событиях +в чате с содержимым, представляющим особый интерес для пользователя. +Уведомления с высоким приоритетом отображаются как уведомления heads-up.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>DEFAULT</code></p> +</td> + <td class="tab1"> +<p>Применяйте для всех уведомлений, не входящих ни в одну из описанных здесь категорий.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>LOW</code></p> +</td> + <td class="tab1"> +<p>Применяйте для уведомлений, которые должны быть переданы пользователю, но +не являются неотложными. Низкоприоритетные уведомления обычно появляются в конце списка, +что позволяет использовать их +для передачи информации, представляющей всеобщий интерес и не имеющей конкретной направленности. Например, если пользователь подписался +на новости, + эта информация не должна иметь преимущество перед неотложными или адресными +сообщениями.</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MIN</code></p> +</td> + <td class="tab1"> +<p>Применяйте для уведомлений, с контекстной или фоновой информацией, такой как прогноз погоды, или с информацией, +связанной с местоположением пользователя. +Уведомления с минимальным приоритетом не отображаются в строке состояния. Пользователь +обнаруживает их при раскрытии панели уведомления.</p> +</td> + </tr> +</table> + + +<h4 id="how_to_choose_an_appropriate_priority"><strong>Как выбрать +подходящий +приоритет</strong></h4> + +<p>При выдаче уведомлений с приоритетами <code>DEFAULT</code>, <code>HIGH</code> и <code>MAX</code> существует риск, что деятельность +пользователя будет прервана +в самом разгаре. Чтобы не раздражать пользователей вашего приложения, применяйте приоритеты этих уровней для +уведомлений,</p> + +<ul> + <li> имеющих отношение к другим пользователям;</li> + <li> быстро теряющих актуальность;</li> + <li> способных немедленно повлиять на поведение пользователя в реальном мире.</li> +</ul> + +<p>Уведомления с приоритетом <code>LOW</code> и <code>MIN</code> могут представлять определенную ценность +для пользователя. Значительное количество, если не большинство, уведомлений не требует немедленной +реакции пользователя, но, тем не менее, содержит информацию, которую пользователь сочтет +ценной, когда решит +просмотреть поступившие уведомления. Приоритеты уровней <code>LOW</code> и <code>MIN</code> + следует присваивать уведомлениям,</p> + +<ul> + <li> не имеющим прямого отношения к другим пользователям;</li> + <li> долго не теряющим актуальность;</li> + <li> содержащим информацию, способную заинтересовать пользователя, если он решит +просмотреть их в свободное время.</li> +</ul> + + + <img src="{@docRoot}images/android-5.0/notifications/notifications_pattern_priority.png" alt="" width="700" /> + + +<h3 style="clear:both" id="set_a_notification_category">Определите категорию +уведомления</h3> + +<p>Если уведомление попадает в одну из заранее определенных категорий (см. +ниже), укажите его +категорию. Процессы системного пользовательского интерфейса, например, панель уведомления (или любой +другой процесс-слушатель +уведомлений) могут воспользоваться этой информацией при классификации и фильтрации уведомлений.</p> +<table> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_CALL">CATEGORY_CALL</a></code></p> +</td> + <td> +<p>Входящий звонок (голосовой или по видеосвязи) или алогичный запрос синхронной +связи</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_MESSAGE">CATEGORY_MESSAGE</a></code></p> +</td> + <td> +<p>Входящее личное сообщение (SMS-сообщение, мгновенное сообщение и т. д.)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EMAIL">CATEGORY_EMAIL</a></code></p> +</td> + <td> +<p>Асинхронное массовое сообщение (по электронной почте)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EVENT">CATEGORY_EVENT</a></code></p> +</td> + <td> +<p>Событие в календаре</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROMO">CATEGORY_PROMO</a></code></p> +</td> + <td> +<p>Промоакция или реклама</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ALARM">CATEGORY_ALARM</a></code></p> +</td> + <td> +<p>Сигнал будильника или таймера</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROGRESS">CATEGORY_PROGRESS</a></code></p> +</td> + <td> +<p>Информация о ходе выполнения длительной фоновой операции</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SOCIAL">CATEGORY_SOCIAL</a></code></p> +</td> + <td> +<p>Новости, поступившие из социальной сети или касающиеся совместного использования ресурсов</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ERROR">CATEGORY_ERROR</a></code></p> +</td> + <td> +<p>Ошибка в фоновой операции или статусе аутентификации</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_TRANSPORT">CATEGORY_TRANSPORT</a></code></p> +</td> + <td> +<p>Управление передачей медиаданных для воспроизведения</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SYSTEM">CATEGORY_SYSTEM</a></code></p> +</td> + <td> +<p>Обновление статуса системы или устройства. Зарезервировано для использования системой.</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SERVICE">CATEGORY_SERVICE</a></code></p> +</td> + <td> +<p>Индикация работающей фоновой службы</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_RECOMMENDATION">CATEGORY_RECOMMENDATION</a></code></p> +</td> + <td> +<p>Конкретная и привязанная ко времени рекомендация относительно одного объекта. Например, приложение +новостей может +порекомендовать пользователю, какую новость читать следующей.</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_STATUS">CATEGORY_STATUS</a></code></p> +</td> + <td> +<p>Текущая информация о статусе устройства или контекста</p> +</td> + </tr> +</table> + +<h3 id="summarize_your_notifications">Суммируйте уведомления</h3> + +<p>Если при наличии ожидающего уведомления определенного типа приложение пытается отправить новое +уведомление того же типа, объедините их в одно сводное уведомление от этого приложения. Не +создавайте новый объект.</p> + +<p>Сводное уведомление формирует сводное описание и дает пользователю возможность +понять, сколько +имеется ожидающих уведомлений того или иного типа.</p> + +<div class="col-6"> + +<p><strong>Неправильно</strong></p> + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Dont.png" alt="" width="311px" /> +</div> + +<div> +<p><strong>Правильно</strong></p> + + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Do.png" alt="" width="311px" /> +</div> + +<p style="clear:left; padding-top:30px; padding-bottom:20px">Разработчик может сообщить +подробности об отдельных уведомлениях, образующих + сводное, используя расширенную компоновку для резюме. Такой подход позволит пользователям +лучше разобраться, какие +уведомления ожидают прочтения, и достаточно ли они интересны, чтобы ознакомиться с ними +более подробно в + соответствующем приложении.</p> +<div class="col-6"> + <img src="{@docRoot}images/android-5.0/notifications/Stack.png" style="margin-bottom:20px" alt="" width="311px" /> + <p class="img-caption"> + Расширенное и сжатое сводное уведомление (с использованием <code>InboxStyle</code>) + </p> +</div> + +<h3 style="clear:both" id="make_notifications_optional">Сделайте уведомления +необязательными</h3> + +<p>В распоряжении пользователей всегда должен быть метод управления уведомлениями. Предоставьте пользователю возможность +отключать уведомления, поступающие от вашего приложения, +или изменять способы оповещения, такие как звуковой сигнал и +вибрация. + С этой целью следует предусмотреть пункт настройки уведомлений в настройках приложения.</p> + +<h3 id="use_distinct_icons">Используйте отчетливые значки</h3> +<p>Беглого взгляда на область уведомлений должно быть достаточно, чтобы распознать +типы +ожидающих уведомлений.</p> + +<div class="figure"> + <img src="{@docRoot}images/android-5.0/notifications/ProductIcons.png" alt="" width="420" /> +</div> + + <div><p><strong>Правильно</strong></p> + <p>Рассмотрите уже существующие значки уведомлений от приложений Android и создайте +собственные, + достаточно уникальные.</p> + + <p><strong>Правильно</strong></p> + <p>Придерживайтесь подходящего <a href="/design/style/iconography.html#notification">стиля значков уведомления</a> + для мелких значков, и + <a href="/design/style/iconography.html#action-bar">стиля строки +действий</a> Material Light для значков + действий.</p> +<p ><strong>Правильно</strong></p> +<p >Стремитесь к визуальной простоте значков, избегайте излишних трудноразличимых +деталей.</p> + + <div><p><strong>Неправильно</strong></p> + <p>Применяйте к мелким значкам и значкам действий дополнительные альфа-эффекты +(постепенное появление/исчезание). + К их краям может быть применено сглаживание, но, поскольку в Android эти значки +служат масками (то есть, + используется только альфа-канал), изображение, как правило, должно отображаться полностью +непрозрачным.</p> + +</div> +<p style="clear:both"><strong>Неправильно</strong></p> + +<p>Чтобы ваше приложение отличалось от других, используйте цвет. Значки уведомлений должны +представлять собой изображение белого цвета на прозрачном фоне.</p> + + +<h3 id="pulse_the_notification_led_appropriately">Правильно используйте индикатор +уведомлений</h3> + +<p>На многих устройствах Android имеется светодиодный индикатор уведомлений, +информирующий пользователя о +событиях, когда экран выключен. Уведомления с приоритетом <code>MAX</code>, +<code>HIGH</code> или <code>DEFAULT</code> должны +вызывать свечение индикатора, а уведомления с низким приоритетом (<code>LOW</code> и +<code>MIN</code>) не должны.</p> + +<p>Возможности пользователя управлять уведомлениями должны распространяться на светодиодный индикатор. Когда разработчик использует +DEFAULT_LIGHTS, +индикатор светится белым цветом. Ваши уведомления не должны вызывать свечение другим +цветом, если +пользователь не указал этого явным образом.</p> + +<h2 id="building_notifications_that_users_care_about">Создание уведомлений, + важных для пользователя</h2> + +<p>Чтобы пользователям понравилось ваше приложение, необходимо тщательно +продумать его уведомления. +Уведомления — это голос приложения. Они определяют его +индивидуальность. Ненужные или +несущественные уведомления раздражают пользователя и заставляют его возмущаться тем, как много +внимания требует от него +приложение. Поэтому необходимо применять уведомления взвешенно.</p> + +<h3 id="when_to_display_a_notification">Ситуации, в которых следует показывать уведомления</h3> + +<p>Чтобы создать приложение, от работы с которым пользователи получат удовольствие, необходимо +осознать, что внимание пользователя + является ресурсом, требующим бережного обращения. Система уведомлений +Android была разработана +так, чтобы как можно меньше отвлекать пользователя. +Однако +вы должны отдавать себе отчет в том, что уведомления прерывают +деятельность пользователя. +Планируя уведомления, спрашивайте себя, достаточно ли они важны, чтобы +послужить основанием для такого прерывания. В случае сомнений предоставьте пользователю возможность запросить +в настройках приложения получение уведомления или измените +приоритет уведомления на <code>LOW</code> или <code>MIN</code>, чтобы +не отвлекать пользователя от +текущих занятий.</p> + + <img src="{@docRoot}images/android-5.0/notifications/TimeSensitive.png" alt="" width="311px" /> + <p style="margin-top:10px" class="img-caption"> + Примеры уведомлений, быстро теряющих актуальность + </p> + +<p>Хотя правильно работающие приложения ведут себя неназойливо, бывают ситуации, +заслуживающие того, чтобы приложение по своей инициативе прервало деятельность пользователя уведомлением.</p> + +<p>Отправляйте уведомления только в случае <strong>событий, требующих неотложной реакции</strong>, особенно + если эти синхронные события <strong>имеют прямое отношение к другим пользователям</strong>. Например, +чат + представляет собой форму синхронного общения в реальном времени, — другой пользователь +с нетерпением ожидает вашего ответа. События в календаре являются еще одним хорошим примером ситуации, в которой следует выдать +уведомление и завладеть + вниманием пользователя, потому что в приближающееся календарное событие часто +вовлечены другие люди.</p> + +<h3 style="clear:both" id="when_not_to_display_a_notification">Ситуации, +в которых не следует показывать уведомления</h3> + +<div class="figure" style="margin-top:60px"> + <img src="{@docRoot}images/android-5.0/notifications/AntiSample1.png" alt="" width="311px" /> +</div> + +<p>В большинстве остальных случаев уведомления неуместны.</p> + +<ul> + <li> Не следует извещать пользователя о событиях, не имеющих отношения +к нему конкретно, или + не теряющих актуальность со временем. Например, асинхронные +и безадресные новости, + циркулирующие в социальных сетях, как правило, не требуют немедленного +привлечения внимания. Пользователям, + действительно интересующимся таким новостями, предоставьте возможность запросить соответствующие уведомления.</li> + <li> Не генерируйте уведомление, если релевантная свежая информация уже находится +на экране. Вместо этого + воспользуйтесь интерфейсом самого приложения, чтобы донести до пользователя новую информацию +непосредственно в контексте. + Например, приложение-чат не должно генерировать системные уведомления, +пока пользователь активно общается с собеседником.</li> + <li> Не отвлекайте пользователя ради низкоуровневых технических действий, такие как сохранение +или синхронизация информации или обновление приложения, если приложение или система способны выполнить задачу +без вмешательства пользователя.</li> + <li> Не отвлекайте пользователя, чтобы проинформировать его об ошибке, если +приложение может восстановиться после нее самостоятельно, не требуя от пользователя +никаких действий.</li> + <li> Не создавайте уведомления, не имеющие осмысленного содержимого и +всего лишь рекламирующие ваше +приложение. Уведомление должно нести полезную, актуальную и новую информацию. Не следует +использовать его + исключительно для презентации приложения.</li> + <li> Не создавайте избыточные уведомления только для того, чтобы продемонстрировать свой бренд +пользователям. + Такие уведомления раздражают и отталкивают аудиторию. Лучший +способ сообщать + новую информацию небольшими порциями и поддерживать связь пользователей +с вашим + приложением заключается в том, чтобы разработать виджет, который они смогут поместить на + главный экран.</li> +</ul> + +<h2 style="clear:left" id="interacting_with_notifications">Взаимодействие с +уведомлениями</h2> + +<p>Уведомления обозначаются значками в строке состояния. Чтобы получить к ним доступ, +следует открыть +панель уведомлений.</p> + +<p>Если коснуться уведомления, откроется соответствующее приложение с подробным содержимым, +связанным с эти уведомлением. +Если провести пальцем по уведомлению влево или вправо, оно будет удалено из панели.</p> + +<h3 id="ongoing_notifications">Постоянные уведомления</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/MusicPlayback.png" alt="" width="311px" /> + <p class="img-caption"> + Постоянные уведомления при воспроизведении музыки + </p> +</div> +<p>Постоянные уведомления информируют пользователя о текущих фоновых +процессах. +Например, плееры сообщают через систему уведомлений информацию о дорожке, +воспроизводимой в данный момент, и +это продолжается, пока пользователь не остановит воспроизведение. Кроме того, постоянные уведомления могут +информировать пользователя +о ходе выполнения длительных задач, таких как загрузка файла или кодирование видеоданных. Пользователь не может вручную +удалить постоянное уведомление из панели уведомлений.</p> + +<h3 id="ongoing_notifications">Воспроизведение медиаданных</h3> +<p>В Android 5.0 на экране блокировки не отображаются элементы управления воспроизведением от устаревшего +класса {@link android.media.RemoteControlClient}. Однако на нем <em>отображаются</em> уведомления, так что теперь каждое +уведомление приложения о воспроизведении является для пользователей основным +способом управления воспроизведением в заблокированном состоянии. В результате у приложения появляется больше возможностей +управлять тем, какие +кнопки отображать, и каким образом. При этом с точки зрения пользователя система ведет себя непротиворечиво, +независимо от того, заблокирован ли экран.</p> + +<h3 style="clear:both" +id="dialogs_and_toasts_are_for_feedback_not_notification">Диалоговые окна +и всплывающие уведомления</h3> + +<p>Приложение, не отображаемое на экране, не должно генерировать диалоговое окно или всплывающее +уведомление. Диалоговое окно или всплывающее уведомление + должно появляться исключительно в качестве немедленной реакции на действия пользователя +в приложении. +Более подробные рекомендации по использованию диалоговых окон и всплывающих уведомлений см. в разделе +<a href="/design/patterns/confirming-acknowledging.html">Подтверждение и уведомление</a>.</p> + +<h3>Упорядочение уведомлений по степени важности</h3> + +<p>По своей сути уведомления — это новости, и поэтому они принципиально отображаются в +обратном хронологическом порядке. +При этом обязательно принимается во внимание +<a href="#correctly_set_and_manage_notification_priority">приоритет</a>, установленный приложением.</p> + +<p>Уведомления являются важной составляющей экрана блокировки и отображаются на видном месте +каждый +раз, когда включается дисплей устройства. На экране блокировки мало свободного места, поэтому +исключительно важно +выявлять неотложные или наиболее релевантные уведомления. По этой +причине Android применяет +сложный алгоритм сортировки уведомлений, в котором учитываются</p> + +<ul> + <li> временная метка и приоритет, установленный приложением;</li> + <li> тот факт, что уведомление только что оповестило пользователя звуковым сигналом +или вибрацией (иными словами, + если телефон издает звуки, и пользователь хочет узнать, в чем +дело, то на экране блокировки + должен находиться ответ, понятный с первого взгляда);</li> + <li> пользователи, связанные с уведомлением при помощи {@link android.app.Notification#EXTRA_PEOPLE}, + и, в частности, присутствие их в списке помеченных контактов.</li> +</ul> + +<p>Чтобы воспользоваться преимуществами этой сортировки наилучшим образом, думайте в первую очередь о создании +удобных условий для +пользователя, и не нацеливайтесь на конкретное место в рейтинге.</p> + + <img src="{@docRoot}images/android-5.0/notifications/AntiSample3.png" alt="" width="700px" /> + + <p class="img-caption" style="margin-top:10px">Уведомления от Gmail имеют +приоритет DEFAULT, поэтому они + обычно оказываются ниже уведомлений от приложений мгновенного обмена сообщениями, таких как Hangouts, но +поднимаются в списке + на некоторое время, когда поступают новые сообщения. + </p> + + +<h3>Уведомления на экране блокировки</h3> + +<p>Поскольку уведомления видны на экране блокировки, защита конфиденциальной информации пользователей приобретает +особо +важное значение. Уведомления нередко содержат частную информацию, и они +не должны быть доступны +каждому, кто взял в руки устройство и включил дисплей.</p> + +<ul> + <li> У устройств, экран блокировки которых защищен (при помощи PIN-кода, графического ключа или пароля), интерфейс имеет + общедоступную и закрытую части. Элементы общедоступного интерфейса отображаются на защищенном экране блокировки и + следовательно, видны всем. Закрытый интерфейс находится "позади" экрана блокировки и + доступен только пользователю, выполнившему вход в устройство.</li> +</ul> + +<h3>Возможности пользователя контролировать информацию, отображаемую на экране блокировки</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/LockScreen@2x.png" srcset="{@docRoot}images/android-5.0/notifications/LockScreen.png 1x" alt="" width="311px" /> + <p class="img-caption"> + Уведомления на экране блокировки с содержимым, отображаемым после того, как пользователь разблокирует устройство. + </p> +</div> + +<p>При настройке защиты экрана блокировки пользователь может предпочесть, + чтобы конфиденциальные данные не отображались на защищенном экране блокировки. В этом случае системный пользовательский интерфейс +учитывает <em>уровень видимости</em> уведомления, чтобы выяснить, какую информацию +можно отображать без риска.</p> +<p> Чтобы установить уровень видимости, вызовите +<code><a +href="/reference/android/app/Notification.Builder.html#setVisibility(int)">Notification.Builder.setVisibility()</a></code> +и укажите одно из следующих значений:</p> + +<ul> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PUBLIC">VISIBILITY_PUBLIC</a></code>. +Содержимое уведомления отображается полностью. + Это значение принимается системой по умолчанию, если уровень видимости не указан.</li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PRIVATE">VISIBILITY_PRIVATE</a></code>. +На экране блокировки отображается основная информация о наличии уведомления, включая его +значок и название приложения, отправившего его. Прочие данные уведомления скрыты. +Здесь уместно дать разработчику пару рекомендаций. + <ul> + <li> Если вы хотите реализовать отдельную общедоступную версию уведомления, +которую система будет отображать на экране блокировки, создайте замещающий +объект Notification в поле<code><a +href="/reference/android/app/Notification.html#publicVersion">Notification.publicVersion</a></code>. + + <li> Этот параметр предоставляет приложению возможность создавать "цензурированную" версию +содержимого, достаточно информативную, но скрывающую личную информацию. Рассмотрим в качестве примера приложение для отправки +SMS-сообщений. Его уведомления содержат текст SMS-сообщения и имя и контактный значок отправителя. +Такое уведомление должно иметь атрибут <code>VISIBILITY_PRIVATE</code>, но его версия <code>publicVersion</code> может +содержать полезную информацию, например, "3 новых сообщения", без уточняющих +подробностей. + </ul> + </li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_SECRET">Notification.VISIBILITY_SECRET</a></code>. Отображается минимум информации, +даже без значка уведомления.</li> +</ul> +<h2 style="clear:both" id="notifications_on_android_wear">Уведомления на +Android Wear</h2> + +<p>По умолчанию уведомления и их <em>действия</em> передаются на носимые устройства. +Разработчики могут управлять тем, какие уведомления следует передавать с +телефона на часы, +и наоборот. У разработчиков также есть возможность управлять передачей действий. Если +приложение включает в себя +действия, которые невозможно выполнить одним касанием, нужно либо скрывать их +в уведомлениях, отображаемых на носимом +устройстве, либо обеспечить их привязку к приложению под управлением Android Wear, позволив пользователю +совершать действие +на часах.</p> + +<h4>Передача уведомлений и действий на другое устройство</h4> + +<p>Подключенное устройство, например, телефон, может передавать уведомления на носимое устройство, +чтобы они отображались и на нем. Аналогичным образом можно передавать действия, чтобы пользователь мог реагировать +на уведомления непосредственно на носимом устройстве.</p> + +<p><strong>Передавайте</strong></p> + +<ul> + <li> новые мгновенные сообщения;</li> + <li> действия, выполняемые одним касанием, например, "+1", "Лайк", "Сердечко".</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/WearBasic.png" width="156px" height="156px" alt="" /> + +<p><strong>Не передавайте</strong></p> + +<ul> + <li> уведомления о новых подкастах;</li> + <li> действия, соответствующие функциям, недоступным на часах.</li> +</ul> + + + +<p><h4>Уникальные действия, определяемые для носимых устройств</h4></p> + +<p>Некоторые действия можно выполнить только на носимых устройствах, например:</p> + +<ul> + <li> выбор из списка шаблонных ответов, например, "Скоро вернусь"</li> + <li> действие "Открыть на телефоне";</li> + <li> действия "Прокомментировать" или "Ответить", открывающие окно речевого ввода;</li> + <li> действия, запускающие приложения, специфичные для Android Wear.</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/ReplyAction.png" width="156px" height="156px" alt="" /> diff --git a/docs/html-intl/intl/zh-cn/design/get-started/principles.jd b/docs/html-intl/intl/zh-cn/design/get-started/principles.jd new file mode 100644 index 0000000..fbb46c9 --- /dev/null +++ b/docs/html-intl/intl/zh-cn/design/get-started/principles.jd @@ -0,0 +1,307 @@ +page.title=Android 设计原则 +@jd:body + +<p>以下设计原则由 Android用户体验团队秉承用户利益至上的理念而制定。他们还会继续为 Android 开发者和设计者针对不同类型的设备制定更详细的设计准则。 + + + +</p> + +<p> +在您应用自己的创意和设计思路时,请考虑这些原则, +切勿固执己见。 +</p> + +<h2 id="enchant-me">让我着迷</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="delight-me">以意想不到的方式让我眼前一亮</h4> +<p>漂亮的界面、精心布置的动画,或恰到好处的声效,都会带来快乐的体验。 +精细的效果能产生一种轻松的氛围,让人感觉自己拥有强大的力量。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_delight.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="real-objects-more-fun">实际对象要比按钮和菜单更有趣</h4> +<p>让用户可以直接触摸和操作您应用中的对象,让执行任务更轻松,让用户更满意。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_real_objects.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-it-mine">我的应用我做主</h4> +<p>用户喜欢添加个性化手势,因为这样会让他们觉得更顺手并且一切尽在他们的掌控之中。提供感性、美观的默认手势,但也要考虑到趣味性,不要让可选的定制手势妨碍主要任务的操作。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_it_mine.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="get-to-know-me">让应用了解我</h4> +<p>逐渐了解用户的偏好。不要让用户反复做出相同的选择,将之前的选择列作快捷选择。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_get_to_know_me.png"> + + </div> +</div> + +<h2 id="simplify-my-life">让我的生活更轻松</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="keep-it-brief">语言简洁</h4> +<p>使用简单的字词组成简短的句子。用户往往会跳过冗长的句子。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_keep_it_brief.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="pictures-faster-than-words">图片比文字更直观</h4> +<p>考虑以图示意。它们会吸引用户的注意力,并且比文字更高效。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_pictures.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="decide-for-me">为我决定,但最终由我做主</h4> +<p>先提供您心目中的最佳选择,而不是先进行询问。太多的选择和决策会让人不悦。 +只是在您的选择可能不当时,才赋予用户“撤消”的权利。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_decide_for_me.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="only-show-when-i-need-it">仅在我需要时显示我所需要的</h4> +<p>如果一次性看到过多内容,用户会感到无所适从。将任务和信息细分为更小、更容易接受的片段。 +隐藏当前不必要的选项,并在用户操作期间提供指导。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_information_when_need_it.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="always-know-where-i-am">我应该始终清楚自己在哪里</h4> +<p>让用户感到轻车熟路。为应用中的不同场景赋予不同的外观,使用过渡效果来展现屏幕之间的关系。 +提供任务进度反馈。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_navigation.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="never-lose-my-stuff">决不能让我的成果付诸东流</h4> +<p>务必保存好用户耗费花时间创造的内容,让他们能随处访问这些内容。跨手机、平板电脑和计算机等平台,记住设置、个人手势和创作内容, +让应用升级变得无比简单。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_never_lose_stuff.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="looks-same-should-act-same">如果看上去一样,其行为也应当相同</h4> +<p>通过视觉上的显著差异(而不是微妙差异)帮助用户区分不同的功能。避免使用固定模式,那样会导致外观相似的场景中,用户执行同样的输入,应用却给出不同的响应。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_looks_same.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="interrupt-only-if-important">只在确实对我很重要时才打断我</h4> +<p>就像优秀的个人助理一样,不要让上司被一些无关紧要的琐事打扰。用户希望专注于核心任务,除非确实非常重要并且情况紧急,否则,打断用户会让人烦不胜烦。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_important_interruption.png"> + + </div> +</div> + +<h2 id="make-me-amazing">给我惊喜</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="give-me-tricks">到处为我提供有用的诀窍</h4> +<p>如果能自己摸索出花样来,用户总是很开心的。利用直观的图案以及其他 Android 应用中常见的习惯手势,让您的应用更容易学习。 +例如,滑动手势就是一种不错的导航快捷手势。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_tricks.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="its-not-my-fault">不是我的错</h4> +<p>在提醒用户改正错误时要礼貌。他们希望在使用您的应用时感觉自己很聪明。如果用户操作出错,请提供清晰的恢复说明,而不要让他们咀嚼详细的技术信息。如果您能在后台修复错误,那当然更好。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_error.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="sprinkle-encouragement">多多鼓励</h4> +<p>将复杂的任务分解为可轻松完成的小步骤。对操作提供反馈,哪怕只是微弱的灯光,也聊胜于无。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_sprinkle_encouragement.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="do-heavy-lifting-for-me">为我处理繁重事务</h4> +<p>通过让新手完成他们认为自己不可能做到的事情,让他们感觉自己就像一名行家。例如,通过提供融合多种照片特效的快捷操作,只需几步,就可以让业余照片达到惊艳的效果。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_heavy_lifting.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-important-things-fast">让重要事项能更快地完成</h4> +<p>不是所有操作都同样重要。确定应用中哪些功能是最重要的,将这些功能放在便于找到和使用的地方,例如相机的快门按钮,或者音乐播放器中的暂停按钮。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_important_fast.png"> + + </div> +</div> diff --git a/docs/html-intl/intl/zh-cn/design/material/index.jd b/docs/html-intl/intl/zh-cn/design/material/index.jd new file mode 100644 index 0000000..78e6d38 --- /dev/null +++ b/docs/html-intl/intl/zh-cn/design/material/index.jd @@ -0,0 +1,186 @@ +page.title=材料设计 +page.tags=Material, design +page.type=设计 +page.image=design/material/images/MaterialLight.png + +@jd:body + +<!-- developer docs box --> +<a class="notice-developers right" href="{@docRoot}training/material/index.html"> + <div> + <h3>开发者文档</h3> + <p>使用材料设计创建应用</p> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=p4gmvHyuZzw"> +<div> + <h3>视频</h3> + <p>材料设计简介</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=YaG_ljfzeUw"> +<div> + <h3>视频</h3> + <p>纸张和墨水:相关材料</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=XOcCOBe8PTc"> +<div> + <h3>视频</h3> + <p>Google I/O 应用中的材料设计</p> +</div> +</a> + + + +<p itemprop="description">材料设计是专为设计适用于多个平台和设备的视觉、运动与互动效果而制定的综合指南。 +Android 现在已支持材料设计应用。 +如果要在您的 Android 应用中使用材料设计,请遵循<a href="http://www.google.com/design/spec">材料设计规范</a>内定义的指导方针,并使用 Android 5.0(API 级别 21)及以上版本所提供的新组件和功能。 + +</p> + +<p>Android 为您提供了以下元素来构建材料设计应用:</p> + +<ul> + <li>全新的风格主题</li> + <li>用于设计复杂视图的全新小工具</li> + <li>用于自定义阴影和动画的全新 API</li> +</ul> + +<p>有关在 Android 上实现材料设计的详细信息,请参阅<a href="{@docRoot}training/material/index.html">创建材料设计应用</a>。 +</p> + + +<h3>材料主题</h3> + +<p>材料主题提供了新的应用样式和系统小工具,让您能够为触摸反馈以及活动转换设置配色工具以及默认动画。 +</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/MaterialDark.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">深色材料主题</p> + </div> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/MaterialLight.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">浅色材料主题</p> + </div> +</div> +<br style="clear:left"/> +</div> + +<p>如需了解详细信息,请参阅<a href="{@docRoot}training/material/theme.html">使用材料主题 +</a>。</p> + + +<h3>列表和卡片</h3> + +<p>Android 提供了两个全新的小工具,用于显示采用材料设计样式和动画的卡片和列表: +</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/list_mail.png" width="500" height="426" /> + <p>全新的 <code>RecyclerView</code> 小工具是 <code>ListView</code> + 的可插入版本,支持不同的布局类型,并且具有更高性能。</p> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/card_travel.png" width="500" height="426" /> + <p>全新的 <code>CardView</code> 小工具可让您展示卡片内的重要信息,并且有统一的观感。 +</p> +</div> +<br style="clear:left"/> +</div> + +<p>如需了解详细信息,请参阅<a href="{@docRoot}training/material/lists-cards.html">创建列表和卡片</a>。 +</p> + + +<h3>视图阴影</h3> + +<p>除了 X 和 Y 属性之外,Android 中的视图现在还提供了 Z +属性。这一新属性用于展现视图的高度,从而确定:</p> + +<ul> +<li>阴影的大小:Z 值越高的视图投射的阴影越长。</li> +<li>绘制顺序:Z 值较高的视图会显示在其他视图的上方。</li> +</ul> + +<div style="width:290px;margin-left:35px;float:right"> + <div class="framed-nexus5-port-span-5"> + <video class="play-on-hover" autoplay> + <source src="{@docRoot}design/material/videos/ContactsAnim.mp4"/> + <source src="{@docRoot}design/videos/ContactsAnim.webm"/> + <source src="{@docRoot}design/videos/ContactsAnim.ogv"/> + </video> + </div> + <div style="font-size:10pt;margin-left:20px;margin-bottom:30px"> + <em>如果要重新播放影片,请点击设备屏幕</em> + </div> +</div> + +<p>如需了解详细信息,请参阅<a href="{@docRoot}training/material/shadows-clipping.html">定义阴影与裁剪视图</a>。 +</p> + + +<h3>动画</h3> + +<p>动画 API 让您可为 UI 控件中的触摸反馈、视图状态更改以及活动转换创建自定义动画。 +</p> + +<p>这些 API 的作用是:</p> + +<ul> +<li style="margin-bottom:15px"> +使用<strong>触摸反馈</strong>动画响应视图中的触摸事件。 +</li> +<li style="margin-bottom:15px"> +使用<strong>循环显示</strong>动画隐藏和显示视图。 +</li> +<li style="margin-bottom:15px"> +使用自定义<strong>活动转换</strong>动画切换活动。 +</li> +<li style="margin-bottom:15px"> +使用<strong>曲线运动</strong>创建更自然的动画。 +</li> +<li style="margin-bottom:15px"> +使用<strong>视图状态更改</strong>动画以动画形式呈现一个或多个视图属性的更改。 +</li> +<li style="margin-bottom:15px"> +在视图状态更改期间以<strong>可绘制状态列表</strong>显示动画。 +</li> +</ul> + +<p>触摸反馈动画内建于数个标准视图(例如按钮)中。全新的 API让您可以自定义这些动画并将其添加至自己的自定义视图中。 +</p> + +<p>如需了解详细信息,请参阅<a href="{@docRoot}training/material/animations.html">定义自定义动画</a>。 +</p> + + +<h3>可绘制对象</h3> + +<p>下列可绘制对象的新功能将帮助您实现材料设计应用:</p> + +<ul> +<li><strong>可绘制矢量</strong>可在不影响清晰度的情况下进行缩放,非常适合单色应用内图标。 +</li> +<li><strong>可绘制底色</strong>可让您将位图定义为 alpha 蒙板,并在运行时为其着色。 +</li> +<li><strong>颜色提取</strong>可让您从位图图像自动提取突出色彩。 +</li> +</ul> + +<p>如需了解详细信息,请参阅<a href="{@docRoot}training/material/drawables.html">使用可绘制内容</a>。 +</p> diff --git a/docs/html-intl/intl/zh-cn/design/patterns/confirming-acknowledging.jd b/docs/html-intl/intl/zh-cn/design/patterns/confirming-acknowledging.jd new file mode 100644 index 0000000..aa4ae1f --- /dev/null +++ b/docs/html-intl/intl/zh-cn/design/patterns/confirming-acknowledging.jd @@ -0,0 +1,70 @@ +page.title=确认和确知 +page.tags=dialog,toast,notification +@jd:body + +<p>在某些情况下,当用户在您的应用中调用某个操作时,最好使用文字内容来<em>确认</em>或<em>确知</em>该操作。</p> + +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_confirming.png"> + <p><strong>确认</strong>是要求用户确认自己确实希望执行刚才所调用的操作。在某些情况下,确认随需要用户考虑的操作所相关的警告或关键信息一起显示。</p> + </div> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_acknowledge.png"> + <p><strong>确知</strong>就是显示一段文字信息,让用户知道自己刚才调用的操作已经完成。这将消除系统正在执行的隐式操作的不确定性。在某些情况下,确知随撤消操作的选项一起显示。</p> + </div> +</div> + +<p>以上述方式通知用户有助于减少用户对已发生或即将发生的事情的不确定性。确认或确知还可以有效防止用户犯下可能让自己后悔的错误。</p> + +<h2>何时需要确认或确知用户操作</h2> +<p>并非所有操作都一定要确认或确知。请使用以下流程图指导自己的设计决策。</p> +<img src="{@docRoot}design/media/confirm_ack_flowchart.png"> + +<h2>确认</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>示例:Google Play 书籍</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_books.png"> + <p>在该示例中,用户要求从其 Google Play 书架中删除一本书。系统显示了一条<a href="{@docRoot}design/building-blocks/dialogs.html#alerts">警告</a>来要求确认该操作,因为用户必须知道,一旦删除,该书籍将无法继续在任何设备上使用。</p> + <p>在设计确认对话框时,请使用反映所请求操作的文字作为标题,使标题更有意义。</p> + </div> + <div class="layout-content-col span-7"> + <h4>示例:Android Beam</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_beam.png"> + <p>确认不一定要显示在有两个按钮的警告中。在启动 Android Beam 后,系统提示用户触摸要分享的内容(本例中是一张照片)。如果他们决定不继续操作,只需移开手机即可。</p> + </div> +</div> + +<h2>确知</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>示例:已保存中断的 Gmail 草稿</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_draftsave.png"> + <p>在本例中,如果用户在 Gmail 撰写邮件屏幕中向后或向上导航,可能会发生一些意外情况,此时会自动保存当前草稿。Toast 形式的确知会明确告知这一点。它会在几秒钟后消失。</p> + <p>在这种情况下不能执行撤消操作,因为保存是由应用发起的,而不是由用户执行的。通过导航至草稿列表,可迅速方便地恢复邮件。</p> + + </div> + <div class="layout-content-col span-6"> + <h4>示例:已删除 Gmail 会话</h4> + <img src="{@docRoot}design/media/confirm_ack_draft_deleted.png"> + <p>在用户从 Gmail 中的列表删除某个会话后,会出现带撤消选项的确知。确知消息会一直等到用户采取无关操作才会消失,例如滚动列表。</p> + </div> +</div> + +<h2>无需确认或确知</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>示例:+1 操作</h4> + <img style="padding: 33px 0 30px;" src="{@docRoot}design/media/confirm_ack_ex_plus1.png"> + <p><strong>无需确认</strong>。如果用户意外触摸 +1 按钮,不会有什么大问题。他们只需再次触摸该按钮,撤消该操作即可。</p> + <p><strong>无需确知</strong>。用户将看到 +1 按钮弹起并变红。这是非常明确的信号。</p> + </div> + <div class="layout-content-col span-7"> + <h4>示例:从主屏幕删除应用</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_removeapp.png"> + <p><strong>无需确认</strong>。这属于有意操作:用户必须将项目拖放到相对较大并且独立的目标上。因此,很难发生意外。但是如果用户反悔决定,只需数秒钟时间即可复原。</p> + <p><strong>无需确知</strong>。用户知道该应用会从主屏幕上消失,因为是他们将其拖走而使其消失的。</p> + + </div> +</div> diff --git a/docs/html-intl/intl/zh-cn/design/patterns/navigation.jd b/docs/html-intl/intl/zh-cn/design/patterns/navigation.jd new file mode 100644 index 0000000..339a2c5 --- /dev/null +++ b/docs/html-intl/intl/zh-cn/design/patterns/navigation.jd @@ -0,0 +1,213 @@ +page.title=使用返回和向上导航 +page.tags="navigation","activity","task","up navigation","back navigation" +page.image=/design/media/navigation_between_siblings_gmail.png +@jd:body + +<a class="notice-developers" href="{@docRoot}training/implementing-navigation/index.html"> + <div> + <h3>开发者文档</h3> + <p>实现有效导航</p> + </div> +</a> + +<p itemprop="description">一致的导航操作是整体用户体验的重要组成部分。如果基本的导航方法都不能保持一致,甚至让用户意想不到的话,恐怕没有比这更让人沮丧的事情了。 +Android 3.0对全局导航行为做出了重大改变。 +对用户来说,认真遵照“返回”和“向上”的指导准则可让应用的导航更可靠、更符合预期。 +</p> +<p>Android 2.3 及更早的版本使用<em>返回</em>按钮来支持应用内的导航。在 Android 3.0 中引入操作栏后,出现了第二种导航机制:即<em>向上</em>按钮,由应用图标和左向箭头构成。 + +</p> + +<img src="{@docRoot}design/media/navigation_with_back_and_up.png"> + +<h2 id="up-vs-back">向上和返回</h2> + +<p>“向上”按钮用于根据屏幕之间的层级关系在应用中导航。 +例如,如果屏幕 A 显示项目列表,并且选择某个项目会调出屏幕 B(该屏幕显示项目的更多详情),则屏幕 B 应提供可返回屏幕 A 的“向上”按钮。 + +</p> +<p>如果屏幕是应用中层级最高的屏幕(即应用的主屏幕),则无需提供向上按钮。 +</p> + +<p>系统的“返回”按钮用于按照用户最近操作的屏幕历史记录,按时间逆序导航。 +它通常基于屏幕之间的时间关系,而非应用的层级关系。 +</p> + +<p>如果之前查看的屏幕也是当前屏幕的父级项,按下“返回”按钮的作用跟按下“向上”按钮一样 — 这种情况很常见。 + +但是,“向上”按钮可确保用户留在应用内,与此不同的是,“返回”按钮可让用户返回到主屏幕,甚至返回不同的应用。 +</p> + +<img src="{@docRoot}design/media/navigation_up_vs_back_gmail.png"> + +<p>“返回”按钮还支持与屏幕间导航并无直接关联的一些行为: +</p> +<ul> +<li>清除浮动窗口(对话框、弹出窗口)</li> +<li>清除上下文操作栏,并取消高亮显示所选项目</li> +<li>隐藏屏幕键盘 (IME)</li> +</ul> +<h2 id="within-app">应用内导航</h2> + +<h4>通过多个入口点导航屏幕</h4> +<p>有时,某个屏幕在应用层级中的位置并不固定,可以从多个入口点抵达 — 例如可从应用中的其他任何屏幕抵达设置屏幕。在这种情况下,选择“向上”按钮会返回到引用屏幕,其行为跟“返回”按钮相同。 + + +</p> +<h4>更改屏幕中的视图</h4> +<p>更改屏幕的视图选项不会更改“向上”或“返回”的行为:屏幕仍然位于应用层级中的同一位置,并且不会创建新的导航历史记录。 +</p> +<p>此类视图更改的示例包括:</p> +<ul> +<li>使用选项卡和/或左右滑动切换视图</li> +<li>使用下拉菜单(即折叠的选项卡)切换视图</li> +<li>筛选列表</li> +<li>列表排序</li> +<li>更改显示特性(例如缩放)</li> +</ul> +<h4>在同级屏幕之间导航</h4> +<p>如果您的应用支持从项目列表导航至其中某个项目的详情视图,通常最好支持从该项目导航到列表中该项目之前或之后的另一项目。 + +例如,在 Gmail 中,只需在会话中向左或向右滑动,即可轻松查看同一收件箱中较新或较旧的会话。 +在某个屏幕内更改视图这样的导航不会改变“向上”或“返回”的行为。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_gmail.png"> + +<p>然而,当在多个彼此相关、但并未通过引用列表绑定在一起的详情视图之间浏览时,例如,在 Play 商店中同一开发商开发的多款应用或者同一艺术家推出的多张专辑之间切换浏览时,会发生值得注意的例外情况。 + +在这些情况下,跟踪每个链接不会创建历史记录,这就导致点击“返回”按钮时会逐一显示之前查看过的每个屏幕。 +点击“向上”按钮则会直接绕过这些相关的屏幕并导航至最近查看的容器屏幕。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market1.png"> + +<p>您可以根据详情视图的实际情况让“向上”按钮的行为更加智能。 +将上述 Play 商店示例进一步展开,设想用户从查看过的上一本图书导航至电影改编详情。 +在这种情况下,“向上”按钮可返回至用户之前导航时未经历过的容器(电影)。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market2.png"> + +<h2 id="into-your-app">通过主屏幕小工具和通知进入您的应用</h2> + +<p>使用主屏幕小工具或通知,您可以帮助用户直接导航至应用中的深层屏幕。 +例如,Gmail 的收件箱小工具和新消息通知都可绕过收件箱屏幕,让用户直接进入会话视图。 +</p> + +<p>对于这两种情况,请按下述说明处理“向上”按钮:</p> + +<ul> +<li><em>如果目的屏幕通常通过应用</em>中的某个特定屏幕抵达,“向上”按钮应导航至该屏幕。 +</li> +<li><em>否则</em>,“向上”按钮应导航至应用的顶级屏幕(“主屏幕”)。</li> +</ul> + +<p>对于“返回”按钮,您应将指向应用顶级屏幕的完整向上导航路径插入到任务的返回栈,从而让导航更具预见性。 +这样,如果用户忘记了之前是如何进入您的应用的,则可以在退出之前导航至应用的顶级屏幕。 + +</p> + +<p>例如,Gmail 的主屏幕小工具有一个按钮可以让您直接进入写邮件屏幕。 +在写邮件屏幕上使用“向上”或“返回”可让用户进入“收件箱”,而在收件箱屏幕上使用“返回”则可回到主屏幕。 +</p> + +<img src="{@docRoot}design/media/navigation_from_outside_back.png"> + +<h4>间接通知</h4> + +<p>如果您的应用需要同时提供关于多个事件的信息,可使用一条通知将用户引导至某个间隙屏幕。 +该屏幕将这些事件汇总,并为用户提供深度导航应用的路径。这种样式的通知称为<em>间接通知</em>。 + +</p> + +<p>与标准(直接)通知不同,在间接通知的间隙屏幕上按下“返回”会让用户回到触发通知的点 — 不会在返回栈中插入额外的屏幕。 + +一旦用户从应用的间隙屏幕进入应用的更深层级,则“向上”和“返回”按钮的行为就与用于标准通知时相同,如上所述:在应用内部导航,而非返回至间隙屏幕。 + +</p> + +<p>例如,假设 Gmail 中的用户收到来自日历的间接通知。触摸该通知会打开间隙屏幕,该屏幕会显示数个不同事件的提醒。 + +在间隙屏幕上触摸“返回”会让用户回到 Gmail。触摸特定事件会让用户离开间隙屏幕并进入完整的日历应用,以显示事件的详情。 + +在事件详情屏幕上,使用“向上”和“返回”可导航至日历的顶级视图。</p> + +<img src="{@docRoot}design/media/navigation_indirect_notification.png"> + +<h4>弹出通知</h4> + +<p><em>弹出通知</em>会绕过抽屉式通知栏,直接显示在用户面前。 +一般很少使用这种通知,<strong>仅在需要即时响应并且有必要中断用户当前操作时使用</strong>。 +例如,Talk 使用这种方式来提醒用户收到了好友加入视频聊天的邀请,因为该邀请将在几秒之后自动过期。 + +</p> + +<p>从导航行为的角度来看,弹出通知会密切跟踪间接通知的间隙屏幕的行为。 +使用“返回”会清除弹出通知。如果用户从弹出通知导航至通知应用中,则“向上”和“返回”会依照标准通知的规则在应用内导航。 + +</p> + +<img src="{@docRoot}design/media/navigation_popup_notification.png"> + +<h2 id="between-apps">在应用之间导航</h2> + +<p>Android 系统的一个基本优势在于能够让应用相互激活,这样用户就可以直接从一个应用导航到另一个应用。 +例如,需要获取照片的应用可激活相机应用,后者可将照片返回给前者。这对于开发者和用户来说都极为有利,开发者可以方便地利用来自其他应用的代码,而用户则在执行常用操作时可以获得一致的体验。 + + + +</p> + +<p>为了理解应用到应用的导航,必须理解下面探讨的 Android 框架行为 +。</p> + +<h4>活动、任务和意向</h4> + +<p>在 Android 中,<strong>活动</strong>是一个应用组件,用于定义信息屏幕以及用户可执行的所有相关操作。 +您的应用是活动的集合,由您创建的活动以及从其他应用重用的活动构成。 +</p> + +<p><strong>任务</strong>是用户为达成某个目标而执行的活动序列。一个 +任务可以只利用一个应用的活动,也可以利用来自多个不同应用的活动。 +</p> + +<p><strong>意向</strong>是应用的一种机制,用于发出信号以表明需要另一个应用的辅助才能执行某个操作。 +应用的活动可指示其可响应哪些意向。 +对于诸如“分享”这样的常用意向,用户可能安装有许多可执行该请求的应用。 +</p> + +<h4>示例:在应用之间导航以支持分享</h4> + +<p>要了解如何结合使用活动、任务和意向,可以考虑一个应用如何让用户通过使用另一应用来分享内容的例子。例如,从主屏幕启动 Play 商店应用可启动新任务 A(参见下图)。 + +在 Play 商店中导航并触摸某本促销图书来查看其详情之后,用户会停留在该任务中并通过添加活动来扩展该任务。 +触发“分享”操作会通过一个对话框来提示用户选择活动,该对话框中会列出来自不同应用、之前已注册用于处理“分享”意向的每一种活动。 + +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_inward.png"> + +<p>如果用户选择通过 Gmail 分享,则会以延续任务 A 的形式添加 Gmail 的写邮件活动 — 而不会创建新任务。 +如果 Gmail 在后台还运行有自己的任务,该任务不会受影响。 +</p> + +<p>在写邮件活动中,发送邮件或触摸“返回”按钮会让用户回到图书详情活动。 +之后继续触摸“返回”会在 Play 商店中继续回退,直至抵达主屏幕。 +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_back.png"> + +<p>尽管如此,用户可通过在写邮件活动中触摸“向上”按钮表明其希望留在 Gmail 中。 +此时会显示 Gmail 的会话列表活动,并为其创建新任务 B。新任务都始于主屏幕,因此从会话列表触摸“返回”按钮,始终会回到主屏幕。 +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_up.png"> + +<p>任务 A 保持在后台运行,用户可稍后回到该任务(例如通过“最近使用的应用”屏幕)。 +如果 Gmail 在后台还运行有自己的任务,该任务会被任务 B 取代 — 之前的上下文会被丢弃,以使用户达成新目标。 +</p> + +<p>如果您的应用经过注册,以使用应用中的深层活动来处理意向,可参阅<a href="#into-your-app">通过主屏幕小工具和通知进入您的应用</a>,获得有关如何指定“向上”导航行为的指导。 + +</p> diff --git a/docs/html-intl/intl/zh-cn/design/patterns/notifications.jd b/docs/html-intl/intl/zh-cn/design/patterns/notifications.jd new file mode 100644 index 0000000..57e02e4 --- /dev/null +++ b/docs/html-intl/intl/zh-cn/design/patterns/notifications.jd @@ -0,0 +1,872 @@ +page.title=通知 +page.tags="notifications","design","L" +@jd:body + + <a class="notice-developers" href="{@docRoot}training/notify-user/index.html"> + <div> + <h3>开发者文档</h3> + <p>通知用户</p> + </div> +</a> + +<a class="notice-designers" href="notifications_k.html"> + <div> + <h3>Android 4.4 及更低版本中的通知</h3> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=Uiq2kZ2JHVY"> +<div> + <h3>视频</h3> + <p>DevBytes:Android L 开发者预览当中的通知</p> +</div> +</a> + +<style> + .col-5, .col-6, .col-7 { + margin-left:0px; + } +</style> + +<p>通知系统可让用户随时了解应用中的相关和即时事件,例如来自好友的新聊天信息或日历事件。可将通知视作新闻频道,在重要的事件发生时提醒用户注意,或者当作日志,在用户未注意时记录事件—可在用户的所有 Android 设备上按需同步。 + + + + + +</p> + +<h4 id="New"><strong>Android 5.0 新增内容</strong></h4> + +<p>在 Android 5.0 中,通知在结构、外观和功能方面获得了重要的更新: +</p> + +<ul> + <li>通知在外观上发生了更改,与新的材料设计主题保持一致。 +</li> + <li> 通知现在可以在设备锁定屏幕上使用,而敏感信息仍然可以隐藏于背后。 + +</li> + <li>设备在使用时收到的高优先级通知现在采用名为浮动通知的新格式。 +</li> + <li>云同步通知:在一台 Android 设备上清除通知,则在其他设备上也会将其清除。 + +</li> +</ul> + +<p class="note"><strong>注:</strong>该版本 Android 的通知设计与之前的版本大不相同。 + +有关之前版本通知设计的信息,请参阅<a href="./notifications_k.html"> Android 4.4 及更低版本中的通知</a>。 +</p> + +<h2 id="Anatomy">通知详解</h2> + +<p>本部分介绍通知的基本组成部分,及其在不同类型设备上显示的方式。 +</p> + +<h3 id="BaseLayout">基本布局</h3> + +<p>所有通知至少要包括一个基本布局,包括:</p> + +<ul> + <li> 通知的<strong>图标</strong>。图标以符号形式表示来源应用。如果应用生成多个类型的通知,它也可用于指明通知类型。 + + +</li> + <li> 通知<strong>标题</strong>以及其他 +<strong>文本</strong>。</li> + <li> <strong>时间戳</strong>。</li> +</ul> + +<p>利用 {@link android.app.Notification.Builder Notification.Builder}为之前版本平台创建的通知,其外观和行为方式与在 Android +5.0 中完全相同,唯一的变动在于系统为您处理通知的方式存在细微的样式变动。 + +如需了解之前 Android 版本通知设计的详细信息,请参阅<a href="./notifications_k.html"> Android 4.4 及更低版本中的通知</a>。 + +</p></p> + + + <img style="margin:20px 0 0 0" src="{@docRoot}images/android-5.0/notifications/basic_combo.png" alt="" width="700px" /> + + +<div style="clear:both;margin-top:20px"> + <p class="img-caption"> + 手持设备通知(左)和穿戴设备(右)上同一通知的基本布局,带有用户照片和通知图标 + + </p> + </div> + +<h3 id="ExpandedLayouts">展开布局</h3> + + +<p>您可以选择让应用的通知提供多少信息详情。 +它们可显示消息的前几行,也可以显示更大的预览图像。 +额外的信息可以为用户提供更多上下文,并且,在某些情况下,可能允许用户完整阅读消息。 + + +用户可进行两指缩放或执行单指滑移,在紧凑和展开布局之间切换。 + + + 对于单一事件通知,Android 提供了三种展开布局模板(文本、收件箱和图像),供您在应用中使用。 + +下图展示单一事件通知在手持设备(左)和穿戴式设备(右)上的外观。 + +</p> + +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/expandedtext_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/stack_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/ExpandedImage.png" + alt="" width="311px" height;="450px" /> + +<h3 id="actions" style="clear:both; margin-top:40px">操作</h3> + +<p>Android 支持在通知底部显示可选的操作。通过操作,用户可在通知栏中处理最常见的任务,而无需打开来源应用。这样可加快交互的速度,而通过结合使用滑动清除通知的功能,有助于用户专注于对自身重要的通知。 + + + + + +</p> + + + <img src="{@docRoot}images/android-5.0/notifications/action_combo.png" alt="" width="700px" /> + + + +<p style="clear:both">请慎重考虑要在通知中包含多少操作。 +您加入的操作越多,用户就越无所适从。 +请通过只包含最重要且有意义的操作,尽量减少通知中的操作数量。 + + +</p> + +<p>适合在通知中使用的操作具有如下特点:</p> + +<ul> + <li> 对正在显示的内容类型必要、常用且常见 + + <li> 让用户可以迅速完成任务 +</ul> + +<p>避免以下类型的操作:</p> + +<ul> + <li> 含义模糊 + <li> 跟通知的默认操作一样(例如“阅读”或“打开”) + +</ul> + + + +<p>您最多可以指定三个操作,每个操作由操作图标和名称组成。 + + 通过为简单的基本布局添加操作,可以展开该通知,即使该通知没有展开布局,此方法仍然有效。 + +由于操作仅对展开的通知显示(否则会隐藏),因此要确保用户从通知调用的任何操作都可在相关联的应用中使用。 + + + + +</p> + +<h2 style="clear:left">浮动通知</h2> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/hun-example.png" alt="" width="311px" /> + <p class="img-caption"> + 出现在沉浸式应用顶部的浮动通知(手机来电,高优先级)示例 + + + </p> +</div> + +<p>收到高优先级通知时(见右侧),它会向用户短时间显示一个包含可选操作的展开布局。 + +</p> +<p> 之后,通知会缩回通知栏。 +如果通知的<a href="#correctly_set_and_manage_notification_priority">优先级</a>标志为高、最大或全屏,则会得到浮动通知。 +</p> + +<p><b>浮动通知的范例</b></p> + +<ul> + <li> 使用设备时来电</li> + <li> 使用设备时闹铃</li> + <li> 新的短信</li> + <li> 电池电量过低</li> +</ul> + +<h2 style="clear:both" id="guidelines">指导原则</h2> + + +<h3 id="MakeItPersonal">个人化</h3> + +<p>对于他人发送的项目通知(例如消息或状态更新),请使用 +{@link android.app.Notification.Builder#setLargeIcon setLargeIcon()} 包含此人的头像。 +另外将有关此人的信息附加到通知的元数据(参阅 {@link android.app.Notification#EXTRA_PEOPLE})。 +</p> + +<p>您通知的主图标仍然会显示,因此,该用户可将其与状态栏中显示的图标相关联。 + +</p> + + +<img src="{@docRoot}images/android-5.0/notifications/Triggered.png" alt="" width="311px" /> +<p style="margin-top:10px" class="img-caption"> + 显示触发通知的用户以及该用户所发送信息的通知。 +</p> + + +<h3 id="navigate_to_the_right_place">导航至正确位置</h3> + +<p>在用户触摸通知的正文时(在操作按钮的外面),打开应用并定位至正确的位置,以便用户可查看通知中引用的数据并据此操作。 + + +在大多数情况下,该位置是某个数据项目(例如消息)的详情视图,但如果是存档通知,那么也可能是摘要视图。 + +如果您的应用将用户带到应用顶层以下的任何位置,可将导航插入应用的返回栈,这样用户就可以通过按下系统返回按钮返回至顶层。 + +如需了解详细信息,请参阅<a href="{@docRoot}design/patterns/navigation.html#into-your-app">导航</a>设计模式中的“通过主屏幕小工具和通知进入您的应用”<em></em>。 + +</p> + +<h3 id="correctly_set_and_manage_notification_priority">正确设置和管理通知优先级。 + +</h3> + +<p>Android 支持通知的优先级标志。该标志可以影响您的通知相对于其他通知出现的位置,并且可以帮助确保用户始终能在第一时间看到对他们最重要的通知。 + + +在发布通知时,您可以选择下列优先级之一: + +</p> +<table> + <tr> + <td class="tab0"> +<p><strong>优先级</strong></p> +</td> + <td class="tab0"> +<p><strong>用法</strong></p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MAX</code></p> +</td> + <td class="tab1"> +<p>用于重要和紧急的通知,告知用户属于时间关键型状况,或者必须予以解决方可继续执行某个特定任务。 + + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>HIGH</code></p> +</td> + <td class="tab1"> +<p>主要用于重要通信,例如包含用户特别感兴趣的内容的消息或聊天事件。高优先级通知会触发浮动通知显示。 + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>DEFAULT</code></p> +</td> + <td class="tab1"> +<p>用于不属于此处所述其他任何优先级的所有通知。</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>LOW</code></p> +</td> + <td class="tab1"> +<p>用于您希望告知用户但不是很紧急的通知。 +低优先级通知最好显示在列表的底部,这里正适合放置公共事项或无收件人姓名的社交更新之类的通知: + +用户要求接收相关通知,但是这些通知的优先级永远不会高于紧急或直接通信。 + + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MIN</code></p> +</td> + <td class="tab1"> +<p>用于上下文或背景信息,例如天气信息或上下文位置信息。最低优先级通知不会出现在状态栏中。 + +用户可在展开的通知栏上找到它们。 +</p> +</td> + </tr> +</table> + + +<h4 id="how_to_choose_an_appropriate_priority"><strong>如何选择合适的优先级</strong> + +</h4> + +<p><code>DEFAULT</code>、<code>HIGH</code> 和 <code>MAX</code> 是中断优先级别,在活动过程中有中断用户的风险。 + +为了避免打扰应用的用户,中断优先级仅保留用于以下通知 +:</p> + +<ul> + <li> 涉及另一个用户</li> + <li> 时间敏感</li> + <li> 可能会立即改变用户在现实世界中的行为</li> +</ul> + +<p>设置为 <code>LOW</code> 和 <code>MIN</code> 的通知可能仍然对用户很重要: +很多通知(如果不是绝大多数)不需要用户立即注意,也不需要振动,但仍然包含用户选择查看通知时将会觉得重要的信息。 + + +<code>LOW</code> 和 <code>MIN</code>优先级通知的条件包括: +</p> + +<ul> + <li> 不涉及其他用户</li> + <li> 不属于时间敏感型</li> + <li> 包含用户可能感兴趣但可选择在空闲时浏览的内容 +</li> +</ul> + + + <img src="{@docRoot}images/android-5.0/notifications/notifications_pattern_priority.png" alt="" width="700" /> + + +<h3 style="clear:both" id="set_a_notification_category">设置通知类别 +</h3> + +<p>如果通知属于以下预定义类别(参阅下文)之一,则为其分配相应的类别。 + +诸如通知栏(或其他任何通知侦听器)这样的系统 UI 项目,可使用该信息来进行评级和筛选决策。 + +</p> +<table> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_CALL">CATEGORY_CALL</a></code></p> +</td> + <td> +<p>来电(语音或视频)或相似的同步通信请求 +</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_MESSAGE">CATEGORY_MESSAGE</a></code></p> +</td> + <td> +<p>传入的直接消息(短信、即时消息等)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EMAIL">CATEGORY_EMAIL</a></code></p> +</td> + <td> +<p>异步群发消息(电子邮件)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EVENT">CATEGORY_EVENT</a></code></p> +</td> + <td> +<p>日历事件</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROMO">CATEGORY_PROMO</a></code></p> +</td> + <td> +<p>促销或广告</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ALARM">CATEGORY_ALARM</a></code></p> +</td> + <td> +<p>闹铃或定时器</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROGRESS">CATEGORY_PROGRESS</a></code></p> +</td> + <td> +<p>长时间运行的后台操作的进度</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SOCIAL">CATEGORY_SOCIAL</a></code></p> +</td> + <td> +<p>社交网络或共享更新</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ERROR">CATEGORY_ERROR</a></code></p> +</td> + <td> +<p>后台操作或身份验证状态中的错误</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_TRANSPORT">CATEGORY_TRANSPORT</a></code></p> +</td> + <td> +<p>媒体传输播放控制</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SYSTEM">CATEGORY_SYSTEM</a></code></p> +</td> + <td> +<p>系统或设备状态更新。保留给系统使用。</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SERVICE">CATEGORY_SERVICE</a></code></p> +</td> + <td> +<p>正在运行的后台服务的指示</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_RECOMMENDATION">CATEGORY_RECOMMENDATION</a></code></p> +</td> + <td> +<p>对于某个事件的特定、及时建议。例如,新闻应用可能会建议用户接下来可能想要阅读的新话题。 + +</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_STATUS">CATEGORY_STATUS</a></code></p> +</td> + <td> +<p>有关设备或上下文状态的持续信息</p> +</td> + </tr> +</table> + +<h3 id="summarize_your_notifications">通知摘要</h3> + +<p>如果特定类型的通知已经在您的应用尝试发送同类型的新通知时挂起,可将它们合并到单个应用摘要通知中,而不要新建对象。 + +</p> + +<p>摘要通知会生成摘要说明,让用户了解特定类型的通知有多少处于挂起状态。 + +</p> + +<div class="col-6"> + +<p><strong>禁忌用法</strong></p> + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Dont.png" alt="" width="311px" /> +</div> + +<div> +<p><strong>建议用法</strong></p> + + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Do.png" alt="" width="311px" /> +</div> + +<p style="clear:left; padding-top:30px; padding-bottom:20px">您可通过使用展开的摘要布局提供有关组成摘要的各个通知的更多详情。 + +此方法可让用户更好地了解哪些通知处于挂起状态,如果他们有足够的兴趣,还可在相关联的应用中阅读详情。 + + + +</p> +<div class="col-6"> + <img src="{@docRoot}images/android-5.0/notifications/Stack.png" style="margin-bottom:20px" alt="" width="311px" /> + <p class="img-caption"> + 展开和收起的摘要通知(使用 <code>InboxStyle</code>) + </p> +</div> + +<h3 style="clear:both" id="make_notifications_optional">将通知设置为可选 +</h3> + +<p>用户应始终能控制通知。允许用户通过将某个通知设置项目添加至您的应用设置,禁用应用的通知或更改其提醒属性,例如警报声和是否使用振动。 + + + +</p> + +<h3 id="use_distinct_icons">使用不同的图标</h3> +<p>通过扫一眼通知区域,用户可以了解哪些类型的通知当前处于挂起状态。 + +</p> + +<div class="figure"> + <img src="{@docRoot}images/android-5.0/notifications/ProductIcons.png" alt="" width="420" /> +</div> + + <div><p><strong>建议用法</strong></p> + <p>查看 Android 应用已经提供的通知图标并为您的应用创建外观明显不同的通知图标。 + +</p> + + <p><strong>建议用法</strong></p> + <p>对小图标使用正确的<a href="/design/style/iconography.html#notification">通知图标样式</a>,对操作图标使用相应的材料灯<a href="/design/style/iconography.html#action-bar">操作栏图标</a>。 + + + +</p> +<p ><strong>建议用法</strong></p> +<p >图标外观要简洁清晰,避免使用过于精细、难以辨认的图标。 +</p> + + <div><p><strong>禁忌用法</strong></p> + <p>对小图标和操作图标设置任何附加的阿尔法通道属性(变暗或变淡);这些图标会有抗锯齿边缘,但是由于 Android 使用这些图标作为蒙板(即仅使用阿尔法通道),因此通常应以完全不透明的方式绘制图像。 + + + + +</p> + +</div> +<p style="clear:both"><strong>禁忌用法</strong></p> + +<p>利用色彩将您的应用与其他应用区分开来。通知图标应该是纯白透明背景图像。 +</p> + + +<h3 id="pulse_the_notification_led_appropriately">对通知 LED 施加相应的脉冲 +</h3> + +<p>许多 Android 设备都配有通知 LED,用于让用户在屏幕关闭时了解事件。 + +优先级为 <code>MAX</code>、 +<code>HIGH</code> 或 <code>DEFAULT</code> 的通知应让 LED 发光,而优先级较低的通知(<code>LOW</code> 和 <code>MIN</code>)则不应让 LED 发光。 + +</p> + +<p>用户对通知的控制应延伸至 LED。当您使用 DEFAULT_LIGHTS 时,LED 将发出白光。 + +您的通知不应使用不同的颜色,除非用户明确对其进行了自定义。 + +</p> + +<h2 id="building_notifications_that_users_care_about">构建用户关注的通知 +</h2> + +<p>要创建用户喜爱的应用,精心设计通知很重要。通知是应用的代言人,还可增强应用的个性化特征。 + + +无用或者不重要的通知会给用户带来烦恼,或者由于过分分散用户的注意力而使其感到愤怒,因此请谨慎使用通知。 + + +</p> + +<h3 id="when_to_display_a_notification">何时显示通知</h3> + +<p>要创建人们乐于使用的应用,就需要认识到用户的注意力和关注点是一种必须予以保护的资源,这一点很重要。 + +尽管 Android 的通知系统在设计上希望最小化通知对用户注意力的影响,但是仍然要重视通知会中断用户任务流程这一事实。在您计划通知时,要问问自己,它们是否足够重要,是否适合让用户中断手上的任务。 + + + + + + +如果您不确定,可允许用户使用应用的通知设置来选择是否接收通知,或者将通知优先级标志调整为 <code>LOW</code> 或 <code>MIN</code>,从而避免在用户做其他事情时分散他们的注意力。 + + + +</p> + + <img src="{@docRoot}images/android-5.0/notifications/TimeSensitive.png" alt="" width="311px" /> + <p style="margin-top:10px" class="img-caption"> + 时间敏感通知的示例 + </p> + +<p>尽管行为良好的应用通常只在用户对其操作后才会发出通知,但在极少数情况下,应用通过无提示的通知形式打断用户也是值得的。 +</p> + +<p>将通知主要用于<strong>时间敏感的事件</strong>,尤其是这些同步事件<strong>涉及其他用户时</strong>。 +例如,传入的聊天属于实时同步通信形式: + +另一个用户在主动等待您的回应。 +日历事件是使用通知并引起用户注意的另一个好例子,因为事件已经迫近,并且日历事件通常涉及其他人员。 + + +</p> + +<h3 style="clear:both" id="when_not_to_display_a_notification">何时不显示通知 +</h3> + +<div class="figure" style="margin-top:60px"> + <img src="{@docRoot}images/android-5.0/notifications/AntiSample1.png" alt="" width="311px" /> +</div> + +<p>在其他很多情况下都不适合显示通知:</p> + +<ul> + <li> 不要将并非特定于用户的信息或并非确实时间敏感的信息告知用户。 + +例如,流经社交网络的异步和未经订阅的更新,通常不适合引发实时中断。 + + +对于确实关注它们的用户,可让他们选择接收通知。 +</li> + <li> 如果相关的新信息当前显示在屏幕上,则不要创建通知。 +不过可以使用应用本身的 UI 在上下文中将新信息直接告知用户。 + + + 例如,聊天应用不应在用户主动和另一名用户聊天时创建系统通知。 +</li> + <li> 对于技术要求不高的操作(例如保存或同步信息或更新应用),如果应用或系统无需用户参与就可解决问题,请不要中断用户。 + +</li> + <li> 如果可以让应用自行恢复错误,而不必让用户采取任何操作,则不要中断用户来告知他们发生此错误。 + +</li> + <li> 请不要创建没有实际通知内容和仅仅是为您的应用做宣传的通知。通知应当提供有用、及时、最新的信息,而不应仅用于推广应用。 + + + +</li> + <li> 请不要为了向用户宣传您的品牌而创建过多的通知。 + + 此类通知会让用户不满,从而很可能离您而去。提供少量更新信息并让用户保持与您的应用交互的最佳方式是开发一个小工具,让用户可以选择是否将其放在主屏幕上。 + + + + +</li> +</ul> + +<h2 style="clear:left" id="interacting_with_notifications">与通知交互 +</h2> + +<p>通知由状态栏中的图标指示,并且可以通过打开抽屉式通知栏进行访问。 + +</p> + +<p>触摸通知会打开相关联的应用并进入与通知匹配的详细内容。在通知上向左或向右滑动会将其从抽屉式通知栏中删除。 + +</p> + +<h3 id="ongoing_notifications">持续性通知</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/MusicPlayback.png" alt="" width="311px" /> + <p class="img-caption"> + 因播放音乐而持续显示的通知 + </p> +</div> +<p>持续性通知可让用户持续了解后台运行的进度。例如,音乐播放器在通知系统中通告当前播放的曲目,并继续进行播放,直至用户停止播放。 + + + +持续性通知也可为持续时间较长的任务(例如下载文件或视频编码之类的任务)向用户显示反馈。 + +用户无法手动从抽屉式通知栏中删除持续性通知。 +</p> + +<h3 id="ongoing_notifications">媒体播放</h3> +<p>在 Android 5.0 中,锁定屏幕不会为弃用的 +{@link android.media.RemoteControlClient} 类显示传输控件。但是它<em>确实</em>会显示通知,因此每个应用的播放通知现在是用户在锁屏状态控制播放的主要方式。 + +此行为可让应用更好地控制显示哪些按钮,这样,无论是否锁屏,都可以为用户提供一致的体验。 + + +</p> + +<h3 style="clear:both" +id="dialogs_and_toasts_are_for_feedback_not_notification">对话框和 Toast +</h3> + +<p>如果您的应用当前未显示在屏幕上,则不应创建对话框或 Toast。 +对话框或 Toast 应仅限用于即时响应用户在应用内部采取的操作。有关使用对话框和 Toast 的进一步指导,请参阅<a href="/design/patterns/confirming-acknowledging.html">确认和确知</a>。 + + + +</p> + +<h3>排名和排序</h3> + +<p>通知属于新闻,因此基本以时间倒序显示,并且会特别考虑应用规定的通知<a href="#correctly_set_and_manage_notification_priority">优先级</a>。 + + +</p> + +<p>通知是锁定屏幕的关键部分,并且在设备显示屏每次亮起时突出显示。 + +锁定屏幕上的空间有限,因此确定哪些通知最为紧急或最密切相关非常重要。 + +由于这个原因,Android 在处理通知时使用了更为精密的排序算法,考虑到以下因素: + +</p> + +<ul> + <li> 时间戳以及应用规定的优先级。</li> + <li> 通知是否最近以声音或振动形式告知过用户。 +(也就是说,如果手机刚发出了铃声,并且用户希望知道“刚才发生了什么?”,那么锁定屏幕应让用户一眼看到相应的通知。) + + +</li> + <li> 与使用 {@link android.app.Notification#EXTRA_PEOPLE} 的通知相关的任何人,尤其是加星标的联系人。 +</li> +</ul> + +<p>为了充分利用此排序功能,请专注于您希望建立的用户体验,而不是拘泥于列表上的某个特定项。 + +</p> + + <img src="{@docRoot}images/android-5.0/notifications/AntiSample3.png" alt="" width="700px" /> + + <p class="img-caption" style="margin-top:10px">Gmail 通知使用的是默认优先级,因此它们的顺序通常低于来自即时通讯应用(例如环聊)的消息,但是在有新邮件送达时会临时占位。 + + + + + </p> + + +<h3>在锁定屏幕上</h3> + +<p>由于通知在锁定屏幕上可见,所以用户隐私是特别重要的考虑事项。 + +通知通常包含敏感信息,并且不一定需要让所有拿起设备并打开显示屏的人看到。 + +</p> + +<ul> + <li> 对于配置了安全锁定屏幕(PIN 码、图案或密码)的设备,界面分为公用和私人部分。 +公用界面可显示在安全锁定屏幕上,因此任何人都可看见。 +私人界面是锁定屏幕背后的内容,只有在用户登录设备后才会显示。 +</li> +</ul> + +<h3>用户对显示在安全锁定屏幕上的信息的控制</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/LockScreen@2x.png" srcset="{@docRoot}images/android-5.0/notifications/LockScreen.png 1x" alt="" width="311px" /> + <p class="img-caption"> + 位于锁定屏幕上的通知,具有用户解锁设备后可显示的内容。 + </p> +</div> + +<p>在设置安全锁定屏幕时,用户可以选择从安全锁定屏幕隐藏敏感的详细信息。 +在这种情况下,系统 UI 会考虑通知的<em>可见性级别</em>,从而确定哪些内容可以安全地显示出来。 + +</p> +<p> 要控制可见性级别,可调用 <code><a +href="/reference/android/app/Notification.Builder.html#setVisibility(int)">Notification.Builder.setVisibility()</a></code>,然后指定以下值之一: + +</p> + +<ul> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PUBLIC">VISIBILITY_PUBLIC</a></code>。显示通知的完整内容。 + + 在未指定可见性的情况下,此设置是系统的默认设置。</li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PRIVATE">VISIBILITY_PRIVATE</a></code>。在锁定屏幕上,会显示通知的基本信息,包括其图标以及发布此通知的应用名称。 + +剩下的通知详细信息不会显示。需要注意的一些有用建议如下: + + <ul> + <li> 如果您希望为通知提供不同的公用版本,供系统显示在安全锁定屏幕上,可在 <code><a +href="/reference/android/app/Notification.html#publicVersion">Notification.publicVersion</a></code> 字段中提供替换通知对象。 + + + + <li> 该设置可让您的应用有机会创建有用内容的删减版本,但是不会显示个人信息。 +可参考短信应用的示例,这种应用的通知包括短信的文本以及发信者的姓名和联系人图标。该通知应为 <code>VISIBILITY_PRIVATE</code>,但是 <code>publicVersion</code> 仍然可以包含“有 3 条新消息”这样的有用信息,而不会提供其他识别性详细信息。 + + + + + </ul> + </li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_SECRET">Notification.VISIBILITY_SECRET</a></code>。仅显示最为精简的信息,甚至不包括通知图标。 +</li> +</ul> +<h2 style="clear:both" id="notifications_on_android_wear">Android Wear 上的通知 +</h2> + +<p>通知及其<em>操作</em>默认会和穿戴设备桥接。开发者可以控制哪些通知会从手机桥接至手表,反之亦然。 + + +开发者也可以控制哪些操作会进行桥接。如果您的应用包含无法通过单次点击完成的操作,则可以将这些操作隐藏在您的 Android Wear 设备通知中,或者考虑将它们连接至 Android Wear 设备应用,从而可让用户在其手表上完成操作。 + + + + + +</p> + +<h4>桥接通知和操作</h4> + +<p>连接的设备,例如手机,可将通知桥接至 Android Wear 设备,从而将通知显示在此处。 +与此相似,您也可以桥接操作,从而让用户可在 Android Wear 设备上直接操作通知。 +</p> + +<p><strong>桥接</strong></p> + +<ul> + <li> 新的即时通讯</li> + <li> 单次点击操作,例如 +1、赞、收藏</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/WearBasic.png" width="156px" height="156px" alt="" /> + +<p><strong>不要桥接</strong></p> + +<ul> + <li> 新收到的播客通知</li> + <li> 映射至手表上无法使用的功能的操作</li> +</ul> + + + +<p><h4>为 Android Wear 设备定义的独特操作</h4></p> + +<p>有些操作只能在 Android Wear 上执行。包括以下情况:</p> + +<ul> + <li> 例如“马上回来”这样的预设回复快速列表</li> + <li> 在手机上打开</li> + <li> 调出语音输入屏幕的“评论”或“回复”操作</li> + <li> 启动 Android Wear 专用应用的操作</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/ReplyAction.png" width="156px" height="156px" alt="" /> diff --git a/docs/html-intl/intl/zh-tw/design/get-started/principles.jd b/docs/html-intl/intl/zh-tw/design/get-started/principles.jd new file mode 100644 index 0000000..27cce81 --- /dev/null +++ b/docs/html-intl/intl/zh-tw/design/get-started/principles.jd @@ -0,0 +1,307 @@ +page.title=Android 設計原則 +@jd:body + +<p>這些設計原則是由 Android 使用者體驗團隊開發,並針對 Android 使用者體驗團隊的需求所開發,以使用者的最大利益為出發點。對於 Android 開發者和設計者而言,針對不同類型的裝置,這些原則仍持續是更詳細設計方針的基礎。 + + + +</p> + +<p> +當您套用您本身的創意與設計思維時,請考慮這些原則。 +偏離一般做法要帶有目的。 +</p> + +<h2 id="enchant-me">使人著迷</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="delight-me">以出乎意外的方式取悅人</h4> +<p>漂亮的外觀、精心設置的動畫,或時機恰到好處的音效,都是令人感到喜悅的體驗。 +微妙的效果有助於產生毫不費力及強大力量就在手邊的感覺。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_delight.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="real-objects-more-fun">真實的物件比按鈕和功能表更有趣</h4> +<p>讓人們可以在您應用程式中直接輕觸和操縱物件,這可減少執行某項工作所需的認知過程,同時在情緒上更令人感到滿足。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_real_objects.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-it-mine">提供個人設定</h4> +<p>人們喜歡加上個人風格,因為這有助於他們感到自在並握有主控權。提供能令人感受及美觀的預設設定,但也可以考慮使用不會阻礙主要工作卻又好玩的可選用性自訂項目。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_it_mine.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="get-to-know-me">設法了解使用者</h4> +<p>隨著時間而學習使用者的偏好。讓人們易於取得之前的選擇,而不是一再詢問他們會做出相同選擇的問題。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_get_to_know_me.png"> + + </div> +</div> + +<h2 id="simplify-my-life">簡化生活</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="keep-it-brief">保持簡潔</h4> +<p>以簡單單字組成簡短語句。人們傾向於略過冗長的句子。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_keep_it_brief.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="pictures-faster-than-words">圖片的傳達效果更勝於言語</h4> +<p>請考慮使用圖片來解釋想法。圖片能吸引人們的注意力,並比言語更有效率。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_pictures.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="decide-for-me">幫使用者決定,但使用者擁有最終決定權</h4> +<p>做出最好的猜測,先行動,而非先詢問。太多的選擇和決定會讓人們不高興。 +為防止錯誤,務必允許復原。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_decide_for_me.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="only-show-when-i-need-it">必要時僅顯示使用者需要的東西</h4> +<p>人們無法承受一次看到太多東西。將工作和資訊細分成小型、易消化的區塊。 +隱藏當下不重要的選項,但在人們需要選擇時要明確指導。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_information_when_need_it.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="always-know-where-i-am">使用者應該總是清楚所在位置</h4> +<p>給人們信心,知道自己沒有迷路。讓您應用程式中的各處看起來都有獨特性,並使用轉換來顯示畫面之間的關係。 +針對進行中的工作提供回饋。</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_navigation.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="never-lose-my-stuff">別弄丟使用者的東西</h4> +<p>儲存使用者花時間所建立的資訊,並且讓使用者可從任何地方存取。跨手機、平板電腦和電腦記住設定、個人風格和建立的資訊。 +這會讓升級變得很簡單。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_never_lose_stuff.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="looks-same-should-act-same">如果看起來一樣,就應該有相同的動作</h4> +<p>讓功能看起來就不一樣,而非變化微妙,這可以協助人們辨別功能差異。在相同輸入環境下,因為模式看起來很類似但卻有不同的動作,請盡量避免使用。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_looks_same.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="interrupt-only-if-important">重要時才打斷</h4> +<p>就像一位好的私人助理,讓人們免於無關緊要的枝微末節。人們總想集中注意力,除非很重要且具時效性,不然貿然中斷會令人感到費力且沮喪。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_important_interruption.png"> + + </div> +</div> + +<h2 id="make-me-amazing">讓使用者驚艷</h2> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="give-me-tricks">提供使用者各處通用的訣竅</h4> +<p>當人們能自行弄清楚來龍去脈時是很棒的體驗。運用來自其他 Android 應用程式的視覺模式和肌肉記憶效應,讓使用者更易於學會您的應用程式。 +例如,擺動手勢可能是很好的導覽捷徑。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_tricks.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="its-not-my-fault">不是使用者的錯</h4> +<p>提示人們更正時要溫和。人們使用您的應用程式時,會想要感受到自已非常明智。如果有什麼不對,請提供明確的復原指示,但不需要使用者明瞭技術細節。如果可以,請盡量在幕後修正。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_error.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="sprinkle-encouragement">分段鼓勵</h4> +<p>將複雜工作細分成更小的步驟,讓使用者可以輕鬆完成。對動作給予回饋,即使只是個微光效果。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_sprinkle_encouragement.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="do-heavy-lifting-for-me">為使用者處理繁重的工作</h4> +<p>讓新手也能做出以前從未想像過可以辦到的事情,讓使用者有專家的感覺。例如,組合多個相片效果的捷徑,只要幾個步驟,即可讓業餘照片令人驚艷。 + +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_heavy_lifting.png"> + + </div> +</div> + +<div class="vspace size-2"> </div> + +<div class="layout-content-row"> + <div class="layout-content-col span-7"> + +<h4 id="make-important-things-fast">快速找到重要的功能</h4> +<p>並非所有的動作都一視同仁。決定應用程式中最重要的部分,並讓使用者易於找到並可迅速使用,例如相機的快門按鈕或音樂播放器的暫停按鈕。 +</p> + + </div> + <div class="layout-content-col span-6"> + + <img src="{@docRoot}design/media/principles_make_important_fast.png"> + + </div> +</div> diff --git a/docs/html-intl/intl/zh-tw/design/material/index.jd b/docs/html-intl/intl/zh-tw/design/material/index.jd new file mode 100644 index 0000000..620ee6e --- /dev/null +++ b/docs/html-intl/intl/zh-tw/design/material/index.jd @@ -0,0 +1,186 @@ +page.title=材料設計 +page.tags=Material, design +page.type=設計 +page.image=design/material/images/MaterialLight.png + +@jd:body + +<!-- developer docs box --> +<a class="notice-developers right" href="{@docRoot}training/material/index.html"> + <div> + <h3>開發人員文件</h3> + <p>使用材料設計建立應用程式</p> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=p4gmvHyuZzw"> +<div> + <h3>影片</h3> + <p>材料設計簡介</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=YaG_ljfzeUw"> +<div> + <h3>影片</h3> + <p>紙張和墨水:重要的材料</p> +</div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=XOcCOBe8PTc"> +<div> + <h3>影片</h3> + <p>Google I/O 應用程式中的材料設計</p> +</div> +</a> + + + +<p itemprop="description">材料設計是一份內容廣泛的綜合性指南,引導您跨平台、跨裝置進行視覺、動態和互動的設計。 +Android 現已納入對材料設計應用程式的支援。 +如果要在 Android 應用程式中使用材料設計,請依照<a href="http://www.google.com/design/spec">材料設計規格</a>中定義的指示,並使用 +Android +5.0 (API 層級 21) 或後續版本中的新元件和新功能。</p> + +<p>Android 提供下列元素,供您打造材料設計應用程式:</p> + +<ul> + <li>一個新的設計風格</li> + <li>用於複雜檢視的小工具</li> + <li>自訂陰影和動畫的新 API</li> +</ul> + +<p>如需取得如何在 Android 上實作材料設計的詳細資訊,請詳見<a href="{@docRoot}training/material/index.html">使用材料設計建立應用程式</a>。 +</p> + + +<h3>材料設計風格</h3> + +<p>材料設計風格提供您應用程式使用的新樣式、可以讓您設定色板的系統小工具,並針對輕觸回饋與操作行為轉換提供預設動畫。 +</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/MaterialDark.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">深色材料設計風格</p> + </div> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/MaterialLight.png" width="500" height="238" /> + <div style="width:140px;margin:0 auto"> + <p style="margin-top:8px">淺色材料設計風格</p> + </div> +</div> +<br style="clear:left"/> +</div> + +<p>如需詳細資訊,請參閱<a href="{@docRoot}training/material/theme.html">使用材料設計風格</a>。 +</p> + + +<h3>清單和卡片</h3> + +<p>Android 提供兩個新的小工具,搭配材料設計樣式與動畫,可用來顯示清單和卡片: +</p> + +<!-- two columns --> +<div style="width:700px;margin-top:25px;margin-bottom:20px"> +<div style="float:left;width:250px;margin-left:40px;margin-right:60px;"> + <img src="{@docRoot}design/material/images/list_mail.png" width="500" height="426" /> + <p>新的 <code>RecyclerView</code> 小工具是 <code>ListView</code> +更容易插入的版本,支援不同的版面配置類型,並提供效能改善。</p> +</div> +<div style="float:left;width:250px;margin-right:0px;"> + <img src="{@docRoot}design/material/images/card_travel.png" width="500" height="426" /> + <p>新的 <code>CardView</code> 小工具讓您可以顯示卡片內的重要資訊,並且該資訊都能擁有一致的外觀與風格。 +</p> +</div> +<br style="clear:left"/> +</div> + +<p>如需詳細資訊,請參閱<a href="{@docRoot}training/material/lists-cards.html">建立清單和卡片</a>。 +</p> + + +<h3>檢視陰影</h3> + +<p>除了 X 和 Y 屬性外,Android 中的檢視現在也有 Z 屬性。 +這個新屬性代表檢視的高度,這會決定:</p> + +<ul> +<li>陰影大小:帶有較高 Z 值的檢視會投射更大的陰影。</li> +<li>繪製順序:具有較高 Z 值的檢視會顯示在其他檢視之上。</li> +</ul> + +<div style="width:290px;margin-left:35px;float:right"> + <div class="framed-nexus5-port-span-5"> + <video class="play-on-hover" autoplay> + <source src="{@docRoot}design/material/videos/ContactsAnim.mp4"/> + <source src="{@docRoot}design/videos/ContactsAnim.webm"/> + <source src="{@docRoot}design/videos/ContactsAnim.ogv"/> + </video> + </div> + <div style="font-size:10pt;margin-left:20px;margin-bottom:30px"> + 如要重播影片,請按一下裝置螢幕<em></em> + </div> +</div> + +<p>如需取得詳細資訊,請參閱<a href="{@docRoot}training/material/shadows-clipping.html">定義陰影和裁剪檢視</a>。 +</p> + + +<h3>動畫</h3> + +<p>新的動畫 API 可針對 UI 控制項的輕觸回饋、檢視狀態中的變更,以及行為轉換,讓您建立自訂動畫。 +</p> + +<p>這些 API 讓您可以:</p> + +<ul> +<li style="margin-bottom:15px"> +回應您檢視中有<strong>輕觸回饋</strong>動畫的輕觸事件。 +</li> +<li style="margin-bottom:15px"> +隱藏和顯示有<strong>循環顯示</strong>動畫的檢視。 +</li> +<li style="margin-bottom:15px"> +在有自訂<strong>行為轉換</strong>動畫的行為間切換。 +</li> +<li style="margin-bottom:15px"> +使用<strong>曲線動作</strong>建立更自然的動畫。 +</li> +<li style="margin-bottom:15px"> +在帶有<strong>檢視狀態變更</strong>動畫的一個或多個檢視屬性中變更動畫。 +</li> +<li style="margin-bottom:15px"> +在檢視狀態變更間,顯示<strong>狀態清單可繪項目</strong>中的動畫。 +</li> +</ul> + +<p>輕觸回饋動畫會內建於數個標準檢視中,例如按鈕等。新 API 可讓您自訂這些動畫,並將其新增至您的自訂檢視中。 +</p> + +<p>如需詳細資訊,請參閱<a href="{@docRoot}training/material/animations.html">定義自訂動畫</a>。 +</p> + + +<h3>可繪項目</h3> + +<p>可繪項目的這些新功能可以幫助您實作材料設計應用程式:</p> + +<ul> +<li><strong>矢量可繪項目</strong>可以調整大小,但又不會喪失定義,最適合於應用程式中的單色圖示。 +</li> +<li><strong>可繪項目著色</strong>可讓您在執行階段將點陣圖定義為 Alpha 遮罩,並以一個顏色進行著色。 +</li> +<li><strong>顏色提取</strong>可讓您自動從點陣圖影像中提取顯著顏色。 +</li> +</ul> + +<p>如需詳細資訊,請參閱<a href="{@docRoot}training/material/drawables.html">使用可繪項目</a>。 +</p> diff --git a/docs/html-intl/intl/zh-tw/design/patterns/confirming-acknowledging.jd b/docs/html-intl/intl/zh-tw/design/patterns/confirming-acknowledging.jd new file mode 100644 index 0000000..ac8975f --- /dev/null +++ b/docs/html-intl/intl/zh-tw/design/patterns/confirming-acknowledging.jd @@ -0,0 +1,70 @@ +page.title=確認及確認完成 +page.tags=dialog,toast,notification +@jd:body + +<p>在某些情況下,當使用者在您應用程式中呼叫一個動作時,最好是透過文字來「確認」(confirm) <em></em>或「確認完成」<em></em>(acknowledge)。</p> + +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_confirming.png"> + <p><strong>確認</strong>是要求使用者確認真的要進行剛剛呼叫的動作。在某些情況下,確認訊息出現時會伴隨警告或需要使用者考量是否採取動作的相關重要資訊。</p> + </div> + <div class="layout-content-col span-6"> + <img src="{@docRoot}design/media/confirm_ack_acknowledge.png"> + <p><strong>確認完成</strong>是顯示文字,讓使用者知道已經完成剛剛呼叫的動作。這會排除系統正在採取之隱式作業的不確定性。在某些情況下,確認完成出現時會伴隨復原動作的選項。</p> + </div> +</div> + +<p>使用這種方式和使用者溝通有助於降低已發生或將發生事情的不確定性。確認或確認完成也可以防止使用者誤犯可能會後悔的錯誤。</p> + +<h2>確認或確認完成使用者動作的時機</h2> +<p>並非所有的動作都能保證會執行確認或確認完成。使用此流程圖可以指引您的設計決策。</p> +<img src="{@docRoot}design/media/confirm_ack_flowchart.png"> + +<h2>確認</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>範例:Google Play 書籍</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_books.png"> + <p>在此範例中,使用者已要求從其 Google Play 媒體庫中刪除一本書籍。顯示<a href="{@docRoot}design/building-blocks/dialogs.html#alerts">警示</a>來確認此動作,因為使用者必須了解將不再針對任何裝置提供這本書籍。</p> + <p>設計一個確認的對話方塊時,要讓標題具有意義就必須回應要求的動作。</p> + </div> + <div class="layout-content-col span-7"> + <h4>範例:Android Beam</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_beam.png"> + <p>確認不一定要以具有兩個按鈕的警示來呈現。在啟動 Android Beam 之後,會提示使用者輕觸要共用的內容 (在此範例中是一張照片)。如果他們決定不進行,只要移開他們的電話即可。</p> + </div> +</div> + +<h2>確認完成</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>範例:已儲存放棄的 Gmail 草稿</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_draftsave.png"> + <p>在此範例中,如果使用者從 Gmail 撰寫畫面返回,可能會發生預期外的狀況:會自動儲存目前的草稿。以快顯通知 (toast) 形式出現的確認完成,會讓使用者明瞭此情況。確認完成會在幾秒鐘後淡出。</p> + <p>在此並不合適使用復原功能,因為儲存動作是由應用程式發起,而非使用者。瀏覽至草稿清單,就可以方便且快速地繼續撰寫。</p> + + </div> + <div class="layout-content-col span-6"> + <h4>範例:已刪除 Gmail 會話群組</h4> + <img src="{@docRoot}design/media/confirm_ack_draft_deleted.png"> + <p>使用者從 Gmail 清單中刪除一個會話群組後,會出現確認完成訊息,並提供一個復原選項。確認完成會持續出現,直到使用者採取不相關的動作,例如捲動清單。</p> + </div> +</div> + +<h2>無「確認」或「確認完成」</h2> +<div class="layout-content-row"> + <div class="layout-content-col span-6"> + <h4>範例:+1 中</h4> + <img style="padding: 33px 0 30px;" src="{@docRoot}design/media/confirm_ack_ex_plus1.png"> + <p><strong>確認並非必要</strong>。如果使用者不小心按了 + 1 按鈕,這並不是什麼大問題。他們可以再次輕觸按鈕,復原此動作。</p> + <p><strong>確認完成並非必要</strong>。使用者將會看到 +1 彈起並變成紅色。這是個非常明確的訊號。</p> + </div> + <div class="layout-content-col span-7"> + <h4>範例:從主螢幕移除應用程式</h4> + <img src="{@docRoot}design/media/confirm_ack_ex_removeapp.png"> + <p><strong>確認並非必要</strong>。這是特意設計的動作:使用者必須拖曳項目放到相對較大且隔離的目標上。因此極不可能發生意外狀況。但如果使用者後悔所做的決定,只需幾秒鐘,就可以恢復原狀。</p> + <p><strong>確認完成並非必要</strong>。使用者會知道應用程式從主螢幕消失,因為是他們將應用程式拖曳離開,所以才會消失。</p> + + </div> +</div> diff --git a/docs/html-intl/intl/zh-tw/design/patterns/navigation.jd b/docs/html-intl/intl/zh-tw/design/patterns/navigation.jd new file mode 100644 index 0000000..db160c2 --- /dev/null +++ b/docs/html-intl/intl/zh-tw/design/patterns/navigation.jd @@ -0,0 +1,213 @@ +page.title=使用 [返回] 及 [上一層] 導覽 +page.tags="navigation","activity","task","up navigation","back navigation" +page.image=/design/media/navigation_between_siblings_gmail.png +@jd:body + +<a class="notice-developers" href="{@docRoot}training/implementing-navigation/index.html"> + <div> + <h3>開發人員文件</h3> + <p>實作有效的導覽</p> + </div> +</a> + +<p itemprop="description">一致的導覽是整體使用者體驗的必備組成。基本導覽的行為若不一致又令人意外,是最令使用者感到更沮喪的狀況。 +Android 3.0 已將重大變更導入全域的導覽行為中。 +完全遵循 [返回] 及 [上一層] 的方針,會讓使用者感到您的應用程式導覽既可靠又符合預期。 +</p> +<p>Android 2.3 和更早版本依賴系統 [返回] +<em></em>按鈕,以支援應用程式內的導覽。在 Android 3.0 導入動作列之後,出現第二個導覽機制:[上一層] +<em></em>按鈕,由應用程式圖示和左指符號組成。</p> + +<img src="{@docRoot}design/media/navigation_with_back_and_up.png"> + +<h2 id="up-vs-back">[上一層] vs.[返回]</h2> + +<p>[上一層] 按鈕用於在畫面間有階層關係的應用程式中導覽。 +例如,如果畫面 A +顯示項目清單,然後選擇其中一個項目導致進入畫面 B (更詳細呈現該項目),那麼畫面 B 應該提供 [上一層] 按鈕,以便返回畫面 A。 +</p> +<p>如果畫面是在應用程式中的最頂端 (亦即應用程式的首頁),則不應該會有 [上一層]按鈕。 +</p> + +<p>系統 [返回] 按鈕用於逆時間順序導覽,透過歷程記錄,可以經歷使用者最近使用過的畫面。 +[返回] 通常基於畫面之間的暫時關係,而非應用程式的階層。 +</p> + +<p>當先前檢視的畫面也是目前畫面的階層父項時,按下 +[返回] 按鈕和按下 [上一層] 按鈕效果相同 — 這是常見的狀況。 +然而,與 [上一層] 按鈕不同的是 (該按鈕可以確保使用者仍停留在您的應用程式內):[返回] +按鈕可以讓使用者返回主畫面,或甚至是不同的應用程式。</p> + +<img src="{@docRoot}design/media/navigation_up_vs_back_gmail.png"> + +<p>[返回] 按鈕還支援幾個間接關聯畫面對畫面導覽的行為: +</p> +<ul> +<li>關閉浮動視窗 (對話、快顯)</li> +<li>關閉內容相關的動作列,並從選取項目移除醒目顯示</li> +<li>隱藏畫面鍵盤 (IME)</li> +</ul> +<h2 id="within-app">在應用程式內導覽</h2> + +<h4>導覽至具有多重入口的畫面</h4> +<p>有時候,一個畫面在應用程式的階層中並沒有嚴謹的位置,而且可以從多個入口存取 — 例如可以從您應用程式中任何其他畫面存取的設定畫面。在這種情況下,[上一層] +按鈕應該選擇返回導引至此畫面的前一畫面,這個行為與 [返回] 相同。 + +</p> +<h4>在畫面內變更檢視</h4> +<p>變更畫面的檢視選項並不會變更 [上一層] 或 [返回] 的行為:畫面仍維持在應用程式階層中的相同位置,並不會建立新的導覽歷程記錄。 +</p> +<p>這類檢視變更的範例如下:</p> +<ul> +<li>使用標籤和/或左與右滑動來切換檢視</li> +<li>使用下拉清單 (亦即折疊標籤) 切換檢視</li> +<li>篩選清單</li> +<li>對清單排序</li> +<li>變更顯示特性 (如縮放)</li> +</ul> +<h4>在同層級畫面間導覽</h4> +<p>當您的應用程式支援從項目清單導覽至項目之一的詳細檢視時,使用者通常會想使用方向導覽功能,以便從該項目導覽至清單中的前一個或後一個項目。 + +例如在 Gmail 中,可以很容易從會話群組向左或右滑動,方便檢視相同「收件匣」中的較新或舊會話群組。 +就像在一個畫面中變更檢視時,這類導覽不會變更 [上一層] 或 [返回] 的行為。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_gmail.png"> + +<p>然而有一個明顯的例外是,在不被引用清單綁在一起的相關詳細資料檢視之間瀏覽時 — 例如在 Play 商店中於相同開發者的不同應用程式之間瀏覽時,或是在相同演出者的專輯間瀏覽時。 + +在這些情況下,瀏覽每個連結都會產生歷程記錄,這會造成 [返回] 按鈕會經歷每個先前檢視過的畫面。 +[上一層] 應該會繼續略過這些相關的畫面,並導覽到最近檢視過的容器畫面。 +</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market1.png"> + +<p>基於您對詳細資料檢視的瞭解,您有能力讓 [上一層] 行為甚至變得更聰明。 +再延伸說明之前提及的 Play 商店範例,想像使用者已從最近檢視的「書籍」導覽至「電影」改編的詳細資料。 +在這種情況下,[上一層] +可以返回到使用者之前沒有導覽過的上層容器 (電影)。</p> + +<img src="{@docRoot}design/media/navigation_between_siblings_market2.png"> + +<h2 id="into-your-app">透過「主畫面小工具」和「通知」,導覽至您的應用程式</h2> + +<p>您可以使用主畫面小工具或通知,協助您直接導覽至深入您應用程式階層中的畫面。 +例如,Gmail 的「收件匣」小工具和新郵件通知,都可以略過「收件匣」畫面,將使用者直接帶到會話群組檢視之中。 +</p> + +<p>針對這兩種情況,可以使用下列方式來處理 [上一層] 按鈕:</p> + +<ul> +<li>如果目的地畫面通常是透過您應用程式中的一個特定畫面到達,那麼 [上一層] 應該要導覽至該畫面。<em></em> +</li> +<li>否則<em></em>, [上一層] 應該導覽至您應用程式的最頂端 (「主」) 畫面。</li> +</ul> + +<p>就 [返回] 按鈕而言,您應讓導覽更符合預期,方法是在工作的返回堆疊中,插入前往應用程式最頂端畫面的完整向上導覽路徑。 +這可讓忘了如何進入您應用程式的使用者,能在退出之前導覽至應用程式的最頂端畫面。 + +</p> + +<p>舉例來說,Gmail 的主畫面小工具有一個按鈕,可以直接往下進入撰寫畫面。 +來自撰寫畫面的 [上一層] 或 [返回] 按鈕,會將使用者帶到「收件匣」中,而此處的 [返回] 按鈕則可繼續前往至「主畫面」。 +</p> + +<img src="{@docRoot}design/media/navigation_from_outside_back.png"> + +<h4>間接通知</h4> + +<p>當您的應用程式需要同時呈現多個事件的資訊時,可以使用單一通知,引導使用者進入一個插頁畫面。 +此畫面會摘要這些事件,並提供路徑,讓使用者可以深入應用程式之中。這種風格的通知稱為「間接通知」<em></em>。 + +</p> + +<p>與標準 (直接) 通知不同的是,從間接通知的插頁畫面按下 [返回],會讓使用者返回至通知觸發的起點 — 無其他畫面會插入至返回堆疊之中。 + +一旦使用者從插頁畫面繼續進入應用程式之後,[上一層] +與 [返回] 會如上所述,其行為就像針對標準通知一樣:在應用程式內導覽,而非返回插頁畫面。 +</p> + +<p>例如,假設 Gmail 中的使用者收到來自「行事曆」的間接通知。輕觸這個通知會打開插頁畫面,而此畫面會顯示數個不同事件的提醒。 + +從插頁畫面輕觸 [返回],會讓使用者返回至 Gmail。輕觸特定事件會將使用者帶離插頁畫面,並進入完整的「行事曆」應用程式,顯示事件的詳細資料。 + +從事件詳細資料中,[上一層] 和 [返回] 會導覽至「行事曆」的最頂層檢視。</p> + +<img src="{@docRoot}design/media/navigation_indirect_notification.png"> + +<h4>快顯通知</h4> + +<p>快顯通知<em></em>會略過通知匣,直接出現在使用者面前。 +這不常使用,<strong>應該要保留在需要適時回應,以及必須中斷使用者前後關聯動作的時候</strong>。 +例如,Talk +就使用這種風格,用來提示使用者有朋友邀請加入視訊聊天,而且此邀請會在幾秒之後自動過期。 +</p> + +<p>就導覽行為而言,快顯通知緊接著間接通知插頁畫面的行為。 +[返回] 會關閉快顯通知。如果使用者從快顯導覽進入通知應用程式,[上一層] +和 [返回] 會遵循標準通知的規則,只在應用程式內導覽。 +</p> + +<img src="{@docRoot}design/media/navigation_popup_notification.png"> + +<h2 id="between-apps">在應用程式間導覽</h2> + +<p>Android 系統的基本優點之一是應用程式互相啟動的能力,讓使用者能夠直接從一個應用程式導覽至另一個應用程式。 +例如,需要擷取一張相片的應用程式可以啟動「相機」應用程式,而此應用程式會將相片傳回引用的應用程式。開發人員可以輕鬆利用其他應用程式的程式碼,而使用者在經常執行的動作中可以享受一致性的體驗,這對雙方都是一大好處。 + + + +</p> + +<p>要瞭解應用程式對應用程式的導覽,重要的是要瞭解以下討論的 Android 架構行為。 +</p> + +<h4>活動、工作和意圖</h4> + +<p>在 Android 中,<strong>活動</strong>是一個應用程式元件,定義了資訊畫面,以及使用者可以執行的所有關聯動作。 +您的應用程式是個活動的集合,包括您可以建立及您能從其他應用程式重複使用的活動。 +</p> + +<p><strong>工作</strong>是使用者遵循以達到目標的一系列活動。單一工作可以利用來自單一應用程式的活動,或是汲取數個不同應用程式的活動。 + +</p> + +<p><strong>意向</strong>是指應用程式所發出想要另一套應用程式協助執行某動作訊號的機制。 +應用程式的活動可指示其可回應哪些意向。 +針對如「共用」等常見意向,使用者可能已安裝許多可以滿足此要求的應用程式。 +</p> + +<h4>範例:在應用程式間導覽,以支援共用</h4> + +<p>要理解活動、工作和意向如何攜手合作,請思考應用程式如何讓使用者使用另一套應用程式來共用內容。例如,從「主」畫面啟動 Play 商店應用程式,開始新工作 A (見下圖)。 + +在導覽經歷 Play 商店,並輕觸一本促銷的書籍以查看詳細資料後,使用者仍會停留在相同工作中,並透過新增行為延伸工作。 +觸發「共用」動作會提示使用者一個對話框,列出已註冊可用來處理「共用」意向的每個活動 (來自不同的應用程式)。 + +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_inward.png"> + +<p>當使用者選擇透過 Gmail 共用,Gmail +的撰寫活動會被新增為工作 A 的延續 — 而不會建立新工作。如果 Gmail 有本身的工作正在背景執行,這並不會影響該工作。 +</p> + +<p>從撰寫活動中,傳送訊息或輕觸 [返回] 按鈕,會讓使用者返回至書籍詳細資料的活動。 +繼續輕觸 [返回] 則會經由 Play 商店往回導覽,最終到達「主畫面」。 +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_back.png"> + +<p>然而,透過輕觸撰寫行為的 [上一層],代表使用者指明停留在 Gmail 的意願。 +Gmail 的會話群組清單活動會隨即出現,並針對該活動建立一個新的工作 B。新工作的最後根源都是「主畫面」,所以從會話群組輕觸 [返回] 會返回至該處。 +</p> + +<img src="{@docRoot}design/media/navigation_between_apps_up.png"> + +<p>工作 A 仍然存在背景之中,而使用者可能會在稍後返回 (例如,透過「最近」畫面)。 +如果 Gmail 在背景正在執行自己的工作,則其會被工作 B 取代 — 並捨棄之前的前後關係,而就使用者的新目標。 +</p> + +<p>當您的應用程式註冊來處理具有深入應用程式階層活動的意向時,請參考<a href="#into-your-app">透過主畫面視窗小工具和通知,導覽至您的應用程式</a>,取得如何指定 [上一層] 導覽的指導方針。 + +</p> diff --git a/docs/html-intl/intl/zh-tw/design/patterns/notifications.jd b/docs/html-intl/intl/zh-tw/design/patterns/notifications.jd new file mode 100644 index 0000000..3e3f59c --- /dev/null +++ b/docs/html-intl/intl/zh-tw/design/patterns/notifications.jd @@ -0,0 +1,872 @@ +page.title=通知 +page.tags="notifications","design","L" +@jd:body + + <a class="notice-developers" href="{@docRoot}training/notify-user/index.html"> + <div> + <h3>開發人員文件</h3> + <p>通知使用者</p> + </div> +</a> + +<a class="notice-designers" href="notifications_k.html"> + <div> + <h3>Android 4.4 及較早版本中的通知</h3> + </div> +</a> + +<!-- video box --> +<a class="notice-developers-video" href="https://www.youtube.com/watch?v=Uiq2kZ2JHVY"> +<div> + <h3>影片</h3> + <p>DevBytes:Android L 開發者預覽版中的通知</p> +</div> +</a> + +<style> + .col-5, .col-6, .col-7 { + margin-left:0px; + } +</style> + +<p>通知系統可以隨時知會使用者有關應用程式中的相關事件與及時事件,例如來自朋友的新聊天訊息。您可以將通知視為一種事件發生時警示使用者的新聞管道,或是在使用者沒注意時,記錄事件的日誌 — 並會視情況跨所有 Android 裝置且同步處理。 + + + + + +</p> + +<h4 id="New"><strong>Android 5.0 新功能</strong></h4> + +<p>在 Android 5.0 中,通知會透過結構化、視覺化和功能化的效果接收重要更新: +</p> + +<ul> + <li>通知已經有視覺方面的變更,與新的材料設計風格一致。 +</li> + <li> 現在可在裝置的鎖定螢幕上提供通知,而敏感內容仍可隱藏於其背後。 + +</li> + <li>當裝置於使用中收到高優先順序的通知時,會使用稱為預告 (heads-up) 通知的新格式。 +</li> + <li>雲端同步化通知:關閉您其中一部 Android 裝置的通知,隨之也會在其他裝置上關閉此通知。 + +</li> +</ul> + +<p class="note"><strong>注意:</strong>此版本 Android 中的通知設計和先前版本大相徑庭。 + +如需有關先前版本通知的設計資訊,請參閱 +<a href="./notifications_k.html">Android 4.4 及較早版本中的通知</a>。</p> + +<h2 id="Anatomy">通知的詳細分析</h2> + +<p>本節會重溫通知的基礎功能,以及其如何可在不同類型裝置上出現。 +</p> + +<h3 id="BaseLayout">基礎版面配置</h3> + +<p>至少,所有通知都必須包含一個基礎版面配置,它包含:</p> + +<ul> + <li> 通知的<strong>圖示</strong>。該圖示代表原始應用程式。如果應用程式會產生一種以上的通知類型,則圖示也有可能表示通知類型。 + + +</li> + <li> 一個通知<strong>標題</strong>和額外<strong>文字</strong>。 +</li> + <li> 一個<strong>時間戳記</strong>。</li> +</ul> + +<p>針對先前平台版本,使用 {@link android.app.Notification.Builder Notification.Builder} +所建立的通知其外觀與運作方式和在 Android 5.0 +中的一樣,只是在系統為您處理的方式上有一點樣式上的變更。 +如需更多有關 Android 先前版本通知的詳細資訊,請參閱 +<a href="./notifications_k.html">Android 4.4 及較早版本中的通知</a>。 +</p></p> + + + <img style="margin:20px 0 0 0" src="{@docRoot}images/android-5.0/notifications/basic_combo.png" alt="" width="700px" /> + + +<div style="clear:both;margin-top:20px"> + <p class="img-caption"> + 手持裝置通知的基礎版面配置 (左),以及穿戴裝置上的相同通知 (右),都帶有使用者相片及一個通知圖示 + + </p> + </div> + +<h3 id="ExpandedLayouts">擴充的版面配置</h3> + + +<p>您可以選擇到底要讓您應用程式的通知提供多詳細的資料。 +通知可以顯示訊息的前幾行,也可以顯示較大的影像預覽。 +此額外資訊可提供使用者更多內容,而且 — 在某些情況下 — 可讓使用者讀取完整訊息。 + + +使用者可以捏合縮放或執行單手指滑動,在精簡的版面配置與擴充的版面配置間切換。 + + + 對於單一事件通知,Android 提供三個擴充版面配置範本 +(文字、收件匣和影像),讓您可以在應用程式中使用。 +以下的影像顯示單一事件通知在手持裝置 (左) 和穿戴裝置 (右) 上的外觀。 + +</p> + +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/expandedtext_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/stack_combo.png" + alt="" width="700px" height;="284px" /> +<img style="margin-top:30px" +src="{@docRoot}images/android-5.0/notifications/ExpandedImage.png" + alt="" width="311px" height;="450px" /> + +<h3 id="actions" style="clear:both; margin-top:40px">動作</h3> + +<p>Android 支援可以在通知底端顯示的選用動作。透過動作,使用者可針對特定通知,從通知欄 (notification shade) 內處理最常見的工作,而無需開啟原始啟動的應用程式。這可加速互動,而且在配合滑動關閉 +(swipe-to-dismiss) +時,有助使用者專注於高重要性的通知。 + + + +</p> + + + <img src="{@docRoot}images/android-5.0/notifications/action_combo.png" alt="" width="700px" /> + + + +<p style="clear:both">明智地決定要在通知中要納入多少個動作。 +您納入的動作愈多,就會發現創造出愈複雜的通知。 +請納入最緊迫重要且有意義的動作,限制自己儘可能使用最少數目的動作。 + + +</p> + +<p>適合用於通知上的動作包含:</p> + +<ul> + <li> 必須是必要、頻繁且典型的想要顯示內容類型 + + <li> 可讓使用者快速完成工作 +</ul> + +<p>避免下列狀況:</p> + +<ul> + <li> 模稜兩可 + <li> 和通知的預設動作相同 (如「讀取」或「開啟」) + +</ul> + + + +<p>您最多可以指定三個動作,每個動作都由一個動作圖示與名稱組成。 + + 為簡單的基礎版面配置新增動作,可讓通知變得更具擴充性 +-- +即使通知並未具備擴充的版面配置。由於動作只針對擴充的通知顯示,其他時候則隱藏,請確認使用者可從通知內呼叫的任何動作,也可以從關聯的應用程式中使用。 + + + + +</p> + +<h2 style="clear:left">預告通知</h2> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/hun-example.png" alt="" width="311px" /> + <p class="img-caption"> + 預告通知 (來電、高優先順序) +出現在沉浸式應用程式之上的範例 + + </p> +</div> + +<p>當高優先順序的通知到達 (如右) 時,會對使用者呈現很短的時間,且會顯示可能執行動作的擴充版面配置。 + +</p> +<p> 在這段時間之後,通知會退回至通知欄。 +如果通知的<a href="#correctly_set_and_manage_notification_priority">優先順序</a>被標記為「高」、「最大」或「全螢幕」,就會取得預告通知。 +</p> + +<p><b>預告通知的好範例</b></p> + +<ul> + <li> 使用裝置時有來電</li> + <li> 使用裝置時啟動鬧鐘功能</li> + <li> 新簡訊</li> + <li> 電池電力不足</li> +</ul> + +<h2 style="clear:both" id="guidelines">指導方針</h2> + + +<h3 id="MakeItPersonal">提供個人設定</h3> + +<p>針對由另一人傳送項目的通知 +(如郵件或狀態更新),使用 +{@link android.app.Notification.Builder#setLargeIcon setLargeIcon()} 納入對方提供的影像。也將對方的資訊附加至通知的中繼資料中 +(請參閱 {@link android.app.Notification#EXTRA_PEOPLE})。</p> + +<p>您通知的主要圖示仍會顯示,這樣使用者就可以將主要圖示與狀態列中的可見圖示關聯起來。 + +</p> + + +<img src="{@docRoot}images/android-5.0/notifications/Triggered.png" alt="" width="311px" /> +<p style="margin-top:10px" class="img-caption"> + 通知會顯示觸發通知的人及其傳送的內容。 +</p> + + +<h3 id="navigate_to_the_right_place">導覽至正確的地方</h3> + +<p>當輕觸通知的本文時 +(在動作按鈕之外),請將您的應用程式開啟至使用者可以檢視的地方,並根據通知中引用資料進行動作。 + +在多數情況下,這將是單一資料項目 (如訊息) 的詳細資料檢視,但如果通知被堆疊時,也可能會是概述檢視。 + +如果您的應用程式會將使用者帶到應用程式頂層之下的任何地方,則請將導覽過程插入應用程式的返回堆疊中,這可以讓使用者能夠按下系統的返回按鈕,返回至頂層。 + +如需詳細資訊,請見<a href="{@docRoot}design/patterns/navigation.html#into-your-app">導覽</a>設計模式中的「透過主螢幕視窗小工具和通知,導覽至您的應用程式」<em></em>。 + +</p> + +<h3 id="correctly_set_and_manage_notification_priority">正確設定和管理通知優先順序 + +</h3> + +<p>Android 支援對通知設定優先順序的旗標。此旗標可與其他通知旗標比較,影響通知顯示的位置,這有助於確保使用者一律會先看到最重要的通知。 + + +在發佈通知時,您可以從以下優先順序等級選擇: + +</p> +<table> + <tr> + <td class="tab0"> +<p><strong>優先順序</strong></p> +</td> + <td class="tab0"> +<p><strong>使用</strong></p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MAX</code></p> +</td> + <td class="tab1"> +<p>用於關鍵且緊急的通知,警示使用者注意此通知具時效性或必須在繼續特定工作前先解決的情況。 + + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>HIGH</code></p> +</td> + <td class="tab1"> +<p>主要用於重要通訊,例如內容為使用者特別感興趣的郵件或聊天事件。高優先順序通知會觸發預告通知的顯示。 + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>DEFAULT</code></p> +</td> + <td class="tab1"> +<p>用於不屬於此處所述任何其他優先事項類型的所有通知。</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>LOW</code></p> +</td> + <td class="tab1"> +<p>用於您希望使用者能夠被告知,但不那麼緊急的通知。 +低優先順序通知往往出現在清單的底端,因此適合於公共或間接的社交更新: + +使用者已要求針對這類事件通知,但這些通知一律不會優先於緊急或直接通訊。 + + +</p> +</td> + </tr> + <tr> + <td class="tab1"> +<p><code>MIN</code></p> +</td> + <td class="tab1"> +<p>用於內容關聯或背景資訊,例如天氣資訊或內容關聯位置的資訊。最低優先順序通知不會出現在狀態列。 + +使用者會在展開通知欄時找到這些通知。 +</p> +</td> + </tr> +</table> + + +<h4 id="how_to_choose_an_appropriate_priority"><strong>如何選擇合適的優先順序</strong> + +</h4> + +<p><code>DEFAULT</code>、<code>HIGH</code> 和 <code>MAX</code> 為可中斷的優先順序等級,且有打斷使用者正進行動作的風險。 + +如要避免惹惱您應用程式的使用者,請將可中斷的優先順序保留給下列通知: +</p> + +<ul> + <li> 涉及另一人</li> + <li> 具時效性</li> + <li> 可能會立即變更使用者在現實世界中的行為</li> +</ul> + +<p>對使用者而言,設定為 <code>LOW</code> 和 <code>MIN</code> 的通知仍可能很有價值: +很多通知 -- 就算不是大多數 -- 並不需要使用者立即注意,或透過振動使用者的手腕加以提醒;但在使用者選擇查看通知時,這些通知仍會包含使用者覺得有價值的資訊。 + + +<code>LOW</code> 和 <code>MIN</code> + 優先順序通知的準則包含:</p> + +<ul> + <li> 不會牽涉到別人</li> + <li> 不具時效性</li> + <li> 包含使用者可能感興趣,但可能在空閒時才會瀏覽的內容 +</li> +</ul> + + + <img src="{@docRoot}images/android-5.0/notifications/notifications_pattern_priority.png" alt="" width="700" /> + + +<h3 style="clear:both" id="set_a_notification_category">設定通知類別 +</h3> + +<p>如果您的通知屬於某個預先定義的類別 +(詳見下列說明),則請據以指派。 +通知欄 (或任何其他通知接聽器) 等系統 UI +可能會使用此資訊,決定排名和篩選結果。 +</p> +<table> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_CALL">CATEGORY_CALL</a></code></p> +</td> + <td> +<p>來電 (語音或視訊) 或類似的同步化通訊要求 +</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_MESSAGE">CATEGORY_MESSAGE</a></code></p> +</td> + <td> +<p>傳入的直接訊息 (簡訊、即時訊息等)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EMAIL">CATEGORY_EMAIL</a></code></p> +</td> + <td> +<p>非同步大量郵件 (電子郵件)</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_EVENT">CATEGORY_EVENT</a></code></p> +</td> + <td> +<p>「行事曆」事件</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROMO">CATEGORY_PROMO</a></code></p> +</td> + <td> +<p>宣傳或廣告</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ALARM">CATEGORY_ALARM</a></code></p> +</td> + <td> +<p>鬧鐘或計時器</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_PROGRESS">CATEGORY_PROGRESS</a></code></p> +</td> + <td> +<p>長時間執行的背景操作其進度</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SOCIAL">CATEGORY_SOCIAL</a></code></p> +</td> + <td> +<p>社交網路或共用更新</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_ERROR">CATEGORY_ERROR</a></code></p> +</td> + <td> +<p>背景操作或驗證狀態中的錯誤</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_TRANSPORT">CATEGORY_TRANSPORT</a></code></p> +</td> + <td> +<p>播放的媒體傳輸控制</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SYSTEM">CATEGORY_SYSTEM</a></code></p> +</td> + <td> +<p>系統或裝置狀態更新。保留供系統使用。</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_SERVICE">CATEGORY_SERVICE</a></code></p> +</td> + <td> +<p>執行背景服務的表示</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_RECOMMENDATION">CATEGORY_RECOMMENDATION</a></code></p> +</td> + <td> +<p>針對單一件事的特定、及時建議。例如,新聞應用程式可能會想推薦其認為使用者下一步想要閱讀的新聞報導。 + +</p> +</td> + </tr> + <tr> + <td> +<p><code><a +href="/reference/android/app/Notification.html#CATEGORY_STATUS">CATEGORY_STATUS</a></code></p> +</td> + <td> +<p>有關裝置或內容關聯狀態的進行中資訊</p> +</td> + </tr> +</table> + +<h3 id="summarize_your_notifications">概述您的通知</h3> + +<p>當您的應用程式嘗試傳送的通知,但已有類型相同的通知仍在等待中,則請針對應用程式將這些相同類型的通知合併為單一概述通知,而不要建立新物件。 + +</p> + +<p>概述通知會建立概述描述,並讓使用者瞭解特定種類的通知有多少數目正在等待處理。 + +</p> + +<div class="col-6"> + +<p><strong>不要這樣做</strong></p> + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Dont.png" alt="" width="311px" /> +</div> + +<div> +<p><strong>請這樣做</strong></p> + + <img src="{@docRoot}images/android-5.0/notifications/Summarise_Do.png" alt="" width="311px" /> +</div> + +<p style="clear:left; padding-top:30px; padding-bottom:20px">您可以使用擴充摘要版面配置,針對組成概述的個別通知,提供更多詳細資料。 + +這種方法可讓使用者更能感覺出哪些通知正處於等待處理,以及是否夠有趣,以便在關聯應用程式中詳細閱讀。 + + + +</p> +<div class="col-6"> + <img src="{@docRoot}images/android-5.0/notifications/Stack.png" style="margin-bottom:20px" alt="" width="311px" /> + <p class="img-caption"> + 概述實際上是通知的展開和收縮 (使用 <code>InboxStyle</code>) + </p> +</div> + +<h3 style="clear:both" id="make_notifications_optional">讓通知成為可選用的 +</h3> + +<p>使用者應該總是能夠控制通知。讓使用者可以停用您應用程式的通知,或變更其警示屬性,如鬧鐘聲音或是否要使用振動,方法則是為您的應用程式設定新增通知設定項目。 + + + +</p> + +<h3 id="use_distinct_icons">使用易於分辨的的圖示</h3> +<p>使用者應該能瞄一下通知區域,即可以分辨哪些種類的通知目前正在等待處理。 + +</p> + +<div class="figure"> + <img src="{@docRoot}images/android-5.0/notifications/ProductIcons.png" alt="" width="420" /> +</div> + + <div><p><strong>請這樣做</strong></p> + <p>查看 Android 應用程式圖示, +Android 應用程式已為您的應用程式提供外觀易於分辨的通知圖示。 +</p> + + <p><strong>請這樣做</strong></p> + <p>針對小圖示使用<a href="/design/style/iconography.html#notification">通知圖示樣式</a>,針對您的動作列圖示使用 Material Light <a href="/design/style/iconography.html#action-bar">動作列圖示樣式</a>。 + + + +</p> +<p ><strong>請這樣做</strong></p> +<p >讓圖示保持看起來簡單的狀態,避免因過多的詳細資料造成使用者難以看清楚。 +</p> + + <div><p><strong>不要這樣做</strong></p> + <p>將任何額外的 +Alpha +(變暗或淡出) +置入您的小圖示和動作圖示之中;它們的邊緣可能會有反鋸齒狀,但因為 Android 使用這些圖示做為遮罩 +(也就是說,只使用 Alpha 通道),所以影像通常會以完全透明度來繪製。 +</p> + +</div> +<p style="clear:both"><strong>不要這樣做</strong></p> + +<p>使用顏色以區分您與其他人的應用程式。通知圖示應該只是個白色圖示透明背景的背景影像。 +</p> + + +<h3 id="pulse_the_notification_led_appropriately">可以調整通知 LED 適當開啟 +</h3> + +<p>許多 Android 裝置具備通知 LED,可用於當螢幕關閉時通知使用者有新事件。 + +優先順序等級為<code>MAX</code>、<code>HIGH</code> 和 <code>DEFAULT</code> 的通知, +應該要讓 LED 亮起,而只有低優先順序 (<code>LOW</code> 和 <code>MIN</code>) 的通知則不需要。 + +</p> + +<p>使用者對通知的控制應該延伸到 LED 上。當您使用 DEFAULT_LIGHTS,LED 會亮白色。 + +除非使用者已明確自訂通知,否則您的通知不應該使用其他顏色。 + +</p> + +<h2 id="building_notifications_that_users_care_about">建立使用者喜歡的通知 +</h2> + +<p>若要建立使用者喜歡的應用程式,精心設計您的通知非常重要。通知代表您應用程式的聲音,並有助於您應用程式的個性。 + + +非必要或非重要的通知會讓使用者不高興,這會讓他們覺得應用程式想要吸引注目不擇手段,所以請明智地使用通知。 + + +</p> + +<h3 id="when_to_display_a_notification">顯示通知的時機</h3> + +<p>若要建立人們喜歡使用的應用程式,重要的是要體認到使用者的注意與專注是必須加以保護的資源。 + +雖然 Android 的通知系統已重新設計,儘量降低通知對使用者注意力的影響。但仍然必須警覺,通知會中斷使用者的工作流程。在規劃您的通知時,請先自問:通知是否足夠重要到可以合理地中斷使用者。 + + + + + + +如果您不確定,則讓使用者可以使用您應用程式的通知設定,或調整通知優先順序旗標為 <code>LOW</code> 或 <code>MIN</code>,避免使用者在從事其他工作時因此分心。 + + + +</p> + + <img src="{@docRoot}images/android-5.0/notifications/TimeSensitive.png" alt="" width="311px" /> + <p style="margin-top:10px" class="img-caption"> + 具時效性的通知範例 + </p> + +<p>妥善規劃的應用程式只會在必要時才出現,但有幾個情況的確有益於應用程式透過無提示通知中斷使用者的行為。 +</p> + +<p>通知主要還是使用於<strong>具時效性時間的事件</strong>,特別是當這些同步事件<strong>涉及其他人</strong>的時候。 +比如說,傳入的聊天是通訊的即時、同步形式: + +另一個使用者正主動等待您的回應。 +「行事曆」事件是何時使用通知吸引使用者注意的另一個好例子,因為事件即將發生,而「行事曆」事件通常牽涉到其他人。 + + +</p> + +<h3 style="clear:both" id="when_not_to_display_a_notification">不顯示通知的時機 +</h3> + +<div class="figure" style="margin-top:60px"> + <img src="{@docRoot}images/android-5.0/notifications/AntiSample1.png" alt="" width="311px" /> +</div> + +<p>在許多其他情況下,通知並不適當:</p> + +<ul> + <li> 當通知並非直接針對使用者,或者資訊並非真正具時效性時,請避免通知使用者。 + +例如,來自社交網路的非同步與間接更新,通常不是即時中斷的好時機。 + + +對於重視這些狀況的使用者,可以讓他們自行選擇加入通知。 +</li> + <li> 如果相關的新資訊目前正在螢幕上,則不要建立另一個通知。 +反之,直接在前後關係中使用應用程式本身的 UI 通知使用者有新資訊。 + + + 例如,當使用者正與另一位使用者聊天時,聊天應用程式不應建立系統通知。 +</li> + <li> 如果應用程式或系統可以不干擾使用者而解決問題,就不要因為如儲存或同步化資訊,或更新應用程式等低層級的技術操作而中斷使用者活動。 + +</li> + <li> 如果可能的話,就讓應用程式能自行從錯誤恢復,在不需要使用者進行任何動作時,就不要告知他們錯誤而中斷使用者的活動。 + +</li> + <li> 不要建立無實質內容的通知,也不要建立內容僅是在廣告您應用程式的通知。 + +通知應該要能夠提供實用、及時的新資訊,而非只是為了啟動一個應用程式。 + +</li> + <li> 請不要為了讓您的品牌出現在使用者面前,而建立多餘的通知。 + + 這類通知會讓您的使用者感到失望並不願意使用您的應用程式。能夠提供少量的更新資訊並可以吸引使用者注意您應用程式的最佳方式,是開發一個小工具,讓使用者可以選擇放置在主畫面上。 + + + + +</li> +</ul> + +<h2 style="clear:left" id="interacting_with_notifications">與通知互動 +</h2> + +<p>通知可由狀態列上的圖示表示,並可以透過開啟通知匣來存取。 + +</p> + +<p>輕觸通知會開啟相關應用程式,顯示符合通知的詳細資料內容。對通知往左右滑動,可以將通知從通知匣中移除。 + +</p> + +<h3 id="ongoing_notifications">進行中通知</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/MusicPlayback.png" alt="" width="311px" /> + <p class="img-caption"> + 因為音樂播放的緣故所以有進行中通知 + </p> +</div> +<p>進行中通知可讓使用者得知在背景中正在進行程序的資訊。例如,音樂播放程式會在通知系統中宣告正在播放的曲目,除非使用者停止曲目,否則就會繼續宣告。 + + + +進行中通知也可以針對如下載檔案或編碼影片等耗時較長的工作,向使用者顯示目前進度。 + +使用者無法手動將進行中通知從通知匣移除。 +</p> + +<h3 id="ongoing_notifications">媒體播放</h3> +<p>在 Android 5.0 中,鎖定螢幕不會針對已過時的 +{@link android.media.RemoteControlClient} 類別,顯示傳輸控制項。但鎖定螢幕「的確」<em></em>會顯示通知,所以每個應用程式的播放通知,現在都已經是使用者從鎖定狀態控制播放的主要方法。 + +這個行為可讓應用程式進一步控制以何種方式顯示哪些按鈕,同時無論螢幕是否鎖定,都能為使用者提供一致性的體驗。 + + +</p> + +<h3 style="clear:both" +id="dialogs_and_toasts_are_for_feedback_not_notification">對話和快顯通知 +</h3> + +<p>您的應用程式目前若不在畫面上,就不應建立對話或快顯通知。 +對話或快顯通知只在使用者於您應用程式內採取動作時產生立即回應時才顯示。至於使用對話與快顯通知的進一步指引,請參閱<a href="/design/patterns/confirming-acknowledging.html">確認和確認完成</a>。 + + + +</p> + +<h3>排名和排序</h3> + +<p>通知就是新聞,所以基本上是以逆時間順序顯示,同時會針對應用程式指定的通知<a href="#correctly_set_and_manage_notification_priority">優先順序</a>,給與特殊考慮。 + + +</p> + +<p>通知是鎖定螢幕的重要部分,並會在裝置重新顯示螢幕時明確作用。 + +鎖定螢幕上的空間有限,所以更重要的是辨別出最緊急或相關的通知。 + +基於這個理由,Android 針對通知提供了更複雜的排序演算法,並同時考慮: + +</p> + +<ul> + <li> 時間戳記和應用程式指定的優先順序。</li> + <li> 通知最近是否以聲音或振動干擾使用者。 +(也就是說,如果電話剛發出一個聲響,而使用者想要知道「剛剛發生什麼事?」,鎖定螢幕應該以瞄一下就能取得通知的方式來回應使用者。 +) + +</li> + <li> 任何使用 {@link android.app.Notification#EXTRA_PEOPLE} 附加至該通知的人員,尤其是他們是否為標記星號的連絡人。 +</li> +</ul> + +<p>要善用這種排序,請著重於您想要建立的使用者體驗,而非著眼於清單上的任何特定排名位置。 + +</p> + + <img src="{@docRoot}images/android-5.0/notifications/AntiSample3.png" alt="" width="700px" /> + + <p class="img-caption" style="margin-top:10px">Gmail 通知使用預設的優先順序,所以通常排序低於像 Hangouts 等即時訊息應用程式,但當有新郵件進來時,會暫時立即提升。 + + + + + </p> + + +<h3>在鎖定螢幕上</h3> + +<p>由於通知可見於鎖定螢幕上,因此使用者隱私是特別重要的考量。 + +通知通常包含敏感資訊,而且不一定要顯示給拿起裝置並打開顯示的任何人。 + +</p> + +<ul> + <li> 針對具有安全鎖定螢幕 (PIN、圖案或密碼) 的裝置,介面有公用和私密兩部分。 +公用介面可以顯示在安全鎖定螢幕上,因此任何人都可看見。 +私密介面是鎖定螢幕背後的世界,只在使用者登入裝置時才會顯示。 +</li> +</ul> + +<h3>使用者控制安全鎖定螢幕上顯示的資訊</h3> +<div class="figure" style="width:311px"> + <img src="{@docRoot}images/android-5.0/notifications/LockScreen@2x.png" srcset="{@docRoot}images/android-5.0/notifications/LockScreen.png 1x" alt="" width="311px" /> + <p class="img-caption"> + 鎖定螢幕上的通知,以及使用者解鎖裝置後顯示的內容。 + </p> +</div> + +<p>當設定安全鎖定螢幕時,使用者可以選擇隱藏來自安全鎖定螢幕的機密詳細資料。 +在這種情況下,系統 UI 會考慮通知的「可見度」<em></em>等級,判斷可以顯示何種內容。 + +</p> +<p> 如要控制可見度等級,可以呼叫 +<code><a +href="/reference/android/app/Notification.Builder.html#setVisibility(int)">Notification.Builder.setVisibility()</a></code>,並指定下列值之一: +</p> + +<ul> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PUBLIC">VISIBILITY_PUBLIC</a></code>。 +顯示通知的完整內容。 + 如果未指定可見度,則這會是系統預設值。</li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_PRIVATE">VISIBILITY_PRIVATE</a></code>。 +在鎖定螢幕上,顯示這個通知存在的基本資訊, +包括通知圖示和發佈通知的應用程式。通知詳細資料的其他部分則不會顯示。 +但請記住的下列幾點: + <ul> + <li> 如果您想要提供您通知的不同公用版本, +以便顯示在安全鎖定螢幕上, +請在 <code><a +href="/reference/android/app/Notification.html#publicVersion">Notification.publicVersion</a></code> +欄位中提供一個取代的「通知」物件。 + <li> 此設定可以讓您的應用程式有機會建立內容的改編版本,非常實用但卻不會透露個人資訊。 +考慮簡訊應用程式的例子, +其通知包含簡訊的文字和傳送者的姓名與連絡人圖示。 +此通知應該是 <code>VISIBILITY_PRIVATE</code>,但 <code>publicVersion</code> 仍包含像「3 個新訊息」等實用資訊, +但卻又不提供任何其他可用來識別的詳細資料。 + + </ul> + </li> + <li><code><a +href="/reference/android/app/Notification.html#VISIBILITY_SECRET">Notification.VISIBILITY_SECRET</a></code>。僅顯示最起碼的資訊, +甚至連通知圖示都排除。</li> +</ul> +<h2 style="clear:both" id="notifications_on_android_wear">Android Wear 上的通知 +</h2> + +<p>預設情況下,通知和其<em>動作</em>會橋接至穿戴裝置。 +開發人員可以控制哪些通知可從電話橋接至手錶上, +反之亦然。 +開發人員還可以控制哪些動作可以橋接。如果您的 +應用程式包含 +無法以單一點選完成的動作, +請在您的穿戴通知上隱藏這些動作 +,或考慮將其連結至穿戴應用程式, +讓使用者可以在手錶上完成動作。 +</p> + +<h4>橋接通知和動作</h4> + +<p>例如電話等已連線的裝置, +可以橋接通知至穿戴裝置,讓通知可以在該處顯示。同樣的,也可以橋接動作, +這樣使用者就可以直接從穿戴裝置對通知執行動作。</p> + +<p><strong>橋接</strong></p> + +<ul> + <li> 新的即時訊息</li> + <li> 例如 +1 等單點選動作,像 Heart</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/WearBasic.png" width="156px" height="156px" alt="" /> + +<p><strong>請勿橋接</strong></p> + +<ul> + <li> 新到播客的通知</li> + <li> 對應至手錶上不可能執行的動作</li> +</ul> + + + +<p><h4>要在穿戴裝置上定義的獨特動作</h4></p> + +<p>有些動作只能在穿戴裝置上執行。這些動作包含:</p> + +<ul> + <li> 罐頭回應的快速清單,例如「會馬上回來」</li> + <li> 在手機上開啟</li> + <li> 帶出語音輸入畫面的「註解」或「回覆」動作</li> + <li> 啟動穿戴裝置特定的應用程式動作</li> +</ul> + +<img src="{@docRoot}images/android-5.0/notifications/ReplyAction.png" width="156px" height="156px" alt="" /> diff --git a/docs/html/design/design_toc.cs b/docs/html/design/design_toc.cs index 85569ef..477eb23 100644 --- a/docs/html/design/design_toc.cs +++ b/docs/html/design/design_toc.cs @@ -3,13 +3,29 @@ <li class="nav-section"> <div class="nav-section-header"><a href="<?cs var:toroot ?>design/get-started/creative-vision.html">Creative Vision</a></div> <ul> - <li><a href="<?cs var:toroot ?>design/get-started/principles.html">Design Principles</a></li> + <li><a href="<?cs var:toroot ?>design/get-started/principles.html" + es-lang="Principios de diseño para Android" + ja-lang="Android デザイン指針" + ko-lang="Android 디자인 원칙" + pt-br-lang="Princípios de projeto para Android" + ru-lang="Принципы проектирования Android" + zh-cn-lang="Android 设计原则" + zh-tw-lang="Android 設計原則"> + Design Principles</a></li> <li><a href="<?cs var:toroot ?>design/patterns/new.html">New in Android</a></li> </ul> </li> <li class="nav-section"> - <div class="nav-section-header empty"><a href="<?cs var:toroot ?>design/material/index.html">Material for Android</a></div> + <div class="nav-section-header empty"><a href="<?cs var:toroot ?>design/material/index.html" + es-lang="Material Design" + ja-lang="マテリアル デザイン" + ko-lang="머티어리얼 디자인" + pt-br-lang="Material Design" + ru-lang="Material Design" + zh-cn-lang="材料设计" + zh-tw-lang="材料設計"> + Material for Android</a></div> </li> <li class="nav-section"> @@ -47,12 +63,39 @@ <ul> <li><a href="<?cs var:toroot ?>design/style/devices-displays.html">Devices and Displays</a></li> <li><a href="<?cs var:toroot ?>design/patterns/app-structure.html">App Structure</a></li> - <li><a href="<?cs var:toroot ?>design/patterns/navigation.html">Navigation</a></li> - <li><a href="<?cs var:toroot ?>design/patterns/notifications.html">Notifications</a></li> + <li><a href="<?cs var:toroot ?>design/patterns/navigation.html" + es-lang="Navegación con los botones Back y Up" + ja-lang="Back と Up を使用したナビゲーション" + ko-lang="뒤로 및 위로 탐색 기능이 포함된 탐색" + pt-br-lang="Navegação com Voltar e Para cima" + ru-lang="Навигация с помощью кнопок \"Назад\" и \"Вверх\"" + zh-cn-lang="使用返回和向上导航" + zh-tw-lang="使用 [返回] 及 [上一層] 導覽"> + Navigation</a></li> + + <li><a href="<?cs var:toroot ?>design/patterns/notifications.html" + es-lang="Notificaciones" + ja-lang="通知" + ko-lang="알림" + pt-br-lang="Notificações" + ru-lang="Уведомления" + zh-cn-lang="通知" + zh-tw-lang="通知"> + Notifications</a></li> <li><a href="<?cs var:toroot ?>design/patterns/widgets.html">Widgets</a></li> <li><a href="<?cs var:toroot ?>design/patterns/swipe-views.html">Swipe Views</a></li> <li><a href="<?cs var:toroot ?>design/patterns/fullscreen.html">Full Screen</a></li> - <li><a href="<?cs var:toroot ?>design/patterns/confirming-acknowledging.html">Confirming & Acknowledging</a></li> + + <li><a href="<?cs var:toroot ?>design/patterns/confirming-acknowledging.html" + es-lang="Confirmación y reconocimiento" + ja-lang="確認と通知" + ko-lang="확인 및 승인하기" + pt-br-lang="Confirmação e reconhecimento" + ru-lang="Подтверждение и уведомление" + zh-cn-lang="确认和确知" + zh-tw-lang="確認及確認完成"> + Confirming & Acknowledging</a></li> + <li><a href="<?cs var:toroot ?>design/patterns/pure-android.html">Pure Android</a></li> <li><a href="<?cs var:toroot ?>design/patterns/compatibility.html">Compatibility</a></li> <li><a href="<?cs var:toroot ?>design/patterns/accessibility.html">Accessibility</a></li> |