{"id":3829,"date":"2012-10-12T08:31:04","date_gmt":"2012-10-11T23:31:04","guid":{"rendered":"http:\/\/www.moonmile.net\/blog\/archives\/3829"},"modified":"2012-10-12T08:37:04","modified_gmt":"2012-10-11T23:37:04","slug":"c-metro-%e3%82%a2%e3%83%97%e3%83%aa%e3%81%a7%e3%82%b3%e3%83%b3%e3%83%88%e3%83%ad%e3%83%bc%e3%83%ab%e3%82%92%e3%83%89%e3%83%a9%e3%83%83%e3%82%b0%e3%81%99%e3%82%8b","status":"publish","type":"post","link":"http:\/\/www.moonmile.net\/blog\/archives\/3829","title":{"rendered":"[C#] Metro \u30a2\u30d7\u30ea\u3067\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u30c9\u30e9\u30c3\u30b0\u3059\u308b"},"content":{"rendered":"<p>[C#] WPF\u306eThumb\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u4f7f\u3063\u3066\u30c9\u30e9\u30c3\u30b0\u3092\u5b9f\u88c5\u3059\u308b | Moonmile Solutions Blog<br \/>\n<a href=\"http:\/\/www.moonmile.net\/blog\/archives\/3701\">http:\/\/www.moonmile.net\/blog\/archives\/3701<\/a><br \/>\n[C#] Thumb\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u7d99\u627f\u3057\u305f\u30e6\u30fc\u30b6\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u4f5c\u308b | Moonmile Solutions Blog<br \/>\n<a href=\"http:\/\/www.moonmile.net\/blog\/archives\/3709\">http:\/\/www.moonmile.net\/blog\/archives\/3709<\/a><\/p>\n<p>\u4e0a\u8a18\u306a\u3068\u3053\u308d\u3067\u3001WPF \u3092\u4f7f\u3063\u3066\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u30c9\u30e9\u30c3\u30b0\u3067\u304d\u308b\u3088\u3046\u306b\u3057\u307e\u3057\u305f\u304c\u3001\u4eca\u56de\u306f Metro \u30a2\u30d7\u30ea\u3067\u518d\u78ba\u8a8d\u3057\u3066\u307f\u307e\u3059\u3002\u4e2d\u8eab\u306f XAML \u5f62\u5f0f\u306a\u306e\u3067\u305d\u306e\u307e\u307e\u52d5\u304f\u3068\u601d\u3046\u306e\u3067\u3059\u304c\u3001\u3069\u3093\u306a\u98a8\u306b\u306a\u308b\u306e\u304b\u306a\u3068\u3002<\/p>\n<ol>\n<li>Thumb \u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u4f7f\u3046\u3002<\/li>\n<li>\u30c9\u30e9\u30c3\u30b0\u5bfe\u8c61\u306e Thumb \u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092 canvas \u306e\u4e2d\u306b\u7f6e\u304f\u3002<\/li>\n<li>Thumb \u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306e\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u306b\u3001\u753b\u50cf\u3092\u8cbc\u308a\u3064\u3051\u308b\u305f\u3081\u306e Ellipse \u30bf\u30b0\u3092\u7528\u610f\u3059\u308b\u3002<\/li>\n<li>Thumb \u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306e\u30cf\u30f3\u30c9\u30e9\u306f\u5f8c\u4ed8\u3051\uff08\u8907\u6570\u914d\u7f6e\u3059\u308b\u305f\u3081\uff09<\/li>\n<\/ol>\n<p>\u3056\u3063\u3068\u3001\u30bd\u30fc\u30b9\u30b3\u30fc\u30c9\u3060\u3051\u6652\u3057\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n<p>\u30c7\u30b6\u30a4\u30f3\u306f\u3053\u3093\u306a\u611f\u3058<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2012\/10\/wpid-dworkblogimage20121012_01org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2012\/10\/wpid-dworkblogimage20121012_01thum.jpg\" border=\"0\" \/><\/a><\/p>\n<p>\u25bcMainPage.xaml<\/p>\n<pre class=\"brush: xml; title: ; notranslate\" title=\"\">\r\n&lt;Page\r\n    x:Class=&amp;quot;KeshoSlidePazzle.MainPage&amp;quot;\r\n    xmlns=&amp;quot;http:\/\/schemas.microsoft.com\/winfx\/2006\/xaml\/presentation&amp;quot;\r\n    xmlns:x=&amp;quot;http:\/\/schemas.microsoft.com\/winfx\/2006\/xaml&amp;quot;\r\n    xmlns:local=&amp;quot;using:KeshoSlidePazzle&amp;quot;\r\n    xmlns:d=&amp;quot;http:\/\/schemas.microsoft.com\/expression\/blend\/2008&amp;quot;\r\n    xmlns:mc=&amp;quot;http:\/\/schemas.openxmlformats.org\/markup-compatibility\/2006&amp;quot;\r\n    mc:Ignorable=&amp;quot;d&amp;quot;&gt;\r\n    &lt;Page.Resources&gt;\r\n        &lt;ControlTemplate TargetType=&amp;quot;Thumb&amp;quot; x:Name=&amp;quot;ImageThumb&amp;quot;&gt;\r\n            &lt;Ellipse Fill=&amp;quot;{TemplateBinding Background}&amp;quot;&gt;&lt;\/Ellipse&gt;\r\n        &lt;\/ControlTemplate&gt;\r\n    &lt;\/Page.Resources&gt;\r\n\r\n    &lt;Grid Background=&amp;quot;{StaticResource ApplicationPageBackgroundThemeBrush}&amp;quot;&gt;\r\n            &lt;TextBlock HorizontalAlignment=&amp;quot;Left&amp;quot; Margin=&amp;quot;10,10,0,0&amp;quot; TextWrapping=&amp;quot;Wrap&amp;quot; Text=&amp;quot;Kesho Slide Pazzle&amp;quot; VerticalAlignment=&amp;quot;Top&amp;quot; Height=&amp;quot;56&amp;quot; Width=&amp;quot;327&amp;quot; FontSize=&amp;quot;24&amp;quot;\/&gt;\r\n        &lt;Canvas HorizontalAlignment=&amp;quot;Left&amp;quot; Height=&amp;quot;692&amp;quot; Margin=&amp;quot;191,94,0,-18&amp;quot; VerticalAlignment=&amp;quot;Top&amp;quot; Width=&amp;quot;866&amp;quot;&gt;\r\n            &lt;Thumb Canvas.Left=&amp;quot;345&amp;quot; Canvas.Top=&amp;quot;99&amp;quot; Height=&amp;quot;143&amp;quot; Name=&amp;quot;mark1&amp;quot;  Width=&amp;quot;144&amp;quot;\r\n                   Template=&amp;quot;{StaticResource ImageThumb}&amp;quot;\r\n                   &gt;&lt;\/Thumb&gt;\r\n            &lt;Thumb Canvas.Left=&amp;quot;55&amp;quot; Canvas.Top=&amp;quot;73&amp;quot; Height=&amp;quot;143&amp;quot; Name=&amp;quot;mark2&amp;quot;  Width=&amp;quot;144&amp;quot;\r\n                   Template=&amp;quot;{StaticResource ImageThumb}&amp;quot;\r\n                &gt;&lt;\/Thumb&gt;\r\n        &lt;\/Canvas&gt;\r\n\r\n    &lt;\/Grid&gt;\r\n&lt;\/Page&gt;\r\n<\/pre>\n<p>\u25bcMainPage.xaml.cs<\/p>\n<pre class=\"brush: csharp; title: ; notranslate\" title=\"\">\r\n\/\/\/ &lt;summary&gt;\r\n\/\/\/ \u305d\u308c\u81ea\u4f53\u3067\u4f7f\u7528\u3067\u304d\u308b\u7a7a\u767d\u30da\u30fc\u30b8\u307e\u305f\u306f\u30d5\u30ec\u30fc\u30e0\u5185\u306b\u79fb\u52d5\u3067\u304d\u308b\u7a7a\u767d\u30da\u30fc\u30b8\u3002\r\n\/\/\/ &lt;\/summary&gt;\r\npublic sealed partial class MainPage : Page\r\n{\r\n    public MainPage()\r\n    {\r\n        this.InitializeComponent();\r\n    }\r\n\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u3053\u306e\u30da\u30fc\u30b8\u304c\u30d5\u30ec\u30fc\u30e0\u306b\u8868\u793a\u3055\u308c\u308b\u3068\u304d\u306b\u547c\u3073\u51fa\u3055\u308c\u307e\u3059\u3002\r\n    \/\/\/ &lt;\/summary&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;e&amp;quot;&gt;\u3053\u306e\u30da\u30fc\u30b8\u306b\u3069\u306e\u3088\u3046\u306b\u5230\u9054\u3057\u305f\u304b\u3092\u8aac\u660e\u3059\u308b\u30a4\u30d9\u30f3\u30c8 \u30c7\u30fc\u30bf\u3002Parameter \r\n    \/\/\/ \u30d7\u30ed\u30d1\u30c6\u30a3\u306f\u3001\u901a\u5e38\u3001\u30da\u30fc\u30b8\u3092\u69cb\u6210\u3059\u308b\u305f\u3081\u306b\u4f7f\u7528\u3057\u307e\u3059\u3002&lt;\/param&gt;\r\n    protected override void OnNavigatedTo(NavigationEventArgs e)\r\n    {\r\n        mark1.Background = getBrush(&amp;quot;koma1.png&amp;quot;); setHandler(mark1);\r\n        mark2.Background = getBrush(&amp;quot;koma2.png&amp;quot;); setHandler(mark2);\r\n    }\r\n\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u753b\u50cf\u3092\u8a2d\u5b9a\r\n    \/\/\/ &lt;\/summary&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;file&amp;quot;&gt;&lt;\/param&gt;\r\n    \/\/\/ &lt;returns&gt;&lt;\/returns&gt;\r\n    private ImageBrush getBrush( string file ) \r\n    {\r\n        var bmp = new BitmapImage(new Uri(&amp;quot;ms-appx:\/\/\/Assets\/&amp;quot; + file));\r\n        var br = new ImageBrush();\r\n        br.ImageSource = bmp;\r\n        return br;\r\n    }\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u30cf\u30f3\u30c9\u30e9\u3092\u8a2d\u5b9a\r\n    \/\/\/ &lt;\/summary&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;t&amp;quot;&gt;&lt;\/param&gt;\r\n    private void setHandler(Thumb t)\r\n    {\r\n        t.DragCompleted += mark_DragCompleted;\r\n        t.DragDelta += mark_DragDelta;\r\n        t.DragStarted += mark_DragStarted;\r\n    }\r\n\r\n\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u30c9\u30e9\u30c3\u30b0\u7d42\u4e86\r\n    \/\/\/ &lt;\/summary&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;sender&amp;quot;&gt;&lt;\/param&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;e&amp;quot;&gt;&lt;\/param&gt;\r\n    private void mark_DragCompleted(object sender, DragCompletedEventArgs e)\r\n    {\r\n        var t = sender as Thumb;\r\n        t.Opacity = 1.0;\r\n    }\r\n\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u30c9\u30e9\u30c3\u30b0\u958b\u59cb\r\n    \/\/\/ &lt;\/summary&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;sender&amp;quot;&gt;&lt;\/param&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;e&amp;quot;&gt;&lt;\/param&gt;\r\n    private void mark_DragStarted(object sender, DragStartedEventArgs e)\r\n    {\r\n        var t = sender as Thumb;\r\n        t.Opacity = 0.5;\r\n    }\r\n\r\n    \/\/\/ &lt;summary&gt;\r\n    \/\/\/ \u30c9\u30e9\u30c3\u30af\u4e2d\r\n    \/\/\/ &lt;\/summary&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;sender&amp;quot;&gt;&lt;\/param&gt;\r\n    \/\/\/ &lt;param name=&amp;quot;e&amp;quot;&gt;&lt;\/param&gt;\r\n    private void mark_DragDelta(object sender, DragDeltaEventArgs e)\r\n    {\r\n        var t = sender as Thumb;\r\n        Canvas.SetLeft(t, Canvas.GetLeft(t) + e.HorizontalChange);\r\n        Canvas.SetTop(t, Canvas.GetTop(t) + e.VerticalChange);\r\n    }\r\n}\r\n<\/pre>\n<p>\u5b9f\u306f\u3001Ellipse \u306e\u3088\u3046\u306a\u666e\u901a\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306b\u3082\u30c9\u30e9\u30c3\u30b0\u306e\u6a5f\u80fd\u306f\u5099\u308f\u3063\u3066\u3044\u308b&#8230;\u3068\u3044\u3046\u304b\u3001\u30de\u30a6\u30b9\u30a4\u30d9\u30f3\u30c8\u3092\u30ad\u30e3\u30d7\u30c1\u30e3\u3059\u308c\u3070\u53ef\u80fd\u306a\u306e\u306f\u53ef\u80fd\u306a\u306e\u3067\u3059\u304c\u3001\u3053\u3093\u306a\u98a8\u306b\u753b\u50cf\u3092\u8cbc\u308a\u3051\u3066\u79fb\u52d5\u3059\u308b\u3060\u3051\u306a\u3089\u3070\u3001Thumb \u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u306b Template \u3092\u914d\u7f6e\u3057\u305f\u307b\u3046\u304c\u624b\u65e9\u304f\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>Thumb \u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u81ea\u4f53\u306b\u306f\u80cc\u666f\u304c\u6307\u5b9a\u3067\u304d\u306a\u3044\u306e\u3067\u3001\u5185\u90e8\u3067 Grid \u3092\u4f5c\u3063\u3066\u305d\u306e\u4e2d\u306b Ellipse \u306e\u3088\u3046\u306a\u56f3\u5f62\u306e\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u914d\u7f6e\u3059\u308b\u306e\u304c\u30df\u30bd\u3067\u3059\u306d\u3002\u3053\u306e\u3042\u305f\u308a\u3001\u3082\u3046\u5c11\u3057\u30b2\u30fc\u30e0\u3063\u307d\u3044\u52d5\u304d\u304c\u3067\u304d\u305f\u3089\u3001Windows Store app \u306e\u30b5\u30f3\u30d7\u30eb\u306b\u4e0a\u3052\u3066\u304a\u304d\u307e\u3059\u3002<\/p>\n<p>\u5b9f\u884c\u3059\u308b\u3068\u3053\u3093\u306a\u611f\u3058\u3067\u3059\u3002\u666e\u901a\u306b\u30bf\u30c3\u30c1\u306e\u30c9\u30e9\u30c3\u30b0\u3067\u52d5\u304d\u307e\u3059\u3002<\/p>\n<p><a href=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2012\/10\/wpid-dworkblogimage20121012_02org.jpg\"><img decoding=\"async\" src=\"http:\/\/www.moonmile.net\/blog\/wp-content\/uploads\/2012\/10\/wpid-dworkblogimage20121012_02thum.jpg\" border=\"0\" \/><\/a><\/p>\n<p>\u3053\u308c\u3067\u3001\u30b9\u30e9\u30a4\u30c9\u30b2\u30fc\u30e0\u306e\u6e96\u5099\u304c\u3067\u304d\u305f\u306e\u3067\u300c\u9032\u3081\u307e\u3059\u300d\u3063\u3066\u3053\u3068\u3067\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>[C#] WPF\u306eThumb\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u3092\u4f7f\u3063\u3066\u30c9\u30e9\u30c3\u30b0\u3092\u5b9f\u88c5\u3059\u308b | Moonmile Solutions Blog http:\/\/www.moonmile.net\/blog\/archives\/3701 [C#] Th &hellip; <a href=\"http:\/\/www.moonmile.net\/blog\/archives\/3829\">\u7d9a\u304d\u3092\u8aad\u3080 <span class=\"meta-nav\">&rarr;<\/span><\/a><\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":""},"categories":[23,49,44],"tags":[],"class_list":["post-3829","post","type-post","status-publish","format-standard","hentry","category-csharp","category-xaml","category-windows-8"],"jetpack_featured_media_url":"","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/3829","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/comments?post=3829"}],"version-history":[{"count":4,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/3829\/revisions"}],"predecessor-version":[{"id":3832,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/posts\/3829\/revisions\/3832"}],"wp:attachment":[{"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/media?parent=3829"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/categories?post=3829"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.moonmile.net\/blog\/wp-json\/wp\/v2\/tags?post=3829"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}