• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Tauruser

            Enjoy Every Day
            posts - 34, comments - 95, trackbacks - 0, articles - 5
              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

            05年寫的直線裁剪算法

            Posted on 2007-01-28 10:28 Tauruser 閱讀(2798) 評論(2)  編輯 收藏 引用 所屬分類: 計算機圖形學
            頭文件<line.h>

            #pragma?once
            #include?
            "afx.h"
            #include?
            "atltypes.h"
            /*
            ?*?Powered?by?Tauruser
            ?*?Tauruser~gmail.com
            ?*?Written?on?2005.12
            ?*?歡迎轉載,請說明出處
            ?
            */
            ?
            class?CLine?:
            ????
            public?CObject
            {
            ????DECLARE_SERIAL?(CLine)
            public:
            ????CLine(
            void);
            ????
            ~CLine(void);
            private:
            ????CPoint?m_ptFrom;
            private:
            ????CPoint?m_ptTo;
            public:
            ????CLine(CPoint?ptFrom,?CPoint?ptTo);
            ????
            void?Draw(CDC*?pDC);
            ????
            void?Serialize(CArchive&?ar);
            ????CLine
            *?SetLine(CPoint?ptFrom,?CPoint?ptTo);
            ????
            //?剪裁線段,參數為窗口左上角和右下角坐標,當線段在窗口內返回TRUE,否則

            FALSE
            ????
            bool?Cut(CPoint?ptUpLeft,?CPoint?ptDownRight);
            }
            ;

            源碼<line.cpp>

            #include?"StdAfx.h"
            #include?
            ".\line.h"
            /*
            ?*?Powered?by?Tauruser
            ?*?Tauruser~gmail.com
            ?*?Written?on?2005.12
            ?*?歡迎轉載,請說明出處
            ?
            */
            ?
            IMPLEMENT_SERIAL?(CLine,CObject,
            1)
            CLine::CLine(
            void)
            :?m_ptFrom(
            0)
            ,?m_ptTo(
            0)
            {
            }


            CLine::
            ~CLine(void)
            {
            }


            CLine::CLine(CPoint?ptFrom,?CPoint?ptTo)
            {
            ????m_ptFrom
            =ptFrom;
            ????m_ptTo
            =ptTo;
            }


            void?CLine::Draw(CDC*?pDC)
            {
            ????pDC
            ->MoveTo(m_ptFrom);
            ????pDC
            ->LineTo(m_ptTo);
            }


            void?CLine::Serialize(CArchive&?ar)
            {
            ????CObject::Serialize(ar);
            ????
            if(ar.IsStoring())
            ????????ar
            <<m_ptFrom<<m_ptTo;
            ????
            else
            ????????ar
            >>m_ptFrom>>m_ptTo;
            }


            CLine
            *?CLine::SetLine(CPoint?ptFrom,?CPoint?ptTo)
            {
            ????m_ptFrom
            =ptFrom;
            ????m_ptTo
            =ptTo;
            ????
            return?this;
            }


            //?剪裁線段,參數為窗口左上角和右下角坐標,當線段在窗口內返回TRUE,否則FALSE
            bool?CLine::Cut(CPoint?ptUpLeft,?CPoint?ptDownRight)
            {
            ????
            //long?iA,iB,iC,iD,iXl,iXr,iYt,iYb;?
            ????const?long?iA(m_ptFrom.x),?iB(m_ptFrom.y),?iC(m_ptTo.x),?iD(m_ptTo.y);
            ????
            long?iXl=ptUpLeft.x,?iXr=ptDownRight.x,?iYt=ptUpLeft.y,?iYb=ptDownRight.y;
            ????
            int?temp;
            ????
            if?(iXl>iXr)?
            ????
            {
            ????????temp
            =iXl;
            ????????iXl
            =iXr;
            ????????iXr
            =temp;
            ????}

            ????
            if(iYb>iYt)
            ????
            {
            ????????temp
            =iYb;
            ????????iYb
            =iYt;
            ????????iYt
            =temp;
            ????}


            ????
            if(iXl<=iA?&&?iA<=iXr)
            ????
            {
            ????????
            if(iYb<=iB?&&?iB<=iYt)
            ????????
            {????;//m_ptFrom保持原值
            ????????}
            else?if(iB<iYb?&&?iD<iYb)?
            ????????????
            return?false;//與窗口無交.
            ????????else?if?(iB<iYb?&&?iD>=iYb)
            ????????
            {
            ????????????
            //1.2
            ????????????int?x;
            ????????????x
            =iA-((iB-iYb)*(iA-iC)/(iB-iD));
            ????????????
            if(iXl<=x?&&?x<=iXr)//檢驗x的有校性
            ????????????{
            ????????????????m_ptFrom.x
            =x;
            ????????????????m_ptFrom.y
            =iYb;

            ????????????}
            else?return?false;//否則無交點

            ????????}
            else?if(iB>iYt?&&?iD>iYt)?????return?false;//與窗口無交
            ????????else?if(iB>iYt?&&?iD<=iYt)
            ????????
            {????
            ????????????
            //1.3
            ????????????int?x;
            ????????????x
            =iA-((iB-iYt)*(iA-iC)/(iB-iD));//檢驗x的有校性?
            ????????????if(iXl<=x?&&?x<=iXr)//
            ????????????{
            ????????????????m_ptFrom.x
            =x;
            ????????????????m_ptFrom.y
            =iYt;
            ????????????}
            else?return?false;//否則無交點

            ????????}

            ????????

            ????}
            else?if(iA<iXl)
            ????
            {
            ????????
            if(iC<iXl)?return?false;
            ????????
            else
            ????????
            {
            ????????????
            int?y;
            ????????????y
            =iB-((iA-iXl)*(iB-iD)/(iA-iC));

            ????????????
            if(iYb<=y?&&?y<=iYt)
            ????????????
            {
            ????????????????m_ptFrom.x
            =iXl;
            ????????????????m_ptFrom.y
            =y;
            ????????????}
            else?if?((y<iYb?||?y>iYt)?&&?(iYb<=iB?&&?iB<=iYt))?
            ????????????
            {
            ????????????????
            return?false;
            ????????????}

            ????????????
            else?if(y<iYb?||?iB<iYb)
            ????????????
            {
            ????????????????
            //1.2
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYb)*(iA-iC)/(iB-iD));
            ????????????????
            if(iXl<=x?&&?x<=iXr)//檢驗x的有校性
            ????????????????{
            ????????????????????m_ptFrom.x
            =x;
            ????????????????????m_ptFrom.y
            =iYb;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}

            ????????????
            else?if(y>iYt?||?iB>iYt)
            ????????????
            {
            ????????????????
            //1.3
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYt)*(iA-iC)/(iB-iD));//檢驗x的有校性?
            ????????????????if(iXl<=x?&&?x<=iXr)//
            ????????????????{
            ????????????????????m_ptFrom.x
            =x;
            ????????????????????m_ptFrom.y
            =iYt;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}

            ????????}


            ????}
            else?if(iA>iXr)
            ????
            {
            ????????
            if(iC>iXr)?return?false;//
            ????????else
            ????????
            {
            ????????????
            int?y;
            ????????????y
            =iB-((iA-iXr)*(iB-iD)/(iA-iC));
            ????????????
            ????????????
            if(iYb<=y?&&?y<=iYt)
            ????????????
            {
            ????????????????m_ptFrom.x
            =iXr;
            ????????????????m_ptFrom.y
            =y;
            ????????????}
            else?if?((y<iYb?||?y>iYt)?&&?(iYb<=iB?&&?iB<=iYt))?
            ????????????
            {
            ????????????????
            return?false;
            ????????????}

            ????????????
            else?if(y<iYb?||?iB<iYb)
            ????????????
            {
            ????????????????
            //1.2
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYb)*(iA-iC)/(iB-iD));
            ????????????????
            if(iXl<=x?&&?x<=iXr)//檢驗x的有校性
            ????????????????{
            ????????????????????m_ptFrom.x
            =x;
            ????????????????????m_ptFrom.y
            =iYb;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}

            ????????????
            else?if(y>iYt?||?iB>iYt)
            ????????????
            {
            ????????????????
            //1.3
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYt)*(iA-iC)/(iB-iD));//檢驗x的有校性?
            ????????????????if(iXl<=x?&&?x<=iXr)//
            ????????????????{
            ????????????????????m_ptFrom.x
            =x;
            ????????????????????m_ptFrom.y
            =iYt;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}


            ????????}


            ????}

            //////////////////////////////////////////////////////////////////////////////////

            ????
            if(iXl<=iC?&&?iC<=iXr)
            ????
            {
            ????????
            if(iYb<=iD?&&?iD<=iYt)?
            ????????????
            return?true;//m_ptFrom保持原值
            ????????else?if(iB<iYb?&&?iD<iYb)?return?false;//與窗口無交.
            ????????else?if(iD<iYb?&&?iB>=iYb)
            ????????
            {
            ????????????
            //1.2
            ????????????int?x;
            ????????????x
            =iA-((iB-iYb)*(iA-iC)/(iB-iD));
            ????????????
            if(iXl<=x?&&?x<=iXr)//檢驗x的有校性
            ????????????{
            ????????????????m_ptTo.x
            =x;
            ????????????????m_ptTo.y
            =iYb;
            ????????????????
            return?true;
            ????????????}
            else?return?false;//否則無交點
            ????????}
            else?if(iB>iYt?&&?iD>iYt)?return?false;
            ????????
            else?if(iD>iYt?&&?iB<=iYt)
            ????????
            {????
            ????????????
            //1.3
            ????????????int?x;
            ????????????x
            =iA-((iB-iYt)*(iA-iC)/(iB-iD));//檢驗x的有校性?
            ????????????if(iXl<=x?&&?x<=iXr)//
            ????????????{
            ????????????????m_ptTo.x
            =x;
            ????????????????m_ptTo.y
            =iYt;
            ????????????????
            return?true;
            ????????????}
            else?return?false;//否則無交點

            ????????}

            ????????

            ????}
            else?if(iC<iXl)
            ????
            {
            ????????
            if(iA<iXl)?return?false;
            ????????
            else
            ????????
            {
            ????????????
            int?y;
            ????????????y
            =iB-((iA-iXl)*(iB-iD)/(iA-iC));

            ????????????
            if(iYb<=y?&&?y<=iYt)
            ????????????
            {
            ????????????????m_ptTo.x
            =iXl;
            ????????????????m_ptTo.y
            =y;
            ????????????????
            return?true;
            ????????????}
            else?if?((y<iYb?||?y>iYt)?&&?(iYb<=iD?&&?iD<=iYt))?
            ????????????
            {
            ????????????????
            return?false;
            ????????????}

            ????????????
            else?if(y<iYb?||?iB<iYb)
            ????????????
            {
            ????????????????
            //1.2
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYb)*(iA-iC)/(iB-iD));
            ????????????????
            if(iXl<=x?&&?x<=iXr)//檢驗x的有校性
            ????????????????{
            ????????????????????m_ptTo.x
            =x;
            ????????????????????m_ptTo.y
            =iYb;
            ????????????????????
            return?true;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}

            ????????????
            else?if(y>iYt?||?iB>iYt)
            ????????????
            {
            ????????????????
            //1.3
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYt)*(iA-iC)/(iB-iD));//檢驗x的有校性?
            ????????????????if(iXl<=x?&&?x<=iXr)//
            ????????????????{
            ????????????????????m_ptTo.x
            =x;
            ????????????????????m_ptTo.y
            =iYt;
            ????????????????????
            return?true;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}

            ????????}


            ????}
            else?if(iC>iXr)
            ????
            {
            ????????
            if(iA>iXr)?return?false;//
            ????????else
            ????????
            {
            ????????????
            int?y;
            ????????????y
            =iB-((iA-iXr)*(iB-iD)/(iA-iC));
            ????????????
            ????????????
            if(iYb<=y?&&?y<=iYt)
            ????????????
            {
            ????????????????m_ptTo.x
            =iXr;
            ????????????????m_ptTo.y
            =y;
            ????????????????
            return?true;
            ????????????}
            else?if?((y<iYb?||?y>iYt)?&&?(iYb<=iD?&&?iD<=iYt))?
            ????????????
            {
            ????????????????
            return?false;
            ????????????}

            ????????????
            else?if(y<iYb?||?iD<iYb)
            ????????????
            {
            ????????????????
            //1.2
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYb)*(iA-iC)/(iB-iD));
            ????????????????
            if(iXl<=x?&&?x<=iXr)//檢驗x的有校性
            ????????????????{
            ????????????????????m_ptTo.x
            =x;
            ????????????????????m_ptTo.y
            =iYb;
            ????????????????????
            return?true;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}

            ????????????
            else?if(y>iYt?||?iB>iYt)
            ????????????
            {
            ????????????????
            //1.3
            ????????????????int?x;
            ????????????????x
            =iA-((iB-iYt)*(iA-iC)/(iB-iD));//檢驗x的有校性?
            ????????????????if(iXl<=x?&&?x<=iXr)//
            ????????????????{
            ????????????????????m_ptTo.x
            =x;
            ????????????????????m_ptTo.y
            =iYt;
            ????????????????????
            return?true;
            ????????????????}
            else?return?false;//否則無交點
            ????????????}


            ????????}


            ????}

            ????
            return?true;
            ????
            }



            Feedback

            # re: 05年寫的直線裁剪算法  回復  更多評論   

            2007-06-30 13:18 by hello007@126.com
            好,謝謝

            # re: 05年寫的直線裁剪算法  回復  更多評論   

            2010-03-01 00:28 by 啊啊啊啊啊啊
            你這個算法也太復雜了吧
            久久综合精品国产一区二区三区 | 久久国产高清一区二区三区| 久久综合综合久久97色| 久久久久久极精品久久久 | 亚洲中文字幕久久精品无码APP | 亚洲国产成人久久一区WWW| 亚洲AV乱码久久精品蜜桃| 国产成人精品久久二区二区| 久久精品国产亚洲AV不卡| 伊人久久大香线蕉亚洲| 久久久久国产一区二区三区| 久久久精品人妻一区二区三区四| 精品久久久久中文字| 国产成人精品白浆久久69| 久久久久人妻一区精品| 国产成人精品久久一区二区三区 | 亚洲人成伊人成综合网久久久| 国产精品免费久久久久影院| 亚洲国产另类久久久精品黑人 | 久久久久亚洲av无码专区导航 | 久久精品人人做人人爽电影| 亚洲?V乱码久久精品蜜桃 | 久久99精品国产99久久6男男| 久久精品国产亚洲AV忘忧草18| 久久国产免费直播| 99热成人精品免费久久| 国产一久久香蕉国产线看观看| 久久婷婷成人综合色综合| 亚洲精品美女久久777777| 一本色道久久88—综合亚洲精品| 性做久久久久久久久浪潮| 亚洲国产一成久久精品国产成人综合 | 久久精品夜夜夜夜夜久久| 久久综合给合久久狠狠狠97色69| 亚洲人成伊人成综合网久久久| 亚洲日韩欧美一区久久久久我 | 国产综合免费精品久久久| 久久99精品久久久久久秒播| 久久亚洲中文字幕精品一区| 久久夜色精品国产www| 国产精品久久久久久久久软件|