diff options
author | reed <reed@chromium.org> | 2014-10-10 15:28:19 -0700 |
---|---|---|
committer | Commit bot <commit-bot@chromium.org> | 2014-10-10 15:28:19 -0700 |
commit | ba5fb932a1b5666a861043735cfb055cc1b600c7 (patch) | |
tree | ab540052f70b11f69b0cd4fe1b640f22f90c8304 | |
parent | 89c7a2ec3e9f7e1b9705214f450bb12288799da9 (diff) |
add drawImageRect to lua, update sample
BUG=skia:
TBR=
Review URL: https://codereview.chromium.org/642353005
-rw-r--r-- | samplecode/SampleLua.cpp | 131 | ||||
-rw-r--r-- | src/utils/SkLua.cpp | 25 |
2 files changed, 92 insertions, 64 deletions
diff --git a/samplecode/SampleLua.cpp b/samplecode/SampleLua.cpp index 00a3227d48..b4460c8550 100644 --- a/samplecode/SampleLua.cpp +++ b/samplecode/SampleLua.cpp @@ -19,70 +19,73 @@ extern "C" { static const char gDrawName[] = "onDrawContent"; static const char gCode[] = "" - "require \"math\" " - "" - "local r = { left = 10, top = 10, right = 100, bottom = 80 } " - "local x = 0;" - "" - "local paint = Sk.newPaint();" - "paint:setAntiAlias(true);" - "" - "local image = Sk.loadImage('/skia/trunk/sailboat.jpg');" - "" - "local color = {a = 1, r = 1, g = 0, b = 0};" - "" - "function rnd(range) " - " return math.random() * range;" - "end " - "" - "rndX = function () return rnd(640) end " - "rndY = function () return rnd(480) end " - "" - "function draw_rand_path(canvas);" - " if not path_paint then " - " path_paint = Sk.newPaint();" - " path_paint:setAntiAlias(true);" - " end " - " path_paint:setColor({a = 1, r = math.random(), g = math.random(), b = math.random() });" - "" - " local path = Sk.newPath();" - " path:moveTo(rndX(), rndY());" - " for i = 0, 50 do " - " path:quadTo(rndX(), rndY(), rndX(), rndY());" - " end " - " canvas:drawPath(path, path_paint);" - "" - " paint:setColor{a=1,r=0,g=0,b=1};" - " local align = { 'left', 'center', 'right' };" - " paint:setTextSize(30);" - " for k, v in next, align do " - " paint:setTextAlign(v);" - " canvas:drawText('Hamburgefons', 320, 200 + 30*k, paint);" - " end " - "end " - "" - "function onStartup() " - " local paint = Sk.newPaint();" - " paint:setColor{a=1, r=1, g=0, b=0};" - " local doc = Sk.newDocumentPDF('/skia/trunk/test.pdf');" - " local canvas = doc:beginPage(72*8.5, 72*11);" - " canvas:drawText('Hello Lua', 300, 300, paint);" - " doc:close();" - " doc = nil;" - "end " - "" - "function onDrawContent(canvas) " - " draw_rand_path(canvas);" - " color.g = x / 100;" - " paint:setColor(color) " - " canvas:translate(x, 0);" - " canvas:drawOval(r, paint) " - " x = x + 1;" - " canvas:drawImage(image, x, r.bottom + 50, 0.5);" - " if x > 100 then x = 0 end;" - "end " - "" - "onStartup();"; + "local r = { left = 10, top = 10, right = 100, bottom = 80 } \n" + "local x = 0;\n" + "\n" + "local paint = Sk.newPaint();\n" + "paint:setAntiAlias(true);\n" + "\n" + "local image = Sk.loadImage('/skia/sailboat.jpg');\n" + "\n" + "local color = {a = 1, r = 1, g = 0, b = 0};\n" + "\n" + "function rnd(range) \n" + " return math.random() * range;\n" + "end \n" + "\n" + "rndX = function () return rnd(640) end \n" + "rndY = function () return rnd(480) end \n" + "\n" + "function draw_rand_path(canvas);\n" + " if not path_paint then \n" + " path_paint = Sk.newPaint();\n" + " path_paint:setAntiAlias(true);\n" + " end \n" + " path_paint:setColor({a = 1, r = math.random(), g = math.random(), b = math.random() });\n" + "\n" + " local path = Sk.newPath();\n" + " path:moveTo(rndX(), rndY());\n" + " for i = 0, 50 do \n" + " path:quadTo(rndX(), rndY(), rndX(), rndY());\n" + " end \n" + " canvas:drawPath(path, path_paint);\n" + "\n" + " paint:setColor{a=1,r=0,g=0,b=1};\n" + " local align = { 'left', 'center', 'right' };\n" + " paint:setTextSize(30);\n" + " for k, v in next, align do \n" + " paint:setTextAlign(v);\n" + " canvas:drawText('Hamburgefons', 320, 200 + 30*k, paint);\n" + " end \n" + "end \n" + "\n" + "function onStartup() \n" + " local paint = Sk.newPaint();\n" + " paint:setColor{a=1, r=1, g=0, b=0};\n" + " local doc = Sk.newDocumentPDF('/skia/trunk/test.pdf');\n" + " local canvas = doc:beginPage(72*8.5, 72*11);\n" + " canvas:drawText('Hello Lua', 300, 300, paint);\n" + " doc:close();\n" + " doc = nil;\n" + "end \n" + "\n" + "function onDrawContent(canvas) \n" + " draw_rand_path(canvas);\n" + " color.g = x / 100;\n" + " paint:setColor(color) \n" + " canvas:translate(x, 0);\n" + " canvas:drawOval(r, paint) \n" + " x = x + 1;\n" + " local r2 = {}\n" + " r2.left = x;\n" + " r2.top = r.bottom + 50;\n" + " r2.right = r2.left + image:width() * 0.1;\n" + " r2.bottom = r2.top + image:height() * 0.1;\n" + " canvas:drawImageRect(image, nil, r2, 0.75);\n" + " if x > 100 then x = 0 end;\n" + "end \n" + "\n" + "onStartup();\n"; class LuaView : public SampleView { public: diff --git a/src/utils/SkLua.cpp b/src/utils/SkLua.cpp index 9880fe4408..1336404d8c 100644 --- a/src/utils/SkLua.cpp +++ b/src/utils/SkLua.cpp @@ -460,6 +460,30 @@ static int lcanvas_drawImage(lua_State* L) { return 0; } +static int lcanvas_drawImageRect(lua_State* L) { + SkCanvas* canvas = get_ref<SkCanvas>(L, 1); + SkImage* image = get_ref<SkImage>(L, 2); + if (NULL == image) { + return 0; + } + + SkRect srcR, dstR; + SkRect* srcRPtr = NULL; + if (!lua_isnil(L, 3)) { + srcRPtr = lua2rect(L, 3, &srcR); + } + lua2rect(L, 4, &dstR); + + SkPaint paint; + const SkPaint* paintPtr = NULL; + if (lua_isnumber(L, 5)) { + paint.setAlpha(SkScalarRoundToInt(lua2scalar(L, 5) * 255)); + paintPtr = &paint; + } + canvas->drawImageRect(image, srcRPtr, dstR, paintPtr); + return 0; +} + static int lcanvas_drawPath(lua_State* L) { get_ref<SkCanvas>(L, 1)->drawPath(*get_obj<SkPath>(L, 2), *get_obj<SkPaint>(L, 3)); @@ -576,6 +600,7 @@ const struct luaL_Reg gSkCanvas_Methods[] = { { "drawOval", lcanvas_drawOval }, { "drawCircle", lcanvas_drawCircle }, { "drawImage", lcanvas_drawImage }, + { "drawImageRect", lcanvas_drawImageRect }, { "drawPath", lcanvas_drawPath }, { "drawText", lcanvas_drawText }, { "getSaveCount", lcanvas_getSaveCount }, |