色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

android實現音樂跳動效果的示例代碼

瀏覽:7日期:2022-09-19 17:14:11
效果圖

android實現音樂跳動效果的示例代碼

實現

整體的流程圖如下

android實現音樂跳動效果的示例代碼

上面主要步驟分為3個1、計算寬度能放下多少列的音頻塊。2、計算每一列中音頻塊的個數3、繪制音頻塊

1、計算寬度能放下多少列的音頻塊。

設置音頻塊的寬度為danceWidth,音頻塊橫向之間的間距為danceGap,那么可以算出能放的列數:

/** * 先計算當前寬度能夠放下多少個音頻塊 */val widthNum = (getAvailableWith() / (danceGap + danceWidth)).toInt() /** * 獲取可以用的寬度 */ private fun getAvailableWith() = mCanvasWidth - paddingLeft - paddingRight2、計算每一列中音頻塊的個數

在算出橫向能放置多少音頻塊后,遍歷橫,然后繪制列中的音頻塊,列中的音頻塊的個數跟音頻的高低相關,這里實現方式是通過Visualizer這個類然后獲取到mRawAudioBytes數組,

mVisualizer.setDataCaptureListener(new Visualizer.OnDataCaptureListener() { @Override public void onWaveFormDataCapture(Visualizer visualizer, byte[] bytes, int samplingRate) {BaseVisualizer.this.mRawAudioBytes = bytes;invalidate(); } @Override public void onFftDataCapture(Visualizer visualizer, byte[] bytes, int samplingRate) { }}, Visualizer.getMaxCaptureRate() / 2, true, false);

這里設置的獲取的mRawAudioBytes數組的大小是128,數組的區間范圍[-128,127],計算列的時候這里做了兩個比較重要的操作,第一個是怎么把mRawAudioBytes數組的值與音頻的個數做映射,第二個是怎么取mRawAudioBytes數組的值。

/** * 先計算當前寬度能夠放下多少個音頻塊 */val widthNum = (getAvailableWith() / (danceGap + danceWidth)).toInt()Log.d( TAG, 'widthNum $widthNum')/** * 算出橫向能放多少后,進行繪制 *//** * 繪制的時候用于標記開始繪制的位置 */var lastDanceRight = paddingLeft.toFloat()if (widthNum > 0 && mRawAudioBytes != null && mRawAudioBytes.isNotEmpty()) for (i in 0 until widthNum) {//先算出當前高度,然后再算這個高度能放下多少個音頻塊val num = (getAvailableHeight() / (danceHeight + danceGap)).toInt()val index = (mRawAudioBytes.size) * (i.toFloat() / widthNum)val b = (mRawAudioBytes[index.toInt()] + 128).toFloat() / 255fvar heightNum = (b * num).toInt()if (heightNum < miniNum) { heightNum = miniNum}if (heightNum > maxNum) { heightNum = maxNum}//拿到最頂部的高度var lastHeight = mCanvasHeight - paddingStart.toFloat()Log.d( TAG, 'heightNum $heightNum lastHeight $lastHeight lastDanceRight $lastDanceRight ${mRawAudioBytes[i]} $num $b $index')lastHeight = drawItem(heightNum, lastDanceRight, lastHeight, canvas)lastDanceRight += danceWidth + danceGap }

上面做了兩個映射,首先可能有0~n橫,但是mRawAudioBytes大小是128,遍歷橫的時候對下標進行一個映射,保證獲得的值是均勻的,

/**通過這個映射得到index*/val index = (mRawAudioBytes.size) * (i.toFloat() / widthNum)

第二個映射,是得到了代表音頻大小的mRawAudioBytes數組,現在要把這里面的值跟列的高度做一個映射,值越大高度越高,音頻塊就越多。

val num = (getAvailableHeight() / (danceHeight + danceGap)).toInt()val b = (mRawAudioBytes[index.toInt()] + 128).toFloat() / 255fvar heightNum =(b * num).toInt()

上面是先得到列最多能展示多少音頻塊,再根據mRawAudioBytes的值來算出當前列展示多少個音頻塊。這一步也叫歸一化,區間映射。

3、繪制每一個音頻塊

private fun drawItem(heightNum: Int,lastDanceRight: Float,lastHeight: Float,canvas: Canvas? ): Float {var lastHeight1 = lastHeightfor (j in 0 until heightNum) { mDanceRect.set(lastDanceRight,lastHeight1 - danceHeight,lastDanceRight + danceWidth,lastHeight1 ) mPaint.shader = null if (j >= heightNum - shaderNum) {val backGradient = LinearGradient( lastDanceRight, lastHeight1 - danceHeight, lastDanceRight + danceWidth, lastHeight1, intArrayOf(colorStart, colorCenter, colorEnd), null, Shader.TileMode.CLAMP)mPaint.shader = backGradient } canvas?.drawRoundRect(mDanceRect, 8f, 8f, mPaint) lastHeight1 -= (danceHeight + danceGap)}return lastHeight1 }

就是根據高度來繪制rectangle,算出一列能繪制多少個音頻塊,每一個音頻塊是一個rectangle,然后繪制rectangle,為了效果更好,判斷上面的音頻塊加上漸變。

github地址

使用方法

<com.masoudss.lib.DanceView android: android:layout_width='320dp' android:layout_height='300dp' android:layout_gravity='center' app:color_center='@color/red' app:color_end='@color/white' app:color_start='@color/yellow' app:dance_color='@color/yellow' app:dance_corner_radius='2dp' app:dance_gap='2dp' app:max_dance_num='30' app:min_dance_num='2' app:shader_num='3' /> shader_num 頂部加漸變的個數 color_end 漸變尾部顏色 color_start 漸變開頭顏色 color_center 漸變中間顏色 min_dance_num 每一列中最少顯示的個數 max_dance_num 每一列中最大顯示的個數 dance_gap 每一個音頻格之間的間距

到此這篇關于android實現音樂跳動效果的示例代碼的文章就介紹到這了,更多相關android 音樂跳動內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: Android
相關文章:
主站蜘蛛池模板: 私人玩物福利 | 亚洲一区毛片 | 午夜成年女人毛片免费观看 | 日韩欧美国产另类 | 国产又色又爽黄的网站免费 | 亚洲激情自拍 | 99久久99热久久精品免费看 | 亚洲欧美视频在线播放 | 亚洲综合天堂网 | 国产成人精品视频频 | 国产精品在线观看 | 92av在线| 韩日一级 | 欧美日本一区视频免费 | 国产手机看片 | 成年人在线免费网站 | 国产精品美女久久久久网站 | 9999毛片免费看 | 黄色大片三级 | 精品欧美一区二区三区在线观看 | 亚洲高清自拍 | 美女黄频免费观看 | 色青青草原桃花久久综合 | 色久视频 | 在线毛片一区二区不卡视频 | 成人五级毛片免费播放 | 欧美在线视频 一区二区 | 欧美一级在线视频 | 精品在线视频播放 | 国产精品久久久久国产精品三级 | 精品一区二区三区免费视频 | 美女的让男人桶到爽软件 | 成人性视频在线 | 国产成人精品一区二区免费视频 | 亚洲视频在线观看网站 | 在线日本看片免费人成视久网 | 国产伦精一区二区三区视频 | 免费一级a毛片在线播 | 免费在线观看亚洲 | 在线观看欧美亚洲日本专区 | 久久国产欧美日韩高清专区 |