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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? nsaver.c

?? microwindows最新源碼
?? C
?? 第 1 頁(yè) / 共 3 頁(yè)
字號(hào):
/* * The contents of this file are subject to the Mozilla Public License * Version 1.1 (the "License"); you may not use this file except in * compliance with the License. You may obtain a copy of the License at * http://www.mozilla.org/MPL/ * * Software distributed under the License is distributed on an "AS IS" * basis, WITHOUT WARRANTY OF ANY KIND, either express or implied. See the * License for the specific language governing rights and limitations * under the License. * * The Original Code is NanoScreenSaver. * * The Initial Developer of the Original Code is Alex Holden. * Portions created by Alex Holden are Copyright (C) 2000, 2002 * Alex Holden <alex@alexholden.net>. All Rights Reserved. * * Contributor(s): * * Alternatively, the contents of this file may be used under the terms * of the GNU General Public license (the  "[GNU] License"), in which case the * provisions of [GNU] License are applicable instead of those * above.  If you wish to allow use of your version of this file only * under the terms of the [GNU] License and not to allow others to use * your version of this file under the MPL, indicate your decision by * deleting  the provisions above and replace  them with the notice and * other provisions required by the [GNU] License.  If you do not delete * the provisions above, a recipient may use your version of this file * under either the MPL or the [GNU] License. *//* * A collection of screen savers for Nano-X by Alex Holden. */#include <errno.h>#include <stdio.h>#include <stdlib.h>#include <time.h>#include <math.h>#include <sys/time.h>#include <nano-X.h>#include <nxcolors.h>#include "nsaver.h"void *my_malloc(size_t size){	void *ret;	if(!(ret = malloc(size))) {		fprintf(stderr, "Out of memory\n");		exit(1);	}	return ret;}GR_COLOR get_random_colour(int min_brightness){	int r, g, b;	do {			r = RANDRANGE(0, 255);		g = RANDRANGE(0, 255);		b = RANDRANGE(0, 255);	} while((r + g + b) / 3 < min_brightness);	return(MWRGB(r, g, b));}void get_random_point_on_screen(nstate *state, GR_COORD *x, GR_COORD *y,							GR_COLOR *c){	if(x) *x = RANDRANGE(0, state->si.cols - 1);	if(y) *y = RANDRANGE(0, state->si.rows - 1);	if(c) *c = get_random_colour(GRP_MINBRIGHTNESS);}int not_square(int n){	while(n) {		if(n & 1) {			if(n - 1) return 1;			else return 0;		}		n >>= 1;	}	return 1;}void make_random_square(nstate *state, int min_brightness, int min_size,			int max_size, int need_square, GR_COORD *retx,			GR_COORD *rety, GR_SIZE *retsize){	int x1, x2, y, size, tmp;	GR_COLOR colour = get_random_colour(min_brightness); 	GrSetGCForeground(state->main_gc, colour);	do {		x1 = RANDRANGE(0, state->si.cols);		x2 = RANDRANGE(0, state->si.cols);		if(x1 > x2) {			tmp = x1;			x1 = x2;			x2 = tmp;		}		size = x2 - x1;	} while(size < min_size || size > max_size ||			(need_square && not_square(size)));	y = RANDRANGE(0, state->si.rows - size - 1);	*retx = x1;	*rety = y;	*retsize = size;}#ifdef HAVE_USLEEPvoid msleep(long ms){	usleep(ms * 1000);}#elsevoid msleep(long ms){	struct timespec req, rem;	req.tv_sec = ms / 1000000;	req.tv_nsec = (ms % 1000000) * 1000000;	while(nanosleep(&req, &rem) == -1) {		if(errno == EINTR) {			req.tv_sec = rem.tv_sec;			req.tv_nsec = rem.tv_nsec;			continue;		} else {			perror("nanosleep() failed");			return;		}	}}#endifGR_WINDOW_ID capture_screen(nstate *state){	GR_WINDOW_ID pid;#if CAPTURESCREEN_DELAY	/* This is a hack to give the system enough time to redraw the screen	 * before capturing it when we switch from one screensaver to another.	 * without it, we often capture an only partially redrawn screen. */	msleep(CAPTURESCREEN_DELAY);#endif		pid = GrNewPixmap(state->si.cols, state->si.rows, NULL);	GrCopyArea(pid, state->main_gc, 0, 0, state->si.cols,			state->si.rows, GR_ROOT_WINDOW_ID, 0, 0, 0);	return pid;}void saver1_init(nstate *state) {}void saver1_exposure(nstate *state){	GrClearWindow(state->main_window, 0);}void saver1_animate(nstate *state) {}void saver2_init(nstate *state){	s2state *s = my_malloc(sizeof(s2state));	state->priv = s;	s->pixels = SAVER2_MAXPIXELS;	state->animate_interval = SAVER2_DELAY;}void saver2_exposure(nstate *state){	GrClearWindow(state->main_window, 0);}void saver2_animate(nstate *state){	GR_COORD x, y;	GR_COLOR c;	int pixels = SAVER2_PIXELS_PER_FRAME;	s2state *s = state->priv;	while(pixels--) {		if(!(s->pixels--)) {			s->pixels = SAVER2_MAXPIXELS;			GrClearWindow(state->main_window, 0);		}		get_random_point_on_screen(state, &x, &y, &c);		GrSetGCForeground(state->main_gc, c);		GrPoint(state->main_window, state->main_gc, x, y);	}}void saver3_init(nstate *state){	s3state *s = my_malloc(sizeof(s3state));	state->priv = s;	s->maxsegments = SAVER3_MAXSEGMENTS;	s->lastx = 0;	s->lasty = 0;	state->animate_interval = SAVER3_DELAY;}void saver3_exposure(nstate *state){	GrClearWindow(state->main_window, 0);}void saver3_animate(nstate *state){	GR_COORD newx, newy;	GR_COLOR c;	s3state *s = state->priv;	int pixels = SAVER3_SEGMENTS_PER_FRAME;	while(pixels--) {		if(!(s->maxsegments--)) {			s->maxsegments = SAVER3_MAXSEGMENTS;			GrClearWindow(state->main_window, 0);		}		get_random_point_on_screen(state, &newx, &newy, &c);		GrSetGCForeground(state->main_gc, c);		GrLine(state->main_window, state->main_gc, s->lastx, s->lasty,							newx, newy);		s->lastx = newx;		s->lasty = newy;	}}void saver4_init(nstate *state){	int i;	GR_COORD x, y;	s4state *s = my_malloc(sizeof(s4state));	state->priv = s;	s->length = 0;	for(i = 0; i < SAVER4_NUMWORMS; i++) {		s->tip = 0;		get_random_point_on_screen(state, &x, &y, &s->worms[i].colour);		s->worms[i].x = x;		s->worms[i].points[0].x = x;		s->worms[i].y = y;		s->worms[i].points[0].y = y;		}	state->animate_interval = SAVER4_DELAY;}void saver4_exposure(nstate *state){	int i;	s4state *s = state->priv;	GrClearWindow(state->main_window, 0);	if(!s->length) return;	for(i = 0; i < SAVER4_NUMWORMS; i++) {		GrSetGCForeground(state->main_gc, s->worms[i].colour);		GrPoints(state->main_window, state->main_gc, s->length,							s->worms[i].points);	}}void saver4_get_new_worm_position(nstate *state, int worm, int newtip){	s4state *s = state->priv;	s4worm *w = &s->worms[worm];	w->d += FRANDRANGE(-SAVER4_MAXROTATION, SAVER4_MAXROTATION);	w->x += cos(w->d) * SAVER4_VELOCITY;	w->y += sin(w->d) * SAVER4_VELOCITY;	if(w->x < 0) w->x = state->si.cols - 1 + w->x;	if(w->x >= state->si.cols) w->x -= state->si.cols;	if(w->y < 0) w->y = state->si.rows - 1 + w->y;	if(w->y >= state->si.rows) w->y -= state->si.rows;	w->points[newtip].x = (GR_COORD)w->x;	w->points[newtip].y = (GR_COORD)w->y;}void saver4_animate(nstate *state){	int i, tail, newtip;	s4state *s = state->priv;	if(s->length == SAVER4_WORMLENGTH) tail = s->tip + 1;	else tail = 0;	if(tail == SAVER4_WORMLENGTH) tail = 0;	newtip = s->tip + 1;	if(newtip == SAVER4_WORMLENGTH) newtip = 0;		for(i = 0; i < SAVER4_NUMWORMS; i++) {		GrSetGCForeground(state->main_gc, GR_COLOR_BLACK);		GrFillRect(state->main_window, state->main_gc,					s->worms[i].points[tail].x,					s->worms[i].points[tail].y,					SAVER4_WORMTHICKNESS,					SAVER4_WORMTHICKNESS);		saver4_get_new_worm_position(state, i, newtip);		GrSetGCForeground(state->main_gc, s->worms[i].colour);		GrFillRect(state->main_window, state->main_gc,					s->worms[i].points[newtip].x,					s->worms[i].points[newtip].y,					SAVER4_WORMTHICKNESS,					SAVER4_WORMTHICKNESS);	}	s->tip = newtip;	if(s->length < SAVER4_WORMLENGTH) s->length++;}void saver5_init(nstate *state){	int i;	s5state *s = my_malloc(sizeof(s5state));	state->priv = s;	s->numstars = 0;	for(i = 0; i < SAVER5_NUMSTARS; i++) {		s->stars[i].angle = FRANDRANGE(0, (2 * M_PI));		s->stars[i].pos = 1;	}	state->animate_interval = SAVER5_DELAY;}int saver5_drawstar(nstate *state, s5state *s, int star, int delete){	int opp, adj;	GR_COORD x, y;	if(delete) GrSetGCForeground(state->main_gc, GR_COLOR_BLACK);	else GrSetGCForeground(state->main_gc, GR_COLOR_WHITE);	opp = (int)(sin(s->stars[star].angle) * s->stars[star].pos);	adj = (int)(cos(s->stars[star].angle) * s->stars[star].pos);	x = (state->si.cols / 2) + adj;	y = (state->si.rows / 2) + opp;	if((x < 0) || (y < 0) || (x >= state->si.cols) || (y >= state->si.rows))		return 1;	GrPoint(state->main_window, state->main_gc, x, y);	return 0;}void saver5_exposure(nstate *state){	int i;	s5state *s = state->priv;	GrClearWindow(state->main_window, 0);	for(i = 0; i < SAVER5_NUMSTARS; i++) {		saver5_drawstar(state, s, i, 0);	}}void saver5_animate(nstate *state){	int i;	double position, scale, increment;	s5state *s = state->priv;	if(s->numstars < SAVER5_NUMSTARS) {		s->numstars += SAVER5_STARS_INCREMENT;		if(s->numstars > SAVER5_NUMSTARS)			s->numstars = SAVER5_NUMSTARS;	}	for(i = 0; i < s->numstars; i++) {		saver5_drawstar(state, s, i, 1);		position = (double)s->stars[i].pos /				(double)(state->si.cols / 2);		scale = sin((position * M_PI_2) + M_PI + M_PI_2) + 1.0;		increment = (scale * SAVER5_STARS_ACCEL_RATE) + 1;		s->stars[i].pos += (int) increment;		if(saver5_drawstar(state, s, i, 0)) {			s->stars[i].pos = 1;			s->stars[i].angle = FRANDRANGE(0, (2 * M_PI));			saver5_drawstar(state, s, i, 0);		}	}}void saver6_init(nstate *state){	int i, n;	s6state *s = my_malloc(sizeof(s6state));	state->priv = s;	s->new_bolt_time = 0;	for(i = 0; i < SAVER6_MAXBOLTS; i++) {		s->bolts[i].duration = 0;		for(n = 0; n < SAVER6_MAXFORKS; n++) {			s->bolts[i].forks[n].valid = 0;		}	}	state->animate_interval = SAVER6_DELAY;}void saver6_drawfork(nstate *state, s6state *s, int bolt, int fork, int delete){	int i;	if(delete) GrSetGCForeground(state->main_gc, GR_COLOR_BLACK);	for(i = 0; i < SAVER6_THICKNESS; i++) {		if(!delete) {			if((i < 2) || (i >= SAVER6_THICKNESS - 2))				 GrSetGCForeground(state->main_gc,						 GR_COLOR_CORNFLOWERBLUE);			else GrSetGCForeground(state->main_gc, GR_COLOR_WHITE);		}		GrPoly(state->main_window, state->main_gc,				s->bolts[bolt].forks[fork].valid,				s->bolts[bolt].forks[fork].vertices[i]);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
青青草97国产精品免费观看无弹窗版| 久久99精品久久久久久| 欧美一区二区久久久| 懂色av中文字幕一区二区三区| 亚洲成人av一区| 国产精品伦理一区二区| 日韩美一区二区三区| 在线观看亚洲成人| 波多野结衣欧美| 国模冰冰炮一区二区| 日韩精品三区四区| 亚洲精品高清在线| 国产精品久久久久久久久久免费看| 91精品一区二区三区在线观看| 99re8在线精品视频免费播放| 国产在线乱码一区二区三区| 亚洲高清一区二区三区| 亚洲欧美色图小说| 国产精品成人网| 久久久久国产精品麻豆ai换脸| 欧美一区二区在线免费观看| 欧美亚洲日本国产| 日本精品视频一区二区| 97精品久久久久中文字幕 | 蜜臀av性久久久久蜜臀aⅴ四虎| 亚洲日本在线天堂| 国产精品不卡在线观看| 久久久不卡网国产精品一区| 欧美xxxx老人做受| 亚洲美女精品一区| 国产精品无人区| 国产欧美日韩卡一| 中文字幕乱码一区二区免费| 久久精品人人做人人综合| 日韩精品一区二区三区四区视频| 在线综合视频播放| 制服丝袜亚洲色图| 91精品国产综合久久精品| 678五月天丁香亚洲综合网| 欧美日韩国产一级片| 欧美色视频在线观看| 欧美性videosxxxxx| 欧美日韩午夜精品| 欧美情侣在线播放| 欧美一级二级三级蜜桃| 日韩免费视频一区二区| 久久综合精品国产一区二区三区| 精品嫩草影院久久| 国产日本亚洲高清| 国产精品二区一区二区aⅴ污介绍| 中文字幕不卡在线播放| 亚洲日本丝袜连裤袜办公室| 亚洲蜜臀av乱码久久精品| 亚洲精品成人在线| 丝袜美腿高跟呻吟高潮一区| 日本欧美在线看| 激情图区综合网| 成人一道本在线| 91浏览器在线视频| 666欧美在线视频| 久久美女艺术照精彩视频福利播放| 国产清纯在线一区二区www| 中文字幕一区二区不卡| 亚洲一线二线三线视频| 蜜桃久久精品一区二区| 国产精品资源网站| 色久综合一二码| 日韩一级片在线观看| 久久久精品天堂| 亚洲精选视频在线| 奇米精品一区二区三区在线观看| 国产精品综合视频| 色悠悠久久综合| 日韩一区二区三区视频在线观看| 国产亚洲制服色| 亚洲国产一区视频| 加勒比av一区二区| 色国产精品一区在线观看| 日韩视频在线你懂得| 国产精品国产三级国产普通话蜜臀| 亚洲精品视频免费看| 久久成人久久爱| 色婷婷精品久久二区二区蜜臂av| 日韩三级精品电影久久久| 国产精品国模大尺度视频| 日韩精品欧美精品| 99久久久久久99| 日韩免费一区二区| 亚洲影视在线观看| 日韩一区二区在线看片| 国产亚洲欧美在线| 日韩激情视频在线观看| aaa亚洲精品| 欧美r级在线观看| 亚洲亚洲人成综合网络| 国产不卡在线播放| 日韩视频一区在线观看| 综合色天天鬼久久鬼色| 国内精品久久久久影院一蜜桃| 色婷婷久久99综合精品jk白丝| 久久综合狠狠综合久久综合88 | 夜夜嗨av一区二区三区网页 | 亚洲自拍另类综合| 国产69精品久久777的优势| 欧美日本乱大交xxxxx| 国产精品久久国产精麻豆99网站 | 一区二区三区在线视频免费观看| 免播放器亚洲一区| 欧美在线视频你懂得| 国产精品三级电影| 国产最新精品精品你懂的| 欧美精品一卡两卡| 亚洲综合在线五月| 99久久99久久精品国产片果冻| 精品福利二区三区| 日本午夜一本久久久综合| 91麻豆文化传媒在线观看| 久久精品视频在线看| 另类小说视频一区二区| 7777精品伊人久久久大香线蕉超级流畅| 综合色天天鬼久久鬼色| 成人永久免费视频| 久久久久久久久久看片| 精品影院一区二区久久久| 日韩一区二区在线观看视频| 亚洲va欧美va国产va天堂影院| 色视频成人在线观看免| 亚洲欧美另类小说| 95精品视频在线| 亚洲图片欧美激情| 91麻豆免费看| 亚洲色图欧美在线| 91片在线免费观看| 一区二区三区精品在线观看| 一本大道久久a久久综合| 亚洲欧洲日本在线| 色综合久久天天综合网| 一区二区三区日本| 欧美日免费三级在线| 午夜精品福利一区二区三区蜜桃| 欧美日韩国产成人在线免费| 亚洲bt欧美bt精品777| 欧美精品色综合| 免费在线观看精品| 精品久久人人做人人爱| 国产伦精品一区二区三区在线观看| 久久亚洲精品小早川怜子| 国产精品一线二线三线精华| 欧美国产97人人爽人人喊| 9人人澡人人爽人人精品| 亚洲一区视频在线| 欧美一区二区三区视频在线| 九色综合国产一区二区三区| 久久蜜桃av一区精品变态类天堂| 福利电影一区二区三区| 亚洲精品久久7777| 欧美日韩国产首页| 久久99国产精品麻豆| 中文字幕免费一区| 一本到三区不卡视频| 天堂蜜桃一区二区三区| 精品国内二区三区| aaa欧美日韩| 午夜久久久影院| 精品国产凹凸成av人网站| 国产精品18久久久久久久久久久久| 中文字幕av免费专区久久| 色成人在线视频| 九九久久精品视频| 亚洲人精品一区| 欧美一区二区久久| 暴力调教一区二区三区| 亚洲aⅴ怡春院| 久久久久九九视频| 精品视频一区二区三区免费| 国产最新精品精品你懂的| 亚洲人成在线观看一区二区| 6080日韩午夜伦伦午夜伦| 国产福利91精品一区| 亚洲第一在线综合网站| 国产亚洲欧美日韩在线一区| 欧美亚州韩日在线看免费版国语版| 久久91精品久久久久久秒播| 综合亚洲深深色噜噜狠狠网站| 日韩一二三四区| 91亚洲精品一区二区乱码| 久久疯狂做爰流白浆xx| 樱桃国产成人精品视频| 久久综合网色—综合色88| 欧美色综合久久| 成人美女视频在线看| 美美哒免费高清在线观看视频一区二区| 国产精品网站在线播放| 精品欧美乱码久久久久久| 欧美亚洲一区三区| av在线播放一区二区三区| 精品亚洲国内自在自线福利| 亚洲v中文字幕| 亚洲精品一二三| 国产精品丝袜久久久久久app|