DHJJ [Hatsune's Journal Japan] blog

Hatsune's Journal Japan blog

目次

Blog 利用状況

ニュース

最新ツイート

運営サイト

Hatsune's Journal Japan
DHJJ

著作など

資格など

OCP
MCP

書庫

日記カテゴリ

わんくま同盟

[VisualStudio]Visual Studio 2013 RCのBlendにはBehaviorが

XAMLといえば、WPF、Silverlight、Windows Phone、WindowsストアアプリなどのプロジェクトでViewを定義する優れものマークアップ言語ですが、なぜか、WindowsストアアプリのXAMLではBehaviorがありませんでした。

Behaviorがないと何が困るかといえば、

  • XAML上のオブジェクトをクリックしたタイミングでStoryBoardを呼び出したい
  • オブジェクトの操作をコードを書かないで実行したい

のようなことができないからです。

「あれ?それって普通できないから、コードビハインド側(xaml.vbとかxaml.csとか)に記述しますよね?」

と思われるかもしれませんが、Behaviorはこの常識を打ち破ってしまう仕組みで、WPF時代にすでに実装(SilverlightはSilverlight3からなので玲ちゃんのときから)されている既存テクノロジーなのです。

知らなければ特に不満はないのですが、知っていてBehaviorを使っていた人にとっては、XAMLなのにBehaviorがないのはWindowsストアアプリのViewを作る上で非常にフラストレーションがたまるものであり、また、View分離前提でチーム開発するうえでの足かせになっていたのです。

それが、Blend for Visual Studio 2013 RCでWindows 8.1ストアアプリのプロジェクトを作成したときにサポートされるようになりました。

 

ただし、あくまでも現状はWindows 8.1用のWindowsストアアプリプロジェクトが対象のようで、Windows 8 用Windowsストアアプリプロジェクトの場合の[アセット]-[ビヘイビアー]表示は次のようになっており「download additional behaviors」とはなっていますが、クリックしても追加ビヘイビアーはありません。

image

 

今回サポートされたBehaviorは次の10個です。

image

  • CallMethodAction : 指定したオブジェクトのメソッドを呼び出す
  • ChangePropertyAction : 指定したオブジェクトのプロパティを変更する
  • ControlStoryboardAction : 指定したStoryboardの動きを制御する
  • DataTriggerBehavior : Binding値が条件に一致したときにActionを実行するトリガー
  • EventTriggerBehavior : イベントが発生したときにActionを実行するトリガー
  • GoToStateAction : 指定したオブジェクトのViewStateに書かれたStoryBoradを起動する
  • IncrementalUpdateBehavior : 
  • InvokeCommandAction : 指定したオブジェクトのイベントに対してICommandなオブジェクトをBindingする
  • NavigateToPageAction : ページ間の移動を定義する
  • PlaySoundAction : 指定したサウンドを再生する

 

それでは簡単にビヘイビアーの使い方を見てみましょう。

[アセット]-[ビヘイビアー]-[CallMethodAction]をドラッグして画面上のCommandにドロップします。

image

この操作だけでButtonコントロールにEventTriggerBehaviorが追加され、更にそこで起動されるActionとしてCallMethodActionが追加されます。

image

 

CallMethodActionのプロパティでMediaElementのPlayメソッドを割り当てましょう。

image

    <grid grid.row="1">      
    <grid.rowdefinitions>
        <rowdefinition height="*">      
        <rowdefinition height="Auto">      
    </rowdefinition>
    <mediaelement x:name="myME" margin="1,1,0,0" autoplay="False" source="ms-appx:///Video/ThroughTheWindow.mp4">      
        <mediaelement.projection>     
            <planeprojection>     
        </planeprojection>     
    </mediaelement.projection>
    <stackpanel grid.row="1" orientation="Horizontal">
        <button x:name="playButton" content="再生" margin="8,8,0,8" width="204" fontsize="24">      
            <interactivity:interaction.behaviors>
                <core:eventtriggerbehavior eventname="Click">
                    <core:callmethodaction targetobject="{Binding ElementName=myME}" methodname="Play">
                </core:callmethodaction>
            </core:eventtriggerbehavior>      
        </interactivity:interaction.behaviors></button>
        <button x:name="pauseButton" content="一時停止" margin="8,8,0,8" width="204" fontsize="24" />
        <button x:name="stopButton" content="停止" margin="0,8,12,8" width="204" fontsize="24" />          
       </stackpanel>
   </mediaelement>
</grid>

ここまでで実行して「再生」ボタンをクリックすると動画が始まります。

ここまででxaml.vbもxaml.csも登場しません。

XAMLの世界だけで完結しています。「再生」ボタンをクリックしたときにView側だけで完結するのであれば、ViewModelにICommandを実装してメソッドを実行したり、Bindingしたり、コードビハインドを使ってViewModelのメソッドを実行する必要はありません。

投稿日時 : 2013年9月16日 20:32

Feedback

# ivermectin 4000 mcg 2021/09/28 20:49 MarvinLic

stromectol xr https://stromectolfive.com/# ivermectin 6mg

# ivermectin buy nz 2021/11/03 0:14 DelbertBup

ivermectin pills canada http://stromectolivermectin19.online# ivermectin rx
ivermectin generic cream

# buy pills online cheap 2021/12/04 8:53 JamesDat

https://genericpillson.com/# cheap generic pills cytotec

# cheap generic ed pills 2021/12/05 4:47 JamesDat

http://genericpillson.online/# cheap generic ed pills clomid

# does sildenafil 20 mg work http://viasild24.online/
2021/12/07 19:29 Nyusjdh

does sildenafil 20 mg work http://viasild24.online/

# how to take sildenafil 20 mg 2021/12/09 18:28 JamesDat

https://viasild24.online/# sildenafil 20 mg tablet

# buy careprost in the usa free shipping 2021/12/12 6:45 Travislyday

https://plaquenils.com/ plaquenil 200mg buy

# best place to buy careprost https://bimatoprostrx.com
bimatoprost
2021/12/13 16:15 Hksfnjkh

best place to buy careprost https://bimatoprostrx.com
bimatoprost

# bimatoprost buy 2021/12/13 21:56 Travislyday

https://plaquenils.com/ plaquenil for osteoarthritis

# bimatoprost generic best price 2021/12/14 17:21 Travislyday

https://plaquenils.com/ hydroxychloroquine sulfate australia

# ivermectin cost canada 2021/12/17 22:59 Eliastib

cotvpn https://stromectolr.com stromectol where to buy

# cost of ivermectin http://stromectolabc.com/
where to buy stromectol online 2022/02/08 2:50 Busjdhj

cost of ivermectin http://stromectolabc.com/
where to buy stromectol online

# buy cheap doxycycline online https://doxycyline1st.com/
buy doxycycline online 270 tabs 2022/02/26 8:27 Doxycycline

buy cheap doxycycline online https://doxycyline1st.com/
buy doxycycline online 270 tabs

# generic for doxycycline https://doxycyline1st.com/
buy doxycycline 100mg 2022/02/26 20:07 Doxycycline

generic for doxycycline https://doxycyline1st.com/
buy doxycycline 100mg

# Trandate https://allpharm.store/ 2022/07/22 6:04 AllPharm

Trandate https://allpharm.store/

# covid antivirals https://paxlovid.best/
molnupiravir brand name 2022/09/08 7:42 Paxlovid

covid antivirals https://paxlovid.best/
molnupiravir brand name

# ed pills comparison https://ed-pills.xyz/
ed pills gnc 2022/09/17 15:05 EdPills

ed pills comparison https://ed-pills.xyz/
ed pills gnc

# prednisone for dogs https://prednisone20mg.icu/ 2022/10/15 13:23 Prednisone

prednisone for dogs https://prednisone20mg.icu/

# dating site free https://datingtopreview.com/
usa free dating sites 2022/10/17 20:39 Dating

dating site free https://datingtopreview.com/
usa free dating sites

# prednisone for cheap https://prednisone20mg.site/
prednisone 54 2022/11/15 17:59 Prednisone

prednisone for cheap https://prednisone20mg.site/
prednisone 54

# st Р°ugstine fl book matches online dateing https://datingsiteonline.site/
searchingforsingles 2022/12/05 23:49 Tading

st Р°ugstine fl book matches online dateing https://datingsiteonline.site/
searchingforsingles

# price prescriptions https://noprescriptioncanada.com/
fda approved pharmacies in canada 2022/12/16 23:47 NoPrescript

price prescriptions https://noprescriptioncanada.com/
fda approved pharmacies in canada

# Get warning information here. Actual trends of drug.
https://canadianfast.com/
Generic Name. drug information and news for professionals and consumers. 2023/02/20 0:25 CanadaBest

Get warning information here. Actual trends of drug.
https://canadianfast.com/
Generic Name. drug information and news for professionals and consumers.

# doors2.txt;1 2023/03/14 14:52 ELNXpFnQ

doors2.txt;1

# doors2.txt;1 2023/03/14 16:27 gjhmKdnVbRhpKWzisgd

doors2.txt;1

# how to buy prednisone - https://prednisonesale.pro/# 2023/04/22 10:34 Prednisone

how to buy prednisone - https://prednisonesale.pro/#

# order cytotec online - https://cytotecsale.pro/# 2023/04/28 23:32 Cytotec

order cytotec online - https://cytotecsale.pro/#

# cheap erectile dysfunction https://edpill.pro/# - best pills for ed 2023/06/27 10:19 EdPills

cheap erectile dysfunction https://edpill.pro/# - best pills for ed

# best free dating sites 2023/08/09 13:52 WayneGurry

free dating services: http://datingtopreview.com/# - american singles

# buy cytotec online 2023/08/26 12:43 Georgejep

https://misoprostol.guru/# purchase cytotec

# farmacia online senza ricetta 2023/09/25 5:12 Archieonelf

https://pharmacieenligne.icu/# acheter medicament a l etranger sans ordonnance

# п»їfarmacia online migliore 2023/09/27 6:26 Archieonelf

https://farmaciabarata.pro/# farmacia online madrid

# cheap erectile dysfunction https://edpillsotc.store/# - buy erection pills 2023/10/07 21:18 EdPills

cheap erectile dysfunction https://edpillsotc.store/# - buy erection pills

# best over the counter ed pills 2023/10/07 22:30 BobbyAtobe

Their health seminars are always enlightening. http://doxycyclineotc.store/# doxycycline 250

# purchase generic valtrex online https://valtrex.auction/ price of valtrex generic 2023/10/24 17:46 Valtrex

purchase generic valtrex online https://valtrex.auction/ price of valtrex generic

# paxlovid for sale 2023/10/24 23:44 LarryNef

https://valtrex.auction/# cost of valtrex canada

# gates of olympus max win - https://gatesofolympus.auction/ gate of olympus hile 2024/03/27 19:08 Olympic

gates of olympus max win - https://gatesofolympus.auction/ gate of olympus hile

# buy misoprostol over the counter https://cytotec.club/ cytotec online 2024/04/28 2:37 Cytotec

buy misoprostol over the counter https://cytotec.club/ cytotec online

タイトル
名前
Url
コメント