ftp.nice.ch/pub/next/graphics/viewer/ToyViewer.2.6.s.tar.gz#/ToyViewer2.6/src/ImageOpr.bproj/ImageCutDown.m

This is ImageCutDown.m in view mode; [Download] [Up]

#import "../ImageOpr.h"
#import <appkit/Application.h>
#import <appkit/publicWraps.h>
#import <appkit/NXBitmapImageRep.h>
#import <appkit/Control.h>
#import <stdio.h>
#import <stdlib.h>
#import <string.h>
#import <libc.h>
#import "../TVController.h"
#import "../ToyWin.h"
#import "../ToyView.h"
#import "../common.h"
#import "../getpixel.h"
#import "imageOperation.h"


@implementation ImageOpr (CutDownBits)

/* Local Method */
- doCutDown:(const char *)fn parent:parent
	info:(commonInfo *)cinf map:(unsigned char **)map to:(int)bits
{
	ToyWin	*tw;
	commonInfo *newinf = NULL;
	unsigned char *working[MAXPLANE], *planes[MAXPLANE];
	int	i, pl;

	working[0] = planes[0] = NULL;
	tw = NULL;
	if ((newinf = (commonInfo *)malloc(sizeof(commonInfo))) == NULL)
		goto ErrEXIT;
	*newinf = *cinf;
	if (cinf->cspace == NX_OneIsBlackColorSpace)
		newinf->cspace = NX_OneIsWhiteColorSpace;
		/* getPixel() fixes 0 as Black */
	newinf->bits = bits;
	newinf->xbytes = byte_length(bits, newinf->width);
	newinf->palette = NULL;
	newinf->palsteps = 0;
	newinf->isplanar = YES;
	pl = newinf->numcolors;
	if (newinf->alpha) pl++;

	if (allocImage(planes, newinf->width, newinf->height, bits, pl))
		goto ErrEXIT;
	tw = [[ToyWin alloc] init:parent by:CutDown];
	[tw initLocateWindow:fn width:newinf->width height:newinf->height];
	[tw makeComment: newinf from: cinf];

	if (!cinf->isplanar || cinf->bits < 8) {
		int	x, y, ptr, pidx;
		int	idx[MAXPLANE];
		int	pix[MAXPLANE];

		for (i = 0; i < newinf->numcolors; i++) idx[i] = i;
		for ( ; i < MAXPLANE; i++) idx[i] = -1;
		if (newinf->alpha) idx[ALPHA] = pl;
		if (allocImage(working, newinf->width, newinf->height, 8, pl))
			goto ErrEXIT;
		resetPixel(map, 0);
		for (y = 0; y < newinf->height; y++) {
			ptr = y * newinf->width;
			for (x = 0; x < newinf->width; x++) {
				getPixelA(pix);
				for (i = 0; i <= ALPHA; i++) {
					if ((pidx = idx[i]) < 0) continue;
					working[pidx][ptr + x] = pix[i];
				}
			}
		}
		packWorkingImage(newinf, pl, working, planes);
		free((void *)working[0]);
	}else
		packWorkingImage(newinf, pl, map, planes);
	if ([tw drawView:planes info: newinf] == nil)
		goto ErrEXIT;
	[theController newWindow: tw];
	return self;

ErrEXIT:
	if (working[0]) free((void *)working[0]);
	if (planes[0]) free((void *)planes[0]);
	if (newinf)  free((void *)newinf);
	if (tw) [[tw window] performClose: self];
		/* This call frees tw */
	return nil;
}


- cutDownBitsTo:(int)bits
{
	ToyWin	*tw;
	ToyView	*tv = NULL;
	NXImageRep	*rep;
	commonInfo	*cinf;
	unsigned char	*map[MAXPLANE];
	const char	*fnam;
	char	fn[256];
	int	err;

	if ((tw = [theController keyWindow]) == nil ||
		(bits != 4 && bits != 2 && bits != 1)) {
		NXBeep();
		return self;
	}
	tv = [tw toyView];
	cinf = [tv commonInfo];
	fnam = [tw filename];
	if (cinf->type == Type_eps) {
		warnAlert(fnam, Err_EPS_IMPL);
		return self;
	}
	if (cinf->bits <= bits) {
		warnAlert(fnam, Err_OPR_IMPL);
		return self;
	}
	if (cinf->cspace == NX_CMYKColorSpace) {
		warnAlert(fnam, Err_IMPLEMENT);
		return self;
	}
	if (cinf->width >= MAXWidth || cinf->height >= MAXWidth) {
		errAlert(fnam, Err_MEMORY);
		return self;
	}
	sprintf(fn, "%s(%dBits)", fnam, bits);

	rep = [[tv image] bestRepresentation];
	[(NXBitmapImageRep *)rep getDataPlanes: map];
	if ((err = initGetPixel(cinf)) != 0) {
		errAlert(fnam, err);
		return self;
	}
	if ([self doCutDown:fn parent:tw info:cinf map:map to:bits] == nil)
		errAlert(fn, Err_MEMORY);
	return self;
}

@end

These are the contents of the former NiCE NeXT User Group NeXTSTEP/OpenStep software archive, currently hosted by Netfuture.ch.