aboutsummaryrefslogtreecommitdiffhomepage
path: root/samplecode
diff options
context:
space:
mode:
authorGravatar reed@google.com <reed@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2011-03-01 15:18:14 +0000
committerGravatar reed@google.com <reed@google.com@2bbb7eff-a529-9590-31e7-b0007b416f81>2011-03-01 15:18:14 +0000
commitb652427197ddaac5d35010e1b199bcb431e656b7 (patch)
tree881345894396be575261aff9f1c3ee2b2fcc234f /samplecode
parentf9bb7a8e2052d21e6a7f48d5b73d2ef97637a09e (diff)
remove obsolete generateLineHeight
use canonical lfHeight so we can compare different LOGFONTs and map equivalent fonts (except for height) to the same typeface. To do this I add fSize to scale the output from GDI to get from the canonical int textSize to the actual fractional size. git-svn-id: http://skia.googlecode.com/svn/trunk@871 2bbb7eff-a529-9590-31e7-b0007b416f81
Diffstat (limited to 'samplecode')
-rw-r--r--samplecode/SampleTextBox.cpp43
1 files changed, 17 insertions, 26 deletions
diff --git a/samplecode/SampleTextBox.cpp b/samplecode/SampleTextBox.cpp
index f8f52a2f71..9511914ab6 100644
--- a/samplecode/SampleTextBox.cpp
+++ b/samplecode/SampleTextBox.cpp
@@ -20,6 +20,8 @@
#include "SkStream.h"
#include "SkKey.h"
+extern SkTypeface* SkCreateTypefaceFromLOGFONT(const LOGFONT&);
+
static const char gText[] =
"When in the Course of human events it becomes necessary for one people "
"to dissolve the political bands which have connected them with another "
@@ -31,7 +33,16 @@ static const char gText[] =
class TextBoxView : public SkView {
public:
TextBoxView() {
- fTextSize = SkIntToScalar(32);
+ LOGFONT lf;
+ sk_bzero(&lf, sizeof(lf));
+ lf.lfHeight = 9;
+ SkTypeface* tf0 = SkCreateTypefaceFromLOGFONT(lf);
+ lf.lfHeight = 12;
+ SkTypeface* tf1 = SkCreateTypefaceFromLOGFONT(lf);
+ // we assert that different sizes should not affect which face we get
+ SkASSERT(tf0 == tf1);
+ tf0->unref();
+ tf1->unref();
}
protected:
@@ -61,36 +72,16 @@ protected:
SkPaint paint;
paint.setAntiAlias(true);
- paint.setTextSize(fTextSize);
+ tbox.setText(gText, strlen(gText), paint);
- tbox.draw(canvas, gText, strlen(gText), paint);
- }
-
- virtual SkView::Click* onFindClickHandler(SkScalar x, SkScalar y) {
- return new Click(this);
- }
-
- virtual bool onClick(Click* click) {
- const SkScalar delta = SkIntToScalar(3);
- if (click->fState == Click::kUp_State) {
- if (click->fCurr.fY < this->height()/2) {
- fTextSize += delta;
- this->inval(NULL);
- return true;
- } else {
- if (fTextSize > delta) {
- fTextSize -= delta;
- this->inval(NULL);
- return true;
- }
- }
+ for (int i = 9; i < 24; i += 2) {
+ paint.setTextSize(SkIntToScalar(i));
+ tbox.draw(canvas);
+ canvas->translate(0, tbox.getTextHeight() + paint.getFontSpacing());
}
- return this->INHERITED::onClick(click);
}
private:
- SkScalar fTextSize;
-
typedef SkView INHERITED;
};