mirror of https://github.com/auygun/kaliber.git
Compare commits
No commits in common. "96d6a52a74293b38bc206f02a38553e85d7d2821" and "fb7f91185d9e9634f5fcf7be151ab10be67db8d5" have entirely different histories.
96d6a52a74
...
fb7f91185d
|
@ -51,6 +51,7 @@ add_library(kaliber SHARED
|
|||
../../../src/base/log.cc
|
||||
../../../src/base/task_runner.cc
|
||||
../../../src/base/thread_pool.cc
|
||||
../../../src/base/timer.cc
|
||||
../../../src/demo/credits.cc
|
||||
../../../src/demo/demo.cc
|
||||
../../../src/demo/enemy.cc
|
||||
|
|
|
@ -15,6 +15,7 @@ source_set("base") {
|
|||
"task_runner.h",
|
||||
"thread_pool.cc",
|
||||
"thread_pool.h",
|
||||
"timer.cc",
|
||||
"timer.h",
|
||||
"vecmath.h",
|
||||
]
|
||||
|
|
|
@ -0,0 +1,46 @@
|
|||
#include "base/timer.h"
|
||||
|
||||
#include <thread>
|
||||
|
||||
namespace base {
|
||||
|
||||
Timer::Timer() {
|
||||
Reset();
|
||||
}
|
||||
|
||||
void Timer::Reset() {
|
||||
gettimeofday(&last_time_, nullptr);
|
||||
|
||||
seconds_passed_ = 0.0f;
|
||||
seconds_accumulated_ = 0.0f;
|
||||
}
|
||||
|
||||
void Timer::Update() {
|
||||
timeval currentTime;
|
||||
gettimeofday(¤tTime, nullptr);
|
||||
seconds_passed_ =
|
||||
(float)(currentTime.tv_sec - last_time_.tv_sec) +
|
||||
0.000001f * (float)(currentTime.tv_usec - last_time_.tv_usec);
|
||||
|
||||
last_time_ = currentTime;
|
||||
|
||||
seconds_accumulated_ += seconds_passed_;
|
||||
}
|
||||
|
||||
void Timer::Sleep(float duration) {
|
||||
Timer timer;
|
||||
float accumulator = 0.0;
|
||||
constexpr float epsilon = 0.0001f;
|
||||
|
||||
while (accumulator < duration) {
|
||||
timer.Update();
|
||||
accumulator += timer.GetSecondsPassed();
|
||||
if (duration - accumulator > epsilon) {
|
||||
float sleep_time = duration - accumulator - epsilon;
|
||||
std::this_thread::sleep_for(
|
||||
std::chrono::microseconds((int)(sleep_time * 1000000.0f)));
|
||||
}
|
||||
};
|
||||
}
|
||||
|
||||
} // namespace base
|
|
@ -1,47 +1,31 @@
|
|||
#ifndef BASE_TIMER_H
|
||||
#define BASE_TIMER_H
|
||||
|
||||
#include <chrono>
|
||||
#include <thread>
|
||||
#include <sys/time.h>
|
||||
|
||||
namespace base {
|
||||
|
||||
class ElapsedTimer {
|
||||
class Timer {
|
||||
public:
|
||||
ElapsedTimer() { time_ = std::chrono::high_resolution_clock::now(); }
|
||||
Timer();
|
||||
~Timer() = default;
|
||||
|
||||
// Return seconds passed since creating the object.
|
||||
double Elapsed() const {
|
||||
auto current_time = std::chrono::high_resolution_clock::now();
|
||||
std::chrono::duration<double> diff = current_time - time_;
|
||||
return diff.count();
|
||||
}
|
||||
void Reset();
|
||||
|
||||
void Update();
|
||||
|
||||
static void Sleep(float duration);
|
||||
|
||||
float GetSecondsPassed() const { return seconds_passed_; }
|
||||
float GetSecondsAccumulated() const { return seconds_accumulated_; }
|
||||
|
||||
private:
|
||||
std::chrono::time_point<std::chrono::high_resolution_clock> time_;
|
||||
float seconds_passed_ = 0.0f;
|
||||
float seconds_accumulated_ = 0.0f;
|
||||
|
||||
timeval last_time_;
|
||||
};
|
||||
|
||||
class DeltaTimer {
|
||||
public:
|
||||
DeltaTimer() { time_ = std::chrono::high_resolution_clock::now(); }
|
||||
|
||||
// Return seconds passed since the last call to this function.
|
||||
double Delta() {
|
||||
auto current_time = std::chrono::high_resolution_clock::now();
|
||||
std::chrono::duration<double> diff = current_time - time_;
|
||||
time_ = current_time;
|
||||
return diff.count();
|
||||
}
|
||||
|
||||
private:
|
||||
std::chrono::time_point<std::chrono::high_resolution_clock> time_;
|
||||
};
|
||||
|
||||
inline void Sleep(double seconds) {
|
||||
std::this_thread::sleep_for(
|
||||
std::chrono::duration<double, std::milli>(seconds * 1000));
|
||||
}
|
||||
|
||||
} // namespace base
|
||||
|
||||
#endif // BASE_TIMER_H
|
||||
|
|
|
@ -150,7 +150,7 @@ void Player::AddNuke(int n) {
|
|||
|
||||
if (!nuke_symbol_animator_.IsPlaying(Animator::kRotation)) {
|
||||
nuke_symbol_animator_.SetRotation(
|
||||
PIf * 5, 2, std::bind(SmootherStep, std::placeholders::_1));
|
||||
M_PI * 5, 2, std::bind(SmootherStep, std::placeholders::_1));
|
||||
nuke_symbol_animator_.Play(Animator::kRotation, false);
|
||||
}
|
||||
}
|
||||
|
@ -220,7 +220,7 @@ void Player::Fire(DamageType type, Vector2f dir) {
|
|||
|
||||
dir.Normalize();
|
||||
float cos_theta = dir.DotProduct(Vector2f(1, 0));
|
||||
float theta = acos(cos_theta) + PIf;
|
||||
float theta = acos(cos_theta) + M_PI;
|
||||
beam_[type].SetTheta(theta);
|
||||
auto offset = beam_[type].GetRotation() * (len / 2);
|
||||
beam_[type].Translate({offset.y, -offset.x});
|
||||
|
@ -285,7 +285,7 @@ void Player::SetupWeapons() {
|
|||
|
||||
weapon_[i].SetFrame(wepon_warmup_frame[i]);
|
||||
warmup_animator_[i].SetFrames(wepon_warmup_frame_count, wepon_anim_speed);
|
||||
warmup_animator_[i].SetRotation(PIf * 2, 20.0f);
|
||||
warmup_animator_[i].SetRotation(M_PI * 2, 20.0f);
|
||||
warmup_animator_[i].Attach(&weapon_[i]);
|
||||
warmup_animator_[i].Play(Animator::kRotation, true);
|
||||
|
||||
|
|
|
@ -5,7 +5,6 @@
|
|||
#include <alsa/asoundlib.h>
|
||||
|
||||
#include "base/log.h"
|
||||
#include "base/timer.h"
|
||||
|
||||
using namespace base;
|
||||
|
||||
|
@ -187,7 +186,7 @@ void AudioSinkAlsa::AudioThreadMain() {
|
|||
if (terminate_audio_thread_.load(std::memory_order_relaxed))
|
||||
return;
|
||||
// Avoid busy-looping.
|
||||
Sleep(1);
|
||||
std::this_thread::sleep_for(std::chrono::milliseconds(1));
|
||||
}
|
||||
|
||||
delegate_->RenderAudio(buffer.get(), num_frames);
|
||||
|
|
|
@ -2,7 +2,6 @@
|
|||
|
||||
#include "base/log.h"
|
||||
#include "base/task_runner.h"
|
||||
#include "base/timer.h"
|
||||
#include "engine/animator.h"
|
||||
#include "engine/asset/font.h"
|
||||
#include "engine/asset/image.h"
|
||||
|
@ -73,7 +72,7 @@ Engine& Engine::Get() {
|
|||
void Engine::Run() {
|
||||
Initialize();
|
||||
|
||||
DeltaTimer timer;
|
||||
timer_.Reset();
|
||||
float accumulator = 0.0;
|
||||
float frame_frac = 0.0f;
|
||||
|
||||
|
@ -84,13 +83,17 @@ void Engine::Run() {
|
|||
if (platform_->should_exit())
|
||||
return;
|
||||
|
||||
if (!renderer_->IsInitialzed())
|
||||
if (!renderer_->IsInitialzed()) {
|
||||
timer_.Reset();
|
||||
input_queue_.clear();
|
||||
continue;
|
||||
}
|
||||
|
||||
Draw(frame_frac);
|
||||
|
||||
// Accumulate time.
|
||||
accumulator += timer.Delta();
|
||||
timer_.Update();
|
||||
accumulator += timer_.GetSecondsPassed();
|
||||
|
||||
// Subdivide the frame time using fixed time steps.
|
||||
while (accumulator >= time_step_) {
|
||||
|
@ -508,6 +511,7 @@ void Engine::LostFocus() {
|
|||
}
|
||||
|
||||
void Engine::GainedFocus(bool from_interstitial_ad) {
|
||||
timer_.Reset();
|
||||
audio_mixer_->Resume();
|
||||
|
||||
if (game_)
|
||||
|
|
|
@ -9,6 +9,7 @@
|
|||
|
||||
#include "base/random.h"
|
||||
#include "base/thread_pool.h"
|
||||
#include "base/timer.h"
|
||||
#include "base/vecmath.h"
|
||||
#include "engine/persistent_data.h"
|
||||
#include "engine/platform/platform_observer.h"
|
||||
|
@ -213,6 +214,7 @@ class Engine : public PlatformObserver {
|
|||
unsigned int replay_index_ = 0;
|
||||
|
||||
base::ThreadPool thread_pool_;
|
||||
base::Timer timer_;
|
||||
base::Randomf random_;
|
||||
|
||||
void Initialize();
|
||||
|
|
|
@ -1536,13 +1536,24 @@ bool VulkanContext::SwapBuffers() {
|
|||
/*pWaitSemaphores*/
|
||||
(separate_present_queue_) ? &image_ownership_semaphores_[frame_index_]
|
||||
: &draw_complete_semaphores_[frame_index_],
|
||||
/*swapchainCount*/ 1,
|
||||
/*pSwapchains*/ &window_.swapchain,
|
||||
/*pImageIndices*/ &window_.current_buffer,
|
||||
/*swapchainCount*/ 0,
|
||||
/*pSwapchain*/ nullptr,
|
||||
/*pImageIndices*/ nullptr,
|
||||
/*pResults*/ nullptr,
|
||||
};
|
||||
|
||||
VkSwapchainKHR* swapchains = (VkSwapchainKHR*)alloca(sizeof(VkSwapchainKHR*));
|
||||
uint32_t* pImageIndices = (uint32_t*)alloca(sizeof(uint32_t*));
|
||||
|
||||
present.pSwapchains = swapchains;
|
||||
present.pImageIndices = pImageIndices;
|
||||
|
||||
DCHECK(window_.swapchain != VK_NULL_HANDLE);
|
||||
|
||||
swapchains[present.swapchainCount] = window_.swapchain;
|
||||
pImageIndices[present.swapchainCount] = window_.current_buffer;
|
||||
present.swapchainCount++;
|
||||
|
||||
err = QueuePresentKHR(present_queue_, &present);
|
||||
|
||||
frame_index_ += 1;
|
||||
|
|
Loading…
Reference in New Issue