加速度センサの値をcsvに書き込んで、スマホのsdカード内にcatコマンドを使ってコピーすると、アクセス拒否のメッセージがでてコピーに失敗します。
やったこと
①テストアプリとして別に作成した、現在時刻を取得してcsvに書き込ませたファイルはcatコマンドでsd内にコピーすることができ、pcからそのcsvを開くと、しっかりと時刻が記述されているのを確認できました。
java
1package to.msn.wings.csvsavetest; 2 3import androidx.appcompat.app.AppCompatActivity; 4import java.io.FileOutputStream; 5import java.util.Calendar; 6import java.text.SimpleDateFormat; 7import android.content.Context; 8import android.os.Bundle; 9 10public class MainActivity extends AppCompatActivity { 11 12 @Override 13 protected void onCreate(Bundle savedInstanceState) { 14 super.onCreate(savedInstanceState); 15 setContentView(R.layout.activity_main); 16 17 18 String filename = "TestTest.csv"; 19 String output = "date\n"; 20 Calendar c = Calendar.getInstance(); 21 SimpleDateFormat sdf = new SimpleDateFormat("yy.MM.dd_HH:mm:ss:SSS"); 22 output += sdf.format(c.getTime()); 23 24 25 FileOutputStream outputStream; 26 try { 27 outputStream = openFileOutput(filename, Context.MODE_PRIVATE); 28 outputStream.write(output.getBytes()); 29 outputStream.close(); 30 } catch (Exception e) { 31 e.printStackTrace(); 32 } 33 } 34}
①のアプリでうまくいったので、加速度センサの値を取得時間と一緒にcsvに記録するアプリを作り、同じ手順でコピーをしようとしたら、アクセス拒否メッセージが出ました。
コピー元のファイルをターミナルからcatで覗くと、中にはちゃんと取得時間と加速度が記録されていました。また、コピー先には容量0バイトの空のcsvファイルが作成していました。
以下のソースはファイル記述周りの一部になります。
java
1 @Override 2 public void onSensorChanged(SensorEvent event){ 3 final float alpha = 0.6f; 4 String strTmp; 5 6 7 if (event.sensor.getType() == Sensor.TYPE_LINEAR_ACCELERATION) { 8 9 if(button_flag == 1) { 10 11 strTmp = "加速度\n" 12 + " X: " + event.values[0] + "\n" 13 + " Y: " + event.values[1] + "\n" 14 + " Z: " + event.values[2]; 15 16 textView.setText(strTmp); 17 18 LineData data = mChart.getLineData(); 19 20 if(data != null){ 21 for(int i = 0; i < 3; i++){ 22 ILineDataSet set3 = data.getDataSetByIndex(i); 23 if(set3 == null){ 24 LineDataSet set = new LineDataSet(null, labels[i]); 25 set.setLineWidth(2.0f); 26 set.setColor(colors[i]); 27 set.setDrawCircles(false); 28 set.setDrawValues(false); 29 set3 = set; 30 data.addDataSet(set3); 31 } 32 33 //更新 34 data.addEntry(new Entry(set3.getEntryCount(), event.values[i]), i); 35 data.notifyDataChanged(); 36 } 37 38 //記録ボタンが押された時 39 if(recording == 1) {//(記録開始) 40 Calendar c = Calendar.getInstance(); 41 SimpleDateFormat sdf = new SimpleDateFormat("yy/MM/dd_HH:mm:ss.SSS"); 42 output += (data_num+" ,"+sdf.format(c.getTime())+","+ event.values[0] +","+ event.values[1] +","+ event.values[2] + "\n");//csvファイルに書き込む情報をoutputに追記 43 data_num++; 44 }else if(recording == 2){//(記録終了) 45 FileOutputStream outputStream; 46 try { 47 outputStream = openFileOutput(filename, Context.MODE_PRIVATE);//ファイルを開く 48 outputStream.write(output.getBytes()); 49 outputStream.close(); 50 Toast.makeText(MainActivity.this, "記録終了",Toast.LENGTH_SHORT).show(); 51 recording = 0; 52 data_num = 1; 53 } catch (Exception e) { 54 e.printStackTrace(); 55 } 56 } 57 mChart.notifyDataSetChanged(); 58 mChart.setVisibleXRangeMaximum(50); 59 mChart.moveViewToX(data.getEntryCount()); 60 } 61 } 62 } 63 }
コピーする際の手順は①と同じなのでファイルをコピーできなくなった原因がわかりません。何が考えられますでしょうか?
回答1件
あなたの回答
tips
プレビュー