diff options
Diffstat (limited to 'docs/html-intl/intl/zh-tw')
5 files changed, 1648 insertions, 0 deletions
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="" /> |