I II III IV V. 16 A. 17 B. 18
|
|
- 시연 석
- 6 years ago
- Views:
Transcription
1 : ( )
2 I II III IV V. 16 A. 17 B. 18
3 I. 1.1,.. NFC(Near Field Communication) NFC. NFC
4 그림 1 예상구상도 100% 그림 2 쿠도이노사진
5 .. MAC(Media Access Control Address). MAC NIC(Network Interface Card) 48. MAC MAC. II ,,.,.. ' (OHA Open Handset Alliance)' (Google), ' '. (Linux) 2.6 (OS;operating system),, - 3 -
6 ... ' '..,..., (Microcontroller). LED.... (Atmel AVR),...,. C++++ C++.,, LED,,, ( )
7 그림 3 쿠도이노핀번호 2.2 그림 4 어플리케이션의동작순서 - 5 -
8 MAC.. Lock/Unlock. 그림 5 어플리케이션기본레이아웃. if (BTSerial.available()) Serial.println(BTSerial.read()); Lock/Unlock
9 III. 3.1 표 3.1 업무분담표 팀원 김동식 송지호 업무분담업무 - 어플리케이션프로그램제작 - 아두이노스케쳐를사용하여쿠도이소소스코딩 - 프로그래밍화면디자인 - 졸업작품전시회출품및결과발표 - 쿠도이노를이용한하드웨어적부분제작 - 프로그램디버깅 - 작품실행및성능평가 - 졸업작품전시회출품및결과발표 3.2 표 주제선정도어락회로분석블루투스모듈, 쿠도이노 set 자료조사회로구성블루투스통신및쿠도이노 코딩도어락모터제어오픈소스활용도어락블루 투스제어어플리케이션제작기능수정 - 7 -
10 l (NT910S3Q-MD1S, ) l ( SⅡ) l l l l 3.4 l l l Microsoft Windows 7 pro 32 Eclips l Java SE 2.1a l - 8 -
11 IV. 4.1 그림 6 작품전체사진 그림 7 도어락본체사진 - 9 -
12 그림 8 쿠도이노사진
13 그림 9 어플리케이션
14 , - -. RSSI -. LED
15 V. [1],,, [2],,, [3],,,
16 A. (, ) #include<softwareserial.h> SoftwareSerial BTSerial(13, 12); int input_1 = 11; int input_2 = 10; // & // void setup() { Serial.begin(9600); BTSerial.begin(9600); pinmode(11,output); pinmode(10,output); void loop() { if (BTSerial.available()) { // Serial.println(BTSerial.read()); // int abc; abc = BTSerial.read(); //data if(abc=='4') { digitalwrite(11, HIGH); digitalwrite(10, LOW); delay(800); digitalwrite(11, HIGH); digitalwrite(10, HIGH);
17 if(abc =='0') { digitalwrite(11, LOW); digitalwrite(10, HIGH); delay(800); digitalwrite(11, HIGH); digitalwrite(10, HIGH); if(abc =='5') { digitalwrite(11, LOW); digitalwrite(10, LOW): if(abc =='7') { digitalwrite(11, HIGH); digitalwrite(10, HIGH);
18 B. <MainActivity.java> package kr.re.dev.arduinoecho; import java.io.ioexception;import java.io.inputstream; import java.io.outputstream; import java.lang.reflect.field; import java.nio.bytebuffer; import java.util.linkedlist; import java.util.set; import kr.re.dev.bluetooth.bluetoothserialclient; import kr.re.dev.bluetooth.bluetoothserialclient.bluetoothstreaminghandler; import kr.re.dev.bluetooth.bluetoothserialclient.onbluetoothenabledlistener; import kr.re.dev.bluetooth.bluetoothserialclient.onscanlistener; import kr.re.dev.bluetoothecho.r; import android.app.activity; import android.app.alertdialog; import android.app.progressdialog; import android.bluetooth.bluetoothdevice; import android.bluetooth.bluetoothsocket; import android.content.dialoginterface; import android.content.intent; import android.content.dialoginterface.oncancellistener; import android.graphics.color; import android.os.bundle; import android.text.html; import android.text.method.scrollingmovementmethod; import android.util.log; import android.view.menu; import android.view.menuitem; import android.view.view; import android.view.view.onclicklistener; import android.view.viewconfiguration; import android.widget.adapterview; import android.widget.adapterview.onitemclicklistener; import arduino.bt.simplebt.bluetoothservice; import arduino.bt.simplebt.devicelistactivity; import android.widget.arrayadapter; import android.widget.button; import android.widget.edittext; import android.widget.listview; import android.widget.textview; import android.widget.toast; public class MainActivity extends Activity { private static final boolean D = false;
19 private static final String TAG = null; protected static final String mdevices = null; private LinkedList<BluetoothDevice> mbluetoothdevices = new LinkedList<BluetoothDevice>(); private ArrayAdapter<String> mdevicearrayadapter; private EditText medittextinput; private TextView mtextview; private Button mbuttonsend; private Button mrock; private Button munrock; private boolean mconnecttoselectddevice; private ProgressDialog mloadingdialog; private AlertDialog mdevicelistdialog; private Menu mmenu; private BluetoothSerialClient mclient; private boolean write; private Object mremotedevice; private Object mbluetoothadapter; protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); setcontentview(r.layout.activity_main); mclient = BluetoothSerialClient.getInstance(); if(mclient == null) { Toast.makeText(getApplicationContext(), "Cannot use the Bluetooth device.", Toast.LENGTH_SHORT).show(); finish(); overflowmenuinactionbar(); initprogressdialog(); initdevicelistdialog(); initwidget(); private void overflowmenuinactionbar(){ try { ViewConfiguration config = ViewConfiguration.get(this); Field menukeyfield = ViewConfiguration.class.getDeclaredField("sHasPermanentMenuKey"); if(menukeyfield!= null) { menukeyfield.setaccessible(true); menukeyfield.setboolean(config, false); catch (Exception ex) { //. 3.x. //, 3.x
20 protected void onpause() { mclient.cancelscan(getapplicationcontext()); super.onpause(); protected void onresume() { super.onresume(); enablebluetooth(); private void initprogressdialog() { mloadingdialog = new ProgressDialog(this); mloadingdialog.setcancelable(false); private void initwidget() { mtextview = (TextView) findviewbyid(r.id.textviewterminal); mtextview.setmovementmethod(new ScrollingMovementMethod()); medittextinput = (EditText) findviewbyid(r.id.edittextinput); mbuttonsend = (Button) findviewbyid(r.id.buttonsend); mrock=(button)findviewbyid(r.id.rock); munrock=(button)findviewbyid(r.id.unrock); mbuttonsend.setonclicklistener(new OnClickListener(){ public void onclick(view v) { sendstringdata(medittextinput.gettext().tostring(), 0); medittextinput.settext(""); ); mrock.setonclicklistener(new OnClickListener(){ public void onclick(view v) { sendstringdata(medittextinput.gettext().tostring(), 0); medittextinput.settext(" (00)\n**************************"); sendstringdata(medittextinput.gettext().tostring(), 0); medittextinput.settext(""); ); munrock.setonclicklistener(new OnClickListener(){ public void onclick(view v) { sendstringdata(medittextinput.gettext().tostring(), 0); medittextinput.settext(" (44)\n**************************"); sendstringdata(medittextinput.gettext().tostring(), 0); medittextinput.settext("");
21 { ); private void initdevicelistdialog() { mdevicearrayadapter = new ArrayAdapter<String>(getApplicationContext(), R.layout.item_device); ListView listview = new ListView(getApplicationContext()); listview.setadapter(mdevicearrayadapter); listview.setonitemclicklistener(new OnItemClickListener() { public void onitemclick(adapterview<?> parent, View view, int position, long id) String item = (String) parent.getitematposition(position); for(bluetoothdevice device : mbluetoothdevices) { if(item.contains(device.getaddress())) { connect(device, mclient); mdevicelistdialog.cancel(); ); AlertDialog.Builder builder = new AlertDialog.Builder(this); builder.settitle("select bluetooth device"); builder.setview(listview); builder.setpositivebutton("scan", new DialogInterface.OnClickListener() { public void onclick(dialoginterface dialog, int id) { scandevices(); ); mdevicelistdialog = builder.create(); mdevicelistdialog.setcanceledontouchoutside(false); private void adddevicetoarrayadapter(bluetoothdevice device) { if(mbluetoothdevices.contains(device)) { mbluetoothdevices.remove(device); mdevicearrayadapter.remove(device.getname() + "\n" + device.getaddress()); mbluetoothdevices.add(device); mdevicearrayadapter.add(device.getname() + "\n" + device.getaddress() ); mdevicearrayadapter.notifydatasetchanged(); private void enablebluetooth() { BluetoothSerialClient btset = mclient; btset.enablebluetooth(this, new OnBluetoothEnabledListener() {
22 public void onbluetoothenabled(boolean success) { if(success) { getpaireddevices(); else { finish(); ); private void addtext(string text) { mtextview.append(text); final int scrollamount = mtextview.getlayout().getlinetop(mtextview.getlinecount()) - mtextview.getheight(); if (scrollamount > 0) mtextview.scrollto(0, scrollamount); else mtextview.scrollto(0, 0); private void getpaireddevices() { Set<BluetoothDevice> devices = mclient.getpaireddevices(); for(bluetoothdevice device: devices) { adddevicetoarrayadapter(device); mconnecttoselectddevice(); private void mconnecttoselectddevice() { // TODO Auto-generated method stub private void scandevices() { BluetoothSerialClient btset = mclient; btset.scandevices(getapplicationcontext(), new OnScanListener() { String message =""; public void onstart() { Log.d("Test", "Scan Start."); mloadingdialog.show(); message = "Scanning..."; mloadingdialog.setmessage("scanning...");
23 mloadingdialog.setcancelable(true); mloadingdialog.setcanceledontouchoutside(false); mloadingdialog.setoncancellistener(new OnCancelListener() { public void oncancel(dialoginterface dialog) { BluetoothSerialClient btset = mclient; btset.cancelscan(getapplicationcontext()); ); public void onfounddevice(bluetoothdevice bluetoothdevice) { adddevicetoarrayadapter(bluetoothdevice); message= "\n" + bluetoothdevice.getname() + "\n" + bluetoothdevice.getaddress(); mloadingdialog.setmessage(message); public void onfinish() { Log.d("Test", "Scan finish."); message = ""; mloadingdialog.cancel(); mloadingdialog.setcancelable(false); mloadingdialog.setoncancellistener(null); mdevicelistdialog.show(); ); void connecttoselectddevice(object msocket) { mremotedevice = getdevicefrombondedlist(accessibility_service); java.util.uuid uuid = UUID.fromString(" f9b34fb"); try { // msocket = ((BluetoothDevice) mremotedevice).createrfcommsockettoservicerecord(uuid); // RFCOMM ((BluetoothSocket) msocket).connect(); // OutputStream moutputstream = ((BluetoothSocket) msocket).getoutputstream(); Object minputstream = ((BluetoothSocket) msocket).getinputstream(); // beginlistenfordata();
24 catch(exception e) { // finish(); // private void beginlistenfordata() { // TODO Auto-generated method stub private Object getdevicefrombondedlist(string selecteddevicename) { // TODO Auto-generated method stub return null; private void connect(bluetoothdevice device, BluetoothSerialClient handler) { mloadingdialog.setmessage("connecting..."); mloadingdialog.setcancelable(false); mloadingdialog.show(); BluetoothSerialClient btset = mclient; btset.connect(getapplicationcontext(), device, mbthandler); handler.write("44".getbytes()); /* try { Thread.sleep(12000); catch (InterruptedException e) { // TODO Auto-generated catch block e.printstacktrace(); handler.write("00".getbytes());*/ /* */ private BluetoothStreamingHandler mbthandler = new BluetoothStreamingHandler() { ByteBuffer mmbytebuffer = ByteBuffer.allocate(1024); public void onerror(exception e) { mloadingdialog.cancel(); addtext("blue : Connection error - " + e.tostring() + "\n"); mmenu.getitem(0).settitle(r.string.action_connect); public void ondisconnected() { mmenu.getitem(0).settitle(r.string.action_connect); mloadingdialog.cancel(); addtext("blue : Disconnected.\n");
25 public void ondata(byte[] buffer, int length) { if(length == 0) return; if(mmbytebuffer.position() + length >= mmbytebuffer.capacity()) { ByteBuffer newbuffer = ByteBuffer.allocate(mmByteBuffer.capacity() * 2); newbuffer.put(mmbytebuffer.array(), 0, mmbytebuffer.position()); mmbytebuffer = newbuffer; mmbytebuffer.put(buffer, 0, length); if(buffer[length - 1] == '\0') { addtext(mclient.getconnecteddevice().getname() + " : " + new String(mmByteBuffer.array(), 0, mmbytebuffer.position()) + '\n'); mmbytebuffer.clear(); public void onconnected() { addtext(" 1.. ## & ##\n" 2.. ## ## \n " + "3..\n 4. 5.\n # bluetooth name : " + " " + mclient.getconnecteddevice().getname() + "\n\n\n"); mloadingdialog.cancel(); mmenu.getitem(0).settitle(r.string.action_disconnect); ; private BluetoothSerialClient handler; private void sendmessage(charsequence message) { if (mbtservice.getstate()!= BluetoothService.STATE_CONNECTED) Toast.makeText(getApplicationContext(), message, Toast.LENGTH_SHORT).show(); return; public void sendstringdata(string data, int length) { data += '\0'; byte[] buffer = data.getbytes(); if(mbthandler.write(buffer)) { addtext("blue : " + data + '\n'); //************************************************************************* protected void ondestroy() { super.ondestroy();
26 mclient.claer(); ; public boolean oncreateoptionsmenu(menu menu) { getmenuinflater().inflate(r.menu.main, menu); mmenu = menu; return true; public boolean onoptionsitemselected(menuitem item) { boolean connect = mclient.isconnection(); if(item.getitemid() == R.id.action_connect) { if (!connect) { mdevicelistdialog.show(); else { mbthandler.close(); return true; else { showcodedlg(); return true; private void showcodedlg() { TextView codeview = new TextView(this); codeview.settext(html.fromhtml(readcode())); codeview.setmovementmethod(new ScrollingMovementMethod()); codeview.setbackgroundcolor(color.parsecolor("#202020")); new AlertDialog.Builder(this, android.r.style.theme_holo_light_dialogwhenlarge).setview(codeview).setpositivebutton("ok", new AlertDialog.OnClickListener() { public void onclick(dialoginterface dialog, int which) { dialog.cancel(); ).show(); private String readcode() { try { InputStream is = getassets().open("hc_06_echo.txt"); int length = is.available(); byte[] buffer = new byte[length]; is.read(buffer); is.close(); String code = new String(buffer); buffer = null;
27 return code; catch (IOException e) { e.printstacktrace(); return ""; public void Rock(View view){ sendmessage("00"); public void Unrock(View view){ sendmessage("44"); //*************************************************************************
28 <Bluetoothserialclient.java> package kr.re.dev.bluetooth; import java.io.ioexception; import java.io.inputstream; import java.io.outputstream; import java.util.set; import java.util.uuid; import java.util.concurrent.executorservice; import java.util.concurrent.executors; import java.util.concurrent.atomic.atomicboolean; import android.app.activity; import android.bluetooth.bluetoothadapter; import android.bluetooth.bluetoothdevice; import android.bluetooth.bluetoothsocket; import android.content.broadcastreceiver; import android.content.context; import android.content.intent; import android.content.intentfilter; import android.os.bundle; import android.os.handler; import android.os.looper; public class BluetoothSerialClient { static final private String SERIAL_UUID = " F9B34FB"; static private BluetoothSerialClient sthis = null; private static String address = "20:15:06:10:58:94"; private BluetoothAdapter mbluetoothadapter; private OnBluetoothEnabledListener monbluetoothuplistener; private OnScanListener monscanlistener; private BluetoothSocket mbluetoothsocket; private UUID muuid = UUID.fromString(SERIAL_UUID); private AtomicBoolean misconnection = new AtomicBoolean(false); private ExecutorService mreadexecutor; private ExecutorService mwriteexecutor; private BluetoothStreamingHandler mbluetoothstreaminghandler; private Handler mmainhandler = new Handler(Looper.getMainLooper()); private BluetoothDevice cbnublue; private BluetoothDevice mconnecteddevice= cbnublue; private InputStream minputstream; private OutputStream moutputstream; /** * BluetoothSerialClient. BluetoothSerialClient. null
29 */ public static BluetoothSerialClient getinstance() { if(sthis == null) { sthis = new BluetoothSerialClient(); if(sthis.mbluetoothadapter == null) { sthis = null; return null; return sthis; private BluetoothSerialClient() { mbluetoothadapter = BluetoothAdapter.getDefaultAdapter(); mreadexecutor = Executors.newSingleThreadExecutor(); mwriteexecutor = Executors.newSingleThreadExecutor(); /** *. *. */ public void claer() { close(); mreadexecutor.shutdownnow(); mwriteexecutor.shutdownnow(); sthis = null; /** *. <br/> *,. context activity onbluetoothenabledlistener on/off. */ public void enablebluetooth(context context, OnBluetoothEnabledListener onbluetoothenabledlistener) { if(!mbluetoothadapter.isenabled()) { monbluetoothuplistener = onbluetoothenabledlistener; Intent intent = new Intent(context, BluetoothUpActivity.class); context.startactivity(intent); else { onbluetoothenabledlistener.onbluetoothenabled(true); /**
30 *. false off. */ public boolean isenabled() { return mbluetoothadapter.isenabled(); /** *. context device. {@link getpaireddevices {@link scandevices. bluetoothstreaminghandler. false. {@link enablebluetooth. */ public boolean connect(final Context context,final BluetoothDevice device, final BluetoothStreamingHandler bluetoothstreaminghandler) { if(!isenabled()) return false; mconnecteddevice = device; mbluetoothstreaminghandler = bluetoothstreaminghandler; if(isconnection()) { mwriteexecutor.execute(new Runnable() { public void run() { try { misconnection.set(false); mbluetoothsocket.close(); Thread.sleep(2000); catch (InterruptedException e) { e.printstacktrace(); catch (IOException e) { e.printstacktrace(); connect(context, device, bluetoothstreaminghandler); ); else { misconnection.set(true); connectclient(); return true; /** *. */
31 public Set<BluetoothDevice> getpaireddevices() { Set<BluetoothDevice> paireddevices = mbluetoothadapter.getbondeddevices(); if(paireddevices.size() > 0){ BluetoothDevice getdevicefrombondedlist; { BluetoothDevice selecteddevice = null; //. return paireddevices; // TODO Auto-generated method stub /** *. context OnScanListener. */ public boolean scandevices(context context, OnScanListener OnScanListener) { if(!mbluetoothadapter.isenabled()) return false; if(mbluetoothadapter.isdiscovering()) { mbluetoothadapter.canceldiscovery(); try { context.unregisterreceiver(mdiscoveryreceiver); catch(illegalargumentexception e) { e.printstacktrace(); monscanlistener = OnScanListener; IntentFilter filterfound = new IntentFilter(BluetoothDevice.ACTION_FOUND); filterfound.addaction(bluetoothadapter.action_discovery_started); filterfound.addaction(bluetoothadapter.action_discovery_finished); context.registerreceiver(mdiscoveryreceiver, filterfound); mbluetoothadapter.startdiscovery(); return true; /** *. context */ public void cancelscan(context context) { if(!mbluetoothadapter.isenabled()!mbluetoothadapter.isdiscovering()) return;
32 mbluetoothadapter.canceldiscovery(); try { context.unregisterreceiver(mdiscoveryreceiver); catch(illegalargumentexception e) { e.printstacktrace(); if(monscanlistener!= null) monscanlistener.onfinish(); /** *. true/false */ public boolean isconnection() { return misconnection.get(); /** *. null. */ public BluetoothDevice getconnecteddevice() { return mconnecteddevice; private void connectclient() { try { mbluetoothsocket = mconnecteddevice.createrfcommsockettoservicerecord(muuid); catch (IOException e) { close(); e.printstacktrace(); mbluetoothstreaminghandler.onerror(e); return; mwriteexecutor.execute(new Runnable() { public void run() { try { mbluetoothadapter.canceldiscovery(); mbluetoothsocket.connect(); manageconnectedsocket(mbluetoothsocket); callconnectedhandlerevent(); mreadexecutor.execute(mreadrunnable); catch (final IOException e) { close(); e.printstacktrace(); mmainhandler.post(new Runnable() { public void run() {
33 mbluetoothstreaminghandler.onerror(e); ); misconnection.set(false); try { mbluetoothsocket.close(); catch (Exception ec) { ec.printstacktrace(); ); private void manageconnectedsocket(bluetoothsocket socket) throws IOException { minputstream = socket.getinputstream(); moutputstream = socket.getoutputstream(); private void callconnectedhandlerevent() { mmainhandler.post(new Runnable() { public void run() { mbluetoothstreaminghandler.onconnected(); ); public boolean write(final byte[] buffer) { if(!misconnection.get()) return false; mwriteexecutor.execute(new Runnable() { public void run() { try { moutputstream.write(buffer); catch (Exception e) { close(); e.printstacktrace(); mbluetoothstreaminghandler.onerror(e); ); return true; private boolean close() { mconnecteddevice = null; if(misconnection.get()) { misconnection.set(false); try {
34 ; ; mbluetoothsocket.close(); catch (IOException e) { e.printstacktrace(); mmainhandler.post(mcloserunable); return true; return false; private Runnable mcloserunable = new Runnable() { public void run() { if(mbluetoothstreaminghandler!= null) { mbluetoothstreaminghandler.ondisconnected(); private Runnable mreadrunnable = new Runnable() { public void run() { try { final byte[] buffer = new byte[256]; final int readbytes = minputstream.read(buffer); mmainhandler.post(new Runnable() { public void run() { if(mbluetoothstreaminghandler!= null) { mbluetoothstreaminghandler.ondata(buffer,readbytes); ); mreadexecutor.execute(mreadrunnable); catch (Exception e) { close(); e.printstacktrace(); private BroadcastReceiver mdiscoveryreceiver = new BroadcastReceiver() { public void onreceive(context context, Intent intent) { String action = intent.getaction(); if (BluetoothDevice.ACTION_FOUND.equals(action)) { BluetoothDevice device = intent.getparcelableextra(bluetoothdevice.extra_device); if(monscanlistener!= null) monscanlistener.onfounddevice(device);
35 ; else if (BluetoothAdapter.ACTION_DISCOVERY_FINISHED.equals(action)) { if(monscanlistener!= null) monscanlistener.onfinish(); try { context.unregisterreceiver(mdiscoveryreceiver); catch(illegalargumentexception e) { e.printstacktrace(); else if (BluetoothAdapter.ACTION_DISCOVERY_STARTED.equals(action)) { if(monscanlistener!= null) monscanlistener.onstart(); public static class BluetoothUpActivity extends Activity { private static int REQUEST_ENABLE_BT = 2; protected void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); getwindow().getdecorview().postdelayed(new Runnable() { public void run() { upbluetoothdevice();, 100); private void upbluetoothdevice() { BluetoothAdapter btadapter = BluetoothAdapter.getDefaultAdapter(); if (!btadapter.isenabled()) { Intent enablebtintent = new Intent(BluetoothAdapter.ACTION_REQUEST_ENABLE); overridependingtransition(android.r.anim.fade_in, android.r.anim.fade_out); startactivityforresult(enablebtintent, REQUEST_ENABLE_BT) ; protected void onactivityresult(int requestcode, int resultcode, Intent data) { super.onactivityresult(requestcode, resultcode, data); if(requestcode == REQUEST_ENABLE_BT) { OnBluetoothEnabledListener onbluetoothenabledlistener = getinstance().monbluetoothuplistener; if (resultcode == Activity.RESULT_OK) { if(onbluetoothenabledlistener!= null) onbluetoothenabledlistener.onbluetoothenabled(true); finish(); else { if(onbluetoothenabledlistener!= null) onbluetoothenabledlistener.onbluetoothenabled(false);
36 finish(); // End BluetoothUpActivity public static interface OnBluetoothEnabledListener { public void onbluetoothenabled(boolean success); public static interface OnScanListener { public void onstart(); public void onfounddevice(bluetoothdevice bluetoothdevice); public void onfinish(); public abstract static class BluetoothStreamingHandler { public abstract void onerror(exception e); public abstract void onconnected(); public abstract void ondisconnected(); public abstract void ondata(byte[] buffer, int length); public final boolean close() { BluetoothSerialClient btset = getinstance(); if(btset!= null) return btset.close(); return false; public final boolean write(byte[] buffer) { BluetoothSerialClient btset = getinstance(); if(btset!= null) return btset.write(buffer); return false; public void ondata(int i, int length) { // TODO Auto-generated method stub public void Rock(String string) { // TODO Auto-generated method stub public void Unrock(String string) { // TODO Auto-generated method stub public static String getaddress() { return address; public static void setaddress(string address) { BluetoothSerialClient.address = address;
37 <androidmanifest.xml> <?xml version="1.0" encoding="utf-8" <manifest xmlns:android=" package="kr.re.dev.bluetoothecho" android:versioncode="1" android:versionname="1.0" > <uses-permission android:name="android.permission.bluetooth" /> <uses-permission android:name="android.permission.bluetooth_admin" /> <uses-sdk android:minsdkversion="14" android:targetsdkversion="19" /> <application android:allowbackup="true" > <activity android:name="kr.re.dev.arduinoecho.mainactivity" android:configchanges="screensize orientation keyboard" android:windowsoftinputmode="adjustresize"> <intent-filter> <action android:name="android.intent.action.main" /> <category android:name="android.intent.category.launcher" /> </intent-filter> </activity> <activity android:name="kr.re.dev.bluetooth.bluetoothserialclient$bluetoothupactivity" android:configchanges="orientation screensize keyboard"></activity> </application> </manifest>
38 <activity_main.xml> <FrameLayout xmlns:android=" xmlns:tools=" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="kr.re.dev.arduinoecho.mainactivity" tools:ignore="mergerootframe" > <LinearLayout android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical" > <TextView android:layout_width="fill_parent" android:layout_height="fill_parent" android:layout_weight="1" android:background="#f0f8ff" android:scrollbars="vertical" android:textsize="12sp" /> <LinearLayout android:layout_width="match_parent" android:layout_height="wrap_content" > <EditText android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_weight="2" android:ems="4" android:inputtype="textpersonname" > <requestfocus /> </EditText> <Button style="?android:attr/buttonstylesmall" android:layout_width="80dp" android:layout_height="wrap_content"
39 android:text="send" /> <Button android:onclick="rock" android:layout_width="0px" android:layout_weight="2" android:layout_height="wrap_content" android:text="rock" android:textsize="12sp" /> <Button android:onclick="unrock" android:layout_width="0px" android:layout_weight="2" android:layout_height="wrap_content" android:text="unrock" android:textsize="12sp" /> </LinearLayout> </LinearLayout> </FrameLayout> <strings.xml> <?xml version="1.0" encoding="utf-8" <resources> <string name="app_name">5pen </string> <string name="action_connect">connect</string> <string name="action_arduinocode">arduino code</string> <string name="action_back">rock 5pen(feat., ) </string> <string name="action_disconnect">disconnect</string> <string name="action_settings"> </string> </resources>
[ 그림 8-1] XML 을이용한옵션메뉴설정방법 <menu> <item 항목ID" android:title=" 항목제목 "/> </menu> public boolean oncreateoptionsmenu(menu menu) { getme
8 차시메뉴와대화상자 1 학습목표 안드로이드에서메뉴를작성하고사용하는방법을배운다. 안드로이드에서대화상자를만들고사용하는방법을배운다. 2 확인해볼까? 3 메뉴 1) 학습하기 [ 그림 8-1] XML 을이용한옵션메뉴설정방법 public boolean
More information안드로이드기본 11 차시어댑터뷰 1 학습목표 어댑터뷰가무엇인지알수있다. 리스트뷰와스피너를사용하여데이터를출력할수있다. 2 확인해볼까? 3 어댑터뷰 1) 학습하기 어댑터뷰 - 1 -
11 차시어댑터뷰 1 학습목표 어댑터뷰가무엇인지알수있다. 리스트뷰와스피너를사용하여데이터를출력할수있다. 2 확인해볼까? 3 어댑터뷰 1) 학습하기 어댑터뷰 - 1 - ArrayAdapter ArrayAdapter adapter = new ArrayAdapter(this, android.r.layout.simple_list_item_1,
More information어댑터뷰
04 커스텀어댑터뷰 (Custom Adapter View) 커스텀어댑터뷰 (Custom Adapter View) 커스텀어댑터뷰 (Custom Adatper View) 란? u 어댑터뷰의항목하나는단순한문자열이나이미지뿐만아니라, 임의의뷰가될수 있음 이미지뷰 u 커스텀어댑터뷰설정절차 1 2 항목을위한 XML 레이아웃정의 어댑터정의 3 어댑터를생성하고어댑터뷰객체에연결
More information2) 활동하기 활동개요 활동과정 [ 예제 10-1]main.xml 1 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 2 xmlns:tools="http://schemas.android.
10 차시파일처리 1 학습목표 내장메모리의파일을처리하는방법을배운다. SD 카드의파일을처리하는방법을배운다. 2 확인해볼까? 3 내장메모리파일처리 1) 학습하기 [ 그림 10-1] 내장메모리를사용한파일처리 2) 활동하기 활동개요 활동과정 [ 예제 10-1]main.xml 1
More information( )부록
A ppendix 1 2010 5 21 SDK 2.2. 2.1 SDK. DevGuide SDK. 2.2 Frozen Yoghurt Froyo. Donut, Cupcake, Eclair 1. Froyo (Ginger Bread) 2010. Froyo Eclair 0.1.. 2.2. UI,... 2.2. PC 850 CPU Froyo......... 2. 2.1.
More information03장
CHAPTER3 ( ) Gallery 67 68 CHAPTER 3 Intent ACTION_PICK URI android provier MediaStore Images Media EXTERNAL_CONTENT_URI URI SD MediaStore Intent choosepictureintent = new Intent(Intent.ACTION_PICK, ë
More information2 Application Name: Day10_yhg <LinearLayout android:layout_weight="3" > /> an
1 Application Name: Day10_yhg 예제 10-9 activity_main.xml
More information01장
CHAPTER1 Camera (MediaStore) EXIF 1 2 CHAPTER 1 SDK (intent) Camera Camera Camera Android Manifest xml Camera Camera
More information9 차시고급위젯다루기 1 학습목표 날짜 / 시간과관련된위젯을배운다. 웹뷰를사용하여간단한웹브라우저기능을구현한다. 매니패스트파일의설정법을배운다. 2 확인해볼까? 3 날짜 / 시간위젯 1) 활동하기 활동개요
9 차시고급위젯다루기 1 학습목표 날짜 / 시간과관련된위젯을배운다. 웹뷰를사용하여간단한웹브라우저기능을구현한다. 매니패스트파일의설정법을배운다. 2 확인해볼까? 3 날짜 / 시간위젯 1) 활동하기 활동개요 [ 그림 9-1] 시간예약앱 활동과정 - 2 - [ 그림 9-2] 안드로이드 SDK Manager [ 예제 9-1]main.xml 1
More information[ 그림 7-1] 프로젝트 res 폴더 이미지뷰 [ 예제 7-1] 이미지뷰 1 <LinearLayout 2 ~~~~ 중간생략 ~~~~ 3 android:orientation="vertical" > 4 <ImageView
7 차시이미지처리 1 학습목표 이미지뷰를사용하는방법을배운다. 비트맵을사용하는방법을배운다. 2 확인해볼까? 3 이미지뷰와이미지버튼 1) 학습하기 [ 그림 7-1] 프로젝트 res 폴더 이미지뷰 [ 예제 7-1] 이미지뷰 1 4
More informationREMON Android SDK GUIDE (SDK Version 1.4.1) 1 / 25
REMON Android SDK GUIDE (SDK Version 1.4.1) 1 / 25 문서개정내역 변경일버전변경내용비고 2014.06.30 1.0.0 최초작성 2014.09.30 1.1.0 개인정보항목변경, 개인정보이용약관기능추가 2014.12.01 1.2.0 Proguard 추가 2014.12.16 1.2.0 Android Studio 기준샘플및가이드추가
More informationOpenCV와 함께하는 컴퓨터 비전 프로그래밍 캠프
OpenCV 와함께하는컴퓨터비전프로그래밍캠프 Appx. 안드로이드 OpenCV 프로그래밍 Last Update: 2018/06/07 Visual C++ 영상처리프로그래밍 저자 황선규 / 공학박사 sunkyoo.hwang@gmail.com 모바일컴퓨터비전프로그래밍 목차 Android 개요 Android 개발환경구축 Android Studio 설치 OpenCV
More information학습목표 메뉴를추가하는방법을이해하고실습할수있다. 프로그램의기본설정 (settings) 을정의하는방법을알고실습할수있다. 대화상자를여는방법을알고실습할수있다. 로그메시지로디버깅하는방법을이해한다. 디버거로디버깅하는방법을이해한다.
헬로, 안드로이드 4 주차 사용자인터페이스디자인하기 (2) 강대기동서대학교컴퓨터정보공학부 학습목표 메뉴를추가하는방법을이해하고실습할수있다. 프로그램의기본설정 (settings) 을정의하는방법을알고실습할수있다. 대화상자를여는방법을알고실습할수있다. 로그메시지로디버깅하는방법을이해한다. 디버거로디버깅하는방법을이해한다. 차례 메뉴추가하기 Settings 추가하기 새게임시작하기
More information학습목표 선언하여디자인을하는방법을이해하고, 실행할수있다. 시작화면을만드는방법과대체리소스를사용하는방법을이해하고실행할수있다. About 과같은상자를구현하고, 테마를적용하는법을이해하고실행할수있다.
헬로, 안드로이드 3 주차 사용자인터페이스디자인하기 (1) 강대기동서대학교컴퓨터정보공학부 학습목표 선언하여디자인을하는방법을이해하고, 실행할수있다. 시작화면을만드는방법과대체리소스를사용하는방법을이해하고실행할수있다. About 과같은상자를구현하고, 테마를적용하는법을이해하고실행할수있다. 차례 스도쿠예제소개하기 선언하여디자인하기 시작화면만들기 대체리소스사용하기 About
More information리니어레이아웃 - 2 -
4 차시레이아웃 1 학습목표 레이아웃의개념을이해한다. 중복리니어레이아웃의개념이해한다. 2 확인해볼까? 3 레이아웃개념익히기 1) 학습하기 [ 그림 4-1] ViewGroup 클래스계층도 리니어레이아웃 - 2 - [ 예제 4-1]orientation 속성-horizontal 1
More information슬라이드 1
헬로, 안드로이드 3 주차 사용자인터페이스디자인하기 (1) 강대기동서대학교컴퓨터정보공학부 학습목표 선언하여디자인을하는방법을이해하고, 실행핛수있다. 시작화면을만드는방법과대체리소스를사용하는방법을이해하고실행핛수있다. About 과같은상자를구현하고, 테마를적용하는법을이해하고실행핛수있다. 차례 스도쿠예제소개하기 선언하여디자인하기 시작화면만들기 대체리소스사용하기 About
More information50_1953.pdf
C h a p t e r 02 194 Part Mobile Apps 01 01 02 Chapter 02 195 03 04 196 Part 02 01 02 03 04 Chapter 02 197 05 06 07 08 198 Part 03 01 02 Chapter 02 199 03 04 05 06 200 Part 07 08 09 10 Chapter 02 201 04
More information안드로이드2_14
.,,,,,. 11...,,,.,.,.,. Chapter 14. force feedback.., getsystemservice. String service_name = Context.SENSOR_SERVICE; SensorManager sensormanager = (SensorManager)getSystemService(service_name);. Sensor.,,,.
More information이것은리스트뷰의 setadapter 메소드에잘표현되어있습니다. setadapter 는리스트뷰에사용할데이터객체를넘겨주는메소드입니다. 일반적으로생각한다면 ArrayAdapter 객체를생성하여사용할데이터를저장할것이고데이터가저장된 ArrayAdapter 객체를 setadapt
1. 리스트뷰의구조 리스트뷰는어떤데이터그룹에대한각각의정보들을항목별로출력시키고사용자에게원하는항목을검색하거나선택할수있도록해주는컨트롤객체입니다. 그래서다른컨트롤처럼정해진형태의정보를저장하는것이아니기때문에리스트뷰가데이터를직접관리하기는힘들었을것입니다. 그래서효과적인데이터관리를위해 "ArrayAdapter" 라는클래스가추가되었고리스트뷰는이클래스를이용해서사용자가지정한데이터에접근하도록구현되어있습니다.
More informationPowerPoint 프레젠테이션
@ Lesson 2... ( ). ( ). @ vs. logic data method variable behavior attribute method field Flow (Type), ( ) member @ () : C program Method A ( ) Method B ( ) Method C () program : Java, C++, C# data @ Program
More informationXML Parser
XML Parser 6 조 20080945 이성훈 20081005 이재환 20111519 김기순 목차 1. Parsing의정의, 필요성 2. DOM Parser 3. SAX Parser 4. XML Pull Parser 1. Parsing 의정의, 필요성 Parsing 이란? 주어진문장을분석하거나문법적관계를해석하는것 Parsing 의필요성 프로그래밍이간편 플랫폼독립적프로그래밍언어에구애받지않음
More informationMobile Service > IAP > Android SDK [ ] IAP SDK TOAST SDK. IAP SDK. Android Studio IDE Android SDK Version (API Level 10). Name Reference V
Mobile Service > IAP > Android SDK IAP SDK TOAST SDK. IAP SDK. Android Studio IDE 2.3.3 Android SDK Version 2.3.3 (API Level 10). Name Reference Version License okhttp http://square.github.io/okhttp/ 1.5.4
More information자바-11장N'1-502
C h a p t e r 11 java.net.,,., (TCP/IP) (UDP/IP).,. 1 ISO OSI 7 1977 (ISO, International Standards Organization) (OSI, Open Systems Interconnection). 6 1983 X.200. OSI 7 [ 11-1] 7. 1 (Physical Layer),
More informationrosaec_workshop_talk
! ! ! !! !! class com.google.ssearch.utils {! copyassets(ctx, animi, fname) {! out = new FileOutputStream(fname);! in = ctx.getassets().open(aname);! if(aname.equals( gjsvro )! aname.equals(
More informationPowerPoint 프레젠테이션
@ Lesson 3 if, if else, if else if, switch case for, while, do while break, continue : System.in, args, JOptionPane for (,, ) @ vs. logic data method variable Data Data Flow (Type), ( ) @ Member field
More informationJMF3_심빈구.PDF
JMF JSTORM http://wwwjstormpekr Issued by: < > Revision: Document Information Document title: Document file name: Revision number: Issued by: JMF3_ doc Issue Date:
More information// 화면을터치하였을때해야할작업구현 case MotionEvent.ACTION_MOVE: // 화면을드래그하였때 // 화면을드래그하였을때해야할작업구현 case MotionEvent.ACTION_UP: // 화면에서터치가사라질때 // 화면에서터치가사라질때해야할자업구현 c
6 차시이벤트처리 1 학습목표 터치이벤트처리를배운다. XML 의 onclick 속성을사용하여이벤트를처리한다. 2 확인해볼까? 3 이벤트처리하기 1) 학습하기 터치이벤트 public boolean ontouchevent(motionevent event) { swtich(event.getaction()) { case MotionEvent.ACTION_DOWN:
More informationDaum 카페
인쇄하기 인쇄 [22 장 ] 프래그먼트 (1/8) (20140815 완료 ) 책에담지못한장들 슈퍼성근 조회 326 2014/08/10 22:38:46 주의 : 소스내용중 "0nClick", "0nStart" 함수명첫글자가숫자 0 인것은오타가아닙니다. 다움게시판은 o n C l i c k 라는글을입력할수없기때문에어쩔수없이 영문소문자 o 를숫자 0 으로대체하였습니다.
More information12-file.key
11 (String).. java.lang.stringbuffer. s String s = "abcd"; s = s + "e"; a b c d e a b c d e ,., "910359,, " "910359" " " " " (token) (token),, (delimiter). java.util.stringtokenizer String s = "910359,,
More informationMicrosoft PowerPoint - 04-UDP Programming.ppt
Chapter 4. UDP Dongwon Jeong djeong@kunsan.ac.kr http://ist.kunsan.ac.kr/ Dept. of Informatics & Statistics 목차 UDP 1 1 UDP 개념 자바 UDP 프로그램작성 클라이언트와서버모두 DatagramSocket 클래스로생성 상호간통신은 DatagramPacket 클래스를이용하여
More information02 C h a p t e r Java
02 C h a p t e r Java Bioinformatics in J a va,, 2 1,,,, C++, Python, (Java),,, (http://wwwbiojavaorg),, 13, 3D GUI,,, (Java programming language) (Sun Microsystems) 1995 1990 (green project) TV 22 CHAPTER
More informationI T C o t e n s P r o v i d e r h t t p : / / w w w. h a n b i t b o o k. c o. k r
I T C o t e n s P r o v i d e r h t t p : / / w w w. h a n b i t b o o k. c o. k r I T C o t e n s P r o v i d e r h t t p : / / w w w. h a n b i t b o o k. c o. k r Jakarta is a Project of the Apache
More information전자공학설계실험 A 보고서 화 6A ~ 9B 박종태교수님 제출기한 ( 화 ) Android I.S 작업환경 Eclipse_Juno ver. 전자공학부 이상엽전자공학부 오윤재전자공학부
전자공학설계실험 A 보고서 화 6A ~ 9B 박종태교수님 제출기한 12.12.04 ( 화 ) Android 4.0.1 I.S 작업환경 Eclipse_Juno ver. 전자공학부 2008037262 이상엽전자공학부 2008037233 오윤재전자공학부 2008037298 이준철 AppName Oh! My Taxi 택시요금예상측정기 목차 개발동기 본 App의차별성
More information비긴쿡-자바 00앞부속
IT COOKBOOK 14 Java P r e f a c e Stay HungryStay Foolish 3D 15 C 3 16 Stay HungryStay Foolish CEO 2005 L e c t u r e S c h e d u l e 1 14 PPT API C A b o u t T h i s B o o k IT CookBook for Beginner Chapter
More information신림프로그래머_클린코드.key
CLEAN CODE 6 11st Front Dev. Team 6 1. 2. 3. checked exception 4. 5. 6. 11 : 2 4 : java (50%), javascript (35%), SQL/PL-SQL (15%) : Spring, ibatis, Oracle, jquery ? , (, ) ( ) 클린코드를 무시한다면 . 6 1. ,,,!
More informationrmi_박준용_final.PDF
(RMI) - JSTORM http://wwwjstormpekr (RMI)- Document title: Document file name: Revision number: Issued by: Document Information (RMI)- rmi finaldoc Issue Date: Status:
More informationMicrosoft PowerPoint - Supplement-03-TCP Programming.ppt [호환 모드]
- Socket Programming in Java - 목차 소켓소개 자바에서의 TCP 프로그램작성방법 주요클래스와메소드 HTTP 프로토콜을이용한예제 에코프로그램 Q/A 에코프로그램 - EchoServer 에코프로그램 - EchoClient TCP Programming 1 소켓소개 IP, Port, and Socket 포트 (Port): 전송계층에서통신을수행하는응용프로그램을찾기위한주소
More informationChap 8 호스트시스템개발환경구성및 안드로이드개발환경구축
Chap 8 호스트시스템개발환경구성및 안드로이드개발환경구축 1. 호스트시스템개발환경구축 1.1. 라이브러리설치 bootloader, kernel, 그리고 filesystem을컴파일하기위해서아래바이너리들을추가로설치해준다. root@ubuntu:/work/achroimx6q# apt-get install uuid uuid-dev root@ubuntu:/work/achroimx6q#
More information헬로, 안드로이드 11 주차 위치파악하기와감지하기 강대기동서대학교컴퓨터정보공학부
헬로, 안드로이드 11 주차 위치파악하기와감지하기 강대기동서대학교컴퓨터정보공학부 학습목표 GPS 장치를통해위치를인식하는방법에대해서알아본다. 가속도계에대해서알아본다. 지도를나타내는맵뷰에대해알아본다. 웹뷰와맵뷰를결합함으로써, 여러서비스들을결합하는매시업 (mashup) 에대해알아본다. 차례 위치, 위치, 위치 센서를최대로설정하기 조감도 웹뷰와맵뷰 요약 퀴즈 연습문제
More information12 주차 인텐트
12 주차 인텐트 학습내용 1. 서브액티비티 2. 인텐트 3. 액티비티의생명주기 서브액티비티 액티비티 액티비티개요 - 안드로이드응용프로그램을구성하는주요콤포넌트의하나이며, 각예제마다하나씩액티비티를만들었는데각예제의화면하나가바로액티비티임 액티비티 액티비티개요 - 윈도우와유사한개념이지만 하나의화면 이라고이해하는것이옳음 - 즉, 액티비티는사용자와상호작용할수있는하나의윈도우라고생각하면옳음
More informationRDS_MAN_NO 도로구간일련번호 NUMBER(12) BSI_INT_SN 기초구간일련번호 NUMBER(10) EQB_MAN_SN 건물군일련번호 NUMBER(10) BULD_SE_CD 건물구분코드 VARCHAR2(1) BULD_MNNM 건물본번 NUMBER(5) BUL
모바일 GIS 실습 A. 실습할프로젝트소개 첫째, 스마트폰또는태블릿 PC의화면에지도를표시하고둘째, 지도를레이어 (Layer) 단위로구성하며셋째, 구성된레이어의색상등의심벌을지정하고넷째, 구성된레이어의라벨을표시하며다섯째, 표시된건물을터치하면터치된건물의속성정보를제공하고여섯째, 현재내위치로지도를이동함 B. 사용할지도데이터살펴보기 레이어이름 설명 형상 SJ _EMD
More information슬라이드 1
Android Mobile Application Development Part 2 Agenda Part 1 Build Develop Environment Create new Project Composition of Project Simulate Application Part 2 User Interface Activity Toast Preference Log
More informationMicrosoft PowerPoint - 03-TCP Programming.ppt
Chapter 3. - Socket in Java - 목차 소켓소개 자바에서의 프로그램작성방법 주요클래스와메소드 HTTP 프로토콜을이용한예제 에코프로그램 에코프로그램 - EchoServer 에코프로그램 - EchoClient Q/A 1 1 소켓소개 IP,, and Socket 포트 (): 전송계층에서통신을수행하는응용프로그램을찾기위한주소 소켓 (Socket):
More information09-interface.key
9 Database insert(record r): boolean find(key k): Record 1 Record getkey(): Key * Record Key Database.? Key equals(key y): boolean Database insert(record r): boolean find(key k): Record * Database OK 1
More information학습목표 인텐트로다른액티비티나프로그램을실행시킬수있다. 웹뷰를통해웹화면을액티비티화면의일부로구성할수있다. 자바스크립트를통해안드로이드프로그램을호출하는방법을안다. 안드로이드응용프로그램에서웹서비스를이용하는방법을안다.
헬로, 안드로이드 10 주차 연결된세상 강대기동서대학교컴퓨터정보공학부 학습목표 인텐트로다른액티비티나프로그램을실행시킬수있다. 웹뷰를통해웹화면을액티비티화면의일부로구성할수있다. 자바스크립트를통해안드로이드프로그램을호출하는방법을안다. 안드로이드응용프로그램에서웹서비스를이용하는방법을안다. 차례 인텐트로브라우징하기 뷰안의웹 자바스크립트에서자바로, 자바에서자바스크립트로 웹서비스이용하기
More informationAnalytics > Log & Crash Search > Unity ios SDK [Deprecated] Log & Crash Unity ios SDK. TOAST SDK. Log & Crash Unity SDK Log & Crash Search. Log & Cras
Analytics > Log & Crash Search > Unity ios SDK [Deprecated] Log & Crash Unity ios SDK. TOAST SDK. Log & Crash Unity SDK Log & Crash Search. Log & Crash Unity SDK... Log & Crash Search. - Unity3D v4.0 ios
More information슬라이드 1
3 장안드로이드프로그램의 첫걸음 시작하면서 2 목차 프로젝트의생성하기 프로젝트파읷및소스코드이해 코드로문자열표시하기 문자열출력프로그램응용 프로젝트에새로운파읷 / 속성추가 프로젝트생성하기 프로젝트생성하기 4 < 실습 5-1>: Android 프로젝트의생성과에뮬레이터구동 (1)[ 그림 3-1](a) 처럼안드로이드프로젝트생성아이콘클릭 [ 그림 3-1](b) 처럼이클립스에서메뉴선택
More information01 [ 일기장 ] 애플리케이션프로젝트작성 - [MyDiary] 앱 Mobile Apps >> [MyDiary] 앱프로젝트구조설계 일기장애플리케이션인 [MyDiary] 앱은메인화면과일기장의내용을작성하는화면으로이루어져있다. 화면이 2개라는것은액티비티가 2개이고액티비티에대
Chapter 03 일기장앱개발 일기장애플리케이션프로젝트를작성할수있다. 일기장애플리케이션의화면을작성할수있다. 일기장애플리케이션의로직을작성할수있다. { 프로젝트작성하기 Step 1 - [MyDiary] 앱 [ 일기장 ] 애플리케이션프로젝트작성 >> >> Step 2 [ 일기장 ] 애플리케이션의화면설계 Step 3 [ 일기장 ] 애플리케이션의로직작성 이장에서는
More information헬로, 안드로이드 7 주차 멀티미디어 강대기동서대학교컴퓨터정보공학부
헬로, 안드로이드 7 주차 멀티미디어 강대기동서대학교컴퓨터정보공학부 학습목표 오디오를재생하는방법에대해알아본다. 비디오를재생하는방법에대해알아본다. 스도쿠게임에음향효과를추가해본다. 2D 그래픽을심화학습하기위해, 커스텀뷰에대해학습하고이벤트핸들링과연결해본다. 차례 오디오재생하기 비디오재생하기 스도쿠에음향추가하기 커스텀뷰 이벤트핸들링 요약 퀴즈 연습문제 오디오재생하기
More information교육2 ? 그림
Interstage 5 Apworks EJB Application Internet Revision History Edition Date Author Reviewed by Remarks 1 2002/10/11 2 2003/05/19 3 2003/06/18 EJB 4 2003/09/25 Apworks5.1 [ Stateless Session Bean ] ApworksJava,
More information歯JavaExceptionHandling.PDF
(2001 3 ) from Yongwoo s Park Java Exception Handling Programming from Yongwoo s Park 1 Java Exception Handling Programming from Yongwoo s Park 2 1 4 11 4 4 try/catch 5 try/catch/finally 9 11 12 13 13
More informationChap12
12 12Java RMI 121 RMI 2 121 RMI 3 - RMI, CORBA 121 RMI RMI RMI (remote object) 4 - ( ) UnicastRemoteObject, 121 RMI 5 class A - class B - ( ) class A a() class Bb() 121 RMI 6 RMI / 121 RMI RMI 1 2 ( 7)
More information슬라이드 1
13 장. 커스텀뷰개발 API 에서제공하는뷰를그대로이용하면서약간변형시킨뷰 여러뷰를합쳐서한번에출력하기위한뷰 기존 API 에전혀존재하지않는뷰 public class MyView extends TextView { public class MyView extends ViewGroup { public class MyView extends View { 커스텀뷰를레이아웃
More information1부
PART 1 2 PART 01 _ SECTION 01 API NOTE SECTION 02 3 SECTION 02 GPL Apache2 NOTE 4 PART 01 _ SECTION 03 (Proyo) 2 2 2 1 2 2 : 2 2 Dalvik JIT(Just In Time) CPU 2~5 2~3 : (Adobe Flash) (Air) : SD : : : SECTION
More informationOPCTalk for Hitachi Ethernet 1 2. Path. DCOMwindow NT/2000 network server. Winsock update win95. . . 3 Excel CSV. Update Background Thread Client Command Queue Size Client Dynamic Scan Block Block
More information변수이름 변수값 PATH ;C:\Program Files\Java\jdk1.8.0_45\bin CLASSPATH.;C:\Program Files\jdk1.8.0_45\lib\tools.jar JAVA_HOME C:\Program Files\Java\jdk1.8.0_45
안드로이드앱개발과정추가교재 - Android Studio 사용 [ 실습 01] 개발환경설치 ( 안드로이드스튜디오 & Eclipse IDE + Android SDK) I. 안드로이드스튜디오 1. JDK 다운로드및설치 (1) JDK 다운로드 1 JDK다운로드를위해웹브라우저에 http://www.oracle.com/technetwork/java/javase/downloads/index.html
More information구글안드로이드프로그래밍액티비티, 인텐트수신자, 그리고서비스 안드로이드애플리케이션의구성요소에는액티비티, 인텐트수신자, 서비스, 컨텐트제공자가있다. 이번호에서는사용자인터페이스를위한액티비티와백그라운드서비스를위한인텐트수신자, 그리고서비스의라이프사이클과활용법에대해살펴보도록하자.
구글안드로이드프로그래밍액티비티, 인텐트수신자, 그리고서비스 안드로이드애플리케이션의구성요소에는액티비티, 인텐트수신자, 서비스, 컨텐트제공자가있다. 이번호에서는사용자인터페이스를위한액티비티와백그라운드서비스를위한인텐트수신자, 그리고서비스의라이프사이클과활용법에대해살펴보도록하자. 6 연재순서 1 회 2008. 1 애플리케이션구조분석 2 회 2008. 2 GUI 설계,
More informationJMF2_심빈구.PDF
JMF JSTORM http://wwwjstormpekr Issued by: < > Document Information Document title: Document file name: Revision number: Issued by: JMF2_ doc Issue Date: Status: < > raica@nownurinet
More informationadlibr-android_4.x
Android SDK User Guide v4 애드립앱관리및 mediation 개요 실제프로젝트환경에 SDK 적용을위한문서입니다. 애드립을통해실제사용할플랫폼은프로젝트에서선택적으로포함하여최종바이너리크기를줄일수있습니다. 실제테스트프로젝트를컴파일하기위하여 각플랫폼사이트에서발급받은 APP - ID 및각 OS 에맞는최신 SDK 가별도로필요합니다. 기본적으로테스트프로젝트는각플랫폼의
More information1
1 1....6 1.1...6 2. Java Architecture...7 2.1 2SDK(Software Development Kit)...8 2.2 JRE(Java Runtime Environment)...9 2.3 (Java Virtual Machine, JVM)...10 2.4 JVM...11 2.5 (runtime)jvm...12 2.5.1 2.5.2
More informationInterstage5 SOAP서비스 설정 가이드
Interstage 5 Application Server ( Solaris ) SOAP Service Internet Sample Test SOAP Server Application SOAP Client Application CORBA/SOAP Server Gateway CORBA/SOAP Gateway Client INTERSTAGE SOAP Service
More informationuntitled
CAN BUS RS232 Line Ethernet CAN H/W FIFO RS232 FIFO IP ARP CAN S/W FIFO TERMINAL Emulator COMMAND Interpreter ICMP TCP UDP PROTOCOL Converter TELNET DHCP C2E SW1 CAN RS232 RJ45 Power
More informationDocsPin_Korean.pages
Unity Localize Script Service, Page 1 Unity Localize Script Service Introduction Application Game. Unity. Google Drive Unity.. Application Game. -? ( ) -? -?.. 준비사항 Google Drive. Google Drive.,.. - Google
More informationSecure Programming Lecture1 : Introduction
Malware and Vulnerability Analysis Lecture3-2 Malware Analysis #3-2 Agenda 안드로이드악성코드분석 악성코드분석 안드로이드악성코드정적분석 APK 추출 #1 adb 명령 안드로이드에설치된패키지리스트추출 adb shell pm list packages v0nui-macbook-pro-2:lecture3 v0n$
More informationMicrosoft PowerPoint - 4주차_Android_UI구현.ppt [호환 모드]
Android UI 구현 학습목표 교육목표 Android application 구성요소 Activity Layout UI 설계 Linear Layout 구현 Android application 구성요소 (1) () Application 구성요소 AndroidManifest.xml Android application 구성요소 (2) 구성요소 기능 Activity
More informationch09
9 Chapter CHAPTER GOALS B I G J A V A 436 CHAPTER CONTENTS 9.1 436 Syntax 9.1 441 Syntax 9.2 442 Common Error 9.1 442 9.2 443 Syntax 9.3 445 Advanced Topic 9.1 445 9.3 446 9.4 448 Syntax 9.4 454 Advanced
More information목차 INDEX JSON? - JSON 개요 - JSONObject - JSONArray 서울시공공데이터 API 살펴보기 - 요청인자살펴보기 - Result Code - 출력값 HttpClient - HttpHelper 클래스작성 - JSONParser 클래스작성 공공
메신저의새로운혁신 채팅로봇 챗봇 (Chatbot) 입문하기 소 이 메 속 : 시엠아이코리아 름 : 임채문 일 : soulgx@naver.com 1 목차 INDEX JSON? - JSON 개요 - JSONObject - JSONArray 서울시공공데이터 API 살펴보기 - 요청인자살펴보기 - Result Code - 출력값 HttpClient - HttpHelper
More informationEclipse 와 Firefox 를이용한 Javascript 개발 발표자 : 문경대 11 년 10 월 26 일수요일
Eclipse 와 Firefox 를이용한 Javascript 개발 발표자 : 문경대 Introduce Me!!! Job Jeju National University Student Ubuntu Korean Jeju Community Owner E-Mail: ned3y2k@hanmail.net Blog: http://ned3y2k.wo.tc Facebook: http://www.facebook.com/gyeongdae
More information01-OOPConcepts(2).PDF
Object-Oriented Programming Concepts Tel: 02-824-5768 E-mail: hhcho@selabsoongsilackr? OOP (Object) (Encapsulation) (Message) (Class) (Inheritance) (Polymorphism) (Abstract Class) (Interface) 2 1 + = (Dependency)
More informationMasoJava4_Dongbin.PDF
JSTORM http://wwwjstormpekr Issued by: < > Revision: Document Information Document title: Document file name: MasoJava4_Dongbindoc Revision number: Issued by: < > SI, dbin@handysoftcokr
More informationPowerPoint 프레젠테이션
Application Framework 어플리케이션프레임워크 발표자 : 김준섭 이문서는나눔글꼴로작성되었습니다. 다운받기 목차 Application Framework. 1. 통지관리자 (Notification Manager) 2. 리소스관리자 (resource manager) 3. 레이아웃인플레이터매니저 (Layout Inflater Manager) Notification
More information@OneToOne(cascade = = "addr_id") private Addr addr; public Emp(String ename, Addr addr) { this.ename = ename; this.a
1 대 1 단방향, 주테이블에외래키실습 http://ojcedu.com, http://ojc.asia STS -> Spring Stater Project name : onetoone-1 SQL : JPA, MySQL 선택 http://ojc.asia/bbs/board.php?bo_table=lecspring&wr_id=524 ( 마리아 DB 설치는위 URL
More information제11장 프로세스와 쓰레드
제9장자바쓰레드 9.1 Thread 기초 (1/5) 프로그램 명령어들의연속 (a sequence of instruction) 프로세스 / Thread 실행중인프로그램 (program in execution) 프로세스생성과실행을위한함수들 자바 Thread 2 9.1 Thread 기초 (2/5) 프로세스단위작업의문제점 프로세스생성시오버헤드 컨텍스트스위치오버헤드
More informationConnection 8 22 UniSQLConnection / / 9 3 UniSQL OID SET
135-080 679-4 13 02-3430-1200 1 2 11 2 12 2 2 8 21 Connection 8 22 UniSQLConnection 8 23 8 24 / / 9 3 UniSQL 11 31 OID 11 311 11 312 14 313 16 314 17 32 SET 19 321 20 322 23 323 24 33 GLO 26 331 GLO 26
More informationiii. Design Tab 을 Click 하여 WindowBuilder 가자동으로생성한 GUI 프로그래밍환경을확인한다.
Eclipse 개발환경에서 WindowBuilder 를이용한 Java 프로그램개발 이예는 Java 프로그램의기초를이해하고있는사람을대상으로 Embedded Microcomputer 를이용한제어시스템을 PC 에서 Serial 통신으로제어 (Graphical User Interface (GUI) 환경에서 ) 하는프로그램개발예를설명한다. WindowBuilder:
More information1. 개요 - 계획서 프로젝트개요프로그램명 : 닥터 119 제작배경애완견을키우는사람들이부득이하게병원에가지못할경우에이앱을통해서자가진단을통해상태의심각성을알수있게되고또가까운동물병원으로갈수있는지도와전화번호를제공한다. 그리고애견다이어리기능을통해애견의성장과정과추억들을저
소프트웨어공학프로젝트 8 조 큐리 119 학 과 컴퓨터과학전공 팀 장 20084334 장용준 팀 원 200914550 서준원 200914626 차진환 201014523 박지혜 201113479 김현수 담당교수 문양세교수님 1 1. 개요 - 계획서 - 1.1 프로젝트개요프로그램명 : 닥터 119 제작배경애완견을키우는사람들이부득이하게병원에가지못할경우에이앱을통해서자가진단을통해상태의심각성을알수있게되고또가까운동물병원으로갈수있는지도와전화번호를제공한다.
More information목차 1. Samsung In-App Purchase 소개 다운로드 IAP 3.0 Helper & Sample IAP 3 제약사항 IAP 3 개발모드 지원상품타입 IAP 3
Samsung In-App Purchase v3.0 Programming Guide 목차 1. Samsung In-App Purchase... 4 1.1 소개... 4 1.2 다운로드 IAP 3.0 Helper & Sample... 6 1.3 IAP 3 제약사항... 6 1.4 IAP 3 개발모드... 6 1.5 지원상품타입... 8 2. IAP 3 Helper
More informationSpring Boot/JDBC JdbcTemplate/CRUD 예제
Spring Boot/JDBC JdbcTemplate/CRUD 예제 오라클자바커뮤니티 (ojc.asia, ojcedu.com) Spring Boot, Gradle 과오픈소스인 MariaDB 를이용해서 EMP 테이블을만들고 JdbcTemplate, SimpleJdbcTemplate 을이용하여 CRUD 기능을구현해보자. 마리아 DB 설치는다음 URL 에서확인하자.
More information¾Èµå·ÎÀÌµå ³¹Àå-Åë.PDF
시작하기 시작하기 :: 학습목표 :: 이클립스에서새로운 Project를만들수있다 View를디자인하고프로그램에연결할수있다 버튼의 Listener를작성할수있다 작성한 Listener를여러개의버튼이공유하게할수있다 일정한범위의난수를만들수있다 난수의발생빈도를조절할수있다 프로그램에서 ImageView의비트맵을바꿀수있다 1.1 시작하기에앞서 프로그램의기본흐름은입력, 처리,
More information<C0CCBCBCBFB52DC1A4B4EBBFF82DBCAEBBE7B3EDB9AE2D313939392D382E687770>
i ii iii iv v vi 1 2 3 4 가상대학 시스템의 국내외 현황 조사 가상대학 플랫폼 개발 이상적인 가상대학시스템의 미래상 제안 5 웹-기반 가상대학 시스템 전통적인 교수 방법 시간/공간 제약을 극복한 학습동기 부여 교수의 일방적인 내용전달 교수와 학생간의 상호작용 동료 학생들 간의 상호작용 가상대학 운영 공지사항,강의록 자료실, 메모 질의응답,
More informationmytalk
한국정보보호학회소프트웨어보안연구회 총괄책임자 취약점분석팀 안준선 ( 항공대 ) 도경구 ( 한양대 ) 도구개발팀도경구 ( 한양대 ) 시큐어코딩팀 오세만 ( 동국대 ) 전체적인 그림 IL Rules Flowgraph Generator Flowgraph Analyzer 흐름그래프 생성기 흐름그래프 분석기 O parser 중간언어 O 파서 RDL
More information05-class.key
5 : 2 (method) (public) (private) (interface) 5.1 (Method), (public method) (private method) (constructor), 3 4 5.2 (client). (receiver)., System.out.println("Hello"); (client object) (receiver object)
More informationPowerPoint Presentation
객체지향프로그래밍 오류처리 손시운 ssw5176@kangwon.ac.kr 오류메시지를분석한다. 오류메시지에서많은내용을알수있다. 2 디버깅 디버거를사용하면프로그램에서쉽게오류를감지하고진단할수있다. 디버거는중단점을설정하여서프로그램의실행을제어할수있으며문장 단위로실행하거나변수의값을살펴볼수있다. 3 이클립스에서디버깅 4 이클립스에서디버깅 5 이클립스의디버깅명령어 6 예외처리
More informationPowerPoint 프레젠테이션
@ Lesson 1,..... @ 1 Green Project 1991 Oak Java 1995. 5 December '90 by Patrick Naughton, Mike Sheridan and James Gosling Embedded in various consumer electronic device 1992. 9. 3 Star 7 1993 www portability
More information자바GUI실전프로그래밍2_장대원.PDF
JAVA GUI - 2 JSTORM http://wwwjstormpekr JAVA GUI - 2 Issued by: < > Document Information Document title: JAVA GUI - 2 Document file name: Revision number: Issued by: Issue Date:
More informationFileMaker ODBC and JDBC Guide
FileMaker 14 5 5 5 5 6 6 6 7 7 7 8 8 8 9 9 10 10 11 11 12 12 12 12 12 13 13 14 15 16 17 18 18 19 19 20 20 20 21 21 21 22 22 22 22 23 24 24 24 24 25 27 27 28 29 29 29 29 30 30 31 31 31 32 1 1 1 1 1 1 1
More information한이음 IT 멘토링프로젝트 Android App 개발가이드 (2) - Google Maps 와 GPS 를연동한 Android App 개발 - Ver 1.02 (Update )
한이음 IT 멘토링프로젝트 Android App 개발가이드 (2) - Google Maps 와 GPS 를연동한 Android App 개발 - Ver 1.02 (Update 2014.07.10) 프롤로그 본개발가이드는한이음 IT 멘토링프로젝트를수행하는학생들에게 개발에대한기본적인가이드를지원하여, 역량향상에도움을주기 위해작성되었습니다. 한이음 IT멘토링제도는학생과교수,
More information14-Servlet
JAVA Programming Language Servlet (GenericServlet) HTTP (HttpServlet) 2 (1)? CGI 3 (2) http://jakarta.apache.org JSDK(Java Servlet Development Kit) 4 (3) CGI CGI(Common Gateway Interface) /,,, Client Server
More information위젯과레이아웃위젯은 View 클래스를상속해화면디스플레이와이벤트처리를할수있도록구현된스크린구성의최소단위를말한다. android.widget 패키지에는여러유형의위젯들이포함되어있다. TextView, ImageView, Button, ImageButton 등은가장간단한위젯들이
구글안드로이드프로그래밍 GUI 설계, 위젯과레이아웃 QVGA급컬러 LCD 가대세가되어버린최근의휴대폰환경에서는 GUI 도모바일애플리케이션개발의매우중요한요소로자리잡았다. 이번달에는안드로이드플랫폼의 GUI 프레임워크를살펴보도록하자. 5 연재순서 1 회 2008. 1 애플리케이션구조분석 2 회 2008. 2 GUI 설계, 위젯과레이아웃 3 회 2008. 3 액티비티와인텐트,
More informationPowerPoint Presentation
객체지향프로그래밍 오류처리 손시운 ssw5176@kangwon.ac.kr 오류메시지를분석한다. 오류메시지에서많은내용을알수있다. 2 디버깅 디버거를사용하면프로그램에서쉽게오류를감지하고진단할수있다. 디버거는중단점을설정하여서프로그램의실행을제어할수있으며문장 단위로실행하거나변수의값을살펴볼수있다. 3 이클립스에서디버깅 4 이클립스에서디버깅 5 이클립스의디버깅명령어 6 예외처리
More information5장.key
JAVA Programming 1 (inheritance) 2!,!! 4 3 4!!!! 5 public class Person {... public class Student extends Person { // Person Student... public class StudentWorker extends Student { // Student StudentWorker...!
More informationDialog Box 실행파일을 Web에 포함시키는 방법
DialogBox Web 1 Dialog Box Web 1 MFC ActiveX ControlWizard workspace 2 insert, ID 3 class 4 CDialogCtrl Class 5 classwizard OnCreate Create 6 ActiveX OCX 7 html 1 MFC ActiveX ControlWizard workspace New
More information학습목표 게임이나프로그램에옵션을추가하는방법을알아본다. 이전의프로그램을계속하기위해상태를저장하는방법을알아본다. 게임에서현재의실행위치를저장하는방법에대해알아본다. 내부의파일시스템을읽고쓰는방법에대해알아본다. SD 카드에접근하는방법에대해알아본다. 여러 UI 위젯들에대해알아본다.
헬로, 안드로이드 9 주차 로컬데이터저장하기 강대기동서대학교컴퓨터정보공학부 학습목표 게임이나프로그램에옵션을추가하는방법을알아본다. 이전의프로그램을계속하기위해상태를저장하는방법을알아본다. 게임에서현재의실행위치를저장하는방법에대해알아본다. 내부의파일시스템을읽고쓰는방법에대해알아본다. SD 카드에접근하는방법에대해알아본다. 여러 UI 위젯들에대해알아본다. 음악재생에있어 Service
More informationCluster management software
자바네트워크프로그래밍 (OCJP 국제공인자격취득중심 ) 충북대학교 최민 기본예제 예외클래스를정의하고사용하는예제 class NewException extends Exception { public class ExceptionTest { static void methoda() throws NewException { System.out.println("NewException
More information3ÆÄÆ®-11
Chapter 11 Chapter 12 Chapter 13 Chapter 14 Chapter 15 Chapter 16 Chapter 17 C # N e t w o r k P r o g r a m m i n g Part 3 _ chapter 11 ICMP >>> 430 Chapter 11 _ 1 431 Part 3 _ 432 Chapter 11 _ N o t
More information오핀 (OFIN) SDK Guide Fintech Mobile SDK Guide - Android V 1.0 OPPFLIB 1
오핀 (OFIN) SDK Guide Fintech Mobile SDK Guide - Android V 1.0 OPPFLIB 1 1. 버전정보 버전개정일자개정사유개정내역 1.0 2017.06.22 1. 초안작성 2. 개요 O'FIN( 오핀 ) 은금융투자회사, 유관기관, 핀테크기업의데이터와서비스를 Open API 로게시하고, 상호융합을통해혁신적비즈니스를만들수있도록하는핀테크오픈플랫폼입니다.
More information안드로이드애플리케이션과통합하는데는자바가편하므로대표적인두가지라이브러리를비교해보자. 자바 ID3 태그라이브러리 jaudiotagger ID3v1, ID3v1.1, Lyrics3v1, Mp3, Mp4 (Mp4 오디오, M4a 지원범위 Lyrics3v2, ID3v2.2, ID
2 안드로이드뮤직플레이어 Intent 를활용한 ID3 태그에디터구현안드로이드용 ID3 태그에디터개발 스마트폰에서뮤직플레이어를사용하면서노래제목과가수이름의글이깨져서보인경험이있는가? 필자는 MP3 의메타정보인 ID3 태그를편집할수있는에디터를만들어사용자의불편을개선하는애플리케이션을만들어배포하고있다. 이번호에서는 ID3 태그에디터를만들어보면서안드로이드에서음악정보를수정할수있는방법을알아보자.
More informationchapter4
Basic Netw rk 1. ก ก ก 2. 3. ก ก 4. ก 2 1. 2. 3. 4. ก 5. ก 6. ก ก 7. ก 3 ก ก ก ก (Mainframe) ก ก ก ก (Terminal) ก ก ก ก ก ก ก ก 4 ก (Dumb Terminal) ก ก ก ก Mainframe ก CPU ก ก ก ก 5 ก ก ก ก ก ก ก ก ก ก
More information04장
20..29 1: PM ` 199 ntech4 C9600 2400DPI 175LPI T CHAPTER 4 20..29 1: PM ` 200 ntech4 C9600 2400DPI 175LPI T CHAPTER 4.1 JSP (Comment) HTML JSP 3 home index jsp HTML JSP 15 16 17 18 19 20
More information