此问题特定于 Windows应用商店应用(Windows 8)。
我正在尝试将Bitmapimage
转换为Byte[]
并将其存储在xml文件中,然后检索并将其转换回Bitmapimage
。
我能够将Bitmapimage
转换为byte[]
(虽然这不是最好的方式,所以我不包括示例)。然后我使用序列化将类转换为xml。以下是用于序列化byte[]
的属性:
private byte[] iconBytes;
[XmlAttribute(DataType = "base64Binary")]
public byte[] IconBytes
{
get
{
// TO DO: Convert BitmapImage to Byte[]
return this.iconBytes;
}
set
{
this.SetProperty(ref this.iconBytes, value);
// TO DO: Convert Byte[] to BitmapImage
}
}
这是生成的XML:
<MyApp xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns:xsd="http://www.w3.org/2001/XMLSchema">
<Groups>
<Group Title="Group1">
<Items>
<Item Title="Item1" IconBytes="7uLC/+7iwv/u4sL/7uLC/0RVZf9heJL/X3OH/+vbvP/r27b/69u2/+vbtv/r27b/7d+9/+3fvf/r27z/R2aO/2Z2t/92h9T/obH3/3uXxP/lz57/5c+e/+XPnv/lz57/6dW3/+nVt//azbf/Um6o/2Jqu/9ib77/lqbp/4uq5//gw5T/4MOU/+DDlP/iyJj/5tCy/97Akf/Mt5b/Ulh+/ygpZv82P47/HhpG/01rpv+Npqn/3LuM/9y7jP/ewJH/27KF/9uyhf+xrKf/VWet/1hatf9reND/UVzD/5Sp8f+qmoL/27KF/9uyhf/ft5H/1q2A/9atgP/WrYD/QU6Y/zY2eP8wKFf/cHit/1ZtsP/WrYD/1q2A/9atgP/bsoX/0KF1/9Chdf/QoXX/NkqC/z5Bh/9KRaH/X3W4/zRMf//QoXX/0KF1/9Chdf/UqXz/zZlv/82Zb/8yJCD/Nj5u/0FOkP9FS5j/Wm+2/09rov9CMTP/zZlv/82Zb//QoXX/KBkV/yUWE/8eEg3/rKCc/ycmUP8yOnL/PU6E/2Nfdf9CLSj/LR0Y/zwnIf9fUUT/IxMQ/yASDP8dDwz/dWpp/4eGiP82QHT/QT5h/4l2c/80IB3/NCAc/yoZFf81IR//IBQO/x0QDP8dDgv/HQ4L/5eTkf+OmKL/k5KT/zAeG/8tHhf/KRsU/zIfGv8tHhf/IREN/x8PC/8fEAz/HhEM/7Suq/+dnaL/qqek/zAeGv8hFA//KBkU/ygaFP8uGhb/" />
</Items>
</Group>
</Groups>
</MyApp>
从xml反序列化该类后,如何将byte[]
转换为BitmapImage
?
有几个例子可以解决这个问题,但它们都与Silverlight和WPF有关,而且没有一个成功转换为 Windows应用商店应用(Windows 8)。
请注意,使用来自网络或本地计算机的流的示例不适用于此问题。图像byte[]
已经在内存中,因为数据是从xml文件反序列化的。
非常感谢任何帮助。新年快乐!
答案 0 :(得分:1)
您可以尝试使用InMemoryRandomAccessStream
:
var stream = new InMemoryRandomAccessStream();
await stream.WriteAsync(iconBytes.AsBuffer());
stream.Seek(0);
var image = new BitmapImage();
await image.SetSourceAsync(stream);
Here是另一个例子。