2007-03-08 04:03:40 +08:00
|
|
|
/**********************************************************************
|
|
|
|
* File: drawedg.c (Formerly drawedge.c)
|
|
|
|
* Description: Collection of functions to draw things to do with edge detection.
|
2008-04-22 08:34:11 +08:00
|
|
|
* Author: Ray Smith
|
|
|
|
* Created: Thu Jun 06 13:29:20 BST 1991
|
2007-03-08 04:03:40 +08:00
|
|
|
*
|
|
|
|
* (C) Copyright 1991, Hewlett-Packard Ltd.
|
|
|
|
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
** you may not use this file except in compliance with the License.
|
|
|
|
** You may obtain a copy of the License at
|
|
|
|
** http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
** Unless required by applicable law or agreed to in writing, software
|
|
|
|
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
** See the License for the specific language governing permissions and
|
|
|
|
** limitations under the License.
|
|
|
|
*
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
#include "mfcpch.h"
|
|
|
|
#include "drawedg.h"
|
|
|
|
|
|
|
|
#define IMAGE_WIN_NAME "Edges"//title of window
|
|
|
|
#define IMAGE_XPOS 250
|
|
|
|
#define IMAGE_YPOS 0 //default position
|
|
|
|
#define CTRLD '\004' //control D
|
|
|
|
|
|
|
|
#define EXTERN
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* create_edges_window
|
|
|
|
*
|
|
|
|
* Create the edges window.
|
|
|
|
**********************************************************************/
|
|
|
|
|
2008-02-01 08:48:25 +08:00
|
|
|
ScrollView* create_edges_window( //make window
|
2007-03-08 04:03:40 +08:00
|
|
|
ICOORD page_tr //size of image
|
|
|
|
) {
|
2008-02-01 08:48:25 +08:00
|
|
|
ScrollView* image_win; //image window
|
2007-03-08 04:03:40 +08:00
|
|
|
|
|
|
|
//create the window
|
2008-02-01 08:48:25 +08:00
|
|
|
image_win = new ScrollView (IMAGE_WIN_NAME, IMAGE_XPOS, IMAGE_YPOS, 0, 0, page_tr.x (), page_tr.y ());
|
2007-03-08 04:03:40 +08:00
|
|
|
return image_win; //window
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/**********************************************************************
|
|
|
|
* draw_raw_edge
|
|
|
|
*
|
|
|
|
* Draw the raw steps to the given window in the given colour.
|
|
|
|
**********************************************************************/
|
|
|
|
|
|
|
|
void draw_raw_edge( //draw the cracks
|
2008-02-01 08:48:25 +08:00
|
|
|
ScrollView* fd, //window to draw in
|
2007-03-08 04:03:40 +08:00
|
|
|
CRACKEDGE *start, //start of loop
|
2008-02-01 08:48:25 +08:00
|
|
|
ScrollView::Color colour //colour to draw in
|
2007-03-08 04:03:40 +08:00
|
|
|
) {
|
|
|
|
CRACKEDGE *edgept; //current point
|
|
|
|
|
2008-04-22 08:34:11 +08:00
|
|
|
fd->Pen(colour);
|
2007-03-08 04:03:40 +08:00
|
|
|
edgept = start;
|
2008-02-01 08:48:25 +08:00
|
|
|
fd->SetCursor(edgept->pos.x (), edgept->pos.y ());
|
2007-03-08 04:03:40 +08:00
|
|
|
do {
|
|
|
|
do
|
|
|
|
edgept = edgept->next;
|
|
|
|
//merge straight lines
|
|
|
|
while (edgept != start && edgept->prev->stepx == edgept->stepx && edgept->prev->stepy == edgept->stepy);
|
|
|
|
|
|
|
|
//draw lines
|
2008-02-01 08:48:25 +08:00
|
|
|
fd->DrawTo(edgept->pos.x (), edgept->pos.y ());
|
2007-03-08 04:03:40 +08:00
|
|
|
}
|
|
|
|
while (edgept != start);
|
|
|
|
}
|
|
|
|
|