Commit 14cd69b1 authored by sumpfralle's avatar sumpfralle

fixed inconsistent scaling for SVG and PS import


git-svn-id: https://pycam.svn.sourceforge.net/svnroot/pycam/trunk@962 bbaffbd6-741e-11dd-a85d-61de82d9cad9
parent 66e12568
...@@ -29,7 +29,7 @@ import os ...@@ -29,7 +29,7 @@ import os
log = pycam.Utils.log.get_logger() log = pycam.Utils.log.get_logger()
def import_model(filename, program_locations=None, unit=None, callback=None): def import_model(filename, program_locations=None, unit="mm", callback=None):
if not os.path.isfile(filename): if not os.path.isfile(filename):
log.error("PSImporter: file (%s) does not exist" % filename) log.error("PSImporter: file (%s) does not exist" % filename)
return None return None
...@@ -50,7 +50,8 @@ def import_model(filename, program_locations=None, unit=None, callback=None): ...@@ -50,7 +50,8 @@ def import_model(filename, program_locations=None, unit=None, callback=None):
# convert eps to dxf via pstoedit # convert eps to dxf via pstoedit
dxf_file_handle, dxf_file_name = tempfile.mkstemp(suffix=".dxf") dxf_file_handle, dxf_file_name = tempfile.mkstemp(suffix=".dxf")
os.close(dxf_file_handle) os.close(dxf_file_handle)
success = convert_eps2dxf(filename, dxf_file_name, location=pstoedit_path) success = convert_eps2dxf(filename, dxf_file_name, unit=unit,
location=pstoedit_path)
if not success: if not success:
result = None result = None
elif callback and callback(): elif callback and callback():
...@@ -61,15 +62,6 @@ def import_model(filename, program_locations=None, unit=None, callback=None): ...@@ -61,15 +62,6 @@ def import_model(filename, program_locations=None, unit=None, callback=None):
# pstoedit uses "inch" -> force a scale operation # pstoedit uses "inch" -> force a scale operation
result = pycam.Importers.DXFImporter.import_model(dxf_file_name, result = pycam.Importers.DXFImporter.import_model(dxf_file_name,
unit=unit, callback=callback) unit=unit, callback=callback)
if unit == "mm":
# pstoedit uses inch internally - we need to scale
if callback:
callback(text="Scaling model from inch to mm")
log.info("PSImporter: scaling model from inch to mm")
scale_x = 25.4
scale_y = 25.4
result.scale(scale_x=scale_x, scale_y=scale_y, scale_z=1.0,
callback=callback)
# always remove the dxf file # always remove the dxf file
remove_temp_file(dxf_file_name) remove_temp_file(dxf_file_name)
return result return result
......
...@@ -48,16 +48,18 @@ def convert_svg2eps(svg_filename, eps_filename, location=None): ...@@ -48,16 +48,18 @@ def convert_svg2eps(svg_filename, eps_filename, location=None):
process.stderr.read())) process.stderr.read()))
return False return False
def convert_eps2dxf(eps_filename, dxf_filename, location=None): def convert_eps2dxf(eps_filename, dxf_filename, location=None, unit="mm"):
if location is None: if location is None:
location = "pstoedit" location = "pstoedit"
args = [location, "-dt", "-nc", "-f", "dxf:-polyaslines"]
if unit == "mm":
# eps uses inch by default - we need to scale
args.extend(("-xscale", "25.4", "-yscale", "25.4"))
args.append(eps_filename)
args.append(dxf_filename)
try: try:
process = subprocess.Popen(stdin=subprocess.PIPE, stdout=subprocess.PIPE, process = subprocess.Popen(stdin=subprocess.PIPE,
stderr=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, args=args)
args = [location,
"-dt", "-nc",
"-f", "dxf:-polyaslines",
eps_filename, dxf_filename])
except OSError, err_msg: except OSError, err_msg:
log.error("SVGImporter: failed to execute 'pstoedit' (%s): %s" \ log.error("SVGImporter: failed to execute 'pstoedit' (%s): %s" \
% (location, err_msg)) % (location, err_msg))
...@@ -77,7 +79,7 @@ def convert_eps2dxf(eps_filename, dxf_filename, location=None): ...@@ -77,7 +79,7 @@ def convert_eps2dxf(eps_filename, dxf_filename, location=None):
process.stderr.read())) process.stderr.read()))
return False return False
def import_model(filename, program_locations=None, unit=None, callback=None): def import_model(filename, program_locations=None, unit="mm", callback=None):
if not os.path.isfile(filename): if not os.path.isfile(filename):
log.error("SVGImporter: file (%s) does not exist" % filename) log.error("SVGImporter: file (%s) does not exist" % filename)
return None return None
...@@ -120,7 +122,8 @@ def import_model(filename, program_locations=None, unit=None, callback=None): ...@@ -120,7 +122,8 @@ def import_model(filename, program_locations=None, unit=None, callback=None):
# convert eps to dxf via pstoedit # convert eps to dxf via pstoedit
dxf_file_handle, dxf_file_name = tempfile.mkstemp(suffix=".dxf") dxf_file_handle, dxf_file_name = tempfile.mkstemp(suffix=".dxf")
os.close(dxf_file_handle) os.close(dxf_file_handle)
success = convert_eps2dxf(eps_file_name, dxf_file_name, location=pstoedit_path) success = convert_eps2dxf(eps_file_name, dxf_file_name, unit=unit,
location=pstoedit_path)
# we don't need the eps file anymore # we don't need the eps file anymore
remove_temp_file(eps_file_name) remove_temp_file(eps_file_name)
if not success: if not success:
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment