Axure教程:音樂播放器中,帶時間的進度條/歌詞顏色變化/旋轉元件
本文以QQ音樂為例,實現了帶時間的進度條、歌詞顏色變化、唱片旋轉、暫停播放等原型交互。
一、效果展示
- 體驗地址:https://v0u9to.axshare.com
- 原型下載鏈接:https://pan.baidu.com/s/1jbrZnENr2MLZvzlWgIze-g 提取碼:34gu
- 交互說明:點擊播放、暫停按鈕可實現原型的播放與暫停;左右拖動頁面可切換唱片、全屏歌詞頁面。
二、唱片旋轉
1. 實現的效果
點擊播放按鈕時,唱片緩慢地圍繞其自身中心旋轉;點擊暫停按鈕時,唱片停止旋轉。
2. 思路
可以通過循環(huán)面板來控制唱片的旋轉。
(1)拖入一個374×645的矩形充當手機頁面,并調整填充顏色;輸入歌曲及歌手名稱;添加一張歌手照片及圓形元件充當唱片,把該組合轉化為動態(tài)面板,命名為“唱片”;添加一個名為“播放-暫?!钡膭討B(tài)面板,該面板共有兩個狀態(tài):暫停、播放,并通過圓形、三角形、垂直線等元件畫出暫停、播放的按鈕。如下圖所示:
(2)拖入一個循環(huán)動態(tài)面板,命名為“循環(huán)1”,該循環(huán)面板共有2個狀態(tài)。
(3)當點擊暫停狀態(tài)圖標時,把“?播放-暫?!痹O置為“播放”狀態(tài),并設置“循環(huán)1”動態(tài)面板循環(huán),循環(huán)時間為400ms;當點擊播放狀態(tài)圖標時,把“播放-暫停按鈕”設置為“播放-暫?!睘椤皶和!睜顟B(tài),并把“循環(huán)1”動態(tài)面板停止暫停。
(4)設置當“循環(huán)1”面板狀態(tài)改變時“唱片”動態(tài)面板順時針圍繞中心線性旋轉10fx,線性時間也剛好是400ms。線性旋轉400ms是與“循環(huán)1”的狀態(tài)改變時間對應,而400ms剛好不快不慢。
三、帶時間的進度條
1. 實現效果
點擊暫停狀態(tài)圖標時,原型切換為播放狀態(tài),進度條每一秒前進一定的距離,與此同時“時間”文本實時顯示已進度條的已播放時間;點擊播放狀態(tài)圖標時,原型切換為暫停狀態(tài),進度條停止前進、停止計時。
2. 思路
點擊暫停狀態(tài)圖標時,設置循環(huán)面板以1000ms的時間差循環(huán)改變狀態(tài);而循環(huán)面板每一次改變則會讓“滑塊”動態(tài)面板向右移動一定的距離,同時,循環(huán)面板的狀態(tài)改變也會改變“時間”文本的值。
3. 交互設置
(1)拖入一條長為255的水平線,調整好線寬及顏色,命名為“底”,讓其充當進度條的底色。
在“底”的頂層添加一個名為“進度條”的動態(tài)面板,在“進度條”的state1里面添加水平線及圓形元件,總寬度也是255,調整好顏色并轉化為動態(tài)面板,該動態(tài)面板命名為“滑塊”,并把“滑塊”的x軸坐標設為“-240”好讓滑塊在頁面初始時僅露出一個圓圈。
在進度條的兩端分別添加兩個文本來顯示進度時間及總時間,左端初始值為0:00并命名為“時間”,總時間為1:00。
(2)拖入一個動態(tài)面板,共有兩個狀態(tài),命名為“循環(huán)2”。當點擊播放按鈕時,設置“循環(huán)2”以1000ms的時間循環(huán)改變狀態(tài),并首個狀態(tài)延時1000ms后切換。
(3)設置“循環(huán)2”狀態(tài)改變時滑塊移動:因為“滑塊”的總移動距離為240、總移動時間為60秒,則每一秒移動的距離是4。因此設置如下事件。
(4)通過以上三步已完成了進度條的移動,現在來實現“時間”文本的顯示。因為“循環(huán)2”每變換一次狀態(tài)的時間是1000ms,而“時間”文本每變換一次值也是1000ms,所以這兩者是對應的。而“時間”文本按字符串顯示可分為三種情況:0:01~0:09、0:10~0:59、1:00。
為此,在【項目】【全局變量】設置全局變量“t”用來記錄時間,當“循環(huán)2”每變換一次狀態(tài)時t=t+1000ms。當t<10000ms時,“時間”的值=0:0[t/1000];當10000ms=<t<60000ms時,“時間”的值=0:[t/1000];當t=60000ms時,“時間”的值=1:00,且循環(huán)1、循環(huán)2停止循環(huán),把“播放-暫?!泵姘逶O置為暫停狀態(tài)。
四、單行歌詞的顏色變化
1. 實現交互
跟QQ音樂的單行歌詞顯示一樣。
2. 思路
在QQ音樂APP中,歌曲的歌詞顏色變化不是勻速的,而是由歌曲本身的音樂性來決定的。此案例中假定每行歌詞里的顏色變化是勻速的。因此,可算出在1分鐘內算出每行歌詞顏色變化的所耗時長,再通過每行歌詞動態(tài)面板的尺寸改變來實現歌詞顏色變化的樣式。
3. 實現過程
(1)拖入一個寬為141、高為16的動態(tài)面板,命名為“歌詞”。寬為141是為了讓所有的歌詞行都能顯示,高為16是為了僅能顯示一行。在“歌詞”的state1里加入八句歌詞,調整好位置且垂直分布,記錄每歌詞的y坐標。
(2)把這八行每句歌詞每行都復制一份,調整好顏色用來當作變色歌詞行,并每把變色歌詞的每一行都轉化為動態(tài)面板,分別命名為:“1”、“2、“3”、“4”、“5”、“6”、“7”、“8”。變色歌詞每一行都疊放在非變色歌詞的正上方。
(3)把“1”~“8”動態(tài)面板的寬度設置為1、把非變色歌詞設為白色且透明度為50%。以此,可通過改變“1”~“8”的寬度來實現歌詞顏色隨著歌曲的播放而改變的交互。把“歌詞”state1里面的全部內容轉化為動態(tài)面板,命名為“歌詞1”。
(4)進度條的總時間1min,八句歌詞的總寬是1016,所以平均每秒歌詞顏色變化的長度為16.93。
又根據每行歌詞的寬度可算出“1”~“8”句歌詞的顏色變化耗時分別為:7.5s、7.5s、8.33s、7.5s、7.5s、8.33s、5.84s、7.5s。
因為歌詞顏色變化是以1s為時間單位的,所以時間不能存在小數點,那么對于以上所述的所耗時長,是要向上取整數還是向下取整數呢?
如果是向上取整數的話,那么這八句歌詞的總時長為64s,這顯然不符合要求,所以設定這八句歌詞的所耗時長分別是7s、7s、8s、7s、7s、8s、5s、7s。
(5)因為每行歌詞的所耗時長已經向下取整數了,所以每1s在歌詞里的每一行顏色變化的寬度就不再是16.93了。把每一行寬度除以時長,得出每一行在1s顏色變化的寬度為18.2、18.2、17.7、18.2、18.2、17.7、19.8、17.7,此處是向上保留一位小樓(如:如果是18.112就簡化為18.2),因為如果向下保留一位小數則會導致在規(guī)則時間內完成不了每行所有的字顏色變化。
(6)“循環(huán)2”狀態(tài)變化時,設置事件。如:當0<t=<7000時,移動“歌詞1″至(0,0)、動態(tài)面板的長度=自身的長度+18.2。
- 當7000<t<=14000時,設置第二行歌詞;當14000<t<=22000時,設置第三行歌詞;
- 當22000<t<=29000時,設置第四行歌詞;當29000<t<=36000時,設置第五行歌詞;
- 當36000<t<=44000時,設置第六行歌詞;當44000<t<=49000時,設置第七行歌詞;
- 當49000<t<=56000時,設置第八行歌詞。具體的設置事件跟第一行類似。
通過上述步驟,已完成了單行歌詞的顏色變化,變化起始第1s,終止于57s。
五、全屏歌詞的顏色變化
1.實現的效果
當向左拖動頁面(代表向左滑)時切換為全屏歌詞頁面,向右拖動頁面(代表左滑)時切換為單句歌詞頁面。全屏歌詞的顏色變化交互樣式跟QQ音樂一樣。
2. 思路
以拖動頁面切換動態(tài)面板狀態(tài)來實現左右滑動;全屏歌詞的顏色變化實現跟單句歌詞類似。
3. 實現過程
(1)把“唱片”、“歌詞”轉化為動態(tài)面板命名為“主面板”,并添加state2。
(2)把“歌詞1”動態(tài)面板的state1里變色歌詞及非變色歌詞都復制到“主面板”的state2,并調整好位置。把變色歌詞分別命名為“11”、“22”、“33”、“44”、“55”、“66”、“77”、“88”。
(3)設置左右滑動時的切換效果。
(4)全屏歌詞的顏色變化是跟單行歌詞同步的。所以全屏歌詞的顏色變化設置只需在單行歌詞事件中設置即可。不同的是,全屏歌詞里非第一行歌詞的事件設置須加上把上一行變色歌詞動態(tài)面板的寬度設置為1。具體設置如下圖所示。
在上圖中,每個case都有兩個或三個設置尺寸的事件,其實在實際的原型制作中不必一步一步地設置尺寸,可在每個case里面一步到位地設置這兩三個需要設置的元件尺寸,此處只是為了演示講解方便而已。
至此,已完成了此案例的全部交互。
作者:稻草人,產品經理。
本文由 @稻草人 原創(chuàng)發(fā)布于人人都是產品經理。未經許可,禁止轉載
題圖來自Unsplash,基于CC0協議
網盤鏈接失效了,可以重新發(fā)一下嗎
看完一篇原型設計文章啦,感覺還是不太會?
?? 想從0基礎開始學習Axure么?推薦你找Axure實戰(zhàn)班的助教小可愛@CC-起點學院(微信:qidiancc520),回復關鍵詞:大禮包
領取原型設計大禮包,多學多練,你也能成為原型設計高手哦!