2018-5-15 藍藍設計的小編
在這里先說一下本文轉自我的老家的:河北華信智原 致敬哈
如果您想訂閱本博客內容,每天自動發到您的郵箱中, 請點這里
UI動效現如今在 APP 和網頁中幾乎已經成為了基本的組成部分,經過仔細打磨的 UI動效對于整個界面的提升是顯著的。
動效呈現出狀態切換的過程,展現了元素之間的邏輯關系,并且吸引用戶的注意力,引導他們執行有效的交互。
在設計動效的過程中,Material Motion 的設計原則,IBM 動畫設計規則和 UX動效宣言都是不錯的設計參考和指引。遵循這些現有的規范,能夠很好地提升動效本身的體驗和效果,從優秀走向卓越。今天的動效設計都是遵循著這些規范使用 InVision Studio 來進行制作的。
左側標簽切換的時候使用了淡入淡出,右側標簽頁切換使用了滑動效果。
內容切換的時候淡入淡出效果不錯。
通過滑動效果來展示內容,不僅呈現了變化的過程,還指明了兩者的位置關系和邏輯關系,更為卓越。
當你在設計諸如標簽頁或者彈出菜單這樣的控件的時候,盡量借助動效讓內容的位置變化關系呈現出來,這樣不僅確保了內容的可見性,而且能夠讓用戶不迷惑。這個時候,滑動手勢交互和位移動效是不錯的搭配,非常符合此處內容切換的語境。
卡片是最常見的 UI 元素,左側的界面中,點擊卡片之后,展開新的界面;右側界面中,點擊卡片之后,卡片擴展并填充整個屏幕。
點擊卡片之后,詳情頁向上滑出或者從左側滑出的設計很不錯。
通過展開動效從卡片直接過渡到詳情頁是更卓越的設計。
最好的動效往往能夠通過變化讓人明白兩種狀態之間的內在關聯。在制作不同狀態之間變化的動效的時候,注意兩個界面中共享的元素,并且將它作為橋梁,將兩個界面狀態連接到一起。在使用 InVision Studio 創建原型的時候,這種同時存在前后兩屏中的控件會自動連接起來,構成動效。這一功能使得動效的構建更加便捷。
左邊的列表使用了較為迅速的淡入淡出動效,而右邊的列表當中,淡入淡出以延時的方式呈現,效果類似瀑布的展開方式。
淡入淡出的動效讓元素遞次出現加上輕微的位移,比較自然,看起來不錯。
列表元素通過延時次第出現,位移更加明顯,形同瀑布,在視覺和體驗上更為卓越。
瀑布式的展開動效只需要通過明顯的延時就能夠實現,適當地控制節奏,讓整個加載速度適當的減緩而不會太慢,讓用戶能夠感知到這個過程即可。谷歌建議每個元素的延時不超過20毫秒。你可以在 Material Motion 中看到設計的原理和更多的實例。
左側的動效是內容在頂層覆蓋列表,而右側的動效是從中間擴展將上下內容頂開。
通過移動、覆蓋、展開的方式來呈現詳情頁的動效,視覺上看起來不錯。
而點擊之后展開頂掉周圍的元素,和周圍的其他的元素有所互動,這樣的動效更加優秀。
界面中所有的元素都應該是有「重量」的,某個 UI 控件隨著動效變化的時候,和周圍的元素發生互動,則能夠強化這種實體感。
左側的動效中,菜單從底部淡入界面,而右側的動效中,菜單是從被點擊的按鈕中擴展開的。
菜單從按鈕的位置淡入進入界面的方式展現了兩者的關聯,這樣的設計還不錯。
通過擴展動效的方式來呈現菜單的展開,讓按鈕和菜單之間的關系得到了進一步的加強,這樣的設計更加優秀。
左側的按鈕通過文本說明和色彩變化來指示狀態改變,而右側按鈕則通過加載控件來展示不同的事件的發生。
好的按鈕會指示狀態的改變,哪怕是通過文本來呈現。
通過按鈕本身,視覺化地呈現加載的狀態變化,比起文本說明更加自然,也更加易于理解,這樣的設計更加優秀。
嘗試使用加載指示器來指示狀態的變化和進度,類似的方式有很多,重點是在于視覺化的、自然的呈現狀態的變化過程,如果搭配上色彩的變化,那么就更好了。
左側僅僅是通過色彩、符號和位置來吸引注意力,而右側加入了微妙的動效來吸引用戶注意。
使用色彩、標識和位置來吸引用戶注意力是頗為有效的手段。
借助微妙自然的動效,不僅能夠吸引用戶注意力,而且不會造成干擾,這樣的設計更優秀。
對于一些重要的組件、事件或者信息,使用類似呼吸式的動效來強化效果是自然且干擾性較低的,這樣的動效設計讓元素的重要性得到凸顯,還不會讓用戶感到反感。
我希望今天所提到的這些技巧能夠讓你在設計交互動畫的時候,拿出更加自然、優秀的方案。從優秀到卓越,有的時候只需要進行微小的改變。值得一提的是,像 InVision Studio 這樣的工具,對于動效本身的提升是很明顯的,它能夠提供更多自然而富有直覺性的動效。
總之,在設計動效的時候,注意狀態變化的指示,元素之間關系的強化,適當地增加一些樂趣。遵循這樣的原則,總能讓動效更上一層樓。
藍藍設計( m.ssll180.com )是一家專注而深入的界面設計公司,為期望卓越的國內外企業提供卓越的UI界面設計、BS界面設計 、 cs界面設計 、 ipad界面設計 、 包裝設計 、 圖標定制 、 用戶體驗 、交互設計、 網站建設 、平面設計服務