2015-10-14 14:49:28 +00:00
|
|
|
/*
|
|
|
|
* Copyright 2015 Google Inc.
|
|
|
|
*
|
|
|
|
* Use of this source code is governed by a BSD-style license that can be
|
|
|
|
* found in the LICENSE file.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "VisualStreamTimingModule.h"
|
|
|
|
|
|
|
|
#include "SkCanvas.h"
|
|
|
|
|
2015-11-13 16:28:49 +00:00
|
|
|
DEFINE_bool(reset, true, "Reset the GL context between samples.");
|
|
|
|
|
|
|
|
VisualStreamTimingModule::VisualStreamTimingModule(VisualBench* owner)
|
2015-10-15 14:18:29 +00:00
|
|
|
: fInitState(kReset_InitState)
|
2015-10-14 14:49:28 +00:00
|
|
|
, fOwner(owner) {
|
2015-10-26 20:14:36 +00:00
|
|
|
fBenchmarkStream.reset(new VisualBenchmarkStream(owner->getSurfaceProps()));
|
2015-10-14 14:49:28 +00:00
|
|
|
}
|
|
|
|
|
2015-10-15 14:18:29 +00:00
|
|
|
inline void VisualStreamTimingModule::handleInitState(SkCanvas* canvas) {
|
|
|
|
switch (fInitState) {
|
|
|
|
case kNewBenchmark_InitState:
|
|
|
|
fBenchmarkStream->current()->delayedSetup();
|
|
|
|
// fallthrough
|
|
|
|
case kReset_InitState:
|
2015-10-21 15:04:24 +00:00
|
|
|
// This will flicker unfortunately, but as we are reseting the GLContext each bench,
|
|
|
|
// we unfortunately don't have a choice
|
2015-11-13 16:56:31 +00:00
|
|
|
fOwner->clear(canvas, SK_ColorWHITE, 3);
|
2015-10-15 14:18:29 +00:00
|
|
|
fBenchmarkStream->current()->preTimingHooks(canvas);
|
|
|
|
break;
|
|
|
|
case kNone_InitState:
|
|
|
|
break;
|
2015-10-14 21:45:07 +00:00
|
|
|
}
|
2015-10-15 14:18:29 +00:00
|
|
|
fInitState = kNone_InitState;
|
2015-10-14 21:45:07 +00:00
|
|
|
}
|
|
|
|
|
2015-10-15 14:18:29 +00:00
|
|
|
inline void VisualStreamTimingModule::handleTimingEvent(SkCanvas* canvas,
|
|
|
|
TimingStateMachine::ParentEvents event) {
|
2015-10-14 14:49:28 +00:00
|
|
|
switch (event) {
|
|
|
|
case TimingStateMachine::kTiming_ParentEvents:
|
|
|
|
break;
|
|
|
|
case TimingStateMachine::kTimingFinished_ParentEvents:
|
2015-10-15 14:18:29 +00:00
|
|
|
if (this->timingFinished(fBenchmarkStream->current(), fTSM.loops(),
|
|
|
|
fTSM.lastMeasurement())) {
|
2015-11-13 16:28:49 +00:00
|
|
|
fBenchmarkStream->current()->postTimingHooks(canvas);
|
|
|
|
fOwner->reset();
|
2015-10-15 14:18:29 +00:00
|
|
|
fTSM.nextBenchmark();
|
|
|
|
if (!fBenchmarkStream->next()) {
|
|
|
|
SkDebugf("Exiting VisualBench successfully\n");
|
|
|
|
fOwner->closeWindow();
|
|
|
|
} else {
|
|
|
|
fInitState = kNewBenchmark_InitState;
|
|
|
|
}
|
2015-11-13 16:28:49 +00:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
// fallthrough
|
|
|
|
case TimingStateMachine::kReset_ParentEvents:
|
|
|
|
if (FLAGS_reset) {
|
|
|
|
fBenchmarkStream->current()->postTimingHooks(canvas);
|
|
|
|
fOwner->reset();
|
2015-10-15 14:18:29 +00:00
|
|
|
fInitState = kReset_InitState;
|
2015-10-14 14:49:28 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
2015-10-15 14:18:29 +00:00
|
|
|
|
|
|
|
void VisualStreamTimingModule::draw(SkCanvas* canvas) {
|
|
|
|
if (!fBenchmarkStream->current()) {
|
|
|
|
// this should never happen but just to be safe
|
|
|
|
// TODO research why this does happen on mac
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
this->handleInitState(canvas);
|
|
|
|
this->renderFrame(canvas, fBenchmarkStream->current(), fTSM.loops());
|
|
|
|
fOwner->present();
|
2015-11-13 16:28:49 +00:00
|
|
|
TimingStateMachine::ParentEvents event = fTSM.nextFrame(FLAGS_reset);
|
2015-10-15 14:18:29 +00:00
|
|
|
this->handleTimingEvent(canvas, event);
|
|
|
|
}
|