1
0
mirror of git://projects.qi-hardware.com/fped.git synced 2024-11-28 17:00:18 +02:00
fped/coord.h
Erich Heinzle 7081258910 diff for gEDA PCB export in fped
I have

1) sorted out the tabbing

2) simplified > 1 element export by exporting elements in a layout (.pcb)

3) documented incompatibilities in the README

4) done it as a diff against origin master

let me know if you need anything else done

Cheers.

Erich

From dae69d9a63071a15c213c72e70b86fe963a67dd4 Mon Sep 17 00:00:00 2001
From: erich_heinzle <a1039181@gmail.com>
Date: Sun, 22 Jan 2017 23:48:57 +1030
Subject: [PATCH] support for export to gEDA format of single and multiple
 footprints in a .pcb layout
2017-01-22 13:15:26 -03:00

120 lines
2.6 KiB
C

/*
* coord.h - Coordinate representation and basic operations
*
* Written 2009, 2010, 2016 by Werner Almesberger
* Copyright 2009, 2010, 2016 by Werner Almesberger
* Copyright 2016, Erich Heinzle (gEDA additions)
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 2 of the License, or
* (at your option) any later version.
*/
#ifndef COORD_H
#define COORD_H
#include <stdint.h>
#define MICRON_UNITS 10
#define MIL_UNITS (25.4*MICRON_UNITS)
#define MM_UNITS (1000.0*MICRON_UNITS)
#define UM_UNITS MICRON_UNITS
#define KICAD_UNIT (MIL_UNITS/10.0)
#define GEDA_UNIT (MIL_UNITS/100.0)
#define MIL_IN_MM 0.0254
#define UM_IN_MM 0.001
typedef int32_t unit_type;
#define UNIT_ERROR ((unit_type) 1 << (sizeof(unit_type)*8-1))
struct coord {
unit_type x, y;
};
static inline unit_type mil_to_units(double mil)
{
return mil*MIL_UNITS;
}
static inline unit_type mm_to_units(double mm)
{
return mm*MM_UNITS;
}
static inline unit_type um_to_units(double mm)
{
return mm*UM_UNITS;
}
static inline double units_to_mm(unit_type u)
{
return (double) u/MM_UNITS;
}
static inline double units_to_um(unit_type u)
{
return (double) u/UM_UNITS;
}
static inline double units_to_mil(unit_type u)
{
return (double) u/MIL_UNITS;
}
static inline int units_to_kicad(unit_type u)
{
return (double) u/KICAD_UNIT;
}
static inline int units_to_geda(unit_type u)
{
return (double) u/GEDA_UNIT;
}
static inline int coord_eq(struct coord a, struct coord b)
{
return a.x == b.x && a.y == b.y;
}
double mm_to_mil(double mm, int exponent);
double mil_to_mm(double mil, int exponent);
double um_to_mm(double um, int exponent);
double units_to_best(unit_type u, int *mm);
struct coord normalize(struct coord v, unit_type len);
struct coord rotate(struct coord v, double angle);
struct coord add_vec(struct coord a, struct coord b);
struct coord sub_vec(struct coord a, struct coord b);
struct coord neg_vec(struct coord v);
struct coord rotate_r(struct coord c, unit_type r, double angle);
double theta_vec(struct coord v);
double theta(struct coord c, struct coord p);
void sort_coord(struct coord *min, struct coord *max);
unit_type dist_point(struct coord a, struct coord b);
unit_type dist_line(struct coord p, struct coord a, struct coord b);
unit_type dist_rect(struct coord p, struct coord a, struct coord b);
int inside_rect(struct coord p, struct coord a, struct coord b);
unit_type dist_circle(struct coord p, struct coord c, unit_type r);
#endif /* !COORD_H */