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"
|
|
|
|
|
|
|
|
VisualStreamTimingModule::VisualStreamTimingModule(VisualBench* owner, bool preWarmBeforeSample)
|
2015-10-15 14:18:29 +00:00
|
|
|
: fInitState(kReset_InitState)
|
2015-10-14 14:49:28 +00:00
|
|
|
, fPreWarmBeforeSample(preWarmBeforeSample)
|
|
|
|
, fOwner(owner) {
|
|
|
|
fBenchmarkStream.reset(new VisualBenchmarkStream);
|
|
|
|
}
|
|
|
|
|
2015-10-15 14:18:29 +00:00
|
|
|
inline void VisualStreamTimingModule::handleInitState(SkCanvas* canvas) {
|
|
|
|
switch (fInitState) {
|
|
|
|
case kNewBenchmark_InitState:
|
|
|
|
fOwner->clear(canvas, SK_ColorWHITE, 2);
|
|
|
|
fBenchmarkStream->current()->delayedSetup();
|
|
|
|
// fallthrough
|
|
|
|
case kReset_InitState:
|
|
|
|
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::kReset_ParentEvents:
|
2015-10-15 14:18:29 +00:00
|
|
|
fBenchmarkStream->current()->postTimingHooks(canvas);
|
2015-10-14 14:49:28 +00:00
|
|
|
fOwner->reset();
|
2015-10-15 14:18:29 +00:00
|
|
|
fInitState = kReset_InitState;
|
2015-10-14 14:49:28 +00:00
|
|
|
break;
|
|
|
|
case TimingStateMachine::kTiming_ParentEvents:
|
|
|
|
break;
|
|
|
|
case TimingStateMachine::kTimingFinished_ParentEvents:
|
2015-10-15 14:18:29 +00:00
|
|
|
fBenchmarkStream->current()->postTimingHooks(canvas);
|
2015-10-14 14:49:28 +00:00
|
|
|
fOwner->reset();
|
2015-10-15 14:18:29 +00:00
|
|
|
if (this->timingFinished(fBenchmarkStream->current(), fTSM.loops(),
|
|
|
|
fTSM.lastMeasurement())) {
|
|
|
|
fTSM.nextBenchmark();
|
|
|
|
if (!fBenchmarkStream->next()) {
|
|
|
|
SkDebugf("Exiting VisualBench successfully\n");
|
|
|
|
fOwner->closeWindow();
|
|
|
|
} else {
|
|
|
|
fInitState = kNewBenchmark_InitState;
|
|
|
|
}
|
2015-10-14 14:49:28 +00:00
|
|
|
} else {
|
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();
|
|
|
|
TimingStateMachine::ParentEvents event = fTSM.nextFrame(fPreWarmBeforeSample);
|
|
|
|
this->handleTimingEvent(canvas, event);
|
|
|
|
}
|