Como posso fazer um bitmap de Styles MapXtreme
Pergunta
Tenho postado esta pergunta no fórum MapXtreme mas desde que ninguém nunca responde a perguntas lá eu estou esperando que alguém aqui tem alguma experiência com este produto (MapXtreme é um SDK GIS feita pelas pessoas que fazem MapInfo)
Eu estou trabalhando em um aplicativo MapXtreme Desktop e precisamos de bitmaps de nossos estilos de recursos
Eu tentei duas maneiras, mas tudo que eu vejo é um bitmap cinza com um escuro X.
aqui está o código que tenho usado em ambos os sentidos estão no código mas é comentado:
public static Bitmap GetStyleBitmap(Style style)
{
var bm = new Bitmap(16, 16, System.Drawing.Imaging.PixelFormat.Format32bppArgb);
var rect = new System.Drawing.Rectangle(0, 0, 16, 16);
var ss = new StyleSample();
ss.Bounds = rect;
if (style is CompositeStyle)
{
ss.ApplyAreaStyle(((CompositeStyle)style).AreaStyle);
ss.ApplyLineStyle(((CompositeStyle)style).LineStyle);
}
if (style is AreaStyle)
{
ss.ApplyAreaStyle((AreaStyle)style);
}
if (style is SimpleLineStyle)
{
ss.ApplyLineStyle((SimpleLineStyle)style);
}
//using MapExport
var me = new MapExport(ss.Map);
var image = me.Export();
return new Bitmap(image);
//using StyleSample.DrawToBitmap
//ss.DrawToBitmap(bm, rect);
//return bm;
}
TIA
Solução
Depois de esperar por uma resposta - e tentando inúmeras outras maneiras - tudo em vão, eu decidi em fazer tudo 'à mão' ou seja, eu simplesmente olhar no objeto estilo de obter a cor do mesmo e desenhar uma adequada bitmap para o tipo de camada (linha ou polígono).
Ela não lidar com cada caso e também estilos doesnt linha alça ou cores interiores mas serve os meus propósitos para agora.
aqui é o código que faz isso.
public static Bitmap GetStyleBitmap(FeatureLayer fl)
{
Feature f = GetFirstFeature(fl);
if (f == null) return null;
var style = f.Style;
Color c;
var bm = new Bitmap(16, 16, System.Drawing.Imaging.PixelFormat.Format32bppArgb);
PointF[] poly = new PointF[]
{
new PointF(2,5),
new PointF(5,2),
new PointF(14,7),
new PointF(14,14),
new PointF(2,14),
new PointF(2,4)
};
SimpleLineStyle line = null;
if (style is CompositeStyle)
line = ((CompositeStyle)style).AreaStyle.Border as SimpleLineStyle;
if (style is AreaStyle)
line = ((AreaStyle)style).Border as SimpleLineStyle;
if (line != null)
{
c = line.Color;
using (var gr = Graphics.FromImage(bm))
{
gr.DrawPolygon(new Pen(c, 2), poly);
}
return bm;
}
line = style as SimpleLineStyle;
if (line != null)
{
c = line.Color;
using (var gr = Graphics.FromImage(bm))
{
gr.DrawLine(new Pen(c, 2), new PointF(2,2), new PointF(14,14));
}
}
return bm;
}
Outras dicas
O primeiro código já quase funcionou. Eu apenas tweaked-lo um pouco para corrigi-lo. Eu testei-o para um estilo de composição que contém um simplevectorpointstyle nele.
/// <summary>
/// Creates an icon for the specified style.
/// </summary>
/// <param name="style">The style.</param>
/// <returns></returns>
private static Bitmap CreateStyleIcon(Style style)
{
const int iconSize = 16; //the size of the icon
System.Drawing.Rectangle iconArea = new System.Drawing.Rectangle(0, 0, iconSize, iconSize); //a rectangle area for the icon
StyleSample ss = new StyleSample { Bounds = iconArea };
if (style is CompositeStyle)
{
CompositeStyle compsiteStyle = style as CompositeStyle;
if (compsiteStyle.AreaStyle != null) //do we have an area style?
{
ss.ApplyAreaStyle(compsiteStyle.AreaStyle);
}
if (compsiteStyle.LineStyle != null) //do we have an LineStyle style?
{
ss.ApplyLineStyle(compsiteStyle.LineStyle);
}
if (compsiteStyle.SymbolStyle != null) //do we have an SymbolStyle style?
{
ss.ApplySymbol(compsiteStyle.SymbolStyle);
}
}
if (style is AreaStyle)
{
ss.ApplyAreaStyle((AreaStyle)style);
}
if (style is BaseLineStyle)
{
ss.ApplyLineStyle((BaseLineStyle)style);
}
//draw the bitmap
Bitmap iconBitmap = new Bitmap(iconSize, iconSize, System.Drawing.Imaging.PixelFormat.Format32bppArgb);//the bitmap to draw the icon to
ss.DrawToBitmap(iconBitmap, iconArea);
return iconBitmap;
}