1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
/* Copyright (C) 2001-2006 Artifex Software, Inc.
All Rights Reserved.
This software is provided AS-IS with no warranty, either express or
implied.
This software is distributed under license and may not be copied, modified
or distributed except as expressly authorized under the terms of that
license. Refer to licensing information at http://www.artifex.com/
or contact Artifex Software, Inc., 7 Mt. Lassen Drive - Suite A-134,
San Rafael, CA 94903, U.S.A., +1(415)492-9861, for further information.
*/
/* $Id$ */
/* RasterOp implementation for monobit memory devices */
#include "memory_.h"
#include "gx.h"
#include "gsbittab.h"
#include "gserrors.h"
#include "gsropt.h"
#include "gxcindex.h"
#include "gxdcolor.h"
#include "gxdevice.h"
#include "gxdevmem.h"
#include "gxdevrop.h"
#include "gdevmem.h"
#include "gdevmrop.h"
/* ---------------- Monobit RasterOp ---------------- */
/* The guts of this function have been moved to gdevm1.c as
* mem_mono_strip_copy_rop_dev. This function takes care of the color
* mapping and then passes control over to the subsidiary function that
* does everything in device space.
*/
int
mem_mono_strip_copy_rop(gx_device * dev, const byte * sdata,
int sourcex,uint sraster, gx_bitmap_id id,
const gx_color_index * scolors,
const gx_strip_bitmap * textures,
const gx_color_index * tcolors,
int x, int y, int width, int height,
int phase_x, int phase_y,
gs_logical_operation_t lop)
{
gx_device_memory *mdev = (gx_device_memory *) dev;
gs_rop3_t rop = gs_transparent_rop(lop); /* handle transparency */
bool invert;
/* If map_rgb_color isn't the default one for monobit memory */
/* devices, palette might not be set; set it now if needed. */
if (mdev->palette.data == 0) {
gx_color_value cv[3];
cv[0] = cv[1] = cv[2] = 0;
gdev_mem_mono_set_inverted(mdev,
(*dev_proc(dev, encode_color)) (dev, cv) != 0);
}
invert = mdev->palette.data[0] != 0;
#ifdef DEBUG
if (gs_debug_c('b'))
trace_copy_rop("mem_mono_strip_copy_rop",
dev, sdata, sourcex, sraster,
id, scolors, textures, tcolors,
x, y, width, height, phase_x, phase_y, lop);
if (gs_debug_c('B'))
debug_dump_bitmap(scan_line_base(mdev, y), mdev->raster,
height, "initial dest bits");
#endif
/*
* RasterOp is defined as operating in RGB space; in the monobit
* case, this means black = 0, white = 1. However, most monobit
* devices use the opposite convention. To make this work,
* we must precondition the Boolean operation by swapping the
* order of bits end-for-end and then inverting.
*/
if (invert)
rop = byte_reverse_bits[rop] ^ 0xff;
return mem_mono_strip_copy_rop_dev(dev, sdata, sourcex, sraster, id,
scolors, textures, tcolors, x, y,
width, height, phase_x, phase_y,
(gs_logical_operation_t)rop);
}
|