📄 pdf_shade4.c
字号:
p->pole[1][1].y = lcp1(p->pole[0][1].y, p->pole[3][1].y) + lcp1(p->pole[1][0].y, p->pole[1][3].y) - lcp1(lcp1(p->pole[0][0].y, p->pole[0][3].y), lcp1(p->pole[3][0].y, p->pole[3][3].y)); p->pole[1][2].y = lcp1(p->pole[0][2].y, p->pole[3][2].y) + lcp2(p->pole[1][0].y, p->pole[1][3].y) - lcp1(lcp2(p->pole[0][0].y, p->pole[0][3].y), lcp2(p->pole[3][0].y, p->pole[3][3].y)); p->pole[2][1].y = lcp2(p->pole[0][1].y, p->pole[3][1].y) + lcp1(p->pole[2][0].y, p->pole[2][3].y) - lcp2(lcp1(p->pole[0][0].y, p->pole[0][3].y), lcp1(p->pole[3][0].y, p->pole[3][3].y)); p->pole[2][2].y = lcp2(p->pole[0][2].y, p->pole[3][2].y) + lcp2(p->pole[2][0].y, p->pole[2][3].y) - lcp2(lcp2(p->pole[0][0].y, p->pole[0][3].y), lcp2(p->pole[3][0].y, p->pole[3][3].y));#undef lcp1#undef lcp2}static voidsplit_curve_s(const fz_point *pole, fz_point *q0, fz_point *q1, int pole_step){#define midpoint(a,b)\ ((a)/2.0f + (b)/2.0f) /* to avoid overflow */ float x12 = midpoint(pole[1 * pole_step].x, pole[2 * pole_step].x); float y12 = midpoint(pole[1 * pole_step].y, pole[2 * pole_step].y); q0[1 * pole_step].x = midpoint(pole[0 * pole_step].x, pole[1 * pole_step].x); q0[1 * pole_step].y = midpoint(pole[0 * pole_step].y, pole[1 * pole_step].y); q1[2 * pole_step].x = midpoint(pole[2 * pole_step].x, pole[3 * pole_step].x); q1[2 * pole_step].y = midpoint(pole[2 * pole_step].y, pole[3 * pole_step].y); q0[2 * pole_step].x = midpoint(q0[1 * pole_step].x, x12); q0[2 * pole_step].y = midpoint(q0[1 * pole_step].y, y12); q1[1 * pole_step].x = midpoint(x12, q1[2 * pole_step].x); q1[1 * pole_step].y = midpoint(y12, q1[2 * pole_step].y); q0[0 * pole_step].x = pole[0 * pole_step].x; q0[0 * pole_step].y = pole[0 * pole_step].y; q0[3 * pole_step].x = q1[0 * pole_step].x = midpoint(q0[2 * pole_step].x, q1[1 * pole_step].x); q0[3 * pole_step].y = q1[0 * pole_step].y = midpoint(q0[2 * pole_step].y, q1[1 * pole_step].y); q1[3 * pole_step].x = pole[3 * pole_step].x; q1[3 * pole_step].y = pole[3 * pole_step].y;#undef midpoint}static inline voidsplit_patch(pdf_tensorpatch *s0, pdf_tensorpatch *s1, const pdf_tensorpatch *p){ split_curve_s(&p->pole[0][0], &s0->pole[0][0], &s1->pole[0][0], 4); split_curve_s(&p->pole[0][1], &s0->pole[0][1], &s1->pole[0][1], 4); split_curve_s(&p->pole[0][2], &s0->pole[0][2], &s1->pole[0][2], 4); split_curve_s(&p->pole[0][3], &s0->pole[0][3], &s1->pole[0][3], 4); copycolor(s0->color[0], p->color[0]); midcolor(s0->color[1], p->color[0], p->color[1]); midcolor(s0->color[2], p->color[2], p->color[3]); copycolor(s0->color[3], p->color[3]); copycolor(s1->color[0], s0->color[1]); copycolor(s1->color[1], p->color[1]); copycolor(s1->color[2], p->color[2]); copycolor(s1->color[3], s0->color[2]);}static inline voidsplit_stripe(pdf_tensorpatch *s0, pdf_tensorpatch *s1, const pdf_tensorpatch *p){ split_curve_s(p->pole[0], s0->pole[0], s1->pole[0], 1); split_curve_s(p->pole[1], s0->pole[1], s1->pole[1], 1); split_curve_s(p->pole[2], s0->pole[2], s1->pole[2], 1); split_curve_s(p->pole[3], s0->pole[3], s1->pole[3], 1); copycolor(s0->color[0], p->color[0]); copycolor(s0->color[1], p->color[1]); midcolor(s0->color[2], p->color[1], p->color[2]); midcolor(s0->color[3], p->color[0], p->color[3]); copycolor(s1->color[0], s0->color[3]); copycolor(s1->color[1], s0->color[2]); copycolor(s1->color[2], p->color[2]); copycolor(s1->color[3], p->color[3]);}static inline int setvertex(float *mesh, fz_point pt, float *color, int ptr, int ncomp){ int i; mesh[ptr++] = pt.x; mesh[ptr++] = pt.y; for (i=0; i < ncomp; ++i) { mesh[ptr++] = color[i]; } return ptr;}static inttriangulatepatch(pdf_tensorpatch p, fz_shade *shade, int ptr, int ncomp){ fz_error* error; ptr = setvertex(shade->mesh, p.pole[0][0], p.color[0], ptr, ncomp); ptr = setvertex(shade->mesh, p.pole[3][0], p.color[1], ptr, ncomp); ptr = setvertex(shade->mesh, p.pole[3][3], p.color[2], ptr, ncomp); ptr = setvertex(shade->mesh, p.pole[0][0], p.color[0], ptr, ncomp); ptr = setvertex(shade->mesh, p.pole[3][3], p.color[2], ptr, ncomp); ptr = setvertex(shade->mesh, p.pole[0][3], p.color[3], ptr, ncomp); if (shade->meshcap - 8*1024 < ptr) { error = growshademesh(shade, 8*1024); if (error) goto cleanup; } return ptr;cleanup: /* error handling */ return -1;}static intdrawstripe(pdf_tensorpatch patch, fz_shade *shade, int ptr, int ncomp, int depth){ pdf_tensorpatch s0, s1; split_stripe(&s0, &s1, &patch); depth++; if (depth >= SEGMENTATION_DEPTH) { ptr = triangulatepatch(s0, shade, ptr, ncomp); ptr = triangulatepatch(s1, shade, ptr, ncomp); } else { ptr = drawstripe(s0, shade, ptr, ncomp, depth); ptr = drawstripe(s1, shade, ptr, ncomp, depth); } return ptr;}static intdrawpatch(pdf_tensorpatch patch, fz_shade *shade, int ptr, int ncomp, int depth){ pdf_tensorpatch s0, s1; split_patch(&s0, &s1, &patch); depth++; if (depth > SEGMENTATION_DEPTH) { ptr = drawstripe(s0, shade, ptr, ncomp, 0); ptr = drawstripe(s1, shade, ptr, ncomp, 0); } else { ptr = drawpatch(s0, shade, ptr, ncomp, depth); ptr = drawpatch(s1, shade, ptr, ncomp, depth); } return ptr;}fz_error *pdf_loadtype6shade(fz_shade *shade, pdf_xref *xref, fz_obj *shading, fz_obj *ref){ fz_error *error; fz_stream *stream; fz_obj *obj; int bpcoord; int bpcomp; int bpflag; int ncomp; fz_point p0, p1; float c0[FZ_MAXCOLORS]; float c1[FZ_MAXCOLORS]; int i, n, j; unsigned int t; int flag; fz_point p[12]; pdf_tensorpatch patch; error = fz_okay; ncomp = shade->cs->n; bpcoord = fz_toint(fz_dictgets(shading, "BitsPerCoordinate")); bpcomp = fz_toint(fz_dictgets(shading, "BitsPerComponent")); bpflag = fz_toint(fz_dictgets(shading, "BitsPerFlag")); obj = fz_dictgets(shading, "Decode"); if (fz_isarray(obj)) { pdf_logshade("decode array\n"); p0.x = fz_toreal(fz_arrayget(obj, 0)); p1.x = fz_toreal(fz_arrayget(obj, 1)); p0.y = fz_toreal(fz_arrayget(obj, 2)); p1.y = fz_toreal(fz_arrayget(obj, 3)); for (i=0; i < fz_arraylen(obj) / 2; ++i) { c0[i] = fz_toreal(fz_arrayget(obj, i*2+4)); c1[i] = fz_toreal(fz_arrayget(obj, i*2+5)); } } else { error = fz_throw("syntaxerror: No Decode key in Type 6 Shade"); goto cleanup; } obj = fz_dictgets(shading, "Function"); if (obj) { ncomp = 1; pdf_loadshadefunction(shade, xref, shading, c0[0], c1[0]); shade->usefunction = 1; } else shade->usefunction = 0; shade->meshcap = 0; shade->mesh = nil; error = growshademesh(shade, 1024); if (error) goto cleanup; n = 2 + shade->cs->n; j = 0; error = pdf_openstream(&stream, xref, fz_tonum(ref), fz_togen(ref)); if (error) { error = fz_rethrow(error, "unable to open shading stream"); goto cleanup; } while (fz_peekbyte(stream) != EOF) { flag = getdata(stream, bpflag); for (i = 0; i < 12; ++i) { t = getdata(stream, bpcoord); p[i].x = (float)(p0.x + (t * (p1.x - p0.x) / (pow(2, bpcoord) - 1.))); t = getdata(stream, bpcoord); p[i].y = (float)(p0.y + (t * (p1.y - p0.y) / (pow(2, bpcoord) - 1.))); } for (i = 0; i < 4; ++i) { int k; for (k=0; k < ncomp; ++k) { t = getdata(stream, bpcomp); patch.color[i][k] = c0[k] + (t * (c1[k] - c0[k]) / (pow(2, bpcomp) - 1.0f)); } } patch.pole[0][0] = p[0]; patch.pole[1][0] = p[1]; patch.pole[2][0] = p[2]; patch.pole[3][0] = p[3]; patch.pole[3][1] = p[4]; patch.pole[3][2] = p[5]; patch.pole[3][3] = p[6]; patch.pole[2][3] = p[7]; patch.pole[1][3] = p[8]; patch.pole[0][3] = p[9]; patch.pole[0][2] = p[10]; patch.pole[0][1] = p[11]; filltensorinterior(&patch); j = drawpatch(patch, shade, j, ncomp, 0); } fz_dropstream(stream); shade->meshlen = j / n / 3; return fz_okay;cleanup: return error;}fz_error *pdf_loadtype7shade(fz_shade *shade, pdf_xref *xref, fz_obj *shading, fz_obj *ref){ fz_error *error; fz_stream *stream; fz_obj *obj; int bpcoord; int bpcomp; int bpflag; int ncomp; float x0, x1, y0, y1; float c0[FZ_MAXCOLORS]; float c1[FZ_MAXCOLORS]; int i, n, j; unsigned int t; int flag; fz_point p[16]; pdf_tensorpatch patch; error = fz_okay; ncomp = shade->cs->n; bpcoord = fz_toint(fz_dictgets(shading, "BitsPerCoordinate")); bpcomp = fz_toint(fz_dictgets(shading, "BitsPerComponent")); bpflag = fz_toint(fz_dictgets(shading, "BitsPerFlag")); obj = fz_dictgets(shading, "Decode"); if (fz_isarray(obj)) { pdf_logshade("decode array\n"); x0 = fz_toreal(fz_arrayget(obj, 0)); x1 = fz_toreal(fz_arrayget(obj, 1)); y0 = fz_toreal(fz_arrayget(obj, 2)); y1 = fz_toreal(fz_arrayget(obj, 3)); for (i=0; i < fz_arraylen(obj) / 2; ++i) { c0[i] = fz_toreal(fz_arrayget(obj, i*2+4)); c1[i] = fz_toreal(fz_arrayget(obj, i*2+5)); } } else { error = fz_throw("syntaxerror: No Decode key in Type 6 Shade"); goto cleanup; } obj = fz_dictgets(shading, "Function"); if (obj) { ncomp = 1; pdf_loadshadefunction(shade, xref, shading, c0[0], c1[0]); shade->usefunction = 1; } else shade->usefunction = 0; shade->meshcap = 0; shade->mesh = nil; error = growshademesh(shade, 1024); if (error) goto cleanup; n = 2 + shade->cs->n; j = 0; error = pdf_openstream(&stream, xref, fz_tonum(ref), fz_togen(ref)); if (error) { error = fz_rethrow(error, "unable to open shading stream"); goto cleanup; } while (fz_peekbyte(stream) != EOF) { flag = getdata(stream, bpflag); for (i = 0; i < 16; ++i) { t = getdata(stream, bpcoord); p[i].x = x0 + (t * (x1 - x0) / (pow(2, bpcoord) - 1.)); t = getdata(stream, bpcoord); p[i].y = y0 + (t * (y1 - y0) / (pow(2, bpcoord) - 1.)); } for (i = 0; i < 4; ++i) { int k; for (k=0; k < ncomp; ++k) { t = getdata(stream, bpcomp); patch.color[i][k] = c0[k] + (t * (c1[k] - c0[k]) / (pow(2, bpcomp) - 1.0f)); } } patch.pole[0][0] = p[0]; patch.pole[0][1] = p[1]; patch.pole[0][2] = p[2]; patch.pole[0][3] = p[3]; patch.pole[1][3] = p[4]; patch.pole[2][3] = p[5]; patch.pole[3][3] = p[6]; patch.pole[3][2] = p[7]; patch.pole[3][1] = p[8]; patch.pole[3][0] = p[9]; patch.pole[2][0] = p[10]; patch.pole[1][0] = p[11]; patch.pole[1][1] = p[12]; patch.pole[1][2] = p[13]; patch.pole[2][2] = p[14]; patch.pole[2][1] = p[15]; j = drawpatch(patch, shade, j, ncomp, 0); } fz_dropstream(stream); shade->meshlen = j / n / 3; return fz_okay;cleanup: return error;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -