|  | @@ -18,7 +18,7 @@ import { changeSongSourceByBate } from "/src/view/audio-list"
 | 
											
												
													
														|  |  import { moveSmoothAnimation, smoothAnimationState, moveSmoothAnimationByPlayTime, moveTranslateXNum, destroySmoothAnimation, calcClientWidth } from "/src/page-instrument/view-detail/smoothAnimation"
 |  |  import { moveSmoothAnimation, smoothAnimationState, moveSmoothAnimationByPlayTime, moveTranslateXNum, destroySmoothAnimation, calcClientWidth } from "/src/page-instrument/view-detail/smoothAnimation"
 | 
											
												
													
														|  |  import { storeData } from "/src/store";
 |  |  import { storeData } from "/src/store";
 | 
											
												
													
														|  |  import { downloadXmlStr } from "./view/music-score"
 |  |  import { downloadXmlStr } from "./view/music-score"
 | 
											
												
													
														|  | -import { musicScoreRef } from "/src/page-instrument/view-detail/index"
 |  | 
 | 
											
												
													
														|  | 
 |  | +import { musicScoreRef, headerColumnHide } from "/src/page-instrument/view-detail/index"
 | 
											
												
													
														|  |  import { headTopData } from "/src/page-instrument/header-top/index";
 |  |  import { headTopData } from "/src/page-instrument/header-top/index";
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  const query: any = getQuery();
 |  |  const query: any = getQuery();
 | 
											
										
											
												
													
														|  | @@ -637,11 +637,18 @@ export const onEnded = () => {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // 根据当前小节动态设置,右上角展示的速度
 |  |  // 根据当前小节动态设置,右上角展示的速度
 | 
											
												
													
														|  |  const dynamicShowPlaySpeed = (index: number) => {
 |  |  const dynamicShowPlaySpeed = (index: number) => {
 | 
											
												
													
														|  | -  const item: any = state.times[index];
 |  | 
 | 
											
												
													
														|  | -  if (item && item.measureSpeed ) {
 |  | 
 | 
											
												
													
														|  | -    // console.log('速度1',item.measureSpeed)
 |  | 
 | 
											
												
													
														|  | -    state.speed = Math.floor(state.basePlayRate * item.measureSpeed)
 |  | 
 | 
											
												
													
														|  | 
 |  | +  if (!headerColumnHide.value) {
 | 
											
												
													
														|  | 
 |  | +    console.log('动态计算速度')
 | 
											
												
													
														|  | 
 |  | +    const item: any = state.times[index];
 | 
											
												
													
														|  | 
 |  | +    if (item && item.measureSpeed ) {
 | 
											
												
													
														|  | 
 |  | +      // console.log('速度1',item.measureSpeed)
 | 
											
												
													
														|  | 
 |  | +      const newSpeed = Math.floor(state.basePlayRate * item.measureSpeed)
 | 
											
												
													
														|  | 
 |  | +      if (state.speed !== newSpeed) {
 | 
											
												
													
														|  | 
 |  | +        state.speed = newSpeed;
 | 
											
												
													
														|  | 
 |  | +      }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // 开始播放时,计算mp3的播放倍率
 |  |  // 开始播放时,计算mp3的播放倍率
 | 
											
										
											
												
													
														|  | @@ -1332,10 +1339,11 @@ const getMusicInfo = async (res: any) => {
 | 
											
												
													
														|  |    downloadXmlStr.value = xmlString //给musice-score 赋值xmlString 以免加载2次
 |  |    downloadXmlStr.value = xmlString //给musice-score 赋值xmlString 以免加载2次
 | 
											
												
													
														|  |    const tracks = xmlToTracks(xmlString) //获取声轨列表
 |  |    const tracks = xmlToTracks(xmlString) //获取声轨列表
 | 
											
												
													
														|  |    // 设置音源  track 为当前的声轨 index为当前的
 |  |    // 设置音源  track 为当前的声轨 index为当前的
 | 
											
												
													
														|  | -  const { track, index } = state.isSimplePage ? { track:tracks[0], index:0} : initMusicSource(res.data, tracks, partIndex)
 |  | 
 | 
											
												
													
														|  | 
 |  | +  const { track, index, musicalInstrumentId } = state.isSimplePage ? { track:tracks[0], index:0, musicalInstrumentId: '' } : initMusicSource(res.data, tracks, partIndex)
 | 
											
												
													
														|  | 
 |  | +  const realTrack = musicalInstrumentId && res.data?.musicalInstruments?.length ? res.data?.musicalInstruments.find((item: any) => item?.id == musicalInstrumentId)?.code?.split(',')?.[0] : '';
 | 
											
												
													
														|  |    const musicInfo = {
 |  |    const musicInfo = {
 | 
											
												
													
														|  |      ...res.data,
 |  |      ...res.data,
 | 
											
												
													
														|  | -    track
 |  | 
 | 
											
												
													
														|  | 
 |  | +    track: res.data.musicSheetType === 'CONCERT' ? track : realTrack
 | 
											
												
													
														|  |    };
 |  |    };
 | 
											
												
													
														|  |    console.log("🚀 ~ musicInfo:", musicInfo);
 |  |    console.log("🚀 ~ musicInfo:", musicInfo);
 | 
											
												
													
														|  |    setState(musicInfo, index);
 |  |    setState(musicInfo, index);
 | 
											
										
											
												
													
														|  | @@ -1354,7 +1362,7 @@ function xmlToTracks(xmlString: string) {
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  // 设置音源
 |  |  // 设置音源
 | 
											
												
													
														|  |  function initMusicSource(data: any, tracks: string[], partIndex: number) {
 |  |  function initMusicSource(data: any, tracks: string[], partIndex: number) {
 | 
											
												
													
														|  | -  let track:string,index:number
 |  | 
 | 
											
												
													
														|  | 
 |  | +  let track:string,index:number, musicalInstrumentId: string
 | 
											
												
													
														|  |    const instrumentId = query.instrumentId || storeData.user?.instrumentId
 |  |    const instrumentId = query.instrumentId || storeData.user?.instrumentId
 | 
											
												
													
														|  |    let { musicSheetType, isAllSubject, musicSheetSoundList, musicSheetAccompanimentList } = data
 |  |    let { musicSheetType, isAllSubject, musicSheetSoundList, musicSheetAccompanimentList } = data
 | 
											
												
													
														|  |    musicSheetSoundList || (musicSheetSoundList = [])
 |  |    musicSheetSoundList || (musicSheetSoundList = [])
 | 
											
										
											
												
													
														|  | @@ -1383,6 +1391,7 @@ function initMusicSource(data: any, tracks: string[], partIndex: number) {
 | 
											
												
													
														|  |      index = tracks.findIndex(item => {
 |  |      index = tracks.findIndex(item => {
 | 
											
												
													
														|  |        return item === track
 |  |        return item === track
 | 
											
												
													
														|  |      })
 |  |      })
 | 
											
												
													
														|  | 
 |  | +    musicalInstrumentId = musicObj?.musicalInstrumentId
 | 
											
												
													
														|  |    } else {
 |  |    } else {
 | 
											
												
													
														|  |      /* 合奏 */
 |  |      /* 合奏 */
 | 
											
												
													
														|  |      // 支持总谱 并且当前是总谱。partIndex是999时候,或者默认是总谱并且partIndex为-1时候  -1就是partIndex没有值
 |  |      // 支持总谱 并且当前是总谱。partIndex是999时候,或者默认是总谱并且partIndex为-1时候  -1就是partIndex没有值
 | 
											
										
											
												
													
														|  | @@ -1410,6 +1419,7 @@ function initMusicSource(data: any, tracks: string[], partIndex: number) {
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |          track = "总谱"
 |  |          track = "总谱"
 | 
											
												
													
														|  |          index = 999
 |  |          index = 999
 | 
											
												
													
														|  | 
 |  | +        musicalInstrumentId = ''
 | 
											
												
													
														|  |      }else{
 |  |      }else{
 | 
											
												
													
														|  |        // 合奏只显示一个声轨
 |  |        // 合奏只显示一个声轨
 | 
											
												
													
														|  |        track = tracks[partIndex===-1?0:partIndex]
 |  |        track = tracks[partIndex===-1?0:partIndex]
 | 
											
										
											
												
													
														|  | @@ -1429,6 +1439,7 @@ function initMusicSource(data: any, tracks: string[], partIndex: number) {
 | 
											
												
													
														|  |        index = tracks.findIndex(item => {
 |  |        index = tracks.findIndex(item => {
 | 
											
												
													
														|  |          return item === track
 |  |          return item === track
 | 
											
												
													
														|  |        })
 |  |        })
 | 
											
												
													
														|  | 
 |  | +      musicalInstrumentId = musicObj?.musicalInstrumentId
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    // 当没有任何曲目的时候报错
 |  |    // 当没有任何曲目的时候报错
 | 
											
										
											
												
													
														|  | @@ -1473,7 +1484,8 @@ function initMusicSource(data: any, tracks: string[], partIndex: number) {
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |    return {
 |  |    return {
 | 
											
												
													
														|  |      index,
 |  |      index,
 | 
											
												
													
														|  | -    track
 |  | 
 | 
											
												
													
														|  | 
 |  | +    track,
 | 
											
												
													
														|  | 
 |  | +    musicalInstrumentId
 | 
											
												
													
														|  |    }
 |  |    }
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  const setState = (data: any, index: number) => {
 |  |  const setState = (data: any, index: number) => {
 | 
											
										
											
												
													
														|  | @@ -1589,7 +1601,8 @@ const setState = (data: any, index: number) => {
 | 
											
												
													
														|  |     * 各平台的乐器声部id不统一,为了兼容处理老的数据,加上乐器code码,此码唯一
 |  |     * 各平台的乐器声部id不统一,为了兼容处理老的数据,加上乐器code码,此码唯一
 | 
											
												
													
														|  |     * 获取指法code
 |  |     * 获取指法code
 | 
											
												
													
														|  |     */
 |  |     */
 | 
											
												
													
														|  | -  const code = state.isConcert ? matchVoicePart(state.trackId, "CONCERT") : matchVoicePart(state.musicalCodeId, "SINGLE");
 |  | 
 | 
											
												
													
														|  | 
 |  | +  // const code = state.isConcert ? matchVoicePart(state.trackId, "CONCERT") : matchVoicePart(state.musicalCodeId, "SINGLE");
 | 
											
												
													
														|  | 
 |  | +  const code = matchVoicePart(state.trackId, "CONCERT")
 | 
											
												
													
														|  |    state.fingeringInfo = subjectFingering(code);
 |  |    state.fingeringInfo = subjectFingering(code);
 | 
											
												
													
														|  |    console.log("🚀 ~ state.fingeringInfo:", code, state.fingeringInfo, state.trackId, state.track);
 |  |    console.log("🚀 ~ state.fingeringInfo:", code, state.fingeringInfo, state.trackId, state.track);
 | 
											
												
													
														|  |    state.musicalCodeId = state.fingeringInfo?.id || 0
 |  |    state.musicalCodeId = state.fingeringInfo?.id || 0
 |