/* * Copyright 2014 Google Inc. * * Use of this source code is governed by a BSD-style license that can be * found in the LICENSE file. */ #include "SkLocalMatrixShader.h" SkFlattenable* SkLocalMatrixShader::CreateProc(SkReadBuffer& buffer) { SkMatrix lm; buffer.readMatrix(&lm); SkAutoTUnref<SkShader> shader(buffer.readShader()); if (!shader.get()) { return NULL; } return SkShader::CreateLocalMatrixShader(shader, lm); } void SkLocalMatrixShader::flatten(SkWriteBuffer& buffer) const { buffer.writeMatrix(this->getLocalMatrix()); buffer.writeFlattenable(fProxyShader.get()); } SkShader::Context* SkLocalMatrixShader::onCreateContext(const ContextRec& rec, void* storage) const { ContextRec newRec(rec); SkMatrix tmp; if (rec.fLocalMatrix) { tmp.setConcat(*rec.fLocalMatrix, this->getLocalMatrix()); newRec.fLocalMatrix = &tmp; } else { newRec.fLocalMatrix = &this->getLocalMatrix(); } return fProxyShader->createContext(newRec, storage); } #ifndef SK_IGNORE_TO_STRING void SkLocalMatrixShader::toString(SkString* str) const { str->append("SkLocalMatrixShader: ("); fProxyShader->toString(str); this->INHERITED::toString(str); str->append(")"); } #endif SkShader* SkShader::CreateLocalMatrixShader(SkShader* proxy, const SkMatrix& localMatrix) { if (NULL == proxy) { return NULL; } if (localMatrix.isIdentity()) { return SkRef(proxy); } const SkMatrix* lm = &localMatrix; SkMatrix otherLocalMatrix; SkAutoTUnref<SkShader> otherProxy(proxy->refAsALocalMatrixShader(&otherLocalMatrix)); if (otherProxy.get()) { otherLocalMatrix.preConcat(localMatrix); lm = &otherLocalMatrix; proxy = otherProxy.get(); } return SkNEW_ARGS(SkLocalMatrixShader, (proxy, *lm)); }