<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Adding event handlers COM seperated from RCW in ArcObjects SDK Questions</title>
    <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401011#M10693</link>
    <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;not really.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I switched to populating the map with the document focus map on startup of the extension.&amp;nbsp; That works for my application, goodness forbids anyone adds a second map frame to the document...&amp;nbsp; Then it all falls apart.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I have the same problem with a task.&amp;nbsp; That is harder to fix because the only hook is the editor that gets passed in.&amp;nbsp; I had to get a reference to my application that has the map set on it.&amp;nbsp; It seems that getting the map from the editor in an event causes problems for setting further event handlers.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I really wish these things worked properly.&amp;nbsp; I can't really go to support because the problem is intermittant and part of a customization that has a few 10s of thousands of lines of code and tied to network resources...&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
    <pubDate>Tue, 06 Aug 2013 14:32:27 GMT</pubDate>
    <dc:creator>AlexanderGray</dc:creator>
    <dc:date>2013-08-06T14:32:27Z</dc:date>
    <item>
      <title>Adding event handlers COM seperated from RCW</title>
      <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401009#M10691</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;Hello Forum,&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I have this intermittent problem, (happens about 60% of the time.)&amp;nbsp; &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;I have an extension (not addin) where I listen for a start editing event&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;In the start editing I start other events listeners, specificaly activeviewevents item added, item removed and mapevents featureclass changed.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;The problem is often (60% of the time but never in debug mode) I get an exception when adding the event handler&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;System.Runtime.InteropServices.InvalidComObjectException: COM object that has been separated from its underlying RCW cannot be used.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;this is a snippet in the startediting event handler&lt;/SPAN&gt;&lt;BR /&gt;&lt;PRE class="plain" name="code"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; m_actViewEvents = CType(m_map, IActiveViewEvents_Event)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Trace.WriteLine("active view events retrieved")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; AddHandler m_actViewEvents.ItemAdded, AddressOf ItemAdded 'exception is thrown here
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Trace.WriteLine("item added event handler added")
&lt;/PRE&gt;&lt;DIV style="display:none;"&gt; &lt;/DIV&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I set the m_map in the start editing.&amp;nbsp; I tried casting the m_Editor.map to the Iactiveviewevents (better design), I tried setting the m_map from the editor, I tried using the document focus map.&amp;nbsp; I tried declaring the m_Editor and m_map member vars as shared (static)&amp;nbsp; I tried declaring the m_activeViewEvents as shared.&amp;nbsp; &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;As far as I know everything is done on the main thread.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;I would rather not populate the m_map variable before the edit session is started since the focus map could change.&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 28 May 2013 20:20:46 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401009#M10691</guid>
      <dc:creator>AlexanderGray</dc:creator>
      <dc:date>2013-05-28T20:20:46Z</dc:date>
    </item>
    <item>
      <title>Re: Adding event handlers COM seperated from RCW</title>
      <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401010#M10692</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;Did you ever sort this out?&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 16 Jul 2013 16:08:42 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401010#M10692</guid>
      <dc:creator>RichardWatson</dc:creator>
      <dc:date>2013-07-16T16:08:42Z</dc:date>
    </item>
    <item>
      <title>Re: Adding event handlers COM seperated from RCW</title>
      <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401011#M10693</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;not really.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I switched to populating the map with the document focus map on startup of the extension.&amp;nbsp; That works for my application, goodness forbids anyone adds a second map frame to the document...&amp;nbsp; Then it all falls apart.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I have the same problem with a task.&amp;nbsp; That is harder to fix because the only hook is the editor that gets passed in.&amp;nbsp; I had to get a reference to my application that has the map set on it.&amp;nbsp; It seems that getting the map from the editor in an event causes problems for setting further event handlers.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;I really wish these things worked properly.&amp;nbsp; I can't really go to support because the problem is intermittant and part of a customization that has a few 10s of thousands of lines of code and tied to network resources...&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Aug 2013 14:32:27 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401011#M10693</guid>
      <dc:creator>AlexanderGray</dc:creator>
      <dc:date>2013-08-06T14:32:27Z</dc:date>
    </item>
    <item>
      <title>Re: Adding event handlers COM seperated from RCW</title>
      <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401012#M10694</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;We also have the same intermittent problems.&amp;nbsp; I was hoping that you had figured it out:(&lt;/SPAN&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Tue, 06 Aug 2013 14:36:01 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401012#M10694</guid>
      <dc:creator>RichardWatson</dc:creator>
      <dc:date>2013-08-06T14:36:01Z</dc:date>
    </item>
    <item>
      <title>Re: Adding event handlers COM seperated from RCW</title>
      <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401013#M10695</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;How are the event handlers being decremented?&amp;nbsp; &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;I have had problems in the past when AddHandler is called multiple times, but RemoveHandler is only called once.&amp;nbsp; &lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BLOCKQUOTE class="jive-quote"&gt;Hello Forum,&lt;BR /&gt;&lt;BR /&gt;I have this intermittent problem, (happens about 60% of the time.)&amp;nbsp; &lt;BR /&gt;I have an extension (not addin) where I listen for a start editing event&lt;BR /&gt;In the start editing I start other events listeners, specificaly activeviewevents item added, item removed and mapevents featureclass changed.&lt;BR /&gt;The problem is often (60% of the time but never in debug mode) I get an exception when adding the event handler&lt;BR /&gt;System.Runtime.InteropServices.InvalidComObjectException: COM object that has been separated from its underlying RCW cannot be used.&lt;BR /&gt;&lt;BR /&gt;this is a snippet in the startediting event handler&lt;BR /&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;&amp;nbsp;&amp;nbsp;&amp;nbsp; 
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; m_actViewEvents = CType(m_map, IActiveViewEvents_Event)
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Trace.WriteLine("active view events retrieved")
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; AddHandler m_actViewEvents.ItemAdded, AddressOf ItemAdded 'exception is thrown here
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Trace.WriteLine("item added event handler added")
&lt;/PRE&gt;&lt;BR /&gt;&lt;BR /&gt;I set the m_map in the start editing.&amp;nbsp; I tried casting the m_Editor.map to the Iactiveviewevents (better design), I tried setting the m_map from the editor, I tried using the document focus map.&amp;nbsp; I tried declaring the m_Editor and m_map member vars as shared (static)&amp;nbsp; I tried declaring the m_activeViewEvents as shared.&amp;nbsp; &lt;BR /&gt;As far as I know everything is done on the main thread.&lt;BR /&gt;I would rather not populate the m_map variable before the edit session is started since the focus map could change.&lt;/BLOCKQUOTE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 18:17:32 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401013#M10695</guid>
      <dc:creator>JeffMatson</dc:creator>
      <dc:date>2021-12-11T18:17:32Z</dc:date>
    </item>
    <item>
      <title>Re: Adding event handlers COM seperated from RCW</title>
      <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401014#M10696</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;RemoveHandler is being called in the stop editing event.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;
 Public Sub StopEditing(ByVal save As Boolean)
&amp;nbsp;&amp;nbsp;&amp;nbsp; Try

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If m_isInSaveEdit = False AndAlso _
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; m_editor.EditWorkspace.Type = esriWorkspaceType.esriLocalDatabaseWorkspace Then

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_mapEvents.FeatureClassChanged, AddressOf FeatureClassChanged
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_actViewEvents.ItemAdded, AddressOf ItemAdded
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_actViewEvents.ItemDeleted, AddressOf ItemRemoved


&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IceLineObjectClassEvents.OnChange, AddressOf LineChange
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IceLineObjectClassEvents.OnDelete, AddressOf LineChange

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IcePointObjectClassEvents.OnChange, AddressOf PointChange
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IcePointObjectClassEvents.OnDelete, AddressOf PointChange
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_AOIObjectClassEvents.OnDelete, AddressOf AOIDelete
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_AOIObjectClassEvents.OnCreate, AddressOf AOICreate

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DisableDockEditorWindows()
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; End If

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Catch ex As Exception
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Trace.WriteLine(ex)
&amp;nbsp;&amp;nbsp;&amp;nbsp; End Try
&amp;nbsp; End Sub&lt;/PRE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 18:17:34 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401014#M10696</guid>
      <dc:creator>AlexanderGray</dc:creator>
      <dc:date>2021-12-11T18:17:34Z</dc:date>
    </item>
    <item>
      <title>Re: Adding event handlers COM seperated from RCW</title>
      <link>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401015#M10697</link>
      <description>&lt;HTML&gt;&lt;HEAD&gt;&lt;/HEAD&gt;&lt;BODY&gt;&lt;SPAN&gt;I see two possibilities that would lead to the same problem I was having:&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;1)&amp;nbsp; AddHandler for one or more events is being called multiple times, but only removed once.&lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;2)&amp;nbsp; AddHandler is called once, but something happens causing StopEditing() to not be hit.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;SPAN&gt;In either case it might leave you with "orphaned" subscribers. &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;For #1 you can keep track of the number of times AddHandler is called, then loop to call RemoveHandler the same number of times.&amp;nbsp; &lt;/SPAN&gt;&lt;BR /&gt;&lt;SPAN&gt;For #2 you might try putting the RemoveHandlers in their own procedure where it can be called from StopEditing and the extension shutdown to make sure it happens.&lt;/SPAN&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BR /&gt;&lt;BLOCKQUOTE class="jive-quote"&gt;RemoveHandler is being called in the stop editing event.&lt;BR /&gt;&lt;BR /&gt;&lt;PRE class="lia-code-sample line-numbers language-none"&gt;
 Public Sub StopEditing(ByVal save As Boolean)
&amp;nbsp;&amp;nbsp;&amp;nbsp; Try

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; If m_isInSaveEdit = False AndAlso _
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; m_editor.EditWorkspace.Type = esriWorkspaceType.esriLocalDatabaseWorkspace Then

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_mapEvents.FeatureClassChanged, AddressOf FeatureClassChanged
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_actViewEvents.ItemAdded, AddressOf ItemAdded
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_actViewEvents.ItemDeleted, AddressOf ItemRemoved


&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IceLineObjectClassEvents.OnChange, AddressOf LineChange
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IceLineObjectClassEvents.OnDelete, AddressOf LineChange

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IcePointObjectClassEvents.OnChange, AddressOf PointChange
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_IcePointObjectClassEvents.OnDelete, AddressOf PointChange
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_AOIObjectClassEvents.OnDelete, AddressOf AOIDelete
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; RemoveHandler m_AOIObjectClassEvents.OnCreate, AddressOf AOICreate

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; DisableDockEditorWindows()
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; End If

&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Catch ex As Exception
&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp; Trace.WriteLine(ex)
&amp;nbsp;&amp;nbsp;&amp;nbsp; End Try
&amp;nbsp; End Sub&lt;/PRE&gt;&lt;/BLOCKQUOTE&gt;&lt;/BODY&gt;&lt;/HTML&gt;</description>
      <pubDate>Sat, 11 Dec 2021 18:17:37 GMT</pubDate>
      <guid>https://community.esri.com/t5/arcobjects-sdk-questions/adding-event-handlers-com-seperated-from-rcw/m-p/401015#M10697</guid>
      <dc:creator>JeffMatson</dc:creator>
      <dc:date>2021-12-11T18:17:37Z</dc:date>
    </item>
  </channel>
</rss>

