Fortran Coder

查看: 2406|回复: 5
打印 上一主题 下一主题

[绘图界面库] fortran读写剪贴板

[复制链接]

712

帖子

4

主题

0

精华

大师

农村外出务工人员

F 币
607 元
贡献
311 点

新人勋章爱心勋章水王勋章元老勋章热心勋章

楼主
发表于 2022-4-12 12:02:31 | 显示全部楼层
本帖最后由 楚香饭 于 2022-4-12 12:15 编辑

这个以前恰好写过。不过只能读取粘贴板里的纯文本。对于 图像,文件,其他数据类型没有用。

[Fortran] 纯文本查看 复制代码
Program www_fcode_cn
  implicit none
  character(len=100) :: c
  integer :: j
  j = getClipboardText(c)
  if(j>0) write(*,'(a)') trim(c)

contains

  Integer Function getClipboardText( text ) result( length )
    use , intrinsic :: ISO_C_Binding
    use user32
    use kernel32
    Character(len=*) :: text
    integer     :: hData , j
    type(c_ptr) :: cp
    character(len=len(text)) , pointer :: p
    length = 0
    text   = ""
    if ( 0==OpenClipboard(0) ) return
    hData = GetClipboardData(CF_TEXT)
    if ( hData /= 0 ) then
      call c_f_pointer(transfer(GlobalLock(hData),cp),p)
      length = index(p,c_null_char)-1
      if(length<0) length = len(text)
      text = p(:length)
      j = GlobalUnlock(hData)
    end if
    j = CloseClipboard()
  End Function getClipboardText

End Program www_fcode_cn

您需要登录后才可以回帖 登录 | 极速注册

本版积分规则

捐赠本站|Archiver|关于我们 About Us|小黑屋|Fcode ( 京ICP备18005632-2号 )

GMT+8, 2024-5-6 20:34

Powered by Tencent X3.4

© 2013-2024 Tencent

快速回复 返回顶部 返回列表