add the following fields to the lua accumulate table:

- rrect.rect
- rrect[1..8] for radii
- rrect.type = "empty|rect|oval|simple|complex"
- path.isRect, path.isOval

Review URL: https://codereview.chromium.org/15192003

git-svn-id: http://skia.googlecode.com/svn/trunk@9163 2bbb7eff-a529-9590-31e7-b0007b416f81
This commit is contained in:
reed@google.com 2013-05-16 13:51:07 +00:00
parent 6bb3efc4db
commit 57de5cfe42

View File

@ -27,6 +27,15 @@ static void setfield_bool(lua_State* L, const char key[], bool value) {
lua_setfield(L, -2, key);
}
// sets [1]...[count] in the table on the top of the stack
static void setfield_arrayf(lua_State* L, const SkScalar array[], int count) {
for (int i = 0; i < count; ++i) {
lua_pushnumber(L, SkScalarToDouble(i + 1)); // key
lua_pushnumber(L, SkScalarToDouble(array[i])); // value
lua_settable(L, -3);
}
}
static void setfield_rect(lua_State* L, const char key[], const SkRect& r) {
lua_newtable(L);
setfield_number(L, "left", r.fLeft);
@ -36,6 +45,34 @@ static void setfield_rect(lua_State* L, const char key[], const SkRect& r) {
lua_setfield(L, -2, key);
}
static const char* rrect_type(const SkRRect& rr) {
switch (rr.getType()) {
case SkRRect::kUnknown_Type: return "unknown";
case SkRRect::kEmpty_Type: return "empty";
case SkRRect::kRect_Type: return "rect";
case SkRRect::kOval_Type: return "oval";
case SkRRect::kSimple_Type: return "simple";
case SkRRect::kComplex_Type: return "complex";
}
SkASSERT(!"never get here");
return "";
}
static void setfield_rrect(lua_State* L, const char key[], const SkRRect& rr) {
lua_newtable(L);
setfield_rect(L, "rect", rr.getBounds());
setfield_string(L, "type", rrect_type(rr));
SkVector rad[4] = {
rr.radii(SkRRect::kUpperLeft_Corner),
rr.radii(SkRRect::kUpperRight_Corner),
rr.radii(SkRRect::kLowerRight_Corner),
rr.radii(SkRRect::kLowerLeft_Corner),
};
setfield_arrayf(L, &rad[0].fX, 8);
lua_setfield(L, -2, key);
}
enum PaintUsage {
kText_PaintUsage,
kImage_PaintUsage,
@ -172,6 +209,7 @@ bool SkLuaCanvas::clipRect(const SkRect& r, SkRegion::Op op, bool doAA) {
bool SkLuaCanvas::clipRRect(const SkRRect& rrect, SkRegion::Op op, bool doAA) {
AUTO_LUA("clipRRect");
setfield_rrect(fL, "rrect", rrect);
setfield_bool(fL, "aa", doAA);
return this->INHERITED::clipRRect(rrect, op, doAA);
}
@ -200,7 +238,7 @@ void SkLuaCanvas::drawPoints(PointMode mode, size_t count,
void SkLuaCanvas::drawOval(const SkRect& rect, const SkPaint& paint) {
AUTO_LUA("drawOval");
setfield_rect(fL, "rect", rect);
setfield_rect(fL, "oval", rect);
setfield_paint(fL, paint);
}
@ -212,13 +250,15 @@ void SkLuaCanvas::drawRect(const SkRect& rect, const SkPaint& paint) {
void SkLuaCanvas::drawRRect(const SkRRect& rrect, const SkPaint& paint) {
AUTO_LUA("drawRRect");
setfield_rect(fL, "rect", rrect.getBounds());
setfield_rrect(fL, "rrect", rrect);
setfield_paint(fL, paint);
}
void SkLuaCanvas::drawPath(const SkPath& path, const SkPaint& paint) {
AUTO_LUA("drawPath");
setfield_rect(fL, "bounds", path.getBounds());
setfield_bool(fL, "isRect", path.isRect(NULL));
setfield_bool(fL, "isOval", path.isOval(NULL));
setfield_paint(fL, paint);
}