달력

3

« 2024/3 »

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
반응형
728x90
반응형

 

 

어플 개발 프로세스 정리하기

 

오늘 문득 이전의 파일들을 정리하다가 어플을 개발했던 노트를 보다가 문득 보니 개발했던 프로세스

를 정리 했던 것들이 있어 개발자가 되려는 초심자들에게 좀더 큰 도움이 될 듯하여 개발 순서에 대한

정보를 포스팅 해본다.

 

 

어플리케이션 개발

1. 아이디어 작성 - 핵심적인 기능을 정리한다.

2. 개발 계획 작성  - 사용 소스 종류 결정, 및 추가 소스확보

3. 오류 수정

4. 사용 이미지 작성

5. 최적화 작업 실시

어플등록

6. 어플 등록용  실행화면 이미지 캡춰

7. 홍보문구 작성

8. 사용 순서작성

9. binery 확인

10. 적용기종확인

11. 가격 결정

12. 어플 등록

13. 판매개시

 

 

<필수 체크사항>

1. 어플 광고 방법 개발

2. 상대적 레이아웃 적용으로 기종적용 확대

3.  다국어 어플 개발

 

안드로이드 어플 개발자가 되고 싶은 분들에게 큰도움이 되길 바라며 포스팅을 마감해 본다.

 

 

 

728x90
반응형
:
Posted by mapagilove
728x90
반응형

 

안드로이드 "px to dp" 변환 유틸리티

 

안드로이드 레이아웃 xml 내용 중에 px를 모두 찾아서 dp로 변환해 주는 유틸리티 입니다.  지금 진행 중인 프로젝트에 사용하려고 급하게 만들었습니다.  소스 공개는 제가 생각한 기능과 UI가 갖춰지면 진행하겠습니다 ^^;


(프로젝트 폴더만 지정하면 스스로 알아서 density를 판단해서 처리하려고 했는데 흐음 ㅡ.ㅡa)


 

픽셀 단위로 계산해서 레이아웃을 작성 한 다음에 한꺼번에 dp로 변환 할 때 편합니다.


사용법은 

  • 프로그램을 실행
  • 텍스트 에디터 영역에 xml 내용을 복사
  • density 선택
  • Convert 버턴을 클릭

px2dp.7z

[그림 1] 실행 화면

자료 출처:http://ryulib.tistory.com/category/Android

728x90
반응형
:
Posted by mapagilove
728x90
반응형

안드로이드 소스 파일 다운받기

안드로이드를 공부하다보면 항상 몇 줄의 설명과 소스로는 조금은 이해가 안가는 부분이 있

다.

이럴때 나는 항상 소스를 검색하여 에클립스에 소스파일을 넣은 다음 실행 보기도 하는 데

좀처럼 전체 실행 파일이 전부 있는 공간(인터넷 주소)을 찾기가 쉽지가 않다.

그래서 이리저리 찾아다니다 찾은 것이 아래 주소에 있는 파일들이다.

다양하게 소스가 비치되어 있어 한번 실행해 보고 이해하는 데는 최고 인듯 하다.

소스파일 사이트: http://www.netmite.com/android/mydroid/2.0/packages/apps/

 

728x90
반응형
:
Posted by mapagilove
728x90
반응형

2013.4.23....새로 코드 작성해서 올릴 예정




예전에 작성했던 것이 안드로이드 3.0 이하에서만 동작해서 구글링해서 원인을 찾았습니다. 

3.0 부터 메인 쓰레드에서 네트워크 사용을 하면 안된다는 거 같습니다.

그래서 AsyncTask를 사용하도록 바꾸어서 잘동작합니다..


안드로이드 4.1.2에서만 테스트해봤습니다. 


ps. 실시간으로 업데이트 하는거 추가



package com.example.test;


import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.Statement;

import java.util.ArrayList;


import android.app.Activity;

import android.app.AlertDialog;

import android.app.AlertDialog.Builder;

import android.content.DialogInterface;

import android.os.AsyncTask;

import android.os.Build;

import android.os.Bundle;

import android.os.Handler;

import android.os.Message;

import android.util.Log;

import android.view.View;

import android.widget.AdapterView;

import android.widget.AdapterView.OnItemClickListener;

import android.widget.ArrayAdapter;

import android.widget.ListView;

import android.widget.Spinner;

import android.widget.Toast;






public class State extends Activity  {


ListView listView;

Spinner spinner;

ArrayList<String> list;

static ArrayAdapter<String> adapter;

ArrayAdapter<String> adapter2;

boolean is = true;

String Query;

    int count=0;

    

    

  //  MyApp appState;

    private AsyncTask<String, String, String> mTask;

    

    @Override

    protected void onCreate(Bundle savedInstanceState) {


    // appState.setState(true);

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

        

list = new ArrayList<String>();  

                    

        adapter2 = new  ArrayAdapter<String> ( this , android.R.layout.simple_spinner_item);

        adapter2.setDropDownViewResource (android.R.layout.simple_spinner_dropdown_item);

        Spinner spinner = (Spinner)this.findViewById (R.id.spinner);  

        spinner.setAdapter (adapter2);

        spinner.setOnItemSelectedListener(spnCountriesListener);


        adapter = new ArrayAdapter<String>(this,  android.R.layout.simple_list_item_1, list);

     listView = (ListView)findViewById(R.id.list);

     listView.setAdapter(adapter);

     listView.setTextFilterEnabled(true);

      

     Query = String.format("select * from v_state ORDER BY username,blnum ASC");


     //spinner.setSelection(0);

     setTitle((CharSequence)"엘리베이터 모니터링");


    

    

     listView.setOnItemClickListener(

                new OnItemClickListener()

                {

                    @Override

                    public void onItemClick(AdapterView<?> parent, View view,int position, long id) 

                    {


                        Object o = listView.getItemAtPosition(position);

                        String pen = o.toString();

                        Toast.makeText(getApplicationContext(), "" + pen, Toast.LENGTH_LONG).show();

                         

                    }

                }

             );


    

        handler2.sendEmptyMessage(1);

     //handler.sendEmptyMessage(1);

         

    }

    




    @Override

   public void onBackPressed() {

// TODO Auto-generated method stub

// super.onBackPressed(); //지워야 실행됨


    

Builder d = new AlertDialog.Builder(this);

d.setMessage("정말 종료하시겠습니까?");

d.setPositiveButton("예", new DialogInterface.OnClickListener() {


public void onClick(DialogInterface dialog, int which) {

  // appState.setState(

((APP)getApplicationContext()).setData("false"); 

mTask.cancel(true);

finish();

}

});

d.setNegativeButton("아니요", new DialogInterface.OnClickListener() {

public void onClick(DialogInterface dialog, int which) {

dialog.cancel();

}

});

d.show();


    

    private Spinner.OnItemSelectedListener spnCountriesListener = 

         new Spinner.OnItemSelectedListener() { 

    

           public void onItemSelected(AdapterView parent, View v, int position, long id) { 

            

             

             Log.d("jungjury",String.format("%d", count));

             

             Log.d("jungjury", parent.getSelectedItem().toString()); 

             

        if ( count != 0 ){

           if (is== false  )

           {

           Log.d("jungjury","CLEAR");

           

           int j=0;

  for( j=0; j<count ; j++) 

  list.set(j, " ");

           }

         }


         Query="select * from v_state where username='"+parent.getSelectedItem().toString()+"' ORDER BY blnum  ASC";

        

         if ( parent.getSelectedItem().toString() =="전체보기" ) Query = String.format("select * from v_state ORDER BY username,blnum ASC");

        

         Log.d("jugjury", Query );

 

        

         handler.sendEmptyMessage(1);

          

        

        

           } 


           public void onNothingSelected(AdapterView parent) {

            Query = String.format("select * from v_state ORDER BY username,blnum ASC");

            handler.sendEmptyMessage(1);

           }             

       }; 

    

       


  Handler handler = new Handler(){

   public void handleMessage(Message msg){

         super.handleMessage(msg);

       

     if (Build.VERSION.SDK_INT >= 11) {


     mTask =  new MyAsyncTask().executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR );


     } else {


     mTask = new MyAsyncTask().execute();


     }


                    

        

          

   }

};



  Handler handler2 = new Handler(){

   public void handleMessage(Message msg){

   super.handleMessage(msg);

   

     if (Build.VERSION.SDK_INT >= 11) {


         new MyAsyncTask2().executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR );


     } else {


     new MyAsyncTask2().execute();


     }

                     

       //   this.sendEmptyMessageDelayed(0, 1000);

          

   }

};


  Handler handler5 = new Handler() {

     @Override

     public void handleMessage(Message msg) {


   runOnUiThread(new Runnable() { 

                   public void run() {

                    adapter.notifyDataSetChanged();

                }

                

               });

   

      

     // MainActivity.this.listView.setSelectionFromTop(0,0);

     }

  };


  

  Handler handler6 = new Handler() {

     @Override

     public void handleMessage(Message msg) {


   runOnUiThread(new Runnable() { 

                   public void run() {

                    adapter2.notifyDataSetChanged();

                }

                

               });

   

      

     // MainActivity.this.listView.setSelectionFromTop(0,0);

     }

  };


    ResultSet reset;



    public void query2( String query )

    {

    

    Connection conn = null;

    

      

    

    try {

    Class.forName("net.sourceforge.jtds.jdbc.Driver").newInstance();    

    conn = DriverManager.getConnection("jdbc:jtds:sqlserver://218.234.17.183/elevator_state","sa","!@#$?><M");

    Statement stmt = conn.createStatement();

    

    

    

    reset = stmt.executeQuery(Query);

    

int i=0;


  

  

  while(reset.next()){

    final String str = reset.getString(12)+" "+reset.getString(1)+" "+reset.getString(4)+" "+reset.getString(5)+" "+reset.getString(6)+" "

    +reset.getString(2)+" "+reset.getString(3);

   

    

    if ( is )

    {

   runOnUiThread(new Runnable() { 

                   public void run() {

                    adapter.add(str);

                    count++;

  

                }

                

               });

   

    }

    else

     {

     list.set(i, str);

     i++;

    

     }

  

     

}

  

  if ( is == false ){

  int j=0;

  for( j=i; j<count ; j++) 

  list.set(j, " ");

  }

  

  

  is=false;


    


            

    conn.close();

    

    

    catch (Exception e)

    {

     //Log.w("111Error connection","" + e.getMessage());

    }

  

  }


    public class MyAsyncTask extends AsyncTask<String, String, String>{

      

       // @Override

        protected void onPreExecute() {

        


        

        }

         

       // @Override

        protected String doInBackground(String... params) {

             


     String str = ((APP)getApplicationContext()).getData();

     String TRUE="true";

    

      if (isCancelled()) return (null); // don't forget to terminate this method


        

             //Log.d("hohoho", str );

         query2(Query);


return null;

        }

         

        //@Override

        protected void onPostExecute(String result) {

         handler5.sendEmptyMessage(0);

         handler.sendEmptyMessageDelayed(0, 500);

        }

         

        //@Override

        protected void onCancelled() {

            super.onCancelled();

        }



    }

    

    public class MyAsyncTask2 extends AsyncTask<String, String, String>{

     Connection conn = null; 

    

        // @Override

         protected void onPreExecute() {

          


         }

          

        // @Override

         protected String doInBackground(String... params) {

          if(this.isCancelled()) {

         this.cancel(true);

         //   appState.setState(false);

        

          

        //if (    appState.getState())

        {

          try {

           // Log.d("Log", "#####################");

          Class.forName("net.sourceforge.jtds.jdbc.Driver").newInstance();

       //   Log.i("Connection","**MSSQL driver load");

          

          conn = DriverManager.getConnection("jdbc:jtds:sqlserver://주소/DB명","아이디","패스워드");

       //   Log.i("Connection","**MSSQL open");

          Statement stmt = conn.createStatement();

          ResultSet reset = stmt.executeQuery("select distinct username from elevator");

     

 runOnUiThread(new Runnable() { 

                     public void run() {


adapter2.add("전체보기");

                   

                 

     });

 

 

          while(reset.next()){

          

           if ( reset.getString(1) != null )

           {

           final String str = reset.getString(1);

     runOnUiThread(new Runnable() { 

                      public void run() {


adapter2.add(str);

                    

                  

      });

           }  

          

          }

          

          conn.close();

          

          

         

          

           catch (Exception e)

          {

           Log.w("222Error connection","" + e.getMessage());

          }

        }

  return null;

         }

          

         //@Override

         protected void onPostExecute(String result) {


         // handler6.sendEmptyMessage(0);

         }

          

         //@Override

         protected void onCancelled() {

             super.onCancelled();

         }



     }

    

    

}

728x90
반응형
:
Posted by mapagilove
728x90
반응형

2013/03/25 10:32

mssql db서버에서 가져온 데이터를 android프로그램의 listview에 뿌리리기

일주일정도 헤매다가 겨우 만들었습니다.. 참고하세요

JSP를 이용하여 안드로이드로 가져오려했는데 방법을 몰라헤매다가

안드로이드에서 직접 데이터베이스를 건드리게 했어요;.

 

아래 라이브러리를 추가해주셔야 함니다..

 jtds-1.2.5.jar

 

 

2013.2.18

andorid 4.1.2 에서 돌려보니 DB 연결이 안된다..

구글링한 결과 3.0 부터 메인 쓰레드에서 네트워크 사용을 하면 안된다는 거 같다. 

그래서 AsyncTask를 사용하도록 바꾸었더니 동작한다. 

 

따라서 아래 코드는 3.0 이하 에서만 동작합니다.

 

 

package com.example.test;

 

import java.sql.Connection;

import java.sql.DriverManager;

import java.sql.ResultSet;

import java.sql.Statement;

import java.util.ArrayList;

import java.util.Timer;

import java.util.TimerTask;

 

import android.app.Activity;

import android.os.Bundle;

import android.os.Handler;

import android.os.Message;

import android.util.Log;

import android.view.View;

import android.widget.ArrayAdapter;

import android.widget.ListView;

 

public class MainActivity extends Activity {

 

    

    

    ArrayList<String> list;

    ArrayAdapter<String> adapter;

    ListView listView;

 

    

    

    final Handler handler = new Handler()  {

 

    public void handleMessage(Message msg) {

 

list.clear();

 

query2();

adapter.notifyDataSetChanged();

 

    }

 

    };

    

    TimerTask myTask = new TimerTask(){

    @Override

public void run()

{

Log.i("test", "timer");

    Message msg = handler.obtainMessage();

    handler.sendMessage(msg);

}

};

 

 

    @Override

    protected void onCreate(Bundle savedInstanceState) {

        super.onCreate(savedInstanceState);

        setContentView(R.layout.main);

          

   

        list = new ArrayList<String>();

 

        adapter = new ArrayAdapter<String>(this,  android.R.layout.simple_list_item_1, list);

   

        listView = (ListView)findViewById(R.id.list);

        listView.setAdapter(adapter);

   

       // query2();

      //  

 

        // 리스트뷰에 어댑터 연결

       

      Timer timer = new Timer();

      timer.schedule( myTask, 1000, 2000 );

     

 

    }

 

    

    public void query2()

    {

   Log.i("Android"," MSSQL Connect Example.");

   Connection conn = null;

   

   

   

   try {

   Class.forName("net.sourceforge.jtds.jdbc.Driver").newInstance();

   Log.i("Connection","MSSQL driver load");

   

   conn = DriverManager.getConnection("jdbc:jtds:sqlserver://서버주소/DB이름","아이디","패스워드");

   Log.i("Connection","MSSQL open");

   Statement stmt = conn.createStatement();

   ResultSet reset = stmt.executeQuery("select * from v_state");

   

   //Print the data to the console

   while(reset.next()){

    //list.add(reset.getString(12)+" "+reset.getString(1)+" "+reset.getString(3));

    list.add(reset.getString(12)+" "+reset.getString(1)+" "+reset.getString(4)+" "+reset.getString(5)+" "+reset.getString(6));

   }

   

   conn.close();

   

   

   catch (Exception e)

   {

    Log.w("Error connection","" + e.getMessage());

   }

 }

    

    

}

출처 : http://webnautes.tistory.com/entry/mssql-db%EC%84%9C%EB%B2%84%EC%97%90%EC%84%9C-%EA%B0%80%EC%A0%B8%EC%98%A8-%EB%8D%B0%EC%9D%B4%ED%84%B0%EB%A5%BC-android%ED%94%84%EB%A1%9C%EA%B7%B8%EB%9E%A8%EC%9D%98-listview%EC%97%90-%EB%BF%8C%EB%A6%AC%EA%B8%B0

 

728x90
반응형
:
Posted by mapagilove
728x90
반응형

안드로이드/Android File 속성 및 생성, 글쓰기, 읽기, 복사 하기
원본출처:
http://arabiannight.tistory.com/47
 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
package arabiannight.tistory.com;
 
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
 
import android.app.Activity;
import android.os.Bundle;
import android.os.Environment;
import android.util.Log;
 
public class TestFileActivity extends Activity {
 
    public static final String TAG = "TestFileActivity";
    public static final String STRSAVEPATH = Environment.
            getExternalStorageDirectory()+"/testfolder/";
    public static final String STRSAVEPATH2 = Environment.
            getExternalStorageDirectory()+"/testfolder2/";
    public static final String SAVEFILEPATH = "MyFile.txt";
 
    @Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.main);
 
        //폴더 생성
        File dir = makeDirectory(STRSAVEPATH);
        //파일 생성
        File file = makeFile(dir, (STRSAVEPATH+SAVEFILEPATH));
        //절대 경로
        Log.i(TAG, ""+getAbsolutePath(dir));
        Log.i(TAG, ""+getAbsolutePath(file));
 
        //파일 쓰기
        String content = new String("가나다라마바다사아자차카타파하");
        writeFile(file , content.getBytes());
         
        //파일 읽기
        readFile(file);
         
        //파일 복사
        makeDirectory(STRSAVEPATH2); //복사할 폴더
        copyFile(file , (STRSAVEPATH2+SAVEFILEPATH));
         
        //디렉토리 내용 얻어 오기
        String[] list = getList(dir);
        for(String s : list){
            Log.d(TAG, s);
        }
    }
 
    /**
     * 디렉토리 생성
     * @return dir
     */
    private File makeDirectory(String dir_path){
        File dir = new File(dir_path);
        if (!dir.exists())
        {
            dir.mkdirs();
            Log.i( TAG , "!dir.exists" );
        }else{
            Log.i( TAG , "dir.exists" );
        }
 
        return dir;
    }
 
    /**
     * 파일 생성
     * @param dir
     * @return file
     */
    private File makeFile(File dir , String file_path){
        File file = null;
        boolean isSuccess = false;
        if(dir.isDirectory()){
            file = new File(file_path);
            if(file!=null&&!file.exists()){
                Log.i( TAG , "!file.exists" );
                try {
                    isSuccess = file.createNewFile();
                } catch (IOException e) {
                    e.printStackTrace();
                } finally{
                    Log.i(TAG, "파일생성 여부 = " + isSuccess);
                }
            }else{
                Log.i( TAG , "file.exists" );
            }
        }
        return file;
    }
 
    /**
     * (dir/file) 절대 경로 얻어오기
     * @param file
     * @return String
     */
    private String getAbsolutePath(File file){
        return ""+file.getAbsolutePath();
    }
 
    /**
     * (dir/file) 삭제 하기
     * @param file
     */
    private boolean deleteFile(File file){
        boolean result;
        if(file!=null&&file.exists()){
            file.delete();
            result = true;
        }else{
            result = false;
        }
        return result;
    }
 
    /**
     * 파일여부 체크 하기
     * @param file
     * @return
     */
    private boolean isFile(File file){
        boolean result;
        if(file!=null&&file.exists()&&file.isFile()){
            result=true;
        }else{
            result=false;
        }
        return result;
    }
 
    /**
     * 디렉토리 여부 체크 하기
     * @param dir
     * @return
     */
    private boolean isDirectory(File dir){
        boolean result;
        if(dir!=null&&dir.isDirectory()){
            result=true;
        }else{
            result=false;
        }
        return result;
    }
 
    /**
     * 파일 존재 여부 확인 하기
     * @param file
     * @return
     */
    private boolean isFileExist(File file){
        boolean result;
        if(file!=null&&file.exists()){
            result=true;
        }else{
            result=false;
        }
        return result;
    }
     
    /**
     * 파일 이름 바꾸기
     * @param file
     */
    private boolean reNameFile(File file , File new_name){
        boolean result;
        if(file!=null&&file.exists()&&file.renameTo(new_name)){
            result=true;
        }else{
            result=false;
        }
        return result;
    }
     
    /**
     * 디렉토리에 안에 내용을 보여 준다.
     * @param file
     * @return
     */
    private String[] getList(File dir){
        if(dir!=null&&dir.exists())
            return dir.list();
        return null;
    }
 
    /**
     * 파일에 내용 쓰기
     * @param file
     * @param file_content
     * @return
     */
    private boolean writeFile(File file , byte[] file_content){
        boolean result;
        FileOutputStream fos;
        if(file!=null&&file.exists()&&file_content!=null){
            try {
                fos = new FileOutputStream(file);
                try {
                    fos.write(file_content);
                    fos.flush();
                    fos.close();
                } catch (IOException e) {
                    e.printStackTrace();
                }
            } catch (FileNotFoundException e) {
                e.printStackTrace();
            }
            result = true;
        }else{
            result = false;
        }
        return result;
    }
 
    /**
     * 파일 읽어 오기
     * @param file
     */
    private void readFile(File file){
        int readcount=0;
        if(file!=null&&file.exists()){
            try {
                FileInputStream fis = new FileInputStream(file);
                readcount = (int)file.length();
                byte[] buffer = new byte[readcount];
                fis.read(buffer);
                for(int i=0 ; i<file.length();i++){
                    Log.d(TAG, ""+buffer[i]);
                }
                fis.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
    }
     
    /**
     * 파일 복사
     * @param file
     * @param save_file
     * @return
     */
    private boolean copyFile(File file , String save_file){
        boolean result;
        if(file!=null&&file.exists()){
            try {
                FileInputStream fis = new FileInputStream(file);
                FileOutputStream newfos = new FileOutputStream(save_file);
                int readcount=0;
                byte[] buffer = new byte[1024];
                while((readcount = fis.read(buffer,0,1024))!= -1){
                    newfos.write(buffer,0,readcount);
                }
                newfos.close();
                fis.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
            result = true;
        }else{
            result = false;
        }
        return result;
    }
}


몇개는 테스트 못해본 메서드 있습니다 ㅎ^^ 으악


파일 생성 및 삭제를 위해서는 AndroidManifest.xml 파일에 아래의 퍼미션을 꼭 추가해야 합니다. 
퍼미션 삽입 위치는

<manifest>
    <퍼미션삽입위치>
    <application>
    </application> 
    <퍼미션삽입위치> 
</manifest>



 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
 




 TestFile.zip




728x90
반응형
:
Posted by mapagilove
반응형