2010年3月11日

由于此博客不让发表任何关于政治的内容,故关闭之.

posted @ 2010-03-11 11:59 侠客西风 阅读(230) | 评论 (0)编辑 收藏

2009年11月4日

写在前面:
下面的这段代码可以直接在LuaForWindows的Scite中运行,这个函数的是仿照LuaForWindows自带教程中的那个创建iup菜单的函数写的,改进的一个地方是可以用一个消息处理回调函数来响应多个菜单项,然后再统一dispatch,个人认为写法上比直接把进行实际处理的函数写在菜单定义表前面美观一些,
说来惭愧,就改写的这个小函数,也是调试了一大会才弄好的,刚接触Lua的时候,就是不熟练啊...(废话? !)


  require 'cdlua'
  require 'iuplua'
  require 'iupluacd'

  function event_handler_g (self)
      iup.Message(self.title,'dispatch message')
  end

  function event_handler1 (self)
      iup.Message(self.title,'event 1 dispatch message')
  end
  function event_handler2 (self)
      iup.Message(self.title,'event 2 dispatch message')
  end
  function event_handler3 (self)
      iup.Message(self.title,'event 3 dispatch message')
  end

  my_menu_test =
  {
      nil,'M1',{event_handler_g,'M11','M12','M13',{event_handler3,'M21','M22',},},'M2',{event_handler_g,'M22','M23',},
  }

  function my_create_menu2(menu_define_table)

      local items={}

      for k,v in pairs(menu_define_table) do
          if type(v) == 'function' or type(v)=='nil' then
  --~             event_handler=v
              ___my_library__global__event_handler=v
          end

          if type(v) =='string' then
  --~             local item=iup.item{title=v,action=event_handler}
              local item=iup.item{title=v,action=___my_library__global__event_handler}
              table.insert(items,item)
          end

          if type(v) =='table' then
              m1_menu_title=table.remove(items)
              local item=iup.submenu {my_create_menu2(v),title=tostring(m1_menu_title.title)}
              table.insert(items,item)
          end
      end--end of for
      return iup.menu(items)
  end

  my_main_frame=iup.frame
      {
          iup.canvas
          {
              cursor='CROSS',
              scrollbar='VERTICAL',
              posy=0.0,
              ymax=0.8,
          }
      }

  dlg = iup.dialog
  {
      my_main_frame,
      size="HALFxHALF",
      title="finally I got the expected result",
      menu=my_create_menu2(my_menu_test),
  }

  dlg:showxy(iup.CENTER,iup.CENTER)

  if (not iup.MainLoopLevel or iup.MainLoopLevel()==0) then
    iup.MainLoop()
  end

后记,已经发布在了我的粘贴里,不过它上面说是根据时间访问来删除旧帖子的,我怕时间久了这点记忆再没有了

posted @ 2009-11-04 17:14 侠客西风 阅读(2938) | 评论 (7)编辑 收藏

2009年10月10日

#if(_WIN32_WINNT>=0x0501)
#defineWS_EX_COMPOSITED       0x02000000L
#endif/* _WIN32_WINNT >= 0x0501 */

准备把语言写的精炼一些,这样节省作者和读者的时间.

相关资料:这里不再摘录,请自行查看msdn

问题描述:在窗口使用了WS_EX_COMPOSITED 风格后,绘图就会变得不正常了,原因是xp特有的双缓冲绘图机制(可能后续版本Windows没有,参考WS_EX_COMPOSITED 风格的定义,在msdn里)的bug(应该算是一个系统的bug)

问题1:GetDC系绘图API不可用,表现为画出来的内容会被立即刷新掉,这个应该不算bug,

解决方法:

把所有的绘图操作放到WM_ERASEBKGND和WM_PAINT消息处理函数里,这个应该满足大多数情况下的要求,特殊情况可以使用加bool标志的方法在这两个函数里面绘图,然后在需要使用GetDC的地方设置bool标志

问题2:即使在上述的两个消息handler里面,GDI+绘图操作还是无法正常工作,而同一个消息处理函数里面的GDI函数就可以工作,这个问题msdn论坛上有人问过,也给出了解决方案,我试了一下果然ok,这个问题应该是GDI+函数内部的问题,具体原因不明

解决方法:

使用内存dc绘图.创建内存兼容dc,然后把这个内存兼容dc传给GDI+,绘图完成后,bitblt到原dc

至此,xp下的系统双缓冲窗口可以正常工作了,也使用GDI+来绘图了.

本文为侠客西风原创,请尊重别人劳动成果,如果转载引用请保留作者出处,谢谢合作.

posted @ 2009-10-10 17:53 侠客西风 阅读(1816) | 评论 (0)编辑 收藏

仅列出标题