有些人向我指出了 wxCore 中的函数,这样我就可以找到一个可行的解决方案。
在原始示例中进行绘图的函数是:
onPaint vbitmap dc viewArea
= do mbBitmap <- get vbitmap value
case mbBitmap of
Nothing -> return ()
Just bm -> drawBitmap dc bm pointZero False []
Run Code Online (Sandbox Code Playgroud)
使用dcSetUserScalewxCore,我可以修改它以按这种方式缩放:
( sw 是滚动窗口)
onPaint sw img dc viewArea = do
mimg <- get img value
case mimg of
Nothing -> return ()
Just bm -> do
bsize <- get bm size
vsize <- get sw size
let scale = calcScale bsize vsize
dcSetUserScale dc scale scale
drawBitmap dc bm pointZero False []
calcScale :: Size -> Size -> Double
calcScale (Size bw bh) (Size vw vh) = min scalew scaleh
where scalew = fromIntegral vw / fromIntegral bw
scaleh = fromIntegral vh / fromIntegral bh
Run Code Online (Sandbox Code Playgroud)