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

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

?? fl_slider.cxx

?? flnx 0.17 是做嵌入linux gui 必備工具箱
?? CXX
字號:
//// "$Id: Fl_Slider.cxx,v 1.1.1.1 2003/08/07 21:18:40 jasonk Exp $"//// Slider widget for the Fast Light Tool Kit (FLTK).//// Copyright 1998-1999 by Bill Spitzak and others.//// This library is free software; you can redistribute it and/or// modify it under the terms of the GNU Library General Public// License as published by the Free Software Foundation; either// version 2 of the License, or (at your option) any later version.//// This library 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// Library General Public License for more details.//// You should have received a copy of the GNU Library General Public// License along with this library; if not, write to the Free Software// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307// USA.//// Please report all bugs and problems to "fltk-bugs@easysw.com".//#include <stdio.h>#include <FL/Fl.H>#include <FL/Fl_Slider.H>#include <FL/fl_draw.H>#include <math.h>voidFl_Slider::_Fl_Slider(){    slider_size_ = 0;    slider_ = 0;		// FL_UP_BOX;}Fl_Slider::Fl_Slider(int x, int y, int w, int h, const char *l)    :Fl_Valuator(x, y, w, h, l){    box(FL_DOWN_BOX);    _Fl_Slider();}Fl_Slider::Fl_Slider(uchar t, int x, int y, int w, int h, const char *l)    :Fl_Valuator(x, y, w, h, l){    type(t);    box(t == FL_HOR_NICE_SLIDER || t == FL_VERT_NICE_SLIDER ?	FL_FLAT_BOX : FL_DOWN_BOX);    _Fl_Slider();}voidFl_Slider::slider_size(double v){    if (v < 0)	v = 0;    if (v > 1)	v = 1;    if (slider_size_ != float (v)) {	slider_size_ = float (v);	damage(FL_DAMAGE_EXPOSE);    }}voidFl_Slider::bounds(double a, double b){    if (minimum() != a || maximum() != b) {	Fl_Valuator::bounds(a, b);	damage(FL_DAMAGE_EXPOSE);    }}voidFl_Slider::slider_ver_lines(int x, int y, int w, int h, int W, Fl_Color c){    int cx = x + w / 2;    int cy = y + h / 2;    fl_color(FL_BLACK);    if (type() != FL_HORIZONTAL) {	draw_box(FL_BORDER_BOX, x, y, w, h, c);    } else {	if (w > 0 && h > 0) {#ifndef PDA	    if (w < 17) {		w = 17;		slider_size(double (w) / double (W));		slider_size_min_ = slider_size();	    }#else	    slider_size_min_ = slider_size();#endif	    draw_box(FL_BORDER_BOX, x, y, w, h, c);	    fl_color(FL_BLACK);	    cx = x + w / 2;	    fl_line(cx, cy - h / 2 + 4, cx, cy + h / 2 - 4);	    fl_line(cx - 3, cy - h / 2 + 4, cx - 3, cy + h / 2 - 4);	    fl_line(cx + 3, cy - h / 2 + 4, cx + 3, cy + h / 2 - 4);	}    }}voidFl_Slider::slider_hor_lines(int x, int y, int w, int h, int W, Fl_Color c){    int cx = x + w / 2;    int cy = y + h / 2;    fl_color(FL_BLACK);    if (type() != FL_VERTICAL) {	draw_box(FL_BORDER_BOX, x, y, w, h, c);    } else {	if (w > 0 && h > 0) {#ifndef PDA	    if (h < 17) {		h = 17;		slider_size(double (h) / double (W));		slider_size_min_ = slider_size();	    }#else	    slider_size_min_ = slider_size();#endif	    draw_box(FL_BORDER_BOX, x, y, w, h, c);	    fl_color(FL_BLACK);	    cy = y + h / 2;	    fl_line(cx + w / 2 - 4, cy, cx - w / 2 + 4, cy);	    fl_line(cx + w / 2 - 4, cy - 3, cx - w / 2 + 4, cy - 3);	    fl_line(cx + w / 2 - 4, cy + 3, cx - w / 2 + 4, cy + 3);	}    }}intFl_Slider::scrollvalue(int p, int w, int t, int l){//      p = position, first line displayed//      w = window, number of lines displayed//      t = top, number of first line//      l = length, total number of lines    step(1, 1);    if (p + w > t + l)	l = p + w - t;    slider_size(w >= l ? 1.0 : double (w) / double (l));#ifdef PDA    if (slider_size() < slider_size_min_) {	slider_size(slider_size_min_);    }#endif    bounds(t, l - w + t);    return value(p);}// All slider interaction is done as though the slider ranges from// zero to one, and the left (bottom) edge of the slider is at the// given position.  Since when the slider is all the way to the// right (top) the left (bottom) edge is not all the way over, a// position on the widget itself covers a wider range than 0-1,// actually it ranges from 0 to 1/(1-size).voidFl_Slider::draw_bg(int x, int y, int w, int h){    if (!(damage() & FL_DAMAGE_ALL)) {	// not a complete redraw	draw_box();    }    Fl_Color black = active_r()? FL_BLACK : FL_INACTIVE_COLOR;    if (type() == FL_VERT_NICE_SLIDER) {	draw_box(FL_THIN_DOWN_BOX, x + w / 2 - 2, y, 4, h, black);    } else if (type() == FL_HOR_NICE_SLIDER) {	draw_box(FL_THIN_DOWN_BOX, x, y + h / 2 - 2, w, 4, black);    }}voidFl_Slider::draw(int x, int y, int w, int h){    double val;    if (minimum() == maximum())	val = 0.5;    else {	val = (value() - minimum()) / (maximum() - minimum());	if (val > 1.0)	    val = 1.0;	else if (val < 0.0)	    val = 0.0;    }    int W = (horizontal()? w : h);    int X, S;    if (type() == FL_HOR_FILL_SLIDER || type() == FL_VERT_FILL_SLIDER) {	S = int (val * W + .5);	if (minimum() > maximum()) {	    S = W - S;	    X = W - S;	} else	    X = 0;    } else {	S = int (slider_size_ * W + .5);	int T = (horizontal()? h : w) / 2 + 1;	if (type() == FL_VERT_NICE_SLIDER || type() == FL_HOR_NICE_SLIDER)	    T += 4;	if (S < T)	    S = T;	X = int (val * (W - S) + .5);    }    int xsl, ysl, wsl, hsl;    if (horizontal()) {	xsl = x + X;	wsl = S;	ysl = y;	hsl = h;    } else {	ysl = y + X;	hsl = S;	xsl = x;	wsl = w;    }    if (damage() & FL_DAMAGE_ALL) {	// complete redraw	draw_bg(x, y, w, h);    } else {			// partial redraw, clip off new position of slider	if (X > 0) {	    if (horizontal())		fl_clip(x, ysl, X, hsl);	    else		fl_clip(xsl, y, wsl, X);	    draw_bg(x, y, w, h);	    fl_pop_clip();	}	if (X + S < W) {	    if (horizontal())		fl_clip(xsl + wsl, ysl, x + w - xsl - wsl, hsl);	    else		fl_clip(xsl, ysl + hsl, wsl, y + h - ysl - hsl);	    draw_bg(x, y, w, h);	    fl_pop_clip();	}    }    Fl_Boxtype box1 = slider();    if (!box1) {	box1 = (Fl_Boxtype) (box() & -2);	if (!box1)	    box1 = FL_UP_BOX;    }    if (type() == FL_VERT_NICE_SLIDER) {	draw_box(box1, xsl, ysl, wsl, hsl, FL_GRAY);	int d = (hsl - 4) / 2;	draw_box(FL_THIN_DOWN_BOX, xsl + 2, ysl + d, wsl - 4, hsl - 2 * d,		 selection_color());    } else if (type() == FL_HOR_NICE_SLIDER) {	draw_box(box1, xsl, ysl, wsl, hsl, FL_GRAY);	int d = (wsl - 4) / 2;	draw_box(FL_THIN_DOWN_BOX, xsl + d, ysl + 2, wsl - 2 * d, hsl - 4,		 selection_color());    } else {			// draw the slider box#ifdef PDA	Fl_Color col = selection_color();	if (horizontal()) {	    slider_ver_lines(xsl, ysl, wsl, hsl, W, col);	} else {	    slider_hor_lines(xsl, ysl, wsl, hsl, W, col);	}#else	if (wsl > 0 && hsl > 0)	    draw_box(box1, xsl, ysl, wsl, hsl, selection_color());#endif    }    draw_label(xsl, ysl, wsl, hsl);}voidFl_Slider::draw(){    if (damage() & FL_DAMAGE_ALL)	draw_box();    draw(x() + Fl::box_dx(box()),	 y() + Fl::box_dy(box()),	 w() - Fl::box_dw(box()), h() - Fl::box_dh(box()));}intFl_Slider::handle(int event, int x, int y, int w, int h){    switch (event) {    case FL_PUSH:	if (!Fl::event_inside(x, y, w, h))	    return 0;	handle_push();    case FL_DRAG:{	    int W = (horizontal()? w : h);	    //int H = (horizontal() ? h : w);	    int mx = (horizontal()? Fl::event_x() - x : Fl::event_y() - y);	    int S = int (slider_size_ * W + .5);	    int X;	    static int offcenter;	    if (type() == FL_HOR_FILL_SLIDER || type() == FL_VERT_FILL_SLIDER) {		double val = (value() - minimum()) / (maximum() - minimum());		if (val >= 1.0)		    X = W;		else if (val <= 0.0)		    X = 0;		else		    X = int (val * W + .5);		if (event == FL_PUSH) {		    offcenter = mx - X;		    if (offcenter < -S / 2)			offcenter = 0;		    else if (offcenter > S / 2)			offcenter = 0;		    else			return 1;		}		S = 0;	    } else {		double val = (value() - minimum()) / (maximum() - minimum());		if (val >= 1.0)		    X = W - S;		else if (val <= 0.0)		    X = 0;		else		    X = int (val * (W - S) + .5);		if (event == FL_PUSH) {		    offcenter = mx - X;		    if (offcenter < 0)			offcenter = 0;		    else if (offcenter > S)			offcenter = S;		    else			return 1;		}	    }	    X = mx - offcenter;	    double v;	  TRY_AGAIN:	    if (X < 0) {		X = 0;		offcenter = mx;		if (offcenter < 0)		    offcenter = 0;	    } else if (X > (W - S)) {		X = W - S;		offcenter = mx - X;		if (offcenter > S)		    offcenter = S;	    }	    v = round(X * (maximum() - minimum()) / (W - S) + minimum());	    // make sure a click outside the sliderbar moves it:	    if (event == FL_PUSH && v == value()) {		offcenter = S / 2;		event = FL_DRAG;		goto TRY_AGAIN;	    }	    handle_drag(clamp(v));	}	return 1;    case FL_RELEASE:	handle_release();	return 1;    default:	return 0;    }}intFl_Slider::handle(int event){    return handle(event,		  x() + Fl::box_dx(box()),		  y() + Fl::box_dy(box()),		  w() - Fl::box_dw(box()), h() - Fl::box_dh(box()));}//// End of "$Id: Fl_Slider.cxx,v 1.1.1.1 2003/08/07 21:18:40 jasonk Exp $".//

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
色综合夜色一区| 色天天综合色天天久久| 日韩电影一二三区| 午夜欧美一区二区三区在线播放| 国产精品久久久久久妇女6080 | 国产一区二区三区四| 秋霞av亚洲一区二区三| 久久精品国产免费看久久精品| 美女久久久精品| 国产麻豆9l精品三级站| 国产成人午夜99999| 成人免费高清在线| 91国偷自产一区二区三区成为亚洲经典| 99精品国产91久久久久久 | 欧美精品久久99久久在免费线| 欧美揉bbbbb揉bbbbb| 欧美一区午夜视频在线观看| 精品美女一区二区| 国产女主播一区| 日韩av高清在线观看| 美女视频一区二区三区| 国产91精品免费| 色国产综合视频| 日韩精品综合一本久道在线视频| 久久久久99精品国产片| 亚洲欧美区自拍先锋| 婷婷成人综合网| 国产一区二区按摩在线观看| www.色精品| 精品日韩欧美在线| 亚洲伦理在线精品| 国产一区二区三区在线观看免费视频 | 精品亚洲免费视频| jiyouzz国产精品久久| 欧美日韩免费观看一区三区| 欧美精品一区二区三区蜜桃视频 | 欧美一级片免费看| 欧美国产综合一区二区| 日日摸夜夜添夜夜添亚洲女人| 国产主播一区二区| 欧美亚洲综合网| 中文字幕av一区二区三区| 亚洲bdsm女犯bdsm网站| 91在线视频在线| 337p日本欧洲亚洲大胆精品| 亚洲影院理伦片| 成人免费高清视频在线观看| 日韩无一区二区| 国模娜娜一区二区三区| 欧美伊人久久久久久久久影院 | 成人黄色在线视频| 欧美电视剧免费全集观看| 一区二区三区日韩精品| 丁香亚洲综合激情啪啪综合| 欧美日本在线一区| 亚洲精品水蜜桃| 99视频精品在线| 国产性色一区二区| 激情综合亚洲精品| 欧美一区二区三区不卡| 亚洲国产成人91porn| 不卡视频在线观看| 国产精品麻豆99久久久久久| 国产一区二区在线影院| 亚洲精品一区在线观看| 麻豆国产欧美一区二区三区| 日韩一区二区三区视频在线观看 | 日韩女优视频免费观看| 亚洲国产成人91porn| 欧美色大人视频| 天天av天天翘天天综合网色鬼国产| 99国内精品久久| 亚洲欧洲性图库| 99精品国产视频| 一区二区三区四区亚洲| 色综合中文字幕国产 | 国产成人精品三级| 久久久久高清精品| 国产成人精品亚洲日本在线桃色| 久久综合久久综合亚洲| 国产精品影视网| 中文字幕av不卡| 91美女蜜桃在线| 亚洲风情在线资源站| 欧美精品丝袜中出| 日本 国产 欧美色综合| 精品免费一区二区三区| 高清国产一区二区三区| 亚洲欧美国产高清| 欧美片网站yy| 国产精品一卡二卡在线观看| 国产精品少妇自拍| 91福利视频网站| 蜜桃久久精品一区二区| 久久午夜免费电影| 99re成人精品视频| 丝袜a∨在线一区二区三区不卡| 欧美高清一级片在线| 国产一区在线不卡| 亚洲天堂网中文字| 欧美丰满美乳xxx高潮www| 精品一区二区成人精品| 国产精品第13页| 91精品国产麻豆| 北条麻妃一区二区三区| 婷婷国产v国产偷v亚洲高清| 久久精品一区二区三区四区| 在线观看视频一区| 国产精品91一区二区| 亚洲自拍偷拍图区| 久久久久久久性| 51精品国自产在线| av中文一区二区三区| 日韩成人一级大片| 国产精品久久一级| 欧美成人猛片aaaaaaa| 色综合久久久久| 国产成人亚洲综合a∨婷婷| 亚洲国产美女搞黄色| 国产精品天干天干在观线| 欧美一级日韩不卡播放免费| 在线视频一区二区三区| 国v精品久久久网| 精品一区二区三区视频 | 欧美精品一区男女天堂| 日本黄色一区二区| 国产**成人网毛片九色| 狠狠色综合色综合网络| 午夜精品在线视频一区| 最新欧美精品一区二区三区| 国产午夜精品久久久久久久 | 色噜噜狠狠色综合欧洲selulu| 激情国产一区二区 | 波多野结衣亚洲| 精品一区二区三区影院在线午夜| 亚洲成人精品影院| 亚洲综合999| 亚洲精品国产成人久久av盗摄| 欧美激情一区二区三区四区| 欧美成人a在线| 日韩视频在线永久播放| 欧美精品v日韩精品v韩国精品v| 91在线观看一区二区| 成人精品国产免费网站| 国产曰批免费观看久久久| 激情小说欧美图片| 国产资源精品在线观看| 国产成人精品一区二区三区网站观看| 九九**精品视频免费播放| 国产在线一区二区| 国产酒店精品激情| 成人免费黄色在线| 色综合久久六月婷婷中文字幕| 99久久精品免费精品国产| 色综合天天综合| 欧洲精品视频在线观看| 欧美三级日本三级少妇99| 欧美肥大bbwbbw高潮| 日韩精品一区在线观看| 久久久久久久久99精品| 国产日韩欧美激情| 亚洲另类色综合网站| 午夜av一区二区| 久久99久久精品| 成人18视频在线播放| 在线观看日韩精品| 日韩一区二区三免费高清| 国产亚洲成av人在线观看导航| 国产亚洲一区二区三区| 自拍偷拍国产精品| 婷婷夜色潮精品综合在线| 麻豆精品国产传媒mv男同| 粉嫩aⅴ一区二区三区四区| 色哟哟一区二区三区| 欧美一区二区国产| 中文字幕制服丝袜成人av | 国产精品久久久一本精品 | 日韩综合一区二区| 另类小说欧美激情| 成人aa视频在线观看| 欧美精品自拍偷拍| 国产欧美日韩一区二区三区在线观看 | 青椒成人免费视频| 成人av中文字幕| 精品视频在线看| 2020国产精品久久精品美国| 又紧又大又爽精品一区二区| 麻豆国产欧美一区二区三区| 99re66热这里只有精品3直播 | 国产精品一二三四区| 色婷婷综合久久久| 国产亚洲欧美在线| 五月天久久比比资源色| 成人国产精品免费观看| 日韩精品一区二区在线| 一区二区三区美女| 成人免费视频视频| 亚洲精品在线观看视频| 首页国产丝袜综合| 日本黄色一区二区|