eeschema: store line style using a more readable format
This commit is contained in:
parent
634fc80916
commit
0517f78085
|
@ -72,6 +72,11 @@
|
||||||
// Token delimiters.
|
// Token delimiters.
|
||||||
const char* delims = " \t\r\n";
|
const char* delims = " \t\r\n";
|
||||||
|
|
||||||
|
// Tokens to read/save graphic lines style
|
||||||
|
#define T_STYLE "style"
|
||||||
|
#define T_COLOR "rgb" // cannot be modifed (used by wxWidgets)
|
||||||
|
#define T_COLORA "rgba" // cannot be modifed (used by wxWidgets)
|
||||||
|
#define T_WIDTH "width"
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @ingroup trace_env_vars
|
* @ingroup trace_env_vars
|
||||||
|
@ -105,7 +110,7 @@ static bool is_eol( char c )
|
||||||
* @param aString - A pointer to the string to compare.
|
* @param aString - A pointer to the string to compare.
|
||||||
* @param aLine - A pointer to string to begin the comparison.
|
* @param aLine - A pointer to string to begin the comparison.
|
||||||
* @param aOutput - A pointer to a string pointer to the end of the comparison if not NULL.
|
* @param aOutput - A pointer to a string pointer to the end of the comparison if not NULL.
|
||||||
* @return True if \a aString was found starting at \a aLine. Otherwise false.
|
* @return true if \a aString was found starting at \a aLine. Otherwise false.
|
||||||
*/
|
*/
|
||||||
static bool strCompare( const char* aString, const char* aLine, const char** aOutput = NULL )
|
static bool strCompare( const char* aString, const char* aLine, const char** aOutput = NULL )
|
||||||
{
|
{
|
||||||
|
@ -1138,6 +1143,62 @@ SCH_LINE* SCH_LEGACY_PLUGIN::loadWire( FILE_LINE_READER& aReader )
|
||||||
if( !strCompare( "Line", line, &line ) )
|
if( !strCompare( "Line", line, &line ) )
|
||||||
SCH_PARSE_ERROR( "invalid wire definition", aReader, line );
|
SCH_PARSE_ERROR( "invalid wire definition", aReader, line );
|
||||||
|
|
||||||
|
// Since Sept 15, 2017, a line style is alloved (width, style, color)
|
||||||
|
// Only non default values are stored
|
||||||
|
while( !is_eol( *line ) )
|
||||||
|
{
|
||||||
|
wxString buf;
|
||||||
|
|
||||||
|
parseUnquotedString( buf, aReader, line, &line );
|
||||||
|
|
||||||
|
if( buf == ")" )
|
||||||
|
continue;
|
||||||
|
|
||||||
|
else if( buf == T_WIDTH )
|
||||||
|
{
|
||||||
|
int size = parseInt( aReader, line, &line );
|
||||||
|
wire->SetLineWidth( size );
|
||||||
|
}
|
||||||
|
else if( buf == T_STYLE )
|
||||||
|
{
|
||||||
|
parseUnquotedString( buf, aReader, line, &line );
|
||||||
|
int style = SCH_LINE::GetLineStyleInternalId( buf );
|
||||||
|
wire->SetLineStyle( style );
|
||||||
|
}
|
||||||
|
else // should be the color parameter.
|
||||||
|
{
|
||||||
|
// The color param is something like rgb(150, 40, 191)
|
||||||
|
// and because there is no space between ( and 150
|
||||||
|
// the first param is inside buf.
|
||||||
|
// So break keyword and the first param into 2 separate strings.
|
||||||
|
wxString prm, keyword;
|
||||||
|
keyword = buf.BeforeLast( '(', &prm );
|
||||||
|
|
||||||
|
if( ( keyword == T_COLOR ) || ( keyword == T_COLORA ) )
|
||||||
|
{
|
||||||
|
long color[4] = { 0 };
|
||||||
|
|
||||||
|
int ii = 0;
|
||||||
|
|
||||||
|
if( !prm.IsEmpty() )
|
||||||
|
{
|
||||||
|
prm.ToLong( &color[ii] );
|
||||||
|
ii++;
|
||||||
|
}
|
||||||
|
|
||||||
|
int prm_count = ( keyword == T_COLORA ) ? 4 : 3;
|
||||||
|
// fix opacity to 1.0 or 255, when not exists in file
|
||||||
|
color[3] = 255;
|
||||||
|
|
||||||
|
for(; ii < prm_count && !is_eol( *line ); ii++ )
|
||||||
|
color[ii] = parseInt( aReader, line, &line );
|
||||||
|
|
||||||
|
wire->SetLineColor( color[0]/255.0, color[1]/255.0, color[2]/255.0,color[3]/255.0 );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Read the segment en points coordinates:
|
||||||
line = aReader.ReadLine();
|
line = aReader.ReadLine();
|
||||||
|
|
||||||
wxPoint begin, end;
|
wxPoint begin, end;
|
||||||
|
@ -1147,27 +1208,6 @@ SCH_LINE* SCH_LEGACY_PLUGIN::loadWire( FILE_LINE_READER& aReader )
|
||||||
end.x = parseInt( aReader, line, &line );
|
end.x = parseInt( aReader, line, &line );
|
||||||
end.y = parseInt( aReader, line, &line );
|
end.y = parseInt( aReader, line, &line );
|
||||||
|
|
||||||
if( !is_eol( *line ) )
|
|
||||||
{
|
|
||||||
int size = parseInt( aReader, line, &line );
|
|
||||||
wire->SetLineWidth( size );
|
|
||||||
}
|
|
||||||
|
|
||||||
if( !is_eol( *line ) )
|
|
||||||
{
|
|
||||||
int style = parseInt( aReader, line, &line );
|
|
||||||
wire->SetLineStyle( style );
|
|
||||||
}
|
|
||||||
|
|
||||||
if( !is_eol( *line ) )
|
|
||||||
{
|
|
||||||
double color[ 4 ] = { 0. };
|
|
||||||
for( int i = 0; i < 4 && !is_eol( *line ); i++ )
|
|
||||||
color[i] = parseDouble( aReader, line, &line );
|
|
||||||
|
|
||||||
wire->SetLineColor( color[0], color[1], color[2], color[3] );
|
|
||||||
}
|
|
||||||
|
|
||||||
wire->SetStartPoint( begin );
|
wire->SetStartPoint( begin );
|
||||||
wire->SetEndPoint( end );
|
wire->SetEndPoint( end );
|
||||||
|
|
||||||
|
@ -1979,23 +2019,33 @@ void SCH_LEGACY_PLUGIN::saveLine( SCH_LINE* aLine )
|
||||||
|
|
||||||
const char* layer = "Notes";
|
const char* layer = "Notes";
|
||||||
const char* width = "Line";
|
const char* width = "Line";
|
||||||
bool styled = aLine->GetPenSize() != aLine->GetDefaultWidth()
|
|
||||||
|| aLine->GetLineStyle() != aLine->GetDefaultStyle()
|
|
||||||
|| aLine->GetLineColor() != aLine->GetDefaultColor();
|
|
||||||
|
|
||||||
if( aLine->GetLayer() == LAYER_WIRE )
|
if( aLine->GetLayer() == LAYER_WIRE )
|
||||||
layer = "Wire";
|
layer = "Wire";
|
||||||
else if( aLine->GetLayer() == LAYER_BUS )
|
else if( aLine->GetLayer() == LAYER_BUS )
|
||||||
layer = "Bus";
|
layer = "Bus";
|
||||||
|
|
||||||
m_out->Print( 0, "Wire %s %s\n", layer, width );
|
m_out->Print( 0, "Wire %s %s", layer, width );
|
||||||
m_out->Print( 0, "\t%-4d %-4d %-4d %-4d", aLine->GetStartPoint().x, aLine->GetStartPoint().y,
|
|
||||||
|
// Write line style (width, type, color) only for non default values
|
||||||
|
if( aLine->GetLayer() == LAYER_NOTES )
|
||||||
|
{
|
||||||
|
if( aLine->GetPenSize() != aLine->GetDefaultWidth() )
|
||||||
|
m_out->Print( 0, " %s %d", T_WIDTH, aLine->GetLineSize() );
|
||||||
|
|
||||||
|
if( aLine->GetLineStyle() != aLine->GetDefaultStyle() )
|
||||||
|
m_out->Print( 0, " %s %s", T_STYLE, SCH_LINE::GetLineStyleName( aLine->GetLineStyle() ) );
|
||||||
|
|
||||||
|
if( aLine->GetLineColor() != aLine->GetDefaultColor() )
|
||||||
|
m_out->Print( 0, " %s",
|
||||||
|
TO_UTF8( aLine->GetLineColor().ToColour().GetAsString( wxC2S_CSS_SYNTAX ) ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
m_out->Print( 0, "\n" );
|
||||||
|
|
||||||
|
m_out->Print( 0, "\t%-4d %-4d %-4d %-4d",
|
||||||
|
aLine->GetStartPoint().x, aLine->GetStartPoint().y,
|
||||||
aLine->GetEndPoint().x, aLine->GetEndPoint().y );
|
aLine->GetEndPoint().x, aLine->GetEndPoint().y );
|
||||||
if( styled )
|
|
||||||
m_out->Print( 0, " %-4d %-4d %-.4f %-.4f %-.4f %-.4f",
|
|
||||||
aLine->GetLineSize(), aLine->GetLineStyle(),
|
|
||||||
aLine->GetLineColor().r, aLine->GetLineColor().g,
|
|
||||||
aLine->GetLineColor().b, aLine->GetLineColor().a );
|
|
||||||
|
|
||||||
m_out->Print( 0, "\n");
|
m_out->Print( 0, "\n");
|
||||||
}
|
}
|
||||||
|
|
|
@ -95,6 +95,55 @@ EDA_ITEM* SCH_LINE::Clone() const
|
||||||
return new SCH_LINE( *this );
|
return new SCH_LINE( *this );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static const char* style_names[] =
|
||||||
|
{
|
||||||
|
"solid", "dashed", "dotted", "dash_dot", nullptr
|
||||||
|
};
|
||||||
|
|
||||||
|
const char* SCH_LINE::GetLineStyleName( int aStyle )
|
||||||
|
{
|
||||||
|
const char * styleName = style_names[1];
|
||||||
|
|
||||||
|
switch( aStyle )
|
||||||
|
{
|
||||||
|
case PLOTDASHTYPE_SOLID:
|
||||||
|
styleName = style_names[0];
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
case PLOTDASHTYPE_DASH:
|
||||||
|
styleName = style_names[1];
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PLOTDASHTYPE_DOT:
|
||||||
|
styleName = style_names[2];
|
||||||
|
break;
|
||||||
|
|
||||||
|
case PLOTDASHTYPE_DASHDOT:
|
||||||
|
styleName = style_names[3];
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
return styleName;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int SCH_LINE::GetLineStyleInternalId( const wxString& aStyleName )
|
||||||
|
{
|
||||||
|
int id = -1; // Default style id
|
||||||
|
|
||||||
|
for( int ii = 0; style_names[ii] != nullptr; ii++ )
|
||||||
|
{
|
||||||
|
if( aStyleName == style_names[ii] )
|
||||||
|
{
|
||||||
|
id = ii;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
void SCH_LINE::Move( const wxPoint& aOffset )
|
void SCH_LINE::Move( const wxPoint& aOffset )
|
||||||
{
|
{
|
||||||
|
|
|
@ -88,6 +88,14 @@ public:
|
||||||
|
|
||||||
int GetLineStyle() const;
|
int GetLineStyle() const;
|
||||||
|
|
||||||
|
/// @return the style name from the style id
|
||||||
|
/// (mainly to write it in .sch file
|
||||||
|
static const char* GetLineStyleName( int aStyle );
|
||||||
|
|
||||||
|
/// @return the style id from the style name
|
||||||
|
/// (mainly to read style from .sch file
|
||||||
|
static int GetLineStyleInternalId( const wxString& aStyleName );
|
||||||
|
|
||||||
void SetLineColor( const COLOR4D aColor );
|
void SetLineColor( const COLOR4D aColor );
|
||||||
|
|
||||||
void SetLineColor( const double r, const double g, const double b, const double a );
|
void SetLineColor( const double r, const double g, const double b, const double a );
|
||||||
|
|
Loading…
Reference in New Issue