Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 1 | /* |
| 2 | * Copyright 2020 Google Inc. |
| 3 | * |
| 4 | * Use of this source code is governed by a BSD-style license that can be |
| 5 | * found in the LICENSE file. |
| 6 | */ |
| 7 | |
| 8 | #include "gm/gm.h" |
| 9 | #include "include/core/SkCanvas.h" |
Brian Osman | 8cbedf9 | 2020-03-31 10:38:31 -0400 | [diff] [blame] | 10 | #include "include/core/SkData.h" |
Kevin Lubick | c3bac5b | 2023-09-25 08:43:57 -0400 | [diff] [blame] | 11 | #include "include/core/SkPicture.h" |
| 12 | #include "include/core/SkPictureRecorder.h" |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 13 | |
Kevin Lubick | bfc7c3a | 2022-11-29 11:58:51 -0500 | [diff] [blame] | 14 | #include <cmath> |
| 15 | |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 16 | struct Info { |
| 17 | float fNear = 0.05f; |
| 18 | float fFar = 4; |
| 19 | float fAngle = SK_ScalarPI / 4; |
| 20 | |
Kevin Lubick | bfc7c3a | 2022-11-29 11:58:51 -0500 | [diff] [blame] | 21 | SkV3 fEye { 0, 0, 1.0f/std::tan(fAngle/2) - 1 }; |
Mike Reed | 00a9764 | 2020-01-25 18:42:23 -0500 | [diff] [blame] | 22 | SkV3 fCOA { 0, 0, 0 }; |
| 23 | SkV3 fUp { 0, 1, 0 }; |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 24 | }; |
| 25 | |
Mike Reed | 00a9764 | 2020-01-25 18:42:23 -0500 | [diff] [blame] | 26 | static SkM44 inv(const SkM44& m) { |
Florin Malita | d589916 | 2020-02-04 10:06:24 -0500 | [diff] [blame] | 27 | SkM44 inverse(SkM44::kUninitialized_Constructor); |
| 28 | if (!m.invert(&inverse)) { |
| 29 | inverse.setIdentity(); |
| 30 | } |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 31 | return inverse; |
| 32 | } |
| 33 | |
Mike Reed | 00a9764 | 2020-01-25 18:42:23 -0500 | [diff] [blame] | 34 | static SkM44 make_ctm(const Info& info, const SkM44& model, SkSize size) { |
| 35 | SkM44 camera, perspective, viewport; |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 36 | |
| 37 | SkScalar w = size.width(); |
| 38 | SkScalar h = size.height(); |
| 39 | |
Michael Ludwig | e501670 | 2021-03-23 15:42:59 -0400 | [diff] [blame] | 40 | perspective = SkM44::Perspective(info.fNear, info.fFar, info.fAngle); |
| 41 | camera = SkM44::LookAt(info.fEye, info.fCOA, info.fUp); |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 42 | viewport.setScale(w*0.5f, h*0.5f, 1);//.postTranslate(r.centerX(), r.centerY(), 0); |
| 43 | |
| 44 | return viewport * perspective * camera * model * inv(viewport); |
| 45 | } |
| 46 | |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 47 | static void do_draw(SkCanvas* canvas, SkColor color) { |
| 48 | SkAutoCanvasRestore acr(canvas, true); |
| 49 | |
| 50 | Info info; |
| 51 | |
Mike Reed | 00a9764 | 2020-01-25 18:42:23 -0500 | [diff] [blame] | 52 | SkM44 m = SkM44::Rotate({0, 1, 0}, SK_ScalarPI/6); |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 53 | |
Mike Reed | 3ef77dd | 2020-04-06 10:41:09 -0400 | [diff] [blame] | 54 | canvas->concat(make_ctm(info, m, {300, 300})); |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 55 | |
| 56 | canvas->translate(150, 150); |
| 57 | SkPaint paint; |
| 58 | paint.setColor(color); |
| 59 | canvas->drawRect({-100, -100, 100, 100}, paint); |
| 60 | } |
| 61 | |
| 62 | /* |
| 63 | * Test calling drawables w/ translate and matrices |
| 64 | */ |
| 65 | DEF_SIMPLE_GM(sk3d_simple, real_canvas, 300, 300) { |
| 66 | do_draw(real_canvas, 0xFFFF0000); |
| 67 | |
| 68 | SkPictureRecorder recorder; |
| 69 | SkCanvas* canvas = recorder.beginRecording(300, 300); |
| 70 | |
| 71 | do_draw(canvas, 0x880000FF); |
| 72 | |
| 73 | auto pic = recorder.finishRecordingAsPicture(); |
John Stiles | 4250eff | 2022-02-04 16:09:04 -0500 | [diff] [blame] | 74 | real_canvas->drawPicture(pic); |
Mike Reed | a3a704a | 2020-01-10 17:21:40 -0500 | [diff] [blame] | 75 | } |