当前位置: 首页>>代码示例>>C#>>正文


C# Song.getBPS方法代码示例

本文整理汇总了C#中Song.getBPS方法的典型用法代码示例。如果您正苦于以下问题:C# Song.getBPS方法的具体用法?C# Song.getBPS怎么用?C# Song.getBPS使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在Song的用法示例。


在下文中一共展示了Song.getBPS方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C#代码示例。

示例1: fakeCreation

    void fakeCreation(Song s)
    {
        var theBPMCounter = 1;
        var theSTOPCounter = 0;
        double mesurecount = 0;
        double prevmesure = 0;
        double timecounter = 0;
        double timeBPM = 0;
        double timestop = 0;
        double timetotal = 0;
        float prec = 0.001f;

        //stepBySecondsAverage
        double timestart = -10f;
        double stoptime = 0;
        int countStep = 0;
        double stepbysecAv = 0f;

        //stepmax
        double maxStepPerSeconds = 0f;
        int numberStepBetweenTwoBeat = 0;
        double timestartMax = -10f;
        //double maxLenght = 0f;

        //longestStream
        double lenghtStream = 0f;
        double maxLenghtStream = 0f;
        double speedOfMaxStream = 0f;
        double previousSpeed = 0f;

        //Footswitch
        int numberOfFootswitch = 0;
        int[] casevalidate = new int[4]; //left down up right
        casevalidate[0] = 0;
        casevalidate[1] = 0;
        casevalidate[2] = 0;
        casevalidate[3] = 0;

        //Cross
        int numberOfCross = 0;
        int[] caseCrossvalidate = new int[4]; //left down up right
        caseCrossvalidate[0] = 0;
        caseCrossvalidate[1] = 0;
        caseCrossvalidate[2] = 0;
        caseCrossvalidate[3] = 0;

        //Hands
        int numberOfHands = 0;

        //freeze
        var freezed = new int[4];
        freezed[0] = 0;
        freezed[1] = 0;
        freezed[2] = 0;
        freezed[3] = 0;

        //graph
        var listNumberStep = new Dictionary<double, double>();

        foreach(var mesure in s.stepchart){

            for(int beat=0;beat<mesure.Count;beat++){

            #region BPMChange
                var bps = s.getBPS(s.bpms.ElementAt(theBPMCounter-1).Value);
                if(theBPMCounter < s.bpms.Count && theSTOPCounter < s.stops.Count){
                    while((theBPMCounter < s.bpms.Count && theSTOPCounter < s.stops.Count)
                        && (s.mesureBPMS.ElementAt(theBPMCounter) < mesurecount - prec || s.mesureSTOPS.ElementAt(theSTOPCounter) < mesurecount - prec)){

                        if(s.mesureBPMS.ElementAt(theBPMCounter) < s.mesureSTOPS.ElementAt(theSTOPCounter)){
                            timecounter += (s.mesureBPMS.ElementAt(theBPMCounter) - prevmesure)/bps;

                            timeBPM += timecounter;
                            timecounter = 0;
                            prevmesure = s.mesureBPMS.ElementAt(theBPMCounter);
                            theBPMCounter++;
                            bps = s.getBPS(s.bpms.ElementAt(theBPMCounter-1).Value);
                            //Debug.Log("And bpm change before / bpm");
                        }else if(s.mesureBPMS.ElementAt(theBPMCounter) > s.mesureSTOPS.ElementAt(theSTOPCounter)){
                            timestop += s.stops.ElementAt(theSTOPCounter).Value;
                            theSTOPCounter++;
                            //Debug.Log("And stop change before");
                        }else{
                            timecounter += (s.mesureBPMS.ElementAt(theBPMCounter) - prevmesure)/bps;
                            timeBPM += timecounter;
                            timecounter = 0;
                            prevmesure = s.mesureBPMS.ElementAt(theBPMCounter);
                            theBPMCounter++;
                            bps = s.getBPS(s.bpms.ElementAt(theBPMCounter-1).Value);

                            timestop += s.stops.ElementAt(theSTOPCounter).Value;
                            theSTOPCounter++;
                            //Debug.Log("And bpm change before");
                            //Debug.Log("And stop change before");
                        }

                    }
                }else if(theBPMCounter < s.bpms.Count){
                    while((theBPMCounter < s.bpms.Count) && s.mesureBPMS.ElementAt(theBPMCounter) < mesurecount - prec){

//.........这里部分代码省略.........
开发者ID:bobwister,项目名称:Unity-ITGHD,代码行数:101,代码来源:OpenChart.cs

示例2: createTheChart

    //Create the chart
    void createTheChart(Song s)
    {
        var ypos = 0f;
        arrowLeftList = new List<Arrow>();
        arrowUpList = new List<Arrow>();
        arrowDownList = new List<Arrow>();
        arrowRightList = new List<Arrow>();
        mineLeftList = new List<Arrow>();
        mineUpList = new List<Arrow>();
        mineDownList = new List<Arrow>();
        mineRightList = new List<Arrow>();

        var theBPMCounter = 1;
        var theSTOPCounter = 0;
        double mesurecount = 0;
        double prevmesure = 0;
        double timecounter = 0;
        double timeBPM = 0;
        double timestop = 0;
        double timetotal = 0;
        float prec = 0.001f;
        var ArrowFreezed = new Arrow[4];
        Bumps = new List<double>();
        foreach(var mesure in s.stepchart){

            for(int beat=0;beat<mesure.Count;beat++){

                var bps = s.getBPS(s.bpms.ElementAt(theBPMCounter-1).Value);
                if(theBPMCounter < s.bpms.Count && theSTOPCounter < s.stops.Count){
                    while((theBPMCounter < s.bpms.Count && theSTOPCounter < s.stops.Count)
                        && (s.mesureBPMS.ElementAt(theBPMCounter) < mesurecount - prec || s.mesureSTOPS.ElementAt(theSTOPCounter) < mesurecount - prec)){

                        if(s.mesureBPMS.ElementAt(theBPMCounter) < s.mesureSTOPS.ElementAt(theSTOPCounter)){
                            timecounter += (s.mesureBPMS.ElementAt(theBPMCounter) - prevmesure)/bps;

                            timeBPM += timecounter;
                            timecounter = 0;
                            prevmesure = s.mesureBPMS.ElementAt(theBPMCounter);
                            theBPMCounter++;
                            bps = s.getBPS(s.bpms.ElementAt(theBPMCounter-1).Value);
                            //Debug.Log("And bpm change before / bpm");
                        }else if(s.mesureBPMS.ElementAt(theBPMCounter) > s.mesureSTOPS.ElementAt(theSTOPCounter)){
                            timestop += s.stops.ElementAt(theSTOPCounter).Value;
                            theSTOPCounter++;
                            //Debug.Log("And stop change before");
                        }else{
                            timecounter += (s.mesureBPMS.ElementAt(theBPMCounter) - prevmesure)/bps;
                            timeBPM += timecounter;
                            timecounter = 0;
                            prevmesure = s.mesureBPMS.ElementAt(theBPMCounter);
                            theBPMCounter++;
                            bps = s.getBPS(s.bpms.ElementAt(theBPMCounter-1).Value);

                            timestop += s.stops.ElementAt(theSTOPCounter).Value;
                            theSTOPCounter++;
                            //Debug.Log("And bpm change before");
                            //Debug.Log("And stop change before");
                        }

                    }
                }else if(theBPMCounter < s.bpms.Count){
                    while((theBPMCounter < s.bpms.Count) && s.mesureBPMS.ElementAt(theBPMCounter) < mesurecount - prec){

                        timecounter += (s.mesureBPMS.ElementAt(theBPMCounter) - prevmesure)/bps;

                        timeBPM += timecounter;
                        timecounter = 0;
                        prevmesure = s.mesureBPMS.ElementAt(theBPMCounter);
                        theBPMCounter++;
                        bps = s.getBPS(s.bpms.ElementAt(theBPMCounter-1).Value);

                    }
                }else if(theSTOPCounter < s.stops.Count){
                    while((theSTOPCounter < s.stops.Count) && s.mesureSTOPS.ElementAt(theSTOPCounter) < mesurecount - prec){

                        timestop += s.stops.ElementAt(theSTOPCounter).Value;
                        theSTOPCounter++;

                    }
                }

                timecounter += (mesurecount - prevmesure)/bps;

                timetotal = timecounter + timeBPM + timestop;
                if((beat)%(mesure.Count/4) == 0) Bumps.Add(timetotal);

                var previousnote = mesure.ElementAt(beat).Trim();

                //Traitement
                if(displayValue[0]){ //No mine
                    previousnote = previousnote.Replace('M', '0');
                }
                if(displayValue[1]){ //No jump
                    if(previousnote.Where( c => c == '1' || c == '2' || c == '4').Count() == 2){
                        var done = false;
                        for(int i=0; i<4; i++){
                            if(previousnote.ElementAt(i) == '1' || 	previousnote.ElementAt(i) == '2' || previousnote.ElementAt(i) == '4'){
                                if(done){
                                    previousnote = previousnote.Remove(i, 1);
//.........这里部分代码省略.........
开发者ID:bobwister,项目名称:Unity-ITGHD,代码行数:101,代码来源:InGameScript.cs


注:本文中的Song.getBPS方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。