1、设置SketchUp菜单窗口中系统设置选项中的OPENGL
硬件加速跟快速反馈虽然都使用显示卡的功能,却是两种不同的观念。SketchUp要求显示卡能100%支持OpenGL是有原因的,运用OpenGL指令集驱动显卡做3D矢量运算,对显示材质和光线做细致的表现,影像在屏幕上显示是全靠显示卡和显存工作,CPU反而帮不上什麽忙。整个显示的效率全靠显卡对OpenGL的支持度。因此只要显卡能支持OpenGL就必须开启硬件加速功能这是毋庸置疑的。
快速反馈也是显示卡的功能,如果一个画面算完了再显示,那麽速度是来不及的,所以由快速反馈功能一面运算一面切换达到快速显示的目的。通常快速反馈也是必勾选的项目。只有显卡对OpenGL的支持度不良的时候产生花屏(反馈速度不足)才会不得已去掉这个功能的勾选。
至于下面那个反锯齿,会跟据SketchUp对显卡检测出能适应的反锯齿运算能力列出的设定值,当然4x最好,0x最差。要注意的反而是前面的颜色、精度和阴影三项。
2、导出图像的大小
导图时你导出的像素点越高,则线就越细。一般上到4000点的图线就很细了,有锯齿也看不清了。
3、设置显卡渲染帧数
渲染帧数意味着CPU渲染了多少帧才交给显卡处理,而不是CPU协助处理,所有帧CPU都要参与处理的。比如默认是3,就是等CPU处理了3帧,才开始由显卡处理,这样可以在性能急降的时候让画面变得流畅,因为你已经缓存了3帧,只需取用缓存的帧就可以了,所以理论上越高越流畅,这个流畅只是指动作连贯而不是帧数高,但是设置太高会造成输入延迟和可能造成慢动作等问题。
显卡设置中由3D应用程序决定”选项,这个选项的用意是让SketchUp这些应用程序内建的OpenGL引擎控制显卡的驱动设置,SketchUp的OpenGL面板上性能选项才能接手控制。通常我们都采用勾选这个选项。如果在显卡设置面板直接设置渲染帧数则需要不断测试显示结果,同时不是仅仅调整其中某一个参数就能得到所期望的效果。
渲染帧数设置好后在SketchUp里选择加速选项
可能是显卡问题,或者试试把主机和显示器的连线重新连接一次,有时接触不良也会有这种情况。 如果是绿色软件,
图标有锯齿是因为程序自带的资源图标比较小,一般为32X32。
有两个办法处理:
1、准备一个大点的png,vga下用90X90像素应该可以了。在注册表中将绿软快捷方式关联的图标改成你自己的。(至于怎么改,在网上搜一下)
2、用icon工具和资源编辑工具直接替换exe文件的资源图标,这种方法比较省心。不过不是所有的程序修改资源图标以后都能正常使用的,修改前做好备份。
我最近修改了9个绿色软件的图标,只有两个不成功。
根据题主提供的某电压信号函数,t分别取20个点和200个点,那如何来对比这两个波形,并理解其局限性?
对于这个问题,我们这样来讨论:
一、t分别取20个点时的图形
1、使用linspace()函数,在t0,004内划分20个点,即
t=linspace(0,004,20);
2、计算对应的电压值,即
u=15sin(314t+pi/2)+2;
3、使用plot)函数,绘制出u(t)曲线
二、t分别取200个点时的图形
1、使用linspace()函数,在t0,004内划分200个点,即
t=linspace(0,004,200);
2、计算对应的电压值,即
u=15sin(314t+pi/2)+2;
3、使用plot)函数,绘制出u(t)曲线
三、使用hold on命令,将取20个点的u(t)曲线和200个点的u(t)曲线,绘制在同一图窗中
四、使用xlabel()函数和ylabel()函数来标注坐标轴名称,即
xlabel('t');ylabel('u');
五、使用legend()函数来标注各曲线的名称
六、汇总上述代码,运行结果如图。
七、对比这两个波形,我们可以看到,取点少的曲线呈显为锯齿形,取点多的曲线接近于实际。
T0832-1asm
;D/A转换实验,产生方波
;根据CHECK配置信息修改下列符号值
IOY0 EQU 9C00H ;片选IOY0对应的端口始地址
;
DA0832 EQU IOY0+00H4 ;DA0832的端口地址
STACK1 SEGMENT STACK
DW 256 DUP()
STACK1 ENDS
DATA SEGMENT
STR1 DB 'DA0832: Square Wave $' ;定义显示的字符串
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START: MOV AX,DATA
MOV DS,AX
MOV DX,OFFSET STR1 ;显示字符串
MOV AH,9
INT 21H
LOOP1: MOV DX,DA0832 ;写00H,输出低电平
MOV AL,00H
OUT DX,AL
CALL DALLY
MOV DX,DA0832 ;写0FH,输出高电平
MOV AL,7FH
OUT DX,AL
CALL DALLY
MOV AH,1 ;判断是否有按键按下
INT 16H
JZ LOOP1 ;无按键则跳回继续循环,有则退出
QUIT: MOV AX,4C00H ;返回到DOS
INT 21H
DALLY PROC NEAR ;软件延时子程序
PUSH CX
PUSH AX
MOV CX,0050H
D1: MOV AX,5000H
D2: DEC AX
JNZ D2
LOOP D1
POP AX
POP CX
RET
DALLY ENDP
CODE ENDS
END START
;T0832-2asm
;D/A转换实验,产生三角波
;根据CHECK配置信息修改下列符号值
IOY0 EQU 9C00H ;片选IOY0对应的端口始地址
;
DA0832 EQU IOY0+00H4 ;DA0832的端口地址
STACK1 SEGMENT STACK
DW 256 DUP()
STACK1 ENDS
DATA SEGMENT
STR1 DB 'DA0832: Triangle Wave $' ;定义显示的字符串
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
START: MOV AX,DATA
MOV DS,AX
MOV DX,OFFSET STR1 ;显示字符串
MOV AH,9
INT 21H
LOOP1: MOV AL,00H ;D/A转换起始值
UP: MOV DX,DA0832 ;启动D/A转换
OUT DX,AL
CALL DALLY
INC AL
CMP AL,7FH
JNE UP
DOWN: MOV DX,DA0832
OUT DX,AL
CALL DALLY
DEC AL
CMP AL,00H
JNE DOWN
MOV AH,1 ;判断是否有按键按下
INT 16H
JZ LOOP1 ;无按键则跳回继续循环,有则退出
QUIT: MOV AX,4C00H ;返回到DOS
INT 21H
DALLY PROC NEAR ;软件延时子程序
PUSH CX
PUSH AX
MOV CX,0010H
D1: MOV AX,0100H
D2: DEC AX
JNZ D2
LOOP D1
POP AX
POP CX
RET
DALLY ENDP
CODE ENDS
END START
消除cad斜线锯齿需要打开cad中的平滑显示。
具体 *** 作步骤如下所示:
1、在桌面点击打开cad程序。
2、在cad程序页面输入命令3DCONFIG,敲击回车。
3、点击手动调节。
4、选择平滑显示。
5、点击打开平滑显示。
6、点击确定,即可完成 *** 作。
单片机和DAC0832控制输出方波,锯齿波,三角波,正弦波。
#include<at89x51h>
//unsigned char TIME0_H=0xec,TIME0_L=0x78; //定时器0的初值设置;全局变量
#include<sinxh>
#include<0832h>
void main()
{
TMOD=0X01;
TH0=0xff;
TL0=0xd9;
IT0=1; //设置中断触发方式,下降沿
EA=1;
EX0=1;
ET0=1;
IP=0X01; //键盘中断级别高
TR0=1;
while(1)
{
// square();
;
}
}
#ifndef __0832_h__
#define __0832_h__
//#define INPUT XBYTE[0xbfff] //即cs 与xfer 轮流低电平。
//#define DACR XBYTE[0x7fff] //单通道输出,单缓冲就行了。
unsigned char i,sqar_num=128; //最大值100,默认值50
unsigned char cho=0; //0:正弦波。1:方波。2:三角波。3:锯齿波。
unsigned char num=0;
unsigned char TIME0_H=0xff,TIME0_L=0xd9; //定时器0的初值设置;全局变量对应正弦波,锯齿波50HZ
sbit chg= P1^0; //三角波100Hz
sbit freq_u=P1^1;
sbit freq_d=P1^2;
sbit duty_u=P1^3;
sbit duty_d=P1^4;
sbit cs =P3^7;
bit flag=0;
unsigned int FREQ=50;//初始化频率,50HZ
//调节部分——频率
void freq_ud(void)
{
unsigned int temp;
if(freq_d==0)
{ FREQ--; }
else if(freq_u==0)
{ FREQ++; }
if(cho==1|cho==3) //锯齿波256次中断一周期,特殊处理下。否则他的频率是100(+\-)n2Hz
{
temp=0xffff-3906/FREQ; //方波,三角波默认为100hz,切换后频率也为50HZ 65336-10^6/(256FREQ)
TIME0_H=temp/256;
TIME0_L=temp%256;
}
else if(cho==0|cho==3){ //正弦波 三角波默认周期50hz 65536-10^6//(512FREQ)
temp=0xffff-1953/FREQ;
TIME0_H=temp/256;
TIME0_L=temp%256;
}
}
//调节部分——方波的占空比
void duty_ud(void) //方波也采用512次中断构成一个周期。
{
if(duty_d==0&sqar_num>0)
sqar_num--;
else if(duty_u==0&sqar_num<255)
sqar_num++;
}
//波形发生函数
void sint(void)
{
if(!flag)
{
cs=0;P2=sin_num[num++];cs=1;
if(num==0){num=255;flag=1;}
}
else if(flag)
{
cs=0;P2=sin_num[num--];cs=1;
if(num==255){num=0;flag=0;}
}
}
void square(void)
{
if(i++<sqar_num) {cs=0;P2=0XFF;cs=1;}
else{cs=0;P2=0X00;cs=1;}
}
void triangle(void)
{
cs=0;P2=num++;cs=1;
}
void stw(void)
{
if(~flag)
{
cs=0;P2=num++;cs=1;
if(num==0){num=255;flag=1;}
}
else if(flag)
{
cs=0;P2=num--;cs=1;
if(num==255){num=1;flag=0;}
}
}
//按键中断处理程序。
void it0() interrupt 0
{
if(chg==0) { if(++cho==4) {cho=0;num=0;} } //num=0;所有数据从新开始,保证波形的完整性
else if(freq_u==0|freq_d==0)
{freq_ud();}
else if (cho==1&(duty_d==0|duty_u==0))
{duty_ud();}
else ;
}
//定时器中断处理程序。
void intt0() interrupt 1
{
//TH0=0x00;TL0=0x00;sinx();
switch(cho)
{
case 0:{TH0=TIME0_H;TL0=TIME0_L;sint() ;break;} //正弦波//每半周期256取样。
case 1:{TH0=TIME0_H;TL0=TIME0_L;square(); break;} //方波 //为了提高方波的最高频率,只有牺牲占空比的最小可调值。分100份 每次1%。
case 2:{TH0=TIME0_H;TL0=TIME0_L;triangle();break;} //三角波
case 3:{TH0=TIME0_H;TL0=TIME0_L;stw(); break;} //锯齿波
default: ;
}
}
#endif
//正弦表;每半个周期256个取值,最大限度保证波形不失真。
//各个值通过MATLAB算出,并四设五如取整。具体程序如下
#ifndef __sinx_h__
#define __sinx_h__
unsigned char code sin_num[]={
0,0, 0, 0, 0, 0, 0, 0, 1, 1, 1, 1, 1, 2, 2, 2,
2, 3, 3, 4, 4, 4, 5, 5, 6, 6, 7, 7, 8, 8, 9, 9,
10, 10, 11, 12, 12, 13, 14, 15, 15, 16, 17, 18, 18, 19, 20, 21,
22, 23, 24, 25, 25, 26, 27, 28, 29, 30, 31, 32, 34, 35, 36, 37,
38, 39, 40, 41, 42, 44, 45, 46, 47, 49, 50, 51, 52, 54, 55, 56,
57, 59, 60, 61, 63, 64, 66, 67, 68, 70, 71, 73, 74, 75, 77, 78,
80, 81, 83, 84, 86, 87, 89, 90, 92, 93, 95, 96, 98, 99, 101,102,
104, 106, 107, 109, 110, 112, 113, 115, 116, 118, 120, 121, 123, 124, 126, 128,
129, 131, 132, 134, 135, 137, 139, 140, 142, 143, 145, 146, 148, 149, 151, 153,
154, 156, 157, 159, 160, 162, 163, 165, 166, 168, 169, 171, 172, 174, 175, 177,
178, 180, 181, 182, 184, 185, 187, 188, 189, 191, 192, 194, 195, 196, 198, 199,
200, 201, 203, 204, 205, 206, 208, 209, 210, 211, 213, 214, 215, 216, 217, 218,
219, 220, 221, 223, 224, 225, 226, 227, 228, 229, 230, 230, 231, 232, 233, 234,
235, 236, 237, 237, 238, 239, 240, 240, 241, 242, 243, 243, 244, 245, 245, 246,
246, 247, 247, 248, 248, 249, 249, 250, 250, 251, 251, 251, 252, 252, 253, 253,
253, 253, 254, 254, 254, 254, 254, 255, 255, 255, 255, 255, 255, 255, 255, 255
};
#endif
//MATLAB程序:
//x=linspace(-pi/2,pi/2,255);%如果过采用1位采用,很多值是重的。虽然实际中并不会。
//y=(sin(x)+1)/20255;
//%uint32(y)%强制类型转换。
//%fprintf('%f\n',uint32(y));%控制输出类型
//round(y)%四舍五入函数
以上就是关于su导出dwg曲线是锯齿状全部的内容,包括:su导出dwg曲线是锯齿状、有关电脑桌面快捷方式的图标的边缘都发白成锯齿状是什么问题、请问在matlab中怎么写这个程序等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)