亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? maingengui.hs

?? HTK系列的
?? HS
?? 第 1 頁 / 共 5 頁
字號:
-- --------------------------------------------------------------------------- $Source: /repository/uni/htk/examples/gengui/MaingenGUI.hs,v $---- HTk - a GUI toolkit for Haskell  -  (c) Universitaet Bremen---- $Revision: 1.5 $ from $Date: 2002/05/30 15:00:16 $-- Last modification by $Author: ger $---- -----------------------------------------------------------------------module Main (main) whereimport HTkimport GenGUIimport Nameimport ReferenceVariablesimport Systemimport IOExtsimport DialogWinfoldref :: Ref (Maybe (Item Obj))foldref = unsafePerformIO (newRef Nothing)imgpathref :: Ref (Maybe FilePath)imgpathref =  unsafePerformIO (newRef Nothing){-# NOINLINE imgpathref #-}lastactiveref :: Ref Buttonlastactiveref = unsafePerformIO (newRef (unsafePerformIO                                           (newButton NONE []))){-# NOINLINE lastactiveref #-}imgref :: Ref (IO Image)imgref = unsafePerformIO (newRef folderImg){-# NOINLINE imgref #-}data Col = Red | Green | Blue | Yellow deriving Eqtype Obj = (Name, IO Image, MyObject)type Id = Intdata MyObject =    MyContainer Id  | MyColor Id Col  | MyImage Id (IO Image)  | MyTxt Id String  | MyNum Id IntgetID :: MyObject -> IdgetID (MyContainer id) = idgetID (MyColor id _) = idgetID (MyImage id _) = idgetID (MyTxt id _) = idgetID (MyNum id _) = idinstance Eq MyObject where  myobj1 == myobj2 = getID myobj1 == getID myobj2instance CItem Obj where  getIcon (_, ic, _) = ic  getName (nm, _, _) = return nminstance Eq Obj where  (_, _, myobj1) == (_, _, myobj2) = myobj1 == myobj2------------------------------------------ external adding of folders / items ------------------------------------------addNum :: IO Id -> GenGUI Obj -> String -> String -> IO ()addNum newID gui name ent = putStrLn "not yet implemented"addTxt :: IO Id -> GenGUI Obj -> String -> String -> IO ()addTxt newID gui name ent =  do    mpar <- getRef foldref    case mpar of      Just par ->        do          id <- newID          let nm = createName name              ic = txtImg              val = MyTxt id ent          addItem gui par (LeafItem (nm, ic, val) Nothing)          done      _ -> doneaddCol :: IO Id -> GenGUI Obj -> String -> String -> IO ()addCol newID gui name ent =  do    mpar <- getRef foldref     case mpar of      Just par ->         do          id <- newID          let nm = createName name              ic = case ent of "Red" -> redImg                               "Blue" -> blueImg                               "Green" -> greenImg                               "Yellow" -> yellowImg              val = MyColor id (case ent of "Red" -> Red                                            "Blue" -> Blue                                            "Green" -> Green                                            "Yellow" -> Yellow)          addItem gui par (LeafItem (nm, ic, val) Nothing)          done      _ -> done{-addImg :: String -> Maybe FilePath -> IO ()addImg nm mimgpath =  do    mpar <- getRef foldref    case mpar of      Just par ->        case mimgpath of          Just imgpath -> do                            let img = newImage [filename imgpath]                            pval <- newProp (toDyn img)                            pname <- newProp (createName nm)                            picon <- newProp imgImg                            addItem par                                    (LeafItem (MyObject pname picon pval))                            done          _ -> done      _ -> done-}{-addFolder :: String -> IO ()addFolder nm =  do    mpar <- getRef foldref    case mpar of      Just par ->        do          pval <- newProp (toDyn nm)          pname <- newProp (createName nm)          img <- getRef imgref          picon <- newProp img          addItem par (FolderItem (MyContainer pname picon pval) [])          done      _ -> done-}--------------------- example items ---------------------addExampleFolders :: IO Id -> GenGUI Obj -> IO ()addExampleFolders newID gui =  let mkNumItem :: IO Id -> String -> (Int, (Int, IO Image)) ->                   IO (NewItem Obj)      mkNumItem newID name (i, (num, ic)) =        do          id <- newID          let val = MyNum id num              nm = createName (name ++ show i)           return (LeafItem (nm, ic, val) Nothing)      addNumFolder :: IO Id -> GenGUI Obj -> Item Obj -> String ->                      IO Image -> String -> [(Int, IO Image)] -> Int ->                      IO ()      addNumFolder newID gui par name ic subnm vals_icons i =        do          let nm = createName (name ++ show i)          items <- mapM (mkNumItem newID subnm)                        (zip [1..(length vals_icons)] vals_icons)          id <- newID          addItem gui par (FolderItem (nm, ic, MyContainer id) items                                      Nothing)          done      mkTxtItem :: IO Id -> String -> (Int, (String, IO Image)) ->                   IO (NewItem Obj)      mkTxtItem newID name (i, (str, ic)) =        do          id <- newID          let val = MyTxt id str              nm = createName (name ++ show i)          return (LeafItem (nm, ic, val) Nothing)      addTxtFolder :: IO Id -> GenGUI Obj -> Item Obj -> String ->                      IO Image -> String -> [(String, IO Image)] -> Int ->                      IO ()      addTxtFolder newID gui par name ic subnm vals_icons i =        do          let nm = createName (name ++ show i)          items <- mapM (mkTxtItem newID subnm)                        (zip [1..(length vals_icons)] vals_icons)          id <- newID          addItem gui par (FolderItem (nm, ic, MyContainer id) items                                      Nothing)          done      mkImgItem :: IO Id -> String -> (Int, (IO Image, IO Image)) ->                   IO (NewItem Obj)      mkImgItem newID name (i, (img, ic)) =        do          id <- newID          let val = MyImage id img              nm = createName (name ++ show i)          return (LeafItem (nm, ic, val) Nothing)      addImgFolder :: IO Id -> GenGUI Obj -> Item Obj -> String ->                      IO Image -> String -> [(IO Image, IO Image)] ->                      Int -> IO ()      addImgFolder newID gui par name ic subnm vals_icons i =        do          let nm = createName (name ++ show i)          items <- mapM (mkImgItem newID subnm)                        (zip [1..(length vals_icons)] vals_icons)          id <- newID          addItem gui par (FolderItem (nm, ic, MyContainer id) items                                      Nothing)          done      mkColItem :: IO Id -> String -> (Int, (Col, IO Image)) ->                   IO (NewItem Obj)      mkColItem newID name (i, (col, ic)) =        do          id <- newID          let val = MyColor id col              nm = createName (name ++ show i)          return (LeafItem (nm, ic, val) Nothing)      addColFolder :: IO Id -> GenGUI Obj -> Item Obj -> String ->                      IO Image -> String -> [(Col, IO Image)] -> Int ->                      IO ()      addColFolder newID gui par name ic subnm vals_icons i =        do          let nm = createName (name ++ show i)          items <- mapM (mkColItem newID subnm)                        (zip [1..(length vals_icons)] vals_icons)          id <- newID          addItem gui par (FolderItem (nm, ic, MyContainer id) items

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91网站最新地址| 久久精品免费观看| 97久久久精品综合88久久| 国产精品成人免费| 91黄色小视频| 日韩电影在线一区二区三区| 日韩一区二区三区三四区视频在线观看 | 91精品国产综合久久久久久久 | 亚洲欧洲一区二区三区| 9i看片成人免费高清| 亚洲国产日韩在线一区模特| 欧美视频一二三区| 蜜桃av一区二区三区电影| 国产亚洲女人久久久久毛片| 色屁屁一区二区| 视频一区二区中文字幕| 久久婷婷久久一区二区三区| 99re6这里只有精品视频在线观看| 亚洲综合免费观看高清完整版 | 色先锋久久av资源部| 偷窥国产亚洲免费视频 | 国产欧美日韩精品一区| 一本久久a久久精品亚洲| 日韩高清欧美激情| 国产日韩高清在线| 欧美三级日本三级少妇99| 蜜桃av噜噜一区二区三区小说| 日本一区二区三区四区在线视频 | 欧美剧情片在线观看| 国产乱人伦偷精品视频免下载| 最新国产成人在线观看| 91.麻豆视频| 9l国产精品久久久久麻豆| 热久久久久久久| 亚洲丝袜精品丝袜在线| 精品嫩草影院久久| 91国在线观看| 成人激情免费电影网址| 男女男精品视频网| 一区二区三区中文字幕精品精品| 日韩精品在线网站| 日本久久一区二区三区| 高清在线观看日韩| 日韩黄色小视频| 亚洲另类春色国产| 久久精品人人做| 欧美tickling挠脚心丨vk| 欧美亚洲免费在线一区| aaa亚洲精品一二三区| 美女视频一区二区| 香蕉久久夜色精品国产使用方法 | 不卡av免费在线观看| 日本vs亚洲vs韩国一区三区二区| 亚洲色图.com| 国产精品麻豆99久久久久久| 精品福利一二区| 69av一区二区三区| 欧美日韩一区久久| 色哟哟一区二区| www.欧美.com| 国产激情视频一区二区在线观看| 美女精品一区二区| 日韩福利电影在线| 亚洲国产毛片aaaaa无费看 | 视频一区视频二区中文字幕| 亚洲九九爱视频| 中文字幕亚洲在| 国产精品麻豆网站| 中文字幕一区二| 国产精品久久久久三级| 国产精品女主播av| 久久精品亚洲精品国产欧美| 亚洲精品一区二区三区四区高清| 日韩一区二区三区四区| 日韩视频在线你懂得| 欧美精品久久久久久久久老牛影院| 91黄色激情网站| 欧美性xxxxxx少妇| 欧美三区在线观看| 欧美日韩的一区二区| 91精品在线免费| 制服丝袜成人动漫| 日韩精品一区二区三区在线播放| 欧美一卡二卡在线观看| 日韩欧美国产1| 精品999在线播放| 国产欧美视频在线观看| 欧美国产欧美亚州国产日韩mv天天看完整| 精品91自产拍在线观看一区| www国产成人| 国产精品三级av| 亚洲精品五月天| 午夜精品一区二区三区免费视频| 五月天国产精品| 精品一区二区在线视频| 国产裸体歌舞团一区二区| 成人福利视频在线看| 在线观看视频一区二区欧美日韩| 欧美性生活大片视频| 日韩免费一区二区| 日本一区免费视频| 亚洲人快播电影网| 爽爽淫人综合网网站| 久久精品久久综合| 成人丝袜18视频在线观看| 一本色道久久综合亚洲aⅴ蜜桃| 91高清视频免费看| 日韩精品最新网址| 亚洲欧美视频在线观看| 蜜桃在线一区二区三区| 成人av片在线观看| 在线综合+亚洲+欧美中文字幕| 精品久久人人做人人爰| 日韩毛片高清在线播放| 日韩专区一卡二卡| 成人性生交大合| 欧美日韩亚洲综合在线 | 国产福利精品一区| 欧洲精品一区二区| 久久精品人人做人人爽人人| 亚洲电影一级黄| 国产成人综合在线| 欧美巨大另类极品videosbest | 91黄色激情网站| 国产香蕉久久精品综合网| 亚洲第一成年网| www.色综合.com| 精品福利视频一区二区三区| 亚洲最新视频在线观看| 国产成人av自拍| 日韩视频123| 亚洲一区二区三区免费视频| 国产高清不卡一区二区| 日韩一区二区精品葵司在线| 一区二区在线免费观看| 国产伦精品一区二区三区视频青涩 | 亚洲黄色免费网站| 风流少妇一区二区| 日韩欧美aaaaaa| 日精品一区二区| 在线免费观看视频一区| 亚洲国产精品av| 国内精品久久久久影院薰衣草| 欧美亚洲国产一区在线观看网站| 国产精品网站一区| 国产一区二区三区四区五区入口 | 寂寞少妇一区二区三区| 欧美日本在线一区| 亚洲国产综合色| 91麻豆精品秘密| 国产精品嫩草影院com| 国产一区福利在线| 精品国产电影一区二区| 青椒成人免费视频| 91精品啪在线观看国产60岁| 性感美女极品91精品| 欧美中文字幕久久| 亚洲一区二区三区激情| 91免费国产在线观看| 亚洲日本在线看| 色综合久久中文综合久久97| 国产精品久久久久久久久久久免费看| 国产老妇另类xxxxx| 精品国产一区二区三区四区四| 日本怡春院一区二区| 5858s免费视频成人| 日韩黄色一级片| 日韩免费在线观看| 黄色资源网久久资源365| 亚洲精品一区二区三区蜜桃下载 | 亚洲女同一区二区| 99国产精品久久久久| 最新久久zyz资源站| 色综合久久88色综合天天免费| 亚洲少妇30p| 欧美色大人视频| 丝袜脚交一区二区| 日韩精品综合一本久道在线视频| 蜜臀av性久久久久蜜臀aⅴ四虎 | 国产日韩欧美在线一区| 国产精品99久久久久久久女警| 欧美一二三区在线观看| 韩国女主播成人在线| 国产日韩欧美一区二区三区综合| 国产成人激情av| 亚洲另类一区二区| 日韩小视频在线观看专区| 国产一区二区美女| 国产精品免费丝袜| 欧美亚洲国产一卡| 六月婷婷色综合| 国产精品三级久久久久三级| 在线亚洲+欧美+日本专区| 天天亚洲美女在线视频| 久久久久一区二区三区四区| 成人一区二区三区视频| 亚洲欧美一区二区三区久本道91| 欧美揉bbbbb揉bbbbb| 国产精品伊人色| 日韩一区在线看|