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

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

?? gdflipeffect.cs.svn-base

?? 這是一個windows mobile程序能夠實現窗體運貨效果非常不錯
?? SVN-BASE
字號:
using System;
using System.Collections.Generic;
using System.Text;
using System.Windows.Forms;
using Aspecto.GapiDrawNet;
using System.Drawing;
using System.Collections;

namespace Aspecto.FlowFX
{
    [Obsolete("Use PocketFrog (Pf) Effects")]
    public class GdFlipEffect : GapiDrawEffect
    {
        public override void Swap(FlowForm lastForm, FlowForm nextForm, bool opening)
        {
            base.Swap(lastForm, nextForm, opening);

            GapiSurface surface = TakeScreenShot(-lastForm.Bounds.Y);

            GapiSurface scaleBuffer = new GapiSurface(surface.GapiDraw);
            scaleBuffer.CreateSurface(Screen.PrimaryScreen.Bounds.Width, Screen.PrimaryScreen.Bounds.Height);

            int halfwidth = surface.Width / 2;
            int frame = 1; // chose 1 instead of 0 to save it drawing the current view again
            gapiDisplay.BackBuffer.SetClipper(0, 0, surface.Width, surface.Height);
            while (frame <  halfwidth )
            {
                gapiDisplay.BackBuffer.FillRect(0);
                if(opening)
                    FlipOut(frame, scaleBuffer, surface, gapiDisplay.BackBuffer);
                else
                    FlipIn(halfwidth - frame - 1, scaleBuffer, surface, gapiDisplay.BackBuffer);
                gapiDisplay.Flip();
                frame += Math.Max(1, (int)(Math.Abs(frame) * 0.4));
            }

            //clear the form so it looks like a blank one
            GDRect gr;
            if (opening)
                gr = new GDRect(0, nextForm.Bounds.Y, surface.Width, nextForm.Bounds.Y + nextForm.Height);
            else
                gr = new GDRect(0, lastForm.Bounds.Y, surface.Width, lastForm.Bounds.Y + lastForm.Height);

            surface.FillRect(gr, GapiUtility.RGB(nextForm.BackColor));

            halfwidth = surface.Width / 2;
            frame = 1;

            while (frame < halfwidth)
            {
                gapiDisplay.BackBuffer.FillRect(0);
                if(opening)
                    FlipIn(frame, scaleBuffer, surface, gapiDisplay.BackBuffer);
                else
                    FlipOut(halfwidth - frame - 1, scaleBuffer, surface, gapiDisplay.BackBuffer);
                gapiDisplay.Flip();
                frame += Math.Max(1, (int)(Math.Abs(halfwidth - frame) * 0.4));
            }

            surface.Dispose();
            scaleBuffer.Dispose();

            //needed on pocket pc everytime. Needed on smartphone to clear the gapidraw evaluation logo when that appears. but ptr 0
            DrawStartBar();
        }

        private void FlipIn(int frame, GapiSurface scaleBuffer, GapiSurface surface, GapiSurface buffer)
        {
            int halfwidth = surface.Width / 2;

            GDRect rect_dest;
            GDRect rect_src;
            GDBLTFX bob = new GDBLTFX();

            Point[] staticTopPath = lineSimple(halfwidth, 0, 0, 0); // moves left along top from middle
            Point[] staticTopLeftPath = lineSimple(halfwidth, 60, surface.Width, 0); // moves from top middle to top right

            //then we draw a new line connecting them per frame/ starting with line from top left, to top right

            if (frame < halfwidth)
            {
                Point[] currLine = lineSimple(staticTopLeftPath[frame].X, staticTopLeftPath[frame].Y, staticTopPath[frame].X, staticTopPath[frame].Y);

                rect_dest = new GDRect(0, 0, frame * 2, surface.Height); // shrinks by 2 
                rect_src = new GDRect(0, 0, surface.Width, surface.Height);

                scaleBuffer.Blt(ref rect_dest, surface, ref rect_src, 0, ref bob);

                for (int i = 0; i < currLine.Length - 1; i++)
                {
                    rect_dest = new GDRect(currLine[i].X, currLine[i].Y, currLine[i].X + 1, surface.Height - currLine[i].Y);
                    rect_src = new GDRect(currLine.Length - i - 1, 0, currLine.Length - i, surface.Height);
                    buffer.Blt(ref rect_dest, scaleBuffer, ref rect_src, 0, ref bob);
                }
            }

        }


        private void FlipOut(int frame,GapiSurface scaleBuffer,GapiSurface surface, GapiSurface buffer)
        {
            int halfwidth = surface.Width / 2;

            GDRect rect_dest;
            GDRect rect_src;
            GDBLTFX bob = new GDBLTFX();

            Point[] staticTopPath = lineSimple(surface.Width, 0, 0, 0); // moves left along top
            Point[] staticTopLeftPath = lineSimple(0, 0, halfwidth, 60); // moves from top left, to top middle

            //then we draw a new line connecting them per frame/ starting with line from top left, to top right

            if (frame < halfwidth)
            {
                Point[] currLine = lineSimple(staticTopLeftPath[frame].X, staticTopLeftPath[frame].Y, staticTopPath[frame].X, staticTopPath[frame].Y);

                rect_dest = new GDRect(0, 0, surface.Width - frame * 2, surface.Height); // shrinks by 2 
                rect_src = new GDRect(0, 0, surface.Width, surface.Height);

                scaleBuffer.Blt(ref rect_dest, surface, ref rect_src, 0, ref bob);

                for (int i = 0; i < currLine.Length - 1; i++)
                {
                    rect_dest = new GDRect(currLine[i].X, currLine[i].Y, currLine[i].X + 1, surface.Height - currLine[i].Y);
                    rect_src = new GDRect(i, 0, i + 1, surface.Height);
                    buffer.Blt(ref rect_dest, scaleBuffer, ref rect_src, 0, ref bob);
                }
            }
        }

        public Point[] lineSimple(int x0, int y0, int x1, int y1)
        {
            ArrayList points = new ArrayList();
            int dx = x1 - x0;
            int dy = y1 - y0;

            points.Add(new Point(x0, y0));
            if (dx != 0)
            {
                float m = (float)dy / (float)dx;
                float b = y0 - m * x0;
                dx = (x1 > x0) ? 1 : -1;
                while (x0 != x1)
                {
                    x0 += dx;
                    y0 = (int)Math.Round(m * x0 + b);
                    points.Add(new Point(x0, y0));
                }
            }
            return (Point[])points.ToArray(typeof(Point));
        }
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产网站一区二区| 欧美国产激情一区二区三区蜜月 | 亚洲国产经典视频| 91精品欧美一区二区三区综合在 | 国产成人自拍网| 久久99精品久久久久婷婷| 日韩中文字幕91| 丝袜亚洲另类丝袜在线| 老司机免费视频一区二区| 久久99久久99精品免视看婷婷| 午夜精品久久久久久久久久 | 国产精品电影院| 国产精品久久久久久一区二区三区| 久久这里都是精品| 欧美国产精品专区| 亚洲一区二区五区| 日韩影院在线观看| 国产精品一区二区三区四区| 国产成人在线网站| 欧美伊人久久久久久久久影院| 欧美三级视频在线观看| 日韩精品在线网站| 国产精品水嫩水嫩| 亚洲国产一区二区三区 | 成人教育av在线| 99久久精品国产毛片| 欧美色成人综合| 精品福利在线导航| 一区二区三区在线视频免费观看| 亚洲成av人片在线| 国产精华液一区二区三区| 色综合久久综合| 精品国产一区二区三区四区四| 日本一区二区久久| 午夜国产精品一区| 风间由美一区二区三区在线观看| 91麻豆视频网站| 精品国产乱码久久久久久浪潮| 国产精品动漫网站| 久久精品国产秦先生| 91视频在线观看免费| 日韩精品一区二区在线| 1区2区3区精品视频| 免费观看成人鲁鲁鲁鲁鲁视频| www.综合网.com| 精品久久久久久久久久久院品网| 中文字幕一区二区三区蜜月| 捆绑变态av一区二区三区| 91免费观看视频| 久久久青草青青国产亚洲免观| 亚洲国产日韩综合久久精品| 成人午夜视频福利| 制服丝袜一区二区三区| 亚洲图片你懂的| 国产精品一级在线| 日韩一区二区免费视频| 亚洲国产日韩a在线播放性色| 99国产精品久久久久久久久久| 欧美成人猛片aaaaaaa| 午夜精品视频一区| 欧美吻胸吃奶大尺度电影| 国产精品日韩成人| 成人福利视频在线| 欧美国产日韩一二三区| 丁香五精品蜜臀久久久久99网站| 精品国产一区二区三区久久影院 | 免费不卡在线视频| 欧美日韩国产综合久久| 亚洲综合自拍偷拍| 91福利社在线观看| 自拍偷在线精品自拍偷无码专区 | 欧美日韩在线不卡| 亚洲综合999| 在线观看免费一区| 有码一区二区三区| 91福利资源站| 亚洲国产精品一区二区久久| 欧美在线免费播放| 日韩福利视频网| 日韩色在线观看| 青青青伊人色综合久久| 欧美mv和日韩mv国产网站| 精品无人码麻豆乱码1区2区 | 成人午夜又粗又硬又大| 国产精品视频九色porn| 一本色道久久综合精品竹菊| 亚洲一区二区三区激情| 在线电影国产精品| 蜜桃91丨九色丨蝌蚪91桃色| 久久影院午夜片一区| 国产a级毛片一区| 亚洲视频狠狠干| 欧美乱熟臀69xxxxxx| 蜜臀av一区二区在线观看 | 91麻豆国产福利精品| 亚洲va欧美va天堂v国产综合| 欧美高清视频一二三区 | 国产成人三级在线观看| 中文字幕中文字幕一区二区| 99精品视频在线观看免费| 亚洲一二三四在线| 日韩精品中文字幕一区| k8久久久一区二区三区| 日韩av一区二| 国产亚洲一区二区三区在线观看| youjizz久久| 日韩福利电影在线| 国产欧美精品在线观看| 欧美日韩亚洲综合| 国产成人精品一区二| 亚洲综合一区二区三区| 久久午夜免费电影| 在线观看国产一区二区| 精品一区二区在线免费观看| 亚洲丝袜精品丝袜在线| 日韩精品自拍偷拍| 欧美曰成人黄网| 国产精一品亚洲二区在线视频| 亚洲精品国产精华液| 国产亚洲1区2区3区| 欧美区视频在线观看| 不卡一区二区在线| 麻豆91在线播放| 一区二区三国产精华液| 久久久久国产精品麻豆 | 久久国产三级精品| 亚洲人成精品久久久久久| 精品国偷自产国产一区| 欧美三级午夜理伦三级中视频| 成人18视频在线播放| 国产一区高清在线| 青青草成人在线观看| 亚洲视频 欧洲视频| 国产丝袜欧美中文另类| 91精品久久久久久久久99蜜臂| 在线观看日韩电影| 91视频免费播放| 国产91精品欧美| 激情六月婷婷久久| 蜜桃精品视频在线观看| 日韩电影免费在线| 午夜精品爽啪视频| 亚洲国产欧美另类丝袜| 中文字幕 久热精品 视频在线 | 国产mv日韩mv欧美| 国内精品第一页| 精品影视av免费| 久久99精品国产91久久来源| 日韩1区2区3区| 日韩成人av影视| 日韩—二三区免费观看av| 日欧美一区二区| 亚洲成人免费av| 日韩高清一区在线| 美女网站色91| 美女视频网站久久| 国内一区二区在线| 国产福利一区二区三区视频在线| 激情综合色综合久久| 国产一区欧美日韩| 成人h动漫精品| 99久久精品国产一区| 91激情在线视频| 欧美日韩国产在线观看| 欧美一二三四区在线| 欧美大片国产精品| 久久久91精品国产一区二区精品| 国产欧美视频一区二区三区| 中文av一区特黄| 亚洲麻豆国产自偷在线| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美精品乱码久久久久久| 制服丝袜亚洲播放| www激情久久| 综合久久久久久久| 日韩福利电影在线| 国产成人免费在线| 一本一道久久a久久精品 | 久久国产欧美日韩精品| 粉嫩aⅴ一区二区三区四区| 91丝袜国产在线播放| 欧美浪妇xxxx高跟鞋交| 久久久亚洲欧洲日产国码αv| 国产免费观看久久| 亚洲成人av在线电影| 国模少妇一区二区三区| 91麻豆高清视频| 精品日韩一区二区三区免费视频| 中文字幕一区二区三| 美洲天堂一区二卡三卡四卡视频| 丰满少妇在线播放bd日韩电影| 欧美三级日韩三级| 国产清纯白嫩初高生在线观看91 | 日韩精品免费专区| 国产大片一区二区| 欧美日本国产一区| 国产精品五月天| 日本在线观看不卡视频| 北岛玲一区二区三区四区| 欧美一级久久久|