EasyEDA Std: import schematic images.

This commit is contained in:
Alex Shvartzkop 2023-10-01 16:19:44 +03:00
parent 979274af7c
commit dca964092f
1 changed files with 50 additions and 0 deletions

View File

@ -36,6 +36,7 @@
#include <sch_junction.h> #include <sch_junction.h>
#include <sch_edit_frame.h> #include <sch_edit_frame.h>
#include <sch_shape.h> #include <sch_shape.h>
#include <sch_bitmap.h>
#include <sch_bus_entry.h> #include <sch_bus_entry.h>
#include <string_utils.h> #include <string_utils.h>
#include <bezier_curves.h> #include <bezier_curves.h>
@ -1386,6 +1387,55 @@ void SCH_EASYEDA_PARSER::ParseSchematic( SCHEMATIC* aSchematic, SCH_SHEET* aRoot
{ {
}*/ }*/
} }
else if( rootType == wxS( "I" ) )
{
VECTOR2D start( Convert( arr[1] ), Convert( arr[2] ) );
VECTOR2D size( Convert( arr[3] ), Convert( arr[4] ) );
double angle = Convert( arr[5] );
wxString imageUrl = arr[6];
if( imageUrl.BeforeFirst( ':' ) == wxS( "data" ) )
{
wxArrayString paramsArr =
wxSplit( imageUrl.AfterFirst( ':' ).BeforeFirst( ',' ), ';', '\0' );
wxString data = imageUrl.AfterFirst( ',' );
if( paramsArr.size() > 0 )
{
wxString mimeType = paramsArr[0];
wxMemoryBuffer buf = wxBase64Decode( data );
if( mimeType == wxS( "image/svg+xml" ) )
{
// TODO: Not supported yet
}
else
{
std::unique_ptr<SCH_BITMAP> bitmap = std::make_unique<SCH_BITMAP>();
wxImage::SetDefaultLoadFlags( wxImage::GetDefaultLoadFlags()
& ~wxImage::Load_Verbose );
if( bitmap->ReadImageFile( buf ) )
{
VECTOR2D kstart = RelPos( start );
VECTOR2D ksize = ScalePos( size );
VECTOR2D kcenter = kstart + ksize / 2;
double scaleFactor = ScaleSize( size.x ) / bitmap->GetSize().x;
bitmap->SetImageScale( scaleFactor );
bitmap->SetPosition( kcenter );
for( double i = angle; i > 0; i -= 90 )
bitmap->Rotate( kcenter );
createdItems.push_back( std::move( bitmap ) );
}
}
}
}
}
} }
BOX2I sheetBBox; BOX2I sheetBBox;