Cú pháp:
answer = inputdlg(prompt)
answer = inputdlg(prompt,title)
answer = inputdlg(prompt,title,lineNo)
answer = inputdlg(prompt,title,lineNo,defAns)
answer = inputdlg(prompt,title,lineNo,defAns,Resize)
Trong đó:
prompt Các tring xuất hiện trên các hộp nhập liệu title Tiêu đề của hộp thoại
lineNo Số dòng trong ô nhập liệu
defAns Kết quả nhập liệu mặc định (xuất hiện ban đầu)
resize Cho phép hay không thay đổi kích thước dialog box
'on' hay 'off'
Ví dụ:
prompt = {'Enter matrix size:','Enter colormap name:'};
title = 'Input for peaks function';
lines= 1;
def = {'20','hsv'};
answer = inputdlg(prompt,title,lines,def);
32 trang |
Chia sẻ: thienmai908 | Lượt xem: 1430 | Lượt tải: 0
Bạn đang xem trước 20 trang nội dung tài liệu Hướng dẫn Matlab Guide, để xem tài liệu hoàn chỉnh bạn click vào nút DOWNLOAD ở trên
edit_laymau,'enable','off')
elseif value==2 %FSK
set(handles.edit_Fc,'enable','off')
set(handles.edit_Fmark,'enable','on')
set(handles.edit_laymau,'enable','on')
elseif value==3 %PSK
set(handles.edit_Fc,'enable','on')
set(handles.edit_Fmark,'enable','off')
set(handles.edit_laymau,'enable','off')
end
% --- Executes on button press in pushbutton_BD.
function pushbutton_BD_Callback(hObject, eventdata, handles)
Biendieu(handles);
% --- Executes during object creation, after setting all properties.
function frame1_CreateFcn(hObject, eventdata, handles)
handles=guihandles(gcbo);
Biendieu(handles);
% --- Ham bien dieu
function Biendieu(handles)
% Nhan chuoi so
binary_seq=get(handles.edit_chuoiso,'string');
binary_seq=str2num(binary_seq);
%Nhan gia tri toc do bit
R=get(handles.edit_tocdo,'string');
R=eval(R);
%Nhan gia tri Fc
Fc=get(handles.edit_Fc,'string');
Fc=eval(Fc);
%Nhan gia tri hang lay mau
Sampling=get(handles.edit_laymau,'string');
Sampling=eval(Sampling);
%Nhan gia tri Fmark(Fcmin) la tan so nho nhat cua song mang
Fmark=get(handles.edit_Fmark,'string');
Fmark=eval(Fmark);
%Nhan gia tri Fspace(Fcmin) la tan so cao nhat cua song mang
Fspace=get(handles.edit_Fspace,'string');
Fspace=eval(Fspace);
Fs=R*Sampling;
%Xet muc duoc chon trong popupmenu
LoaiBD=get(handles.popupmenu_BD,'value');
if LoaiBD==1 %ASK
if (Fc>=(R*Sampling)/2) ErrorDlg('Fspace<Sampling*(R/2)');
return;
end
ve_digital(handles,binary_seq,Fs)
out=ASK(handles,binary_seq,Fc,Fs,R);
Pho_digital(handles,out);
set(handles.text_title,'string','Bien dieu ASK')
elseif LoaiBD==2 %FSK
if (Fc>=(R*Sampling)/2) ErrorDlg('Fspace<Sampling*(R/2)');
return;
end
if (Fmark=R');
return;
end
ve_digital(handles,binary_seq,Fs)
out=FSK(handles,binary_seq,[Fmark Fspace],Fs,R);
Pho_digital(handles,out);
set(handles.text_title,'string','Bien dieu FSK')
elseif LoaiBD==3 %PSK
if (Fc>=(R*Sampling)/2) ErrorDlg('Fspace<Sampling*(R/2)');
return;
end
ve_digital(handles,binary_seq,Fs)
out=PSK(handles,binary_seq,Fc,Fs,R);
Pho_digital(handles,out);
set(handles.text_title,'string','Bien dieu PSK')
end
% Ham ve tin hieu so
function ve_digital(handles,binary_seq,Fs)
SAMPLING_FREQ=Fs;
Ts=1/SAMPLING_FREQ;
binary_seq=binary_seq(:); %Doi thanh cot
no_sample=length(binary_seq); %Xet chieu dai chuoi
amplitude=max(abs(binary_seq));
time=[1:(no_sample)]*Ts;
ax=[min(time)/100 max(time) -2*amplitude 2*amplitude];
axes(handles.axes1)
stair(time,binary_seq); %Ham ve tin hieu so
axis(ax);
set(gca,'XTickLabel',{'','','','','',''});
xlabel('Tin hieu nen','fontname','SVNhelvetica','fontsize',12,'color','r');
% --- Ham stair ---
function [xo,yo]=stair(x,y)
n=length(x);
if nargin==1
y=x; x=1:n;
end
delta=(max(x)-min(x))/(n-1);
nn=2*n; yy=zeros(nn+2,1); xx=yy;
t=x(:)'-delta; xx(1:2:nn)=t; xx(2:2:nn)=t;
xx(nn+1:nn+2)=t(n)+[delta;delta];
yy(2:2:nn)=y; yy(3:2:nn+1)=y;
if nargout==0
plot(xx,yy)
else
xo=xx; yo=yy;
end
% Ham bien dieu ASK
function out=ASK(handles,binary_seq,Fc,Fs,R)
%Tao data cua dang song khong tro ve zero nrz
x=wave_gen(handles,binary_seq,'unipolar_nrz',Fs,R);
out=mixer(x,osc(Fc,Fs));
Ts=1/Fc;
out=out(:);
no_sample=length(out);
amplitude=max(abs(out));
t=[1:(no_sample)]*Ts;
ax=[min(t) max(t) -2*amplitude 2*amplitude]
axes(handles.axes2) y=plot(t,out); axis(ax);
set(gca,'XTickLabel',{'','','','','',''});
xlabel('Tin hieu sau khi bien dieu','fontname','SVNhelvetica','fontsize',12,'color','r');
% Ham tao dang song nrz
function out=wave_gen(handles,binary_sequence,linecode,Fs,Rb)
binary_sequence=binary_sequence(:);
if (any(abs(binary_sequence)-sign(binary_sequence)))
error('Khong phai tin hieu digital')
end
if strcmp(linecode,'unipolar_nrz') pulse='rect_nrz(Rb,Fs)';
b_seq=binary_sequence;
elseif strcmp(linecode,'polar_nrz')
pulse='rect_nrz(Rb,Fs)';
b_seq=bin2pol(handles,binary_sequence);
else
error('Ma khong phu hop')
end
x=(b_seq*eval(pulse))';
out=x(:);
%Tao tin hieu khong tro ve zero
function out=rect_nrz(Rb,Fs)
out=ones(1,Fs/Rb);
%Ham tao song mang
function [carrier]=osc(fc,Fs)
t=[1:50000]/Fs;
carrier=sin(2*pi*t*fc);
% Ham tron 2 tin hieu
function [out]=mixer(in,fc)
%Z=MIXER(X,Y) Tao chuoi Z: Z(n)=X(n)*Y(n)
n=length(in);
carrier=fc(1:n);
x=in;
x=x(:)';
out=carrier.*x;
% Ham ve pho
function Pho_digital(handles,x)
x=x(:);
xx=fft(x,512);
Pxx=xx.*conj(xx)/512;
f=1000*(0:255)/512;
no_sample=length(Pxx);
amplitude=max(abs(Pxx));
ax=[min(f) max(f) -2*amplitude 2*amplitude]
axes(handles.axes3)
plot(f,Pxx(1:256),'r');
axis(ax);
set(gca,'XTickLabel',{'','','','','',''});
xlabel('Pho cua song bien dieu','fontname','SVNhelvetica','fontsize',12,'color','r');
%Ham bien dieu FSK
function out=FSK(handles,binary_seq,Fc,Fs,Rb)
CARRIER_FREQUENCY=[min(Fc) max(Fc)];
x=wave_gen(handles,binary_seq,'polar_nrz',Fs,Rb);
f_r=(CARRIER_FREQUENCY(2)+CARRIER_FREQUENCY(1))/2
kf=(CARRIER_FREQUENCY(2)-CARRIER_FREQUENCY(1))/2
out=vco_digital(x,f_r,kf,Fs);
Ts=1/f_r; out=out(:);
no_sample=length(out);
amplitude=max(abs(out));
t=[1:(no_sample)]*Ts;
ax=[min(t) max(t) -2*amplitude 2*amplitude]
axes(handles.axes2)
y=plot(t,out);
axis(ax);
set(gca,'XTickLabel',{'','','','','',''});
xlabel('Tin hieu sau khi bien dieu','fontname','SVNhelvetica','fontsize',12,'color','r');
% Ham luong cuc hoa chuoi nhi phan vao
function [polar_sequence]=bin2pol(handles,binary_sequence)
polar_sequence=2*binary_sequence-ones(size(binary_sequence));
% Dao dong duoc dieu khien bang dien the
function [out]=vco_digital(in,arg2,arg3,Fs)
Ts=1/Fs; fc=arg2; kf=arg3;
lenfc=ones(length(in),1)*fc;
phase=cumsum((lenfc+in*kf)*Ts*2*pi);
out=sin(phase);
% Ham bien dieu PSK
function out=PSK(handles,binary_seq,Fc,Fs,Rb)
x=wave_gen(handles,binary_seq,'polar_nrz',Fs,Rb);
out=mixer(x,osc(Fc,Fs));
Ts=1/Fc; out=out(:);
no_sample=length(out);
amplitude=max(abs(out));
t=[1:(no_sample)]*Ts;
ax=[min(t) max(t) -2*amplitude 2*amplitude]
axes(handles.axes2)
plot(t,out);
axis(ax);
set(gca,'XTickLabel',{'','','','','',''});
xlabel('Tin hieu sau khi bien dieu','fontname','SVNhelvetica','fontsize',12,'color','r');
3. Chạy ứng dụng:
IX.CÁC HỘP HỘI THOẠI DIALOG CỦA WINDOWS
Các hộp thoại dialog:
Dialog boxes
Ý nghĩa
errordlg
Tạo dialog box báo lỗi
helpdlg
Hiển thị một dialog box giúp đỡ
inputdlg
Tạo một dialog box nhập liệu
listdlg
Tạo một dialog danh sách chọn lựa
msgbox
Tạo một dialog box thông tin
pagedlg
Tạo một dialog box page layout
printdlg
Hiển thị một dialog in
Dialog boxes
Ý nghĩa
questdlg
Tạo một dialog hỏi
uigetfile
Hiển thị dialog box nhận tên của file cần đọc
uiputfile
Hiển thị dialog box nhận tên của file để ghi
uisetcolor
Chọn màu bằng bảng màu của windows
uisetfont
Chọn font
warndlg
Tạo một dialog cảnh báo
CHƯƠNG 7: GUI VÀ ỨNG DỤNG
IX.CÁC HỘP HỘI THOẠI DIALOG CỦA WINDOWS
1. errordlg
Cú pháp:
errordlg errordlg('errorstring')
errordlg('errorstring','dlgname')
errordlg('errorstring','dlgname','on')
%'on' Î cho phép hay không thay thế dialog có cùng tên
h = errordlg(...)
Ví dụ:
errordlg('File not found','File Error')
2. helpdlg
Cú pháp:
helpdlg helpdlg('helpstring')
helpdlg('helpstring','dlgname')
h = helpdlg(...)
Ví dụ:
helpdlg('Choose 10 points from the figure','Point Selection');
3. inputdlg
Cú pháp:
answer = inputdlg(prompt)
answer = inputdlg(prompt,title)
answer = inputdlg(prompt,title,lineNo)
answer = inputdlg(prompt,title,lineNo,defAns)
answer = inputdlg(prompt,title,lineNo,defAns,Resize)
Trong đó:
prompt Î Các tring xuất hiện trên các hộp nhập liệu title Î Tiêu đề của hộp thoại
lineNo Î Số dòng trong ô nhập liệu
defAns Î Kết quả nhập liệu mặc định (xuất hiện ban đầu)
resize Î Cho phép hay không thay đổi kích thước dialog box
'on' hay 'off'
Ví dụ:
prompt = {'Enter matrix size:','Enter colormap name:'};
title = 'Input for peaks function';
lines= 1;
def = {'20','hsv'};
answer = inputdlg(prompt,title,lines,def);
4. listdlg
Cú pháp:
[Selection,ok] = listdlg('ListString',S,...)
% Cho phép chọn một hay nhiều item trong danh sách
Trong đó:
Selection Î vector chứa các string được chọn
ok = 1 Î khi chọn nút OK
0 Î khi chọn cancel hoặc đóng hộp thoại
S là các thông số trong bảng sau:
Parameter
Ý nghĩa
'ListString'
Dãy các chuỗi để chọn nằm trong list box 'single' chỉ cho chọn 1
'SelectionMode'
'multiple' (the default) cho phép chọn nhiều
'ListSize'
Kích thước list box, tính bằng pixel,là vector [width height]. Mặc định là [160 300]
'InitialValue'
Item được chọn ban đầu. Mặc định là 1 (item đầu)
'Name'
Tieu đề của dialog box. Mặc định là ' '
'PromptString'
Các string xuất hiện phía trên listbox. Mặc định {}
'OKString'
String cho nút nhấn OK. Mặc định là 'OK'
'CancelString'
String cho nút nhấn Cancel. Mặc định là 'Cancel'.
Ví dụ:
d=dir;
str={d.name};
[s,v]=listdlg('PromptString','Select a file:','SelectionMode','single','ListString',str)
5. msgbox
Cú pháp: msgbox(message) msgbox(message,title)
msgbox(message,title,'icon') msgbox(message,title,'custom',iconData,iconCmap) msgbox(...,'createMode')
h = msgbox(...)
Trong đó:
'icon' Î là {'none','error','help','warn','custom'}
iconData Î chứa dữ liệu ảnh tạo nên icon
iconCmap Î Màu dùng cho ảnh
'createMode' Î {'modal','non-modal', 'replace'}
Ví dụ:
msgbox('Day la icon giup do','Vi du ve msgbox','help')
msgbox('Day la icon bao loi','Vi du ve msgbox','error')
msgbox('Day la icon canh bao','Vi du ve msgbox','warn')
msgbox('Day la icon binh thuong','Vi du ve msgbox')
6. pagedlg
Cú pháp:
pagedlg
pagedlg(fig)
7. printdlg
Cú pháp: printdlg printdlg(fig)
printdlg('-crossplatform',fig)
printdlg('-setup',fig)
Ví dụ:
printdlg(fig) Î in cửa sổ đồ họa được chỉ định
printdlg('-crossplatform',fig) Î sử dụng chuẩn của Matlab
printdlg('-setup',fig) Î cho phép cài đặt thông số in
8. questdlg
Cú pháp:
button = questdlg('qstring')
button = questdlg('qstring','title')
button = questdlg('qstring','title','default')
button = questdlg('qstring','title','str1','str2','default')
button = questdlg('qstring','title','str1','str2','str3','default')
% hộp thoại có 3 nút 'Yes', 'No', 'Cancel‘
% button nhận giá trị trả về
Trong đó:
'default' Î Nút chọn mặc định {'Yes', 'No', 'Cancel'}
'str1','str2','str3' Î Tạo các nút nhấn có tên…
Ví dụ:
button = questdlg('Do you want to continue?',...
'Continue Operation','Yes','No','Help','No');
if strcmp(button,'Yes') disp('Creating file')
elseif strcmp(button,'No') disp('Canceled file operation')
elseif strcmp(button,'Help') disp('Sorry, no help available')
end
9. uigetfile
Cú pháp:
uigetfile uigetfile('FilterSpec')
uigetfile('FilterSpec','DialogTitle')
uigetfile('FilterSpec','DialogTitle',x,y)
[fname,pname] = uigetfile(...)
Trong đó:
'FilterSpec' Î Lọc chọn các tập tin. Mặc định là *.m
[x,y] Î Vị trí xuất hiện hộp thoại
[fname,pname] Î Trả về tên tập tin và đường dẫn
Ví dụ:
>> [fname,pname] = uigetfile('*.m','Sample Dialog Box')
fname = canhhoa.m pname = D:\work\
10. uiputfile
Cú pháp:
uiputfile uiputfile('InitFile')
uiputfile('InitFile','DialogTitle')
uiputfile('InitFile','DialogTitle',x,y)
[fname,pname] = uiputfile(...)
Trong đó:
'InitFile' Î Hộp thoại hiển thị các file trong thư mục hiện hành xác định bởi 'InitFile'
[fname,pname] Î Trả về tên file và đường dẫn ghi file
Ví dụ:
>> [newfile,newpath] = uiputfile('animinit.m','Save file name');
newfile = animinit.m newpath = D:\work\
11. warndlg
Cú pháp:
h = warndlg('warningstring','dlgname')
Ví dụ:
warndlg('Pressing OK will clear memory','!! Warning !!')
Các file đính kèm theo tài liệu này:
- TaiLieuTongHop.Com---Huong dan Matlab Guide.doc