Could not load file or assembly 'System.Windows.Interactivity' [duplicate]
Asked Answered
B

7

23

I just added System.Windows.Interactivity assembly. XamlParse throw me an exception on run time:

Could not load file or assembly 'System.Windows.Interactivity, PublicKeyToken=31bf3856ad364e35' or one of its dependencies. The system cannot find the file specified.

Google search found only results related to prism - which I do not use.

Any idea why does it happen?

Burgoo answered 22/11, 2012 at 13:44 Comment(9)
It's part of Expression StudioEducative
So? Should I install something?Burgoo
Here's the MSDN page - msdn.microsoft.com/en-us/library/…Educative
I did not understand how it helps me. I know how to use the class, it compiled fine, crash on run time.Burgoo
Just a guess, might be you are not referencing the libraries in the MAIN project?Nomarch
@Tilak, Thanks, this is the solution. Write it as answer so I can accept it.Burgoo
Another thought that might help some: At least one element from assembly "i" must be named, so that VS correctly hooks up the assembly. <i:InvokeCommandAction Command="{Binding MyCommand}" x:Name="interactivityFix" />Endurant
@AmadeuszWieczorek : please add your solution as answer, it helped me a lot. Thanks.Clad
I actually found the solution for this here which was different than any of the answer for this question.Retaliate
N
61

Just a guess, might be you are not referencing the libraries in the MAIN project.

It has happened to me several times.

Nomarch answered 25/11, 2012 at 13:39 Comment(0)
E
20

Tilak's answer helped me out a big deal, but I also needed to name at least one element from assembly "i" in the XAML code. When the element is named, Visual Studio correctly hooks up the assembly.

Change

<i:InvokeCommandAction Command="{Binding MyCommand}"/>

into

<i:InvokeCommandAction Command="{Binding MyCommand}" x:Name="interactivityFix" />

This needs to be done to only one element in the entire XAML file.

Endurant answered 10/8, 2015 at 21:6 Comment(5)
My Window is called from a DLL inside a non-WPF application. This seemed to do the trick, thanks!Olive
All I had to do with my was just add a name per this answer. Definitely instills confidence in me with regards to the tooling...Hoarding
I'm in the same context as @Olive and I wouldn't have believed that would do the trick. Yet it does...Entozoon
I had this happen with my VS extension Start Page+. The XAML is in a ToolWindow, in a separate project from the VSIX project. Following Tilak's advise didn't help in my situation, but following Amadeusz's did, but I only needed the naming hack, not both answers together.Lamellibranch
This name detail was the only thing I needed to do. If you are having this problem, first try the name trick by itself. Do not add any additional references before confirming they are actually necessary, because they may not be.Hardfavored
E
10

Sometimes, when you add a new library, in introduces a clashing version of System.Windows.Interactivity.dll.

This prevents the project from working.

To fix, add an Assembly Binding Redirect by editing your app.config to look something like this:

<?xml version="1.0"?>
<configuration>
  <runtime>
    <assemblyBinding xmlns="urn:schemas-microsoft-com:asm.v1">
      <dependentAssembly>
        <assemblyIdentity name="System.Windows.Interactivity"
                          publicKeyToken="31bf3856ad364e35"
                          culture="neutral"/>
        <bindingRedirect oldVersion="4.0.0.0"
                         newVersion="4.5.0.0" />
      </dependentAssembly>
    </assemblyBinding>
  </runtime>
  <startup><supportedRuntime version="v4.0" sku=".NETFramework,Version=v4.5"/></startup>
  <appSettings>
    <add key="TestKey" value="true"/>
  </appSettings>
</configuration>

Don't worry about changing the PublicKeyToken, that's constant across all versions, as it depends on the name of the .dll, not the version.

Ensure that you match the newVersion in your appConfig to the actual version that you end up pointing at:

enter image description here

Estimation answered 24/7, 2015 at 10:49 Comment(0)
T
4

You can find this dll in Blend SDK.

Below is link to it:

http://www.microsoft.com/en-us/download/details.aspx?id=10801

Taler answered 22/11, 2012 at 15:52 Comment(0)
W
1

You can scan through each of your project for the version of System.Windows.Interactivity eg. 4.0.0.0 or 4.5.0.0. Also, there is a possibility that one of the third party dll that might reference, is depending on System.Windows.Interactivity. So make sure you align the version across your project. This must fix your issue.

Walls answered 18/11, 2016 at 9:31 Comment(1)
Rather than 'This must fix your issue', try and say something less forceful. If it doesn't fix it (And since the post is 3 years old, it probably already has a fix), then your answer will be downvoted a lot.Economically
O
1

This was this morning's task. The problem for us was just that the installer moved the location of the DLL. Sometimes it's not a subtle version mismatch: a simple misplacement will cause the same signs. You can use Fuslogvw.exe to help diagnose this. Once you (a) remember to launch the tool with Admin privs and (b) configure the tool to show you binding failures ("Settings"), you'll see log entries like this:

LOG: DisplayName = System.Windows.Interactivity, PublicKeyToken=31bf3856ad364e35 (Partial) WRN: Partial binding information was supplied for an assembly: [ red herring, not a problem for us ] ... LOG: GAC Lookup was unsuccessful [ another red herring: System.Windows.Interactivity.dll is not a core assembly and not registered in the GAC by default ] LOG: Attempting download of new URL file:///C:/Program Files (x86)/<path>/System.Windows.Interactivity.DLL. ... LOG: All probing URLs attempted and failed. After you put the DLL where it belongs, the log will look like this: LOG: GAC Lookup was unsuccessful. LOG: Attempting download of new URL file:///C:/Program Files (x86)/<path>/System.Windows.Interactivity.DLL. LOG: Assembly download was successful. Attempting setup of file: C:\Program Files (x86)\<path>\System.Windows.Interactivity.dll

Otorhinolaryngology answered 20/12, 2018 at 22:9 Comment(0)
C
0

You could check the project properties -> Build -> Output Path.

Go to the output Path director using windows explorer. Then see whether the 'System.Windows.Interactivity.dll' exist in that folder. It might because the CopyLocal flag is false or there is reason The dll file does not generate in the output path folder.

Corry answered 9/4, 2018 at 3:51 Comment(0)

© 2022 - 2024 — McMap. All rights reserved.