skia2/bench/SkBenchmark.cpp
agl@chromium.org 652807bbc8 Revert "Revert "Use hairline when line width <= 1.0, instead of < 1.0.""
This reverts commit r560. Chromium has landed at r560, so I'm applying the
revert-revert. (See the comments in r560 for details.)

git-svn-id: http://skia.googlecode.com/svn/trunk@561 2bbb7eff-a529-9590-31e7-b0007b416f81
2010-04-27 15:47:34 +00:00

70 lines
1.6 KiB
C++

#include "SkBenchmark.h"
#include "SkPaint.h"
#include "SkParse.h"
template BenchRegistry* BenchRegistry::gHead;
SkBenchmark::SkBenchmark(void* defineDict) {
fDict = reinterpret_cast<const SkTDict<const char*>*>(defineDict);
fForceAlpha = 0xFF;
fForceAA = true;
fDither = SkTriState::kDefault;
fHasStrokeWidth = false;
}
const char* SkBenchmark::getName() {
return this->onGetName();
}
SkIPoint SkBenchmark::getSize() {
return this->onGetSize();
}
void SkBenchmark::draw(SkCanvas* canvas) {
this->onDraw(canvas);
}
void SkBenchmark::setupPaint(SkPaint* paint) {
paint->setAlpha(fForceAlpha);
paint->setAntiAlias(fForceAA);
paint->setFilterBitmap(fForceFilter);
if (SkTriState::kDefault != fDither) {
paint->setDither(SkTriState::kTrue == fDither);
}
}
const char* SkBenchmark::findDefine(const char* key) const {
if (fDict) {
const char* value;
if (fDict->find(key, &value)) {
return value;
}
}
return NULL;
}
bool SkBenchmark::findDefine32(const char* key, int32_t* value) const {
const char* valueStr = this->findDefine(key);
if (valueStr) {
SkParse::FindS32(valueStr, value);
return true;
}
return false;
}
bool SkBenchmark::findDefineScalar(const char* key, SkScalar* value) const {
const char* valueStr = this->findDefine(key);
if (valueStr) {
SkParse::FindScalar(valueStr, value);
return true;
}
return false;
}
///////////////////////////////////////////////////////////////////////////////
SkIPoint SkBenchmark::onGetSize() {
return SkIPoint::Make(640, 480);
}