diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..c6cbe56 --- /dev/null +++ b/.gitignore @@ -0,0 +1,8 @@ +*.iml +.gradle +/local.properties +/.idea/workspace.xml +/.idea/libraries +.DS_Store +/build +/captures diff --git a/.idea/.name b/.idea/.name new file mode 100644 index 0000000..ce6cd19 --- /dev/null +++ b/.idea/.name @@ -0,0 +1 @@ +IF3111-2016-Tugas1-Android \ No newline at end of file diff --git a/.idea/compiler.xml b/.idea/compiler.xml new file mode 100644 index 0000000..96cc43e --- /dev/null +++ b/.idea/compiler.xml @@ -0,0 +1,22 @@ + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/copyright/profiles_settings.xml b/.idea/copyright/profiles_settings.xml new file mode 100644 index 0000000..e7bedf3 --- /dev/null +++ b/.idea/copyright/profiles_settings.xml @@ -0,0 +1,3 @@ + + + \ No newline at end of file diff --git a/.idea/encodings.xml b/.idea/encodings.xml new file mode 100644 index 0000000..97626ba --- /dev/null +++ b/.idea/encodings.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/.idea/gradle.xml b/.idea/gradle.xml new file mode 100644 index 0000000..fc132b2 --- /dev/null +++ b/.idea/gradle.xml @@ -0,0 +1,19 @@ + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..5d19981 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000..ef6f09b --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + \ No newline at end of file diff --git a/.idea/runConfigurations.xml b/.idea/runConfigurations.xml new file mode 100644 index 0000000..7f68460 --- /dev/null +++ b/.idea/runConfigurations.xml @@ -0,0 +1,12 @@ + + + + + + \ No newline at end of file diff --git a/.idea/vcs.xml b/.idea/vcs.xml new file mode 100644 index 0000000..6564d52 --- /dev/null +++ b/.idea/vcs.xml @@ -0,0 +1,6 @@ + + + + + + \ No newline at end of file diff --git a/README.md b/README.md index 5ce4793..ad0dc72 100644 --- a/README.md +++ b/README.md @@ -1 +1,32 @@ -# IF3111-2016-Tugas1-Android \ No newline at end of file +# Tugas Besar 1 IF3111 Pengembangan Aplikasi pada Platform Khusus +Jessica Handayani -13513069 +*** + +## CapLocs +![alt text](http://i787.photobucket.com/albums/yy159/m00chi/splash_screen.png) + +>CapLocs - Capture Your Locations! adalah sebuah aplikasi berbasis Android yang berisi quest-quest dimana pengguna harus mencari lokasi-lokasi yang terletak di ITB dan kemudian berfoto di lokasi tersebut. Pengguna kemudian dapat mengirimkan jawaban mengenai lokasi yang menjadi quest tersebut untuk dapat melanjutkan ke quest selanjutnya hingga selesai. + +## Spesifikasi Aplikasi +* Aplikasi dapat menampilkan kompas, peta, dan lokasi dari pengguna, serta menandai lokasi yang harus dituju +![alt text](http://i787.photobucket.com/albums/yy159/m00chi/Mobile%20Uploads/Screenshot_20160328-113828.png) + +![alt text](http://i787.photobucket.com/albums/yy159/m00chi/Mobile%20Uploads/Screenshot_20160328-115609.png) + +* Aplikasi dapat menerima jawaban dari pengguna +![alt text](http://i787.photobucket.com/albums/yy159/m00chi/Mobile%20Uploads/Screenshot_20160328-113939.png)) + +* Aplikasi dapat memberikan respon berdasarkan jawaban pengguna. + - Jika jawaban pengguna benar, pengguna akan mendapat quest selanjutnya + - Jika jawaban pengguna salah, pengguna dapat menjawab kembali + - Jika quest selesai, akan diberikan pesan kepada pengguna + +* Aplikasi dapat memanggil aplikasi Camera bawaan dan menyimpan hasil foto yang diambil ke folder khusus +*![alt text](http://i787.photobucket.com/albums/yy159/m00chi/Mobile%20Uploads/Screenshot_20160328-113840.png) + +### Lokasi File +* [Source Code] +* [Binary File] + + [Source Code]: + [Binary File]: \ No newline at end of file diff --git a/app-debug.apk b/app-debug.apk new file mode 100644 index 0000000..8909ec5 Binary files /dev/null and b/app-debug.apk differ diff --git a/app/.gitignore b/app/.gitignore new file mode 100644 index 0000000..796b96d --- /dev/null +++ b/app/.gitignore @@ -0,0 +1 @@ +/build diff --git a/app/build.gradle b/app/build.gradle new file mode 100644 index 0000000..9b849b5 --- /dev/null +++ b/app/build.gradle @@ -0,0 +1,28 @@ +apply plugin: 'com.android.application' + +android { + compileSdkVersion 23 + buildToolsVersion "23.0.3" + + defaultConfig { + applicationId "jessicahandayani.caplocs" + minSdkVersion 14 + targetSdkVersion 23 + versionCode 1 + versionName "1.0" + } + buildTypes { + release { + minifyEnabled false + proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro' + } + } +} + +dependencies { + compile fileTree(include: ['*.jar'], dir: 'libs') + testCompile 'junit:junit:4.12' + compile 'com.android.support:appcompat-v7:23.2.1' + compile 'com.android.support:design:23.2.1' + compile 'com.google.android.gms:play-services:8.4.0' +} diff --git a/app/proguard-rules.pro b/app/proguard-rules.pro new file mode 100644 index 0000000..22ffa45 --- /dev/null +++ b/app/proguard-rules.pro @@ -0,0 +1,17 @@ +# Add project specific ProGuard rules here. +# By default, the flags in this file are appended to flags specified +# in C:\Users\jessica\AppData\Local\Android\sdk/tools/proguard/proguard-android.txt +# You can edit the include path and order by changing the proguardFiles +# directive in build.gradle. +# +# For more details, see +# http://developer.android.com/guide/developing/tools/proguard.html + +# Add any project specific keep options here: + +# If your project uses WebView with JS, uncomment the following +# and specify the fully qualified class name to the JavaScript interface +# class: +#-keepclassmembers class fqcn.of.javascript.interface.for.webview { +# public *; +#} diff --git a/app/src/androidTest/java/jessicahandayani/caplocs/ApplicationTest.java b/app/src/androidTest/java/jessicahandayani/caplocs/ApplicationTest.java new file mode 100644 index 0000000..1b6e2e2 --- /dev/null +++ b/app/src/androidTest/java/jessicahandayani/caplocs/ApplicationTest.java @@ -0,0 +1,13 @@ +package jessicahandayani.caplocs; + +import android.app.Application; +import android.test.ApplicationTestCase; + +/** + * Testing Fundamentals + */ +public class ApplicationTest extends ApplicationTestCase { + public ApplicationTest() { + super(Application.class); + } +} \ No newline at end of file diff --git a/app/src/main/AndroidManifest.xml b/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000..cee01e8 --- /dev/null +++ b/app/src/main/AndroidManifest.xml @@ -0,0 +1,46 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/java/jessicahandayani/caplocs/Client.java b/app/src/main/java/jessicahandayani/caplocs/Client.java new file mode 100644 index 0000000..94c2446 --- /dev/null +++ b/app/src/main/java/jessicahandayani/caplocs/Client.java @@ -0,0 +1,168 @@ +package jessicahandayani.caplocs; + +import android.os.AsyncTask; + +import org.json.JSONException; +import org.json.JSONObject; + +import java.io.BufferedReader; +import java.io.IOException; +import java.io.InputStreamReader; +import java.io.PrintWriter; +import java.net.ConnectException; +import java.net.Socket; +import java.net.UnknownHostException; + +/** + * Created by jessica + */ +public class Client extends AsyncTask { + String serverIP ="167.205.34.132"; + int port = 3111; + + private String dstAddress; + private int dstPort; + private String strResponse = ""; + private JSONObject request = new JSONObject(); + private JSONObject response; + private boolean responseStatus = false; + + Client(){ + setDstAddress(serverIP); + setDstPort(port); + } + + Client(String addr, int port) { + setDstAddress(addr); + setDstPort(port); + } + + public void setRequestLocation(){ + try { + request.put("com","req_loc"); + request.put("nim", "13513069"); + //System.out.println("Set request: " + request); + } catch (JSONException e) { + e.printStackTrace(); + } + + } + + public void setAnswer(String answer, String longitude, String latitude, String token){ + try { + request = new JSONObject(); + request.put("com","answer"); + request.put("nim", "13513069"); + request.put("answer", answer); + request.put("longitude",longitude); + request.put("latitude",latitude); + request.put("token",token); + + //System.out.println("Set answer: " + request); + } catch (JSONException e) { + e.printStackTrace(); + } + } + + @Override + protected Void doInBackground(Void... arg0) { + Socket socket = null; + + try { + socket = new Socket(getDstAddress(), getDstPort()); + BufferedReader in = new BufferedReader(new InputStreamReader(socket.getInputStream())); + PrintWriter out = new PrintWriter(socket.getOutputStream(), true); + out.println(request.toString()); + System.out.println("Sent request: " + request.toString()); + String line; + + while ((line=in.readLine()) != null){ + //System.out.println(line); + setStrResponse(strResponse + line); + } + //System.out.println("strResponse: "+ strResponse); + if (!strResponse.equals("")){ + try { + setResponse(new JSONObject(strResponse)); + System.out.println("Server Response: " + response.toString()); + setResponseStatus(true); + } catch (JSONException e) { + e.printStackTrace(); + } + } + } catch (ConnectException e) { + e.printStackTrace(); + } + catch (UnknownHostException e) { + e.printStackTrace(); + setStrResponse("UnknownHostException: " + e.toString()); + } catch (IOException e) { + e.printStackTrace(); + setStrResponse("IOException: " + e.toString()); + } finally { + if (socket != null) { + try { + socket.close(); + } catch (IOException e) { + e.printStackTrace(); + } + } + } + return null; + } + + + @Override + protected void onPostExecute(Void result) { + super.onPostExecute(result); + } + + + public String getDstAddress() { + return dstAddress; + } + + public void setDstAddress(String dstAddress) { + this.dstAddress = dstAddress; + } + + public int getDstPort() { + return dstPort; + } + + public void setDstPort(int dstPort) { + this.dstPort = dstPort; + } + + public String getStrResponse() { + return strResponse; + } + + public void setStrResponse(String strResponse) { + this.strResponse = strResponse; + } + + public JSONObject getRequest() { + return request; + } + + public void setRequest(JSONObject request) { + this.request = request; + } + + public JSONObject getResponse() { + return response; + } + + public void setResponse(JSONObject response) { + this.response = response; + } + + public boolean isResponseStatus() { + return responseStatus; + } + + public void setResponseStatus(boolean responseStatus) { + this.responseStatus = responseStatus; + } +} \ No newline at end of file diff --git a/app/src/main/java/jessicahandayani/caplocs/MainActivity.java b/app/src/main/java/jessicahandayani/caplocs/MainActivity.java new file mode 100644 index 0000000..7235433 --- /dev/null +++ b/app/src/main/java/jessicahandayani/caplocs/MainActivity.java @@ -0,0 +1,323 @@ +package jessicahandayani.caplocs; + +import android.Manifest; +import android.app.Activity; +import android.content.ContentResolver; +import android.content.DialogInterface; +import android.content.Intent; +import android.content.pm.PackageManager; +import android.database.Cursor; +import android.graphics.Bitmap; +import android.hardware.Sensor; +import android.hardware.SensorEvent; +import android.hardware.SensorEventListener; +import android.hardware.SensorManager; +import android.net.Uri; +import android.os.Bundle; +import android.os.Environment; +import android.provider.MediaStore; +import android.support.annotation.NonNull; +import android.support.design.widget.FloatingActionButton; +import android.support.design.widget.Snackbar; +import android.support.v4.app.ActivityCompat; +import android.support.v4.content.ContextCompat; +import android.support.v7.app.AppCompatActivity; +import android.support.v7.widget.Toolbar; +import android.support.v7.app.AlertDialog; +import android.util.Log; +import android.view.Surface; +import android.view.View; +import android.view.Menu; +import android.view.MenuItem; +import android.view.animation.Animation; +import android.view.animation.RotateAnimation; +import android.widget.ImageView; +import android.widget.Toast; + +import com.google.android.gms.location.LocationServices; +import com.google.android.gms.maps.CameraUpdateFactory; +import com.google.android.gms.maps.GoogleMap; +import com.google.android.gms.maps.MapFragment; +import com.google.android.gms.maps.OnMapReadyCallback; +import com.google.android.gms.maps.SupportMapFragment; +import com.google.android.gms.maps.model.LatLng; +import com.google.android.gms.maps.model.MarkerOptions; + +import org.json.JSONException; +import org.json.JSONObject; + +import java.io.File; + +public class MainActivity extends AppCompatActivity + implements + GoogleMap.OnMyLocationButtonClickListener, + OnMapReadyCallback, + ActivityCompat.OnRequestPermissionsResultCallback, + SensorEventListener { + + private static final int LOCATION_PERMISSION_REQUEST_CODE = 1; + private boolean mPermissionDenied = false; + private GoogleMap mMap; + + private ImageView mPointer; + private SensorManager mSensorManager; + private Sensor mAccelerometer; + private Sensor mMagnetometer; + private float[] mLastAccelerometer = new float[3]; + private float[] mLastMagnetometer = new float[3]; + private boolean mLastAccelerometerSet = false; + private boolean mLastMagnetometerSet = false; + private float[] mR = new float[9]; + private float[] mOrientation = new float[3]; + private float mCurrentDegree = 0f; + + private static final int TAKE_PICTURE = 1; + private static final int SUBMIT_ANSWER = 2; + private Uri imageUri; + + private Client client; + private JSONObject response = new JSONObject(); + public final static String EXTRA_MESSAGE = "jessicahandayani.CapLocs.MESSAGE"; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.activity_main); + Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar); + setSupportActionBar(toolbar); + + MapFragment mapFragment = (MapFragment) getFragmentManager() + .findFragmentById(R.id.map); + mapFragment.getMapAsync(this); + + mSensorManager = (SensorManager) getSystemService(SENSOR_SERVICE); + mAccelerometer = mSensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER); + mMagnetometer = mSensorManager.getDefaultSensor(Sensor.TYPE_MAGNETIC_FIELD); + mPointer = (ImageView) findViewById(R.id.pointer); + + client = new Client(); + client.setRequestLocation(); + + client.execute(); + + long endTime = System.currentTimeMillis() + 5000; + + while (!client.isResponseStatus() && System.currentTimeMillis() < endTime) { + //do nothing + } + if (client.isResponseStatus()){ + response = client.getResponse(); + } + + } + + protected void onResume() { + super.onResume(); + //System.out.println("Resuming..."); + mSensorManager.registerListener(this, mAccelerometer, SensorManager.SENSOR_DELAY_GAME); + mSensorManager.registerListener(this, mMagnetometer, SensorManager.SENSOR_DELAY_GAME); + } + + protected void onPause() { + super.onPause(); + //System.out.println("Pausing..."); + mSensorManager.unregisterListener(this, mAccelerometer); + mSensorManager.unregisterListener(this, mMagnetometer); + } + + @Override + public void onMapReady(GoogleMap googleMap) { + mMap = googleMap; + + mMap.setOnMyLocationButtonClickListener(this); + enableMyLocation(); + + setTargetMap(); + } + + private void setTargetMap(){ + if (!response.optString("latitude").equals("") && !response.optString("longitude").equals("")) { + double lat = response.optDouble("latitude"); + double lng = response.optDouble("longitude"); + System.out.println(response.optDouble("latitude") + ", " + response.optDouble("longitude")); + //TODO tuker lat lng + LatLng targetMap = new LatLng(lat, lng); + mMap.moveCamera(CameraUpdateFactory.newLatLng(targetMap)); + mMap.animateCamera(CameraUpdateFactory.newLatLngZoom(targetMap, 17.0f)); + mMap.addMarker(new MarkerOptions().position(targetMap).title("Marker")); + } + else { + Toast.makeText(this, "Connection Error", Toast.LENGTH_LONG); + } + } + + private void enableMyLocation() { + if (ContextCompat.checkSelfPermission(this, Manifest.permission.ACCESS_FINE_LOCATION) + == PackageManager.PERMISSION_GRANTED) { + mMap.setMyLocationEnabled(true); + } else { + Toast.makeText(this, "Please enable Location", Toast.LENGTH_SHORT).show(); + } + } + + @Override + public boolean onMyLocationButtonClick() { + return false; + } + + + @Override + public void onRequestPermissionsResult(int requestCode, @NonNull String[] permissions, + @NonNull int[] grantResults) { + + if (permissions.length == 1 && + permissions[0] == Manifest.permission.ACCESS_FINE_LOCATION && + grantResults[0] == PackageManager.PERMISSION_GRANTED) { + enableMyLocation(); + } else { + Toast.makeText(this, "Please enable Location.", Toast.LENGTH_SHORT); + mPermissionDenied = true; + } + } + + @Override + protected void onResumeFragments() { + super.onResumeFragments(); + if (mPermissionDenied) { + + mPermissionDenied = false; + } + } + + + @Override + public void onSensorChanged(SensorEvent event) { + int rotation = getWindowManager().getDefaultDisplay().getRotation(); + int screenDegree = 0; + switch(rotation) { + case Surface.ROTATION_0: + screenDegree = 0; + break; + case Surface.ROTATION_90: + screenDegree = 90; + break; + case Surface.ROTATION_180: + screenDegree = 180; + break; + case Surface.ROTATION_270: + screenDegree = 270; + break; + default: + break; + } + + //System.out.print("Rotation: "); System.out.println(screenDegree); + + if (event.sensor == mAccelerometer) { + System.arraycopy(event.values, 0, mLastAccelerometer, 0, event.values.length); + mLastAccelerometerSet = true; + } else if (event.sensor == mMagnetometer) { + System.arraycopy(event.values, 0, mLastMagnetometer, 0, event.values.length); + mLastMagnetometerSet = true; + } + if (mLastAccelerometerSet && mLastMagnetometerSet) { + SensorManager.getRotationMatrix(mR, null, mLastAccelerometer, mLastMagnetometer); + SensorManager.getOrientation(mR, mOrientation); + float azimuthInRadians = mOrientation[0]; + float azimuthInDegress = (float)(Math.toDegrees(azimuthInRadians)+360)%360; + RotateAnimation ra = new RotateAnimation( + mCurrentDegree, + -azimuthInDegress, + Animation.RELATIVE_TO_SELF, 0.5f, + Animation.RELATIVE_TO_SELF, + 0.5f); + + ra.setDuration(250); + + ra.setFillAfter(true); + + mPointer.startAnimation(ra); + mCurrentDegree = -azimuthInDegress-screenDegree; + } + } + + @Override + public void onAccuracyChanged(Sensor sensor, int accuracy) { + + + } + + public void startCamera(View view){ + //when users click camera button + Intent intent = new Intent("android.media.action.IMAGE_CAPTURE"); + File directory = new File(Environment.getExternalStoragePublicDirectory(Environment.DIRECTORY_DCIM) + "/CapLocs"); + + if (!directory.exists()) { + directory.mkdirs(); + } + + File photo = new File(directory, System.currentTimeMillis() + ".jpg"); + intent.putExtra(MediaStore.EXTRA_OUTPUT, + Uri.fromFile(photo)); + imageUri = Uri.fromFile(photo); + startActivityForResult(intent, 0); + } + + protected void onActivityResult(int requestCode, int resultCode, Intent data) { + super.onActivityResult(requestCode, resultCode, data); + + switch (requestCode) { + case TAKE_PICTURE: { + if (resultCode == Activity.RESULT_OK) { + Uri selectedImage = imageUri; + getContentResolver().notifyChange(selectedImage, null); + ContentResolver cr = getContentResolver(); + Toast.makeText(this, "Saved to Gallery.", Toast.LENGTH_LONG).show(); + } + } + case SUBMIT_ANSWER: { + if (resultCode == RESULT_OK && data != null) { + try { + response = new JSONObject(data.getStringExtra(SubmitFormActivity.EXTRA_MESSAGE)); + System.out.println("Result :" + response.toString()); + + if (!response.optString("latitude").equals("") && !response.optString("longitude").equals("")){ + //System.out.println("Next quest"); + setTargetMap(); + Toast.makeText(this, "Next quest", Toast.LENGTH_SHORT).show(); + } + else { + new AlertDialog.Builder(this) + .setMessage("Get another quest?") + .setCancelable(false) + .setPositiveButton("Yes", new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int id) { + startActivity(getIntent()); + finish(); + } + }) + .setNegativeButton("No", new DialogInterface.OnClickListener() { + public void onClick(DialogInterface dialog, int id) { + finish(); + } + }) + .show(); + finish(); + } + + } catch (JSONException e) { + e.printStackTrace(); + } + } + } + } + } + + public void startSubmitForm(View view){ + Intent intent = new Intent(this, SubmitFormActivity.class); + intent.putExtra(EXTRA_MESSAGE,response.toString()); + startActivityForResult(intent, SUBMIT_ANSWER); + } + +} + diff --git a/app/src/main/java/jessicahandayani/caplocs/SubmitFormActivity.java b/app/src/main/java/jessicahandayani/caplocs/SubmitFormActivity.java new file mode 100644 index 0000000..f528317 --- /dev/null +++ b/app/src/main/java/jessicahandayani/caplocs/SubmitFormActivity.java @@ -0,0 +1,126 @@ +package jessicahandayani.caplocs; + +import android.content.Intent; +import android.os.Bundle; +import android.support.v7.app.AppCompatActivity; +import android.support.v7.widget.Toolbar; +import android.view.View; +import android.widget.ArrayAdapter; +import android.widget.Spinner; +import android.widget.Toast; + +import org.json.JSONException; +import org.json.JSONObject; + +/** + * Created by jessica + */ +public class SubmitFormActivity extends AppCompatActivity { + + private JSONObject message; + private JSONObject response = new JSONObject(); + + public final static String EXTRA_MESSAGE = "jessicahandayani.CapLocs.MESSAGE"; + + @Override + protected void onCreate(Bundle savedInstanceState) { + super.onCreate(savedInstanceState); + setContentView(R.layout.content_submit_form); + + Intent intent = getIntent(); + try { + message = new JSONObject(intent.getStringExtra(MainActivity.EXTRA_MESSAGE)); + } catch (JSONException e) { + e.printStackTrace(); + } + + Spinner spinner = (Spinner) findViewById(R.id.spinner); + ArrayAdapter adapter = ArrayAdapter.createFromResource(this, + R.array.location_options, android.R.layout.simple_spinner_item); + adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item); + + spinner.setAdapter(adapter); + } + + public void submitAnswer(View view){ + //submit answer to server + Spinner spinner = (Spinner) findViewById(R.id.spinner); + String answer = setLocationAnswer(spinner.getItemAtPosition(spinner.getSelectedItemPosition()).toString()); + Client client = new Client(); + client.setAnswer(answer, message.optString("longitude"), message.optString("latitude"), message.optString("token")); + client.execute(); + while (!client.isResponseStatus()){ + + } + response = client.getResponse(); + checkResponse(); + } + + private String setLocationAnswer(String selectedAnswer){ + switch (selectedAnswer){ + case "GKU Barat" :{ + return "gku_barat"; + } + case "GKU Timur" :{ + return "gku_timur"; + } + case "Intel" : { + return "intel"; + } + case "CC Barat" : { + return "cc_barat"; + } + case "CC Timur" : { + return "cc_timur"; + } + case "DPR" : { + return "dpr"; + } + case "Oktagon" : { + return "oktagon"; + } + case "Perpustakaan" : { + return "perpustakaan"; + } + case "PAU" : { + return "pau"; + } + case "Kubus" : { + return "kubus"; + } + default:{ + return selectedAnswer; + } + } + } + + private void checkResponse(){ + String status = response.optString("status"); + System.out.println("Status: " + status); + switch (status){ + case "ok": { + //System.out.println("masuk ke ok"); + Intent intent = new Intent(); + intent.putExtra(EXTRA_MESSAGE, response.toString()); + setResult(RESULT_OK, intent); + finish(); + break; + } + case "wrong_answer": { + //System.out.println("masuk ke wrong"); + Toast.makeText(this, "Wrong answer! Try again.", Toast.LENGTH_LONG).show(); + break; + } + case "finish": { + //System.out.println("masuk ke finish"); + Toast.makeText(this, "You've finished the quests!", Toast.LENGTH_LONG).show(); + Intent intent = new Intent(); + intent.putExtra(EXTRA_MESSAGE, response.toString()); + setResult(RESULT_OK, intent); + finish(); + break; + } + } + } + +} diff --git a/app/src/main/res/drawable/camera.png b/app/src/main/res/drawable/camera.png new file mode 100644 index 0000000..fd652ed Binary files /dev/null and b/app/src/main/res/drawable/camera.png differ diff --git a/app/src/main/res/drawable/pointer.png b/app/src/main/res/drawable/pointer.png new file mode 100644 index 0000000..d7e534d Binary files /dev/null and b/app/src/main/res/drawable/pointer.png differ diff --git a/app/src/main/res/drawable/splash_screen.png b/app/src/main/res/drawable/splash_screen.png new file mode 100644 index 0000000..7782792 Binary files /dev/null and b/app/src/main/res/drawable/splash_screen.png differ diff --git a/app/src/main/res/drawable/submit.png b/app/src/main/res/drawable/submit.png new file mode 100644 index 0000000..92ea075 Binary files /dev/null and b/app/src/main/res/drawable/submit.png differ diff --git a/app/src/main/res/layout-land/content_main.xml b/app/src/main/res/layout-land/content_main.xml new file mode 100644 index 0000000..d5accdd --- /dev/null +++ b/app/src/main/res/layout-land/content_main.xml @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/layout/activity_main.xml b/app/src/main/res/layout/activity_main.xml new file mode 100644 index 0000000..348c905 --- /dev/null +++ b/app/src/main/res/layout/activity_main.xml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + diff --git a/app/src/main/res/layout/content_main.xml b/app/src/main/res/layout/content_main.xml new file mode 100644 index 0000000..d4dfcca --- /dev/null +++ b/app/src/main/res/layout/content_main.xml @@ -0,0 +1,60 @@ + + + + + + + + + + + + + + + + + + diff --git a/app/src/main/res/layout/content_submit_form.xml b/app/src/main/res/layout/content_submit_form.xml new file mode 100644 index 0000000..bbd4c34 --- /dev/null +++ b/app/src/main/res/layout/content_submit_form.xml @@ -0,0 +1,47 @@ + + + + + + + +