Как обрезать изображение в Silverlight, используя собственный путь (в коде позади, а не в XAML).
У меня есть кусок головоломки, похожая на фигуру, написанная на пути, и я хочу использовать его для обрезки любого изображения.
В настоящее время это работает путем отсечения, используя прямоугольник, код (C #):
private void UserControl_Loaded(object sender, RoutedEventArgs e)
{
int NUM_COLUMN = 8;
int NUM_ROW = 8;
double gridWidth = 60;
double gridHeight = 60;
string url = "Images/Sun.png";
// C#
for (int i = 0; i < NUM_COLUMN; i++)
{
for (int j = 0; j < NUM_ROW; j++)
{
double offsetX = (double)i * gridWidth;
double offsetY = (double)j * gridHeight;
Image image = new Image();
image.Source = new BitmapImage(new Uri(url, UriKind.Relative));
// clip the image
RectangleGeometry r = new RectangleGeometry();
r.Rect = new Rect(offsetX, offsetY, gridWidth, gridHeight);
image.Clip = r;
this.ClipCanvas.Children.Add(image);
}
}
}
В XAML есть только один Canvas
, называемый ClipCanvas
.