Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(432)

Side by Side Diff: samplecode/SampleAll.cpp

Issue 1772463002: use Make instead of Create to return a shared shader (Closed) Base URL: https://skia.googlesource.com/skia.git@master
Patch Set: partial update of skia call-sites Created 4 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 1
2 /* 2 /*
3 * Copyright 2011 Google Inc. 3 * Copyright 2011 Google Inc.
4 * 4 *
5 * Use of this source code is governed by a BSD-style license that can be 5 * Use of this source code is governed by a BSD-style license that can be
6 * found in the LICENSE file. 6 * found in the LICENSE file.
7 */ 7 */
8 #include "SampleCode.h" 8 #include "SampleCode.h"
9 #include "SkBlurMask.h" 9 #include "SkBlurMask.h"
10 #include "SkCanvas.h" 10 #include "SkCanvas.h"
(...skipping 343 matching lines...) Expand 10 before | Expand all | Expand 10 after
354 for (index = 0; index < asciiLength; index++) 354 for (index = 0; index < asciiLength; index++)
355 pos2[index].set(SkIntToScalar((unsigned int)index * 10), 355 pos2[index].set(SkIntToScalar((unsigned int)index * 10),
356 SkIntToScalar(20)); 356 SkIntToScalar(20));
357 357
358 // shaders 358 // shaders
359 SkPoint linearPoints[] = { { 0, 0, }, { SkIntToScalar(40), SkIntToScalar (40) } }; 359 SkPoint linearPoints[] = { { 0, 0, }, { SkIntToScalar(40), SkIntToScalar (40) } };
360 SkColor linearColors[] = { SK_ColorRED, SK_ColorBLUE }; 360 SkColor linearColors[] = { SK_ColorRED, SK_ColorBLUE };
361 SkScalar* linearPos = nullptr; 361 SkScalar* linearPos = nullptr;
362 int linearCount = 2; 362 int linearCount = 2;
363 SkShader::TileMode linearMode = SkShader::kMirror_TileMode; 363 SkShader::TileMode linearMode = SkShader::kMirror_TileMode;
364 SkShader* linear = SkGradientShader::CreateLinear(linearPoints, 364 auto linear = SkGradientShader::MakeLinear(linearPoints,
365 linearColors, linearPos, linearCount, linearMode); 365 linearColors, linearPos, linearCount, linearMode);
366 366
367 SkPoint radialCenter = { SkIntToScalar(25), SkIntToScalar(25) }; 367 SkPoint radialCenter = { SkIntToScalar(25), SkIntToScalar(25) };
368 SkScalar radialRadius = SkIntToScalar(25); 368 SkScalar radialRadius = SkIntToScalar(25);
369 SkColor radialColors[] = { SK_ColorGREEN, SK_ColorGRAY, SK_ColorRED }; 369 SkColor radialColors[] = { SK_ColorGREEN, SK_ColorGRAY, SK_ColorRED };
370 SkScalar radialPos[] = { 0, SkIntToScalar(3) / 5, SkIntToScalar(1)}; 370 SkScalar radialPos[] = { 0, SkIntToScalar(3) / 5, SkIntToScalar(1)};
371 int radialCount = 3; 371 int radialCount = 3;
372 SkShader::TileMode radialMode = SkShader::kRepeat_TileMode; 372 SkShader::TileMode radialMode = SkShader::kRepeat_TileMode;
373 SkShader* radial = SkGradientShader::CreateRadial(radialCenter, 373 auto radial = SkGradientShader::MakeRadial(radialCenter,
374 radialRadius, radialColors, radialPos, radialCount, 374 radialRadius, radialColors, radialPos, radialCount,
375 radialMode); 375 radialMode);
376 376
377 SkEmbossMaskFilter::Light light; 377 SkEmbossMaskFilter::Light light;
378 light.fDirection[0] = SK_Scalar1/2; 378 light.fDirection[0] = SK_Scalar1/2;
379 light.fDirection[1] = SK_Scalar1/2; 379 light.fDirection[1] = SK_Scalar1/2;
380 light.fDirection[2] = SK_Scalar1/3; 380 light.fDirection[2] = SK_Scalar1/3;
381 light.fAmbient = 0x48; 381 light.fAmbient = 0x48;
382 light.fSpecular = 0x80; 382 light.fSpecular = 0x80;
383 SkScalar sigma = SkBlurMask::ConvertRadiusToSigma(SkIntToScalar(12)/5); 383 SkScalar sigma = SkBlurMask::ConvertRadiusToSigma(SkIntToScalar(12)/5);
384 SkMaskFilter* embossFilter = SkEmbossMaskFilter::Create(sigma, light); 384 SkMaskFilter* embossFilter = SkEmbossMaskFilter::Create(sigma, light);
385 385
386 SkXfermode* xfermode = SkXfermode::Create(SkXfermode::kXor_Mode); 386 SkXfermode* xfermode = SkXfermode::Create(SkXfermode::kXor_Mode);
387 SkColorFilter* lightingFilter = SkColorMatrixFilter::CreateLightingFilte r( 387 SkColorFilter* lightingFilter = SkColorMatrixFilter::CreateLightingFilte r(
388 0xff89bc45, 0xff112233); 388 0xff89bc45, 0xff112233);
389 389
390 canvas->save(); 390 canvas->save();
391 canvas->translate(SkIntToScalar(0), SkIntToScalar(5)); 391 canvas->translate(SkIntToScalar(0), SkIntToScalar(5));
392 paint.setAntiAlias(true); 392 paint.setAntiAlias(true);
393 paint.setFilterQuality(kLow_SkFilterQuality); 393 paint.setFilterQuality(kLow_SkFilterQuality);
394 // !!! draw through a clip 394 // !!! draw through a clip
395 paint.setColor(SK_ColorLTGRAY); 395 paint.setColor(SK_ColorLTGRAY);
396 paint.setStyle(SkPaint::kFill_Style); 396 paint.setStyle(SkPaint::kFill_Style);
397 SkRect clip = {0, 0, SkIntToScalar(320), SkIntToScalar(120)}; 397 SkRect clip = {0, 0, SkIntToScalar(320), SkIntToScalar(120)};
398 canvas->clipRect(clip); 398 canvas->clipRect(clip);
399 paint.setShader(SkShader::CreateBitmapShader(fTx, 399 paint.setShader(SkShader::MakeBitmapShader(fTx,
400 SkShader::kMirror_TileMode, SkShader::kRepeat_TileMode))->unref(); 400 SkShader::kMirror_TileMode, SkShader::kRepeat_TileMode));
401 canvas->drawPaint(paint); 401 canvas->drawPaint(paint);
402 canvas->save(); 402 canvas->save();
403 403
404 // line (exercises xfermode, colorShader, colorFilter, filterShader) 404 // line (exercises xfermode, colorShader, colorFilter, filterShader)
405 paint.setColor(SK_ColorGREEN); 405 paint.setColor(SK_ColorGREEN);
406 paint.setStrokeWidth(SkIntToScalar(10)); 406 paint.setStrokeWidth(SkIntToScalar(10));
407 paint.setStyle(SkPaint::kStroke_Style); 407 paint.setStyle(SkPaint::kStroke_Style);
408 paint.setXfermode(xfermode)->unref(); 408 paint.setXfermode(xfermode)->unref();
409 paint.setColorFilter(lightingFilter)->unref(); 409 paint.setColorFilter(lightingFilter)->unref();
410 canvas->drawLine(start.fX, start.fY, stop.fX, stop.fY, paint); // should not be green 410 canvas->drawLine(start.fX, start.fY, stop.fX, stop.fY, paint); // should not be green
411 paint.setXfermode(nullptr); 411 paint.setXfermode(nullptr);
412 paint.setColorFilter(nullptr); 412 paint.setColorFilter(nullptr);
413 413
414 // rectangle 414 // rectangle
415 paint.setStyle(SkPaint::kFill_Style); 415 paint.setStyle(SkPaint::kFill_Style);
416 canvas->translate(SkIntToScalar(50), 0); 416 canvas->translate(SkIntToScalar(50), 0);
417 paint.setColor(SK_ColorYELLOW); 417 paint.setColor(SK_ColorYELLOW);
418 paint.setShader(linear)->unref(); 418 paint.setShader(linear);
419 paint.setPathEffect(pathEffectTest())->unref(); 419 paint.setPathEffect(pathEffectTest())->unref();
420 canvas->drawRect(rect, paint); 420 canvas->drawRect(rect, paint);
421 paint.setPathEffect(nullptr); 421 paint.setPathEffect(nullptr);
422 422
423 // circle w/ emboss & transparent (exercises 3dshader) 423 // circle w/ emboss & transparent (exercises 3dshader)
424 canvas->translate(SkIntToScalar(50), 0); 424 canvas->translate(SkIntToScalar(50), 0);
425 paint.setMaskFilter(embossFilter)->unref(); 425 paint.setMaskFilter(embossFilter)->unref();
426 canvas->drawOval(rect, paint); 426 canvas->drawOval(rect, paint);
427 canvas->translate(SkIntToScalar(10), SkIntToScalar(10)); 427 canvas->translate(SkIntToScalar(10), SkIntToScalar(10));
428 // paint.setShader(transparentShader)->unref(); 428 // paint.setShader(transparentShader)->unref();
429 canvas->drawOval(rect, paint); 429 canvas->drawOval(rect, paint);
430 canvas->translate(0, SkIntToScalar(-10)); 430 canvas->translate(0, SkIntToScalar(-10));
431 431
432 // path 432 // path
433 canvas->translate(SkIntToScalar(50), 0); 433 canvas->translate(SkIntToScalar(50), 0);
434 paint.setColor(SK_ColorRED); 434 paint.setColor(SK_ColorRED);
435 paint.setStyle(SkPaint::kStroke_Style); 435 paint.setStyle(SkPaint::kStroke_Style);
436 paint.setStrokeWidth(SkIntToScalar(5)); 436 paint.setStrokeWidth(SkIntToScalar(5));
437 paint.setShader(radial)->unref(); 437 paint.setShader(radial);
438 paint.setMaskFilter(nullptr); 438 paint.setMaskFilter(nullptr);
439 canvas->drawPath(path, paint); 439 canvas->drawPath(path, paint);
440 440
441 paint.setShader(nullptr); 441 paint.setShader(nullptr);
442 // bitmap 442 // bitmap
443 canvas->translate(SkIntToScalar(50), 0); 443 canvas->translate(SkIntToScalar(50), 0);
444 paint.setStyle(SkPaint::kFill_Style); 444 paint.setStyle(SkPaint::kFill_Style);
445 canvas->drawBitmap(fBug, left, top, &paint); 445 canvas->drawBitmap(fBug, left, top, &paint);
446 446
447 canvas->translate(-SkIntToScalar(30), SkIntToScalar(30)); 447 canvas->translate(-SkIntToScalar(30), SkIntToScalar(30));
448 paint.setShader(shaderTest())->unref(); // test compose shader 448 paint.setShader(shaderTest()); // test compose shader
449 canvas->drawRect(rect2, paint); 449 canvas->drawRect(rect2, paint);
450 paint.setShader(nullptr); 450 paint.setShader(nullptr);
451 451
452 canvas->restore(); 452 canvas->restore();
453 // text 453 // text
454 canvas->translate(0, SkIntToScalar(60)); 454 canvas->translate(0, SkIntToScalar(60));
455 canvas->save(); 455 canvas->save();
456 paint.setColor(SK_ColorGRAY); 456 paint.setColor(SK_ColorGRAY);
457 canvas->drawPosText(ascii, asciiLength, pos.begin(), paint); 457 canvas->drawPosText(ascii, asciiLength, pos.begin(), paint);
458 canvas->drawPosText(ascii, asciiLength, pos2.begin(), paint); 458 canvas->drawPosText(ascii, asciiLength, pos2.begin(), paint);
(...skipping 34 matching lines...) Expand 10 before | Expand all | Expand 10 after
493 SkPathEffect* outer = SkPath1DPathEffect::Create(path, SkIntToScalar(12) , 493 SkPathEffect* outer = SkPath1DPathEffect::Create(path, SkIntToScalar(12) ,
494 gPhase, SkPath1DPathEffect::kRotate_Style); 494 gPhase, SkPath1DPathEffect::kRotate_Style);
495 SkPathEffect* inner = SkDiscretePathEffect::Create(SkIntToScalar(2), 495 SkPathEffect* inner = SkDiscretePathEffect::Create(SkIntToScalar(2),
496 SkIntToScalar(1)/10); // SkCornerPathEffect(SkIntToScalar(2)); 496 SkIntToScalar(1)/10); // SkCornerPathEffect(SkIntToScalar(2));
497 SkPathEffect* result = SkComposePathEffect::Create(outer, inner); 497 SkPathEffect* result = SkComposePathEffect::Create(outer, inner);
498 outer->unref(); 498 outer->unref();
499 inner->unref(); 499 inner->unref();
500 return result; 500 return result;
501 } 501 }
502 502
503 SkShader* shaderTest() { 503 sk_sp<SkShader> shaderTest() {
504 SkPoint pts[] = { { 0, 0, }, { SkIntToScalar(100), 0 } }; 504 SkPoint pts[] = { { 0, 0, }, { SkIntToScalar(100), 0 } };
505 SkColor colors[] = { SK_ColorRED, SK_ColorBLUE }; 505 SkColor colors[] = { SK_ColorRED, SK_ColorBLUE };
506 SkShader* shaderA = SkGradientShader::CreateLinear(pts, colors, nullptr, 506 auto shaderA = SkGradientShader::MakeLinear(pts, colors, nullptr,
507 2, SkShader::kClamp_TileMode); 507 2, SkShader::kClamp_TileMode);
508 pts[1].set(0, SkIntToScalar(100)); 508 pts[1].set(0, SkIntToScalar(100));
509 SkColor colors2[] = {SK_ColorBLACK, SkColorSetARGB(0x80, 0, 0, 0)}; 509 SkColor colors2[] = {SK_ColorBLACK, SkColorSetARGB(0x80, 0, 0, 0)};
510 SkShader* shaderB = SkGradientShader::CreateLinear(pts, colors2, nullptr , 510 auto shaderB = SkGradientShader::MakeLinear(pts, colors2, nullptr,
511 2, SkShader::kClamp_TileMode); 511 2, SkShader::kClamp_TileMode);
512 SkXfermode* mode = SkXfermode::Create(SkXfermode::kDstIn_Mode); 512 SkAutoTUnref<SkXfermode> mode(SkXfermode::Create(SkXfermode::kDstIn_Mode ));
513 SkShader* result = SkShader::CreateComposeShader(shaderA, shaderB, mode) ; 513 return SkShader::MakeComposeShader(shaderA, shaderB, mode);
514 shaderA->unref();
515 shaderB->unref();
516 mode->unref();
517 return result;
518 } 514 }
519 515
520 virtual void startTest() { 516 virtual void startTest() {
521 SkImageDecoder::DecodeFile("/Users/caryclark/Desktop/bugcirc.gif", &fBug ); 517 SkImageDecoder::DecodeFile("/Users/caryclark/Desktop/bugcirc.gif", &fBug );
522 SkImageDecoder::DecodeFile("/Users/caryclark/Desktop/tbcirc.gif", &fTb); 518 SkImageDecoder::DecodeFile("/Users/caryclark/Desktop/tbcirc.gif", &fTb);
523 SkImageDecoder::DecodeFile("/Users/caryclark/Desktop/05psp04.gif", &fTx) ; 519 SkImageDecoder::DecodeFile("/Users/caryclark/Desktop/05psp04.gif", &fTx) ;
524 } 520 }
525 521
526 void drawRaster(SkCanvas* canvas) { 522 void drawRaster(SkCanvas* canvas) {
527 for (size_t index = 0; index < SK_ARRAY_COUNT(gRastProcs); index++) 523 for (size_t index = 0; index < SK_ARRAY_COUNT(gRastProcs); index++)
(...skipping 42 matching lines...) Expand 10 before | Expand all | Expand 10 after
570 private: 566 private:
571 SkPoint fClickPt; 567 SkPoint fClickPt;
572 SkBitmap fBug, fTb, fTx; 568 SkBitmap fBug, fTb, fTx;
573 typedef SampleView INHERITED; 569 typedef SampleView INHERITED;
574 }; 570 };
575 571
576 ////////////////////////////////////////////////////////////////////////////// 572 //////////////////////////////////////////////////////////////////////////////
577 573
578 static SkView* MyFactory() { return new DemoView; } 574 static SkView* MyFactory() { return new DemoView; }
579 static SkViewRegister reg(MyFactory); 575 static SkViewRegister reg(MyFactory);
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698