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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? bezier.cpp

?? video linux conference
?? CPP
字號(hào):
/***************************************************************************** * bezier.cpp ***************************************************************************** * Copyright (C) 2003 VideoLAN * $Id: bezier.cpp 10101 2005-03-02 16:47:31Z robux4 $ * * Authors: Cyril Deguet     <asmax@via.ecp.fr> *          Olivier Teuli鑢e <ipkiss@via.ecp.fr> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA. *****************************************************************************/#include <vlc/vlc.h>#include "bezier.hpp"#include <math.h>#ifndef HAVE_LRINTF#   define lrintf(a) (int)rint(a)#endifBezier::Bezier( intf_thread_t *p_intf, const vector<float> &rAbscissas,                const vector<float> &rOrdinates, Flag_t flag )    : SkinObject( p_intf ){    // Copy the control points coordinates    m_ptx.assign( rAbscissas.begin(), rAbscissas.end() );    m_pty.assign( rOrdinates.begin(), rOrdinates.end() );    // We expect m_ptx and m_pty to have the same size, of course    m_nbCtrlPt = m_ptx.size();    // Precalculate the factoriels    m_ft.push_back( 1 );    for( int i = 1; i < m_nbCtrlPt; i++ )    {        m_ft.push_back( i * m_ft[i - 1] );    }    // Calculate the first point    int oldx, oldy;    computePoint( 0, oldx, oldy );    m_leftVect.push_back( oldx );    m_topVect.push_back( oldy );    m_percVect.push_back( 0 );    // Calculate the other points    float percentage;    int cx, cy;    for( float j = 1; j <= MAX_BEZIER_POINT; j++ )    {        percentage = j / MAX_BEZIER_POINT;        computePoint( percentage, cx, cy );        if( ( flag == kCoordsBoth && ( cx != oldx || cy != oldy ) ) ||            ( flag == kCoordsX && cx != oldx ) ||            ( flag == kCoordsY && cy != oldy ) )        {            m_percVect.push_back( percentage );            m_leftVect.push_back( cx );            m_topVect.push_back( cy );            oldx = cx;            oldy = cy;        }    }    m_nbPoints = m_leftVect.size();    // If we have only one control point, we duplicate it    // This allows to simplify the algorithms used in the class    if( m_nbPoints == 1 )    {        m_leftVect.push_back( m_leftVect[0] );        m_topVect.push_back( m_topVect[0] );        m_percVect.push_back( 1 );        m_nbPoints = 2;   }    // Ensure that the percentage of the last point is always 1    m_percVect[m_nbPoints - 1] = 1;}float Bezier::getNearestPercent( int x, int y ) const{    int nearest = findNearestPoint( x, y );    return m_percVect[nearest];}float Bezier::getMinDist( int x, int y ) const{    int nearest = findNearestPoint( x, y );    return sqrt( (m_leftVect[nearest] - x) * (m_leftVect[nearest] - x) +                 (m_topVect[nearest] - y) * (m_topVect[nearest] - y) );}void Bezier::getPoint( float t, int &x, int &y ) const{    // Find the precalculated point whose percentage is nearest from t    int refPoint = 0;    float minDiff = fabs( m_percVect[0] - t );    // The percentages are stored in increasing order, so we can stop the loop    // as soon as 'diff' starts increasing    float diff;    while( refPoint < m_nbPoints &&           (diff = fabs( m_percVect[refPoint] - t )) <= minDiff )    {        refPoint++;        minDiff = diff;    }    // The searched point is then (refPoint - 1)    // We know that refPoint > 0 because we looped at least once    x = m_leftVect[refPoint - 1];    y = m_topVect[refPoint - 1];}int Bezier::getWidth() const{    int width = 0;    for( int i = 0; i < m_nbPoints; i++ )    {        if( m_leftVect[i] >= width )        {            width = m_leftVect[i] + 1;        }    }    return width;}int Bezier::getHeight() const{    int height = 0;    for( int i = 0; i < m_nbPoints; i++ )    {        if( m_topVect[i] >= height )        {            height = m_topVect[i] + 1;        }    }    return height;}int Bezier::findNearestPoint( int x, int y ) const{    // The distance to the first point is taken as the reference    int refPoint = 0;    int minDist = (m_leftVect[0] - x) * (m_leftVect[0] - x) +                  (m_topVect[0] - y) * (m_topVect[0] - y);    int dist;    for( int i = 1; i < m_nbPoints; i++ )    {        dist = (m_leftVect[i] - x) * (m_leftVect[i] - x) +               (m_topVect[i] - y) * (m_topVect[i] - y);        if( dist < minDist )        {            minDist = dist;            refPoint = i;        }    }    return refPoint;}void Bezier::computePoint( float t, int &x, int &y ) const{    // See http://astronomy.swin.edu.au/~pbourke/curves/bezier/ for a simple    // explanation of the algorithm    float xPos = 0;    float yPos = 0;    float coeff;    for( int i = 0; i < m_nbCtrlPt; i++ )    {        coeff = computeCoeff( i, m_nbCtrlPt - 1, t );        xPos += m_ptx[i] * coeff;        yPos += m_pty[i] * coeff;    }    x = lrintf(xPos);    y = lrintf(yPos);}inline float Bezier::computeCoeff( int i, int n, float t ) const{    return (power( t, i ) * power( 1 - t, (n - i) ) *        (m_ft[n] / m_ft[i] / m_ft[n - i]));}inline float Bezier::power( float x, int n ) const{    if( n > 0 )        return x * power( x, n - 1);    else        return 1;}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
中文字幕一区视频| 欧美美女一区二区三区| 久久久一区二区三区捆绑**| 日本视频一区二区三区| 538prom精品视频线放| 青青草国产精品亚洲专区无| 日韩欧美中文一区| 久久99精品久久久久久国产越南 | 欧美大胆人体bbbb| 国产在线日韩欧美| 国产精品私人影院| 欧美视频日韩视频在线观看| 午夜精品视频一区| 亚洲精品在线免费播放| 国产成人精品亚洲午夜麻豆| 日韩理论片在线| 欧美年轻男男videosbes| 日韩电影一区二区三区四区| 久久久午夜精品| 成人看片黄a免费看在线| 国产在线视频精品一区| 国产日韩精品久久久| 91麻豆视频网站| 日本在线不卡视频| 国产精品欧美一级免费| 欧美性猛交xxxxxx富婆| 精品一区二区三区在线观看国产 | 无吗不卡中文字幕| 欧美一级久久久久久久大片| 国产成人免费视频精品含羞草妖精 | 蜜臀av一区二区| 国产精品久久久久影院色老大| 欧美色成人综合| 高清免费成人av| 亚洲国产精品麻豆| 国产精品无遮挡| 日韩欧美一二三区| 色噜噜狠狠色综合中国| 一本大道久久a久久综合| 尤物视频一区二区| 国产婷婷色一区二区三区在线| 在线视频一区二区三| 国产精品一区二区x88av| 五月婷婷久久丁香| 中文字幕综合网| 久久亚洲综合av| 91精品一区二区三区在线观看| 成人av电影在线观看| 久久精品国产99国产| 亚洲午夜久久久久久久久电影网| 久久久国际精品| 欧美成人精品1314www| 91久久精品一区二区| 成人激情文学综合网| 韩国视频一区二区| 青青青伊人色综合久久| 亚洲一区二区三区四区五区中文| 欧美激情一区二区三区| 精品国精品国产| 欧美一区午夜视频在线观看| 91国偷自产一区二区开放时间| 国产不卡视频在线观看| 久久99久久久久久久久久久| 亚洲国产成人porn| 亚洲一级不卡视频| 亚洲摸摸操操av| 日韩理论片在线| 国产一区二区电影| 婷婷成人激情在线网| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲欧洲成人自拍| |精品福利一区二区三区| 国产精品美女久久久久久| 国产精品久久久久aaaa樱花| 日本一区二区视频在线观看| 久久亚洲精华国产精华液| 欧美videos中文字幕| 欧美电视剧在线观看完整版| 欧美一区在线视频| 日韩欧美激情四射| 26uuu国产在线精品一区二区| 日韩欧美精品在线视频| 精品国产人成亚洲区| 精品国产精品一区二区夜夜嗨| 日韩久久精品一区| 亚洲精品一区二区三区在线观看| 欧美精品一区二区三区在线播放| 精品成人私密视频| 国产精品入口麻豆原神| 国产精品超碰97尤物18| 亚洲男同1069视频| 一二三区精品福利视频| 夜夜夜精品看看| 99久久综合99久久综合网站| 欧美精品在线一区二区三区| 欧美在线观看视频一区二区三区| 91浏览器入口在线观看| 日本精品一区二区三区四区的功能| 97久久超碰国产精品电影| 欧美综合天天夜夜久久| 5566中文字幕一区二区电影| 欧美精品一区二区三区蜜臀 | 欧美日韩一区二区欧美激情| 欧美丰满一区二区免费视频| 日韩你懂的在线观看| 国产日韩欧美在线一区| 国产精品福利在线播放| 亚洲影院在线观看| 激情文学综合丁香| 99精品欧美一区二区三区综合在线| 一本色道久久综合亚洲aⅴ蜜桃| 欧美日韩视频一区二区| 精品国产sm最大网站| 中文字幕亚洲一区二区av在线| 亚洲一卡二卡三卡四卡无卡久久| 奇米精品一区二区三区四区| 国产成人av网站| 国产乱码精品一区二区三区av| 亚洲欧美色一区| 午夜精品一区二区三区电影天堂| 国内精品视频一区二区三区八戒| 成人爱爱电影网址| 欧美久久免费观看| 欧美激情一区二区三区全黄| 一区二区国产视频| 国产一区二区三区四区五区入口| 色噜噜夜夜夜综合网| 久久久久99精品国产片| 亚洲一区二区三区视频在线| 国产麻豆一精品一av一免费| 欧美日韩在线免费视频| 国产视频一区二区在线| 亚洲成人av一区二区| 国产成人在线视频免费播放| 欧美剧情片在线观看| 中文字幕亚洲一区二区va在线| 日韩高清电影一区| 91久久精品国产91性色tv| 久久久.com| 美女一区二区视频| 欧美人妇做爰xxxⅹ性高电影| 国产精品久久久久久久久免费桃花| 蜜桃av一区二区三区| 欧美调教femdomvk| 国产精品久久久久久久久果冻传媒| 免费成人美女在线观看.| 床上的激情91.| 日韩一级在线观看| 一区二区三区精品在线| 成人午夜电影小说| 日韩久久精品一区| 日韩电影在线观看电影| 欧美性色黄大片| 亚洲视频小说图片| 成人免费av网站| 国产色产综合色产在线视频| 琪琪久久久久日韩精品| 日本乱码高清不卡字幕| 国产精品国产三级国产aⅴ原创| 九色|91porny| 欧美成人在线直播| 久久aⅴ国产欧美74aaa| 日韩欧美一区二区在线视频| 三级久久三级久久| 欧美日韩一区在线观看| 一区二区三区视频在线看| 99久久精品国产网站| 18成人在线观看| 99精品一区二区| 亚洲乱码国产乱码精品精98午夜| 日韩av中文在线观看| 一本色道久久加勒比精品| 国产精品不卡在线| 99精品视频在线观看免费| 亚洲色图视频网| 色婷婷av一区二区三区软件| 亚洲欧美一区二区久久| 在线一区二区观看| 亚洲综合在线五月| 欧美肥妇free| 美女视频免费一区| 精品免费一区二区三区| 国产成人午夜精品影院观看视频 | 欧美日韩一级二级| 免费在线看成人av| 精品少妇一区二区三区日产乱码| 日韩av高清在线观看| 久久综合国产精品| 成人免费不卡视频| 亚洲高清免费一级二级三级| 欧美一区二区三区在线观看| 久久99精品国产麻豆婷婷| 欧美激情在线一区二区三区| 91丨国产丨九色丨pron| 午夜精品久久久久久久99樱桃| 日韩精品资源二区在线| 成人一区二区三区视频 | 亚洲mv在线观看| 精品少妇一区二区三区在线播放 | 九九九久久久精品|