00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00025
00026 #ifndef VecFilter_H
00027 #define VecFilter_H
00028
00029 #include "H3DNetworkingUtils/Config.h"
00030 #include <deque>
00031 #include <H3DUtil/H3DMath.h>
00032 #include <H3DUtil/Vec3f.h>
00033
00034
00035 namespace H3DNetworkingUtils {
00036
00042
00043 class H3D_NETWORKING_UTILS_DLL_SPEC VecFilter {
00044 public:
00046 VecFilter(int sample_sz);
00047
00052 H3DUtil::ArithmeticTypes::Vec3f filter(H3DUtil::ArithmeticTypes::Vec3f const & raw_value, double time);
00053
00055 virtual void resetValue(int sample_sz);
00056
00058 int sampleSize() const { return sample_size;}
00059
00060 private:
00061 std::deque<H3DUtil::ArithmeticTypes::Vec3f> sample_vals;
00062 std::deque<double> sample_times;
00063 int sample_size;
00064 int num_samples;
00065 bool filling_samples;
00066 };
00067
00068 }
00069
00070 #endif