sketchucation logo sketchucation
    • 登入
    Oops, your profile's looking a bit empty! To help us tailor your experience, please fill in key details like your SketchUp version, skill level, operating system, and more. Update and save your info on your profile page today!
    🔌 Smart Spline | Fluid way to handle splines for furniture design and complex structures. Download

    State of Observers — 28 February 2010

    已排程 已置頂 已鎖定 已移動 Developers' Forum
    38 貼文 12 Posters 17.6k 瀏覽 12 Watching
    正在載入更多貼文
    • 從舊到新
    • 從新到舊
    • 最多點贊
    回覆
    • 在新貼文中回覆
    登入後回覆
    此主題已被刪除。只有擁有主題管理權限的使用者可以查看。
    • thomthomT 離線
      thomthom
      最後由 編輯

      InstanceObserver.onClose does not trigger - at least not under SU7.1.

      Thomas Thomassen — SketchUp Monkey & Coding addict
      List of my plugins and link to the CookieWare fund

      1 條回覆 最後回覆 回覆 引用 0
      • K 離線
        kwalkerman
        最後由 編輯

        EntityObserver - (and possibly others)

        it seems that OnEraseEntity is activated after onChangeEntity, which means that if the entity is erased, it can cause bugs for whatever you are trying to do with OnChangeEntity. If OnEraseEntity were activated first, you could create a simple boolean value:

        def initialize
        @still_here = true
        end

        def OnEraseEntity(entity)

        whatever you want to do...

        @still_here = false
        end

        def OnChangeEntity(entity)
        if (still_here)

        whatever you want to do...

        end
        end

        This is a problem because the entity seems to be erased before OnChangeEntity is called, which means that doing something to the entity gives errors, but your observer doesn't know it until it gets through OnChangeEntity to OnEraseEntity.

        --
        Karen

        1 條回覆 最後回覆 回覆 引用 0
        • thomthomT 離線
          thomthom
          最後由 編輯

          @kwalkerman said:

          This is a problem because the entity seems to be erased before OnChangeEntity is called, which means that doing something to the entity gives errors, but your observer doesn't know it until it gets through OnChangeEntity to OnEraseEntity.

          Yea - the Entity and Entities observers aren't easy to deal with. 😞

          Thomas Thomassen — SketchUp Monkey & Coding addict
          List of my plugins and link to the CookieWare fund

          1 條回覆 最後回覆 回覆 引用 0
          • J 離線
            Jernej Vidmar
            最後由 編輯

            Hi guys,

            seems like we have found new observer problem (MacOSX + SketchUp8). When InstanceObserver is attached to the Group and SketchUp is then exited, bugsplat window appears. If the model is saved before exiting SketchUp, no bugsplat window appears.

            class TestObserver <  Sketchup;;InstanceObserver
            	def onOpen(entity)
            		p 'on called'
            	end
            
            	def onClose(entity)
            		p 'onClose called'
            	end
            end
            # Select a Skethcup Group and call this method
            # so the observer will be attached to the Group
            def attach_observer
            	group = Sketchup.active_model.selection[0]
            	group.add_observer(TestObserver.new)
            end
            

            Can anyone please confirm that?

            It seems to be MAC OS X + SketchUp 8 specific problem, Windows version works OK, and SU 7 on Mac OS X too.

            Cheers,
            N78

            1 條回覆 最後回覆 回覆 引用 0
            • thomthomT 離線
              thomthom
              最後由 編輯

              I've not gotten around to test the InstanceObserver - but I'll see if I can test it this weekend.

              Thomas Thomassen — SketchUp Monkey & Coding addict
              List of my plugins and link to the CookieWare fund

              1 條回覆 最後回覆 回覆 引用 0
              • AdamBA 離線
                AdamB
                最後由 編輯

                Yes, I can confirm its a repeatable bug on Mac OSX SketchUp 8.

                I've logged a very grumpy bug report with Google.

                Useful to know you can stop the crash by saving before exiting, but I am disappointed a bug like this could be missed. I know software has bugs in it etc, but this seems like any basic regression testing / smoke testing would flush this one out.

                Developer of LightUp Click for website

                1 條回覆 最後回覆 回覆 引用 0
                • S 離線
                  spring.freediver
                  最後由 編輯

                  Does the View.remove_observer method work in SU7.1?

                  I have a tool that needs to turn a ViewObserver on and off.

                  In tool methods that receive a view argument:
                  I use "@observer = view.add_observer(MyViewObserver.new)" to turn it on;
                  and "view.remove_observer(@observer)" to turn it off.

                  view.remove_observer returns false, and the observer is not removed.

                  I tried changing @observer to a class variable (@@observer), and it still did not work.

                  Any ideas?

                  1 條回覆 最後回覆 回覆 引用 0
                  • thomthomT 離線
                    thomthom
                    最後由 編輯

                    hm... I have not tried to remove observers from view objects...

                    btw - I am compiling a new observer list: http://forums.sketchucation.com/viewtopic.php?f=180&t=30793
                    If you find new information not included in the list - can you please let me know so I can update the list?

                    Thomas Thomassen — SketchUp Monkey & Coding addict
                    List of my plugins and link to the CookieWare fund

                    1 條回覆 最後回覆 回覆 引用 0
                    • thomthomT 離線
                      thomthom
                      最後由 編輯

                      @spring.freediver said:

                      Does the View.remove_observer method work in SU7.1?

                      I have a tool that needs to turn a ViewObserver on and off.

                      In tool methods that receive a view argument:
                      I use "@observer = view.add_observer(MyViewObserver.new)" to turn it on;
                      and "view.remove_observer(@observer)" to turn it off.

                      view.remove_observer returns false, and the observer is not removed.

                      I tried changing @observer to a class variable (@@observer), and it still did not work.

                      Any ideas?

                      Hang on... aren't you suppose to do it like this:
                      @observer = MyViewObserver.new view.add_observer(@observer)
                      ...
                      view.remove_observer(@observer)

                      ❓

                      Thomas Thomassen — SketchUp Monkey & Coding addict
                      List of my plugins and link to the CookieWare fund

                      1 條回覆 最後回覆 回覆 引用 0
                      • thomthomT 離線
                        thomthom
                        最後由 編輯

                        Yea - pretty sure so - because .add_observer also returns true/false . You need to keep a reference to the actual observer instance.

                        Thomas Thomassen — SketchUp Monkey & Coding addict
                        List of my plugins and link to the CookieWare fund

                        1 條回覆 最後回覆 回覆 引用 0
                        • AdamBA 離線
                          AdamB
                          最後由 編輯

                          @adamb said:

                          Yes, I can confirm its a repeatable bug on Mac OSX SketchUp 8.

                          I've logged a very grumpy bug report with Google.

                          Useful to know you can stop the crash by saving before exiting, but I am disappointed a bug like this could be missed. I know software has bugs in it etc, but this seems like any basic regression testing / smoke testing would flush this one out.

                          After I'm done with a Tool, I always done .pop_tool rather than .select_tool(nil) because it seems less presumptuous. ie restore what the user was doing before rather than cancel their previous selection.

                          However, Gaieus found out a problem/conflict with Jim Toolbar Organizer - long story short, I've switched to doing select_tool(nil) to avoid some weird race-condition with menu validation procs.

                          But it seems to have cured the crash on exit of SU8 on Mac when using Observers as well...

                          Adam

                          Developer of LightUp Click for website

                          1 條回覆 最後回覆 回覆 引用 0
                          • thomthomT 離線
                            thomthom
                            最後由 編輯

                            @adamb said:

                            After I'm done with a Tool, I always done .pop_tool rather than .select_tool(nil) because it seems less presumptuous. ie restore what the user was doing before rather than cancel their previous selection.

                            However, Gaieus found out a problem/conflict with Jim Toolbar Organizer - long story short, I've switched to doing select_tool(nil) to avoid some weird race-condition with menu validation procs.

                            But it seems to have cured the crash on exit of SU8 on Mac when using Observers as well...

                            what? damn! I rely on this feature for a plugin I'm making. what kind of race condition? you got a small example?
                            windows, osx?

                            Thomas Thomassen — SketchUp Monkey & Coding addict
                            List of my plugins and link to the CookieWare fund

                            1 條回覆 最後回覆 回覆 引用 0
                            • AdamBA 離線
                              AdamB
                              最後由 編輯

                              Ok, it appears to be that if you select_tool but then pop_tool, things can get fubar.

                              Mostly its benign - hence I got away with it - but with the LargeToolSet showing from Jim's Tool Organizer, the additional calls to the validation procs reveal the error. In that it is wrong to be selecting a tool then popping it, but you might hope SU would just ignore it.

                              The attached Ruby is a simple Tool that always performs pop_tool on keypress Escape.

                              It can be invoked either by calling "baddoit()" which starts it using select_tool, or by calling "evian()" which starts it using push_tool.


                              poptool.rb

                              Developer of LightUp Click for website

                              1 條回覆 最後回覆 回覆 引用 0
                              • thomthomT 離線
                                thomthom
                                最後由 編輯

                                Ok, so:

                                select_tool + pop_tool = fubar
                                but
                                push_tool + pop_tool = OK
                                ❓

                                Thought I'd tried pop_tool with select_tool before - without pop_tool doing anything. Thought it only worked after push_tool.

                                Thomas Thomassen — SketchUp Monkey & Coding addict
                                List of my plugins and link to the CookieWare fund

                                1 條回覆 最後回覆 回覆 引用 0
                                • AdamBA 離線
                                  AdamB
                                  最後由 編輯

                                  @thomthom said:

                                  Ok, so:

                                  select_tool + pop_tool = fubar
                                  but
                                  push_tool + pop_tool = OK
                                  ❓

                                  Thought I'd tried pop_tool with select_tool before - without pop_tool doing anything. Thought it only worked after push_tool.

                                  Not quite. select_tool + pop_tool = fubar isn't always terminal. Just apparently if there are really large toolbars around hence its never caused a problem for me in the past.

                                  Thomthom, can you get Jims' Organiser thing and see if you can repro this.

                                  Developer of LightUp Click for website

                                  1 條回覆 最後回覆 回覆 引用 0
                                  • thomthomT 離線
                                    thomthom
                                    最後由 編輯

                                    Size of toolbars matter?
                                    Or is it toolbars with validation procs?

                                    I have Jim's plugin installed on my Sy7 installation. Is it a particular pre-set toolbar that should be tested against?

                                    Thomas Thomassen — SketchUp Monkey & Coding addict
                                    List of my plugins and link to the CookieWare fund

                                    1 條回覆 最後回覆 回覆 引用 0
                                    • Dan RathbunD 離線
                                      Dan Rathbun
                                      最後由 編輯

                                      @adamb said:

                                      After I'm done with a Tool, I always done .pop_tool rather than .select_tool(nil) because it seems less presumptuous. ie restore what the user was doing before rather than cancel their previous selection.

                                      However, Gaieus found out a problem/conflict with Jim Toolbar Organizer - long story short, I've switched to doing select_tool(nil) to avoid some weird race-condition with menu validation procs.

                                      This issue is caused by the tool stack having no tool_id (or more precisely Tools.active_tool_id == 0 ).

                                      @unknownuser said:

                                      (http://code.google.com/apis/sketchup/docs/ourdoc/tools.html#active_tool_name)":u0sru3py]NOTE: Calling active_tool_name on an empty Tools collection might cause a crash. Before calling this method, it is important to check whether or not the Tools collection is empty. The Tools collection is empty if the method .active_tool_id returns zero.

                                      So always check if tools.active_tool_id==0 before using .pop_tool() or .active_tool_name()

                                      I'm not here much anymore.

                                      1 條回覆 最後回覆 回覆 引用 0
                                      • Dan RathbunD 離線
                                        Dan Rathbun
                                        最後由 編輯


                                        onQuit() callback


                                        I have noticed that on SU 8.0M1 (at least,) that Sketchup does not wait until the callback returns, before it closes all it's child and owned popups, and it's own app window and shuts down.

                                        You can still have code in an onQuit() callback running after all Sketchup's windows have closed. (You can try it with a messagebox.)

                                        I was trying to save size and position of some windows, but Sketchup closes all it's windows before my onQuit() callback code can use Win32API calls to grab the window sizes. I even 'leaned' the code out as much as possible, but still to no avail, ... my code writes empty size arrays into the registry.

                                        My next choice will be to try and use Ruby's built-in define_finalizer for one of my objects, perhaps the plugin module, or the observer object, .. and see if Sketchup will wait until the finalizer block returns.

                                        Did anyone notice this behaviour in SU 7.x ?

                                        I'm not here much anymore.

                                        1 條回覆 最後回覆 回覆 引用 0
                                        • Dan RathbunD 離線
                                          Dan Rathbun
                                          最後由 編輯

                                          Quick Question ...

                                          Seems I remember that AppObserver::onNewModel does not get called when Sketchup starts up.

                                          Is this generally true.. or specific to PC or Mac ?

                                          I see the API says that a command line skp file will not fire the onOpenModel() callback.

                                          I'm not here much anymore.

                                          1 條回覆 最後回覆 回覆 引用 0
                                          • thomthomT 離線
                                            thomthom
                                            最後由 編輯

                                            @dan rathbun said:

                                            Seems I remember that AppObserver::onNewModel does not get called when Sketchup starts up.

                                            Is this generally true.. or specific to PC or Mac ?

                                            Aye.

                                            Thomas Thomassen — SketchUp Monkey & Coding addict
                                            List of my plugins and link to the CookieWare fund

                                            1 條回覆 最後回覆 回覆 引用 0
                                            • 1
                                            • 2
                                            • 2 / 2
                                            • 第一個貼文
                                              最後的貼文
                                            Buy SketchPlus
                                            Buy SUbD
                                            Buy WrapR
                                            Buy eBook
                                            Buy Modelur
                                            Buy Vertex Tools
                                            Buy SketchCuisine
                                            Buy FormFonts

                                            Advertisement