本文整理汇总了C++中Style::GetFillGradient方法的典型用法代码示例。如果您正苦于以下问题:C++ Style::GetFillGradient方法的具体用法?C++ Style::GetFillGradient怎么用?C++ Style::GetFillGradient使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Style
的用法示例。
在下文中一共展示了Style::GetFillGradient方法的3个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: OutputFillRadialGradient
bool XARGenerator::OutputFillRadialGradient(const Style& style, const Transformation& trans, const RectD& boundings)
{
bool ok = true;
CXaraFileRecord Rec(0);
const Gradient* pGradient = style.GetFillGradient();
const GradientStopList& stops = pGradient->stops;
if (stops.GetCount() < 1) {
#if SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "gradient '%s' has no stop points, giving up\n", (const char *)pGradient->xmlId.mb_str(wxConvUTF8));
#endif
return false;
}
#if SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "using radial fill gradient '%s' with %d colours\n", (const char *)pGradient->xmlId.mb_str(wxConvUTF8), stops.GetCount());
svgtrace(DBGTRACE_GRADIENTS, "gradient trans: ");
DebugDumpTransformation(DBGTRACE_GRADIENTS, trans);
#endif
// center, major and minor axis points of gradient
DocCoord pC, pMaj, pMin;
DetermineRadialGradientPoints(pGradient, trans, boundings, pC, pMaj, pMin);
if (stops.GetCount() < 3) { // 1 or 2 stops
wxColour col1, col2;
double fOpacity1, fOpacity2;
if (stops.GetCount() == 1) {
GradientStop* pStop1 = stops.GetFirst()->GetData();
col2 = col1 = pStop1->stopColour;
fOpacity1 = fOpacity2 = pStop1->stopOpacity;
} else { // stops.GetCount() == 2
GradientStop* pStop1 = stops.GetFirst()->GetData();
GradientStop* pStop2 = stops.GetLast()->GetData();
col1 = pStop1->stopColour;
col2 = pStop2->stopColour;
fOpacity1 = pStop1->stopOpacity;
fOpacity2 = pStop2->stopOpacity;
}
#if SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "stop points: %d, %d and %d, %d\n", pMaj.x, pMaj.y, pMin.x, pMin.y);
#endif
UINT32 iRecNo1 = DefineColour(col1);
UINT32 iRecNo2 = DefineColour(col2);
Rec.Reinit(TAG_ELLIPTICALFILL, TAG_ELLIPTICALFILL_SIZE);
ok = Rec.WriteCoord(pC);
ok = Rec.WriteCoord(pMaj);
ok = Rec.WriteCoord(pMin);
ok = Rec.WriteReference(iRecNo1);
ok = Rec.WriteReference(iRecNo2);
ok = Rec.WriteDOUBLE(0.0); // bias
ok = Rec.WriteDOUBLE(0.0); // gain
ok = m_pExporter->WriteRecord(&Rec);
if (fOpacity1 != 1.0 || fOpacity2 != 1.0) {
// the fill has also alpha transparency
BYTE bOpacity1 = (BYTE)((1.0-fOpacity1)*255.0);
BYTE bOpacity2 = (BYTE)((1.0-fOpacity2)*255.0);
Rec.Reinit(TAG_ELLIPTICALTRANSPARENTFILL, TAG_ELLIPTICALTRANSPARENTFILL_SIZE);
ok = Rec.WriteCoord(pC);
ok = Rec.WriteCoord(pMaj);
ok = Rec.WriteCoord(pMin);
ok = Rec.WriteBYTE(bOpacity1);
ok = Rec.WriteBYTE(bOpacity2);
ok = Rec.WriteBYTE(0x01); // mix
ok = Rec.WriteDOUBLE(0.0); // bias
ok = Rec.WriteDOUBLE(0.0); // gain
ok = m_pExporter->WriteRecord(&Rec);
}
} else { // stops.GetCount() > 2
// XXX ?
}
return true;
}
示例2: OutputStyles
bool XARGenerator::OutputStyles(const Style& style, const Transformation& trans, const RectD& boundings, UINT32 witch)
{
bool ok = true;
CXaraFileRecord Rec(0);
wxString sXmlId = style.GetXmlId();
if (!sXmlId.IsEmpty()) {
// XXX how to output object labels in XAR?
#if SVGDEBUG
svgtrace(DBGTRACE_SHAPES, "object id: %s\n", (const char *)sXmlId.mb_str(wxConvUTF8));
#endif
}
// XXX TODO to avoid XAR redundancy, we should look
// if the styles we are outputting are already the default
// in Xara's stack
if (witch & STYLE_FILL_COLOUR) {
if (style.IsFillColourDefined()) {
wxColour col = style.GetFillColour();
if (col.Ok()) {
UINT32 iRecNo = DefineColour(col);
Rec.Reinit(TAG_FLATFILL, TAG_FLATFILL_SIZE);
ok = Rec.WriteReference(iRecNo);
ok = m_pExporter->WriteRecord(&Rec);
#if SVGDEBUG
svgtrace(DBGTRACE_STYLES, "fill colour %d,%d,%d\n", col.Red(), col.Green(), col.Blue());
#endif
} else {
m_pExporter->WriteZeroSizedRecord(TAG_FLATFILL_NONE);
#if SVGDEBUG
svgtrace(DBGTRACE_STYLES, "no fill colour\n");
#endif
}
} else if (!style.IsFillGradientDefined()) {
m_pExporter->WriteZeroSizedRecord(TAG_FLATFILL_NONE);
#if SVGDEBUG
svgtrace(DBGTRACE_STYLES, "no fill colour\n");
#endif
}
}
if (witch & STYLE_FILL_GRADIENT && style.IsFillGradientDefined()) {
Gradient* pGradient = style.GetFillGradient();
if (pGradient->type == Gradient::Linear) {
OutputFillLinearGradient(style, trans, boundings);
} else if (pGradient->type == Gradient::Radial) {
OutputFillRadialGradient(style, trans, boundings);
}
}
if (witch & STYLE_FILL_OPACITY && style.IsFillOpacityDefined()) {
double opacity = style.GetFillOpacity();
if (opacity < 1.0) {
BYTE bOpacity = (BYTE)((1.0-opacity)*255.0);
Rec.Reinit(TAG_FLATTRANSPARENTFILL, TAG_FLATTRANSPARENTFILL_SIZE);
ok = Rec.WriteBYTE(bOpacity);
ok = Rec.WriteBYTE(0x01);
ok = m_pExporter->WriteRecord(&Rec);
}
}
if (witch & STYLE_STROKE_COLOUR) {
if (style.IsStrokeColourDefined()) {
wxColour col = style.GetStrokeColour();
if (col.Ok()) {
UINT32 iRecNo = DefineColour(col);
Rec.Reinit(TAG_LINECOLOUR, TAG_LINECOLOUR_SIZE);
ok = Rec.WriteReference(iRecNo);
ok = m_pExporter->WriteRecord(&Rec);
#if SVGDEBUG
svgtrace(DBGTRACE_STYLES, "stroke colour %d,%d,%d\n", col.Red(), col.Green(), col.Blue());
#endif
} else {
m_pExporter->WriteZeroSizedRecord(TAG_LINECOLOUR_NONE);
#if SVGDEBUG
svgtrace(DBGTRACE_STYLES, "no stroke colour\n");
#endif
}
} else {
m_pExporter->WriteZeroSizedRecord(TAG_LINECOLOUR_NONE);
#if SVGDEBUG
svgtrace(DBGTRACE_STYLES, "no stroke colour\n");
#endif
}
}
if (witch & STYLE_STROKE_WIDTH && style.IsStrokeWidthDefined()) {
UINT32 iStrokeWidth = style.GetStrokeWidth();
Rec.Reinit(TAG_LINEWIDTH, TAG_LINEWIDTH_SIZE);
ok = Rec.WriteINT32(iStrokeWidth);
ok = m_pExporter->WriteRecord(&Rec);
}
//.........这里部分代码省略.........
示例3: OutputFillLinearGradient
bool XARGenerator::OutputFillLinearGradient(const Style& style, const Transformation& trans, const RectD& boundings)
{
bool ok = true;
CXaraFileRecord Rec(0);
const Gradient* pGradient = style.GetFillGradient();
const GradientStopList& stops = pGradient->stops;
if (stops.GetCount() < 1) {
#if SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "gradient '%s' has no stop points, giving up\n", (const char *)pGradient->xmlId.mb_str(wxConvUTF8));
#endif
return false;
}
#if SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "using linear fill gradient '%s' with %d colours\n", (const char *)pGradient->xmlId.mb_str(wxConvUTF8), stops.GetCount());
svgtrace(DBGTRACE_GRADIENTS, "gradient trans: ");
DebugDumpTransformation(DBGTRACE_GRADIENTS, trans);
#endif
// start and end points of gradient
DocCoord p1, p2;
DetermineLinearGradientPoints(pGradient, trans, boundings, p1, p2);
if (pGradient->units == Gradient::ObjectBoundingBox) {
// first and last offsets of gradient
double fOffsetFirst, fOffsetLast;
if (stops.GetCount() == 1) {
fOffsetFirst = 0.0;
fOffsetLast = 1.0;
} else { // stops.GetCount() > 1
GradientStop* pStop1 = stops.GetFirst()->GetData();
GradientStop* pStop2 = stops.GetLast()->GetData();
fOffsetFirst = pStop1->offset;
fOffsetLast = pStop2->offset;
}
#if 0
// determine vector of direction of object gradient
double fDX=1.0, fDY=0.0;
trans.ApplyToCoordinate(fDX, fDY, &fDX, &fDY);
double fMod = sqrt(fDX*fDX+fDY*fDY);
fDX /= fMod;
fDY /= fMod;
#if SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "direction of gradient: %.2f %.2f\n", fDX, fDY);
#endif
#endif
PointD pLower = boundings.LowerCoord();
PointD pHigher = boundings.HigherCoord();
double fWidth = fabs(pHigher.x - pLower.x);
//double fHeight = fabs(pHigher.x - pLower.x);
p1.x += (INT32)(fWidth * fOffsetFirst);
//p1.y += (INT32)(fHeight * fOffsetFirst);
p2.x -= (INT32)(fWidth * (1.0 - fOffsetLast));
//p2.y -= (INT32)(fHeight * (1.0 - fOffsetLast));
#ifdef SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "new ObjectBoundingBox %d,%d %d,%d\n", p1.x, p1.y, p2.x, p2.y);
#endif
}
if (stops.GetCount() < 3) { // 1 or 2 stops
wxColour col1, col2;
double fOpacity1, fOpacity2;
if (stops.GetCount() == 1) {
GradientStop* pStop1 = stops.GetFirst()->GetData();
col2 = col1 = pStop1->stopColour;
fOpacity1 = fOpacity2 = pStop1->stopOpacity;
} else { // stops.GetCount() == 2
GradientStop* pStop1 = stops.GetFirst()->GetData();
GradientStop* pStop2 = stops.GetLast()->GetData();
col1 = pStop1->stopColour;
col2 = pStop2->stopColour;
fOpacity1 = pStop1->stopOpacity;
fOpacity2 = pStop2->stopOpacity;
}
#if SVGDEBUG
svgtrace(DBGTRACE_GRADIENTS, "stop points: %d, %d and %d, %d\n", p1.x, p1.y, p2.x, p2.y);
#endif
UINT32 iRecNo1 = DefineColour(col1);
UINT32 iRecNo2 = DefineColour(col2);
Rec.Reinit(TAG_LINEARFILL, TAG_LINEARFILL_SIZE);
ok = Rec.WriteCoord(p1);
ok = Rec.WriteCoord(p2);
ok = Rec.WriteReference(iRecNo1);
ok = Rec.WriteReference(iRecNo2);
ok = Rec.WriteDOUBLE(0.0); // bias
ok = Rec.WriteDOUBLE(0.0); // gain
ok = m_pExporter->WriteRecord(&Rec);
if (fOpacity1 != 1.0 || fOpacity2 != 1.0) {
// the fill has also alpha transparency
BYTE bOpacity1 = (BYTE)((1.0-fOpacity1)*255.0);
//.........这里部分代码省略.........