forked from stepmania/stepmania
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathAdjustSync.h
92 lines (82 loc) · 3.4 KB
/
AdjustSync.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
#ifndef AdjustSync_H
#define AdjustSync_H
#include <string>
#include <vector>
/**
* @brief The minimum number of steps to hit for syncing purposes.
*
* To future developers: this statement should be moved out somewhere else
* in the future.
*/
#define OFFSET_SAMPLE_COUNT 24
class TimingData;
/**
* @brief Allows for adjusting the sync of a song.
*
* This class defines two ways of adjusting the sync of a song.
* The first adjusts only the offset, "on the fly". It can adjust either the
* song itself or the machine. The other style adjusts both the BPM and the
* offset of the song, but it needs more data.
*/
class AdjustSync
{
public:
/**
* @brief The original TimingData before adjustments were made.
*
* This is designed to work with Split Timing. */
static std::vector<TimingData> s_vpTimingDataOriginal;
static float s_fGlobalOffsetSecondsOriginal;
/* We only want to call the Reset methods before a song, not immediately after
* a song. If we reset it at the end of a song, we have to carefully check
* the logic to make sure we never reset it before the user gets a chance to
* save or revert the change. Resetting at the start of the song is
* sufficient. */
static void ResetOriginalSyncData();
static void ResetAutosync();
static bool IsSyncDataChanged();
static void SaveSyncChanges();
static void RevertSyncChanges();
static void HandleAutosync( float fNoteOffBySeconds, float fStepTime );
static void HandleSongEnd();
static void AutosyncOffset();
static void AutosyncTempo();
static void GetSyncChangeTextGlobal( std::vector<std::string> &vsAddTo );
static void GetSyncChangeTextSong( std::vector<std::string> &vsAddTo );
static float s_fAutosyncOffset[OFFSET_SAMPLE_COUNT];
static int s_iAutosyncOffsetSample;
static float s_fStandardDeviation;
// Measured in seconds. If the average error is too high, we
// reject the recorded data for the Least Squares Regression.
static const float ERROR_TOO_HIGH;
static std::vector< std::pair<float, float> > s_vAutosyncTempoData;
static float s_fAverageError;
static int s_iStepsFiltered;
};
#endif
/**
* @file
* @author Chris Danford, John Bauer (c) 2003-2006
* @section LICENSE
* All rights reserved.
*
* Permission is hereby granted, free of charge, to any person obtaining a
* copy of this software and associated documentation files (the
* "Software"), to deal in the Software without restriction, including
* without limitation the rights to use, copy, modify, merge, publish,
* distribute, and/or sell copies of the Software, and to permit persons to
* whom the Software is furnished to do so, provided that the above
* copyright notice(s) and this permission notice appear in all copies of
* the Software and that both the above copyright notice(s) and this
* permission notice appear in supporting documentation.
*
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
* OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT OF
* THIRD PARTY RIGHTS. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR HOLDERS
* INCLUDED IN THIS NOTICE BE LIABLE FOR ANY CLAIM, OR ANY SPECIAL INDIRECT
* OR CONSEQUENTIAL DAMAGES, OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS
* OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
* OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
* PERFORMANCE OF THIS SOFTWARE.
*/