123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233 |
- package com.example.ueberwachungssystem;
-
- import androidx.camera.core.ExperimentalGetImage;
- import androidx.fragment.app.Fragment;
- import androidx.fragment.app.FragmentTransaction;
- import androidx.annotation.NonNull;
- import androidx.appcompat.app.AppCompatActivity;
-
- import android.annotation.SuppressLint;
- import android.content.ComponentName;
- import android.content.Context;
- import android.content.Intent;
- import android.content.ServiceConnection;
- import android.os.Bundle;
- import android.os.IBinder;
- import android.util.Log;
- import android.view.Menu;
- import android.view.MenuItem;
- import android.view.View;
- import android.widget.Button;
- import android.widget.ImageView;
- import android.widget.TextView;
- import android.widget.Toast;
- import android.widget.ToggleButton;
-
- import com.example.ueberwachungssystem.Fragments.Fragment1;
- import com.example.ueberwachungssystem.Detection.DetectorService;
- import com.example.ueberwachungssystem.Fragments.Fragment3;
- import com.example.ueberwachungssystem.Fragments.VideoListFragment;
-
- import java.util.OptionalInt;
-
- @ExperimentalGetImage
- public class MainActivity extends AppCompatActivity implements Fragment3.OnImageViewReadyListener{
- //StringBuffer
- private StringBuffer messageBuffer = new StringBuffer();
-
- //Fragmente
- private Fragment aktuellesFragment;
- private Fragment fragment1_;
- private Fragment fragment2_;
- private Fragment fragment3_;
-
- private Fragment1 fragment1;
- private Fragment3 fragment3;
-
- private ImageView fragmentImage;
- private ImageView fragmentImage2;
- private VideoListFragment videoListFragment = new VideoListFragment();
- private DetectorService detectorService = new DetectorService();
- int num = 0;
- //Textviews
- private TextView Auswahl;
- private TextView AoderA;
- private String auswahltext = "Wahl des Detektionsmodus";
- private String auswahlAoderA = "Wahl von Alarmmeldungen oder Auswahl von Alarmaufzeichnungen";
- //Buttons
- private ToggleButton toggleKamera;
- private ToggleButton toggleAudio;
- private ToggleButton toggleBewegung;
-
- @Override
- protected void onCreate(Bundle savedInstanceState) {
- super.onCreate(savedInstanceState);
- setTitle("Supervision");
- setContentView(R.layout.activity_main);
- Auswahl = findViewById(R.id.textAuswahl);
- Auswahl.setText(auswahltext);
- AoderA = findViewById(R.id.textAoderA);
- AoderA.setText(auswahlAoderA);
- toggleKamera = findViewById(R.id.toggleKamera);
- toggleAudio = findViewById(R.id.toggleAudio);
- toggleBewegung = findViewById(R.id.toggleBewegung);
- }
-
- @Override
- protected void onResume() {
- super.onResume();
-
- PermissionHandler permissionHandler = new PermissionHandler(this);
- //permissionHandler.getPermissions();
- if (permissionHandler.hasPermissions()) {
-
- Intent serviceIntent = new Intent(this, DetectorService.class);
- bindService(serviceIntent, serviceConnection, Context.BIND_AUTO_CREATE);
- startService(serviceIntent);
-
- toggleKamera.setOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View v) {
- if (toggleKamera.isChecked()) {
- if(detectorService != null) {
- detectorService.videoDetector.startDetection();
- }
- } else {
- if(detectorService != null) {
- detectorService.videoDetector.stopDetection();
- }
- }
- }
- });
- toggleAudio.setOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View v) {
- if (toggleAudio.isChecked()) {
- if(detectorService != null) {
- detectorService.audioDetector.startDetection();
- }
- } else {
- if(detectorService != null) {
- detectorService.audioDetector.stopDetection();
- }
- }
- }
- });
- toggleBewegung.setOnClickListener(new View.OnClickListener() {
- @Override
- public void onClick(View v) {
- if (toggleBewegung.isChecked()) {
- if(detectorService != null) {
- detectorService.motionDetector.startDetection();
- }
- } else {
- if(detectorService != null) {
- detectorService.motionDetector.stopDetection();
- }
- }
- }
- });
- }else{
- Toast.makeText(this,"Bitte Rechte geben", Toast.LENGTH_SHORT).show();
- }
-
- }
-
- public boolean onCreateOptionsMenu(Menu menu) {
- getMenuInflater().inflate(R.menu.options_menu, menu);
- return true;
- }
-
- public boolean onOptionsItemSelected(MenuItem item) {
- Toast.makeText(this, "Selected Item: " + item.getTitle(), Toast.LENGTH_SHORT).show();
- PopUpClass popUpClass;
- switch (item.getItemId()) {
- case R.id.Rechteverwaltung:
- popUpClass = new PopUpClass(MainActivity.this);
- popUpClass.showPopupWindow(toggleAudio);
- popUpClass.RechtePrüfen();
- return true;
- case R.id.Sensoren:
- popUpClass = new PopUpClass(MainActivity.this);
- popUpClass.showPopupWindow(toggleAudio);
- popUpClass.Sensoren();
- return true;
- case R.id.Impressum:
- popUpClass = new PopUpClass(MainActivity.this);
- popUpClass.showPopupWindow(toggleAudio);
- popUpClass.Impressum();
- return true;
- case R.id.Detection:
- popUpClass = new PopUpClass(MainActivity.this);
- popUpClass.showPopupWindow(toggleAudio);
- popUpClass.DetectionTotal(num);
- return true;
- default:
- return super.onOptionsItemSelected(item);
- }
- }
-
- private ServiceConnection serviceConnection = new ServiceConnection() {
- @Override
- public void onServiceConnected(ComponentName name, IBinder service) {
- DetectorService.ServiceBinder binder = (DetectorService.ServiceBinder) service;
- detectorService = binder.getBoundService();
-
- detectorService.setOnDetectionListener(new DetectorService.OnDetectionListener() {
- @Override
- public void onDetection(@NonNull StringBuffer stringBuffer) {
- Log.d("onDetection", stringBuffer.toString()); //Für oli hier Textview einbauen
- num = stringBuffer.toString().split("\n").length;
- messageBuffer = stringBuffer;
- if ((aktuellesFragment == fragment1_) && (aktuellesFragment != null)) {
- Log.d("Fragment", aktuellesFragment.toString() + " " + fragment1_.toString());
- fragment1_ = zeigeFragment(fragment1.erstellen(messageBuffer.toString()));
- }
- }
- });
- }
- @Override
- public void onServiceDisconnected(ComponentName name) {
- }
- };
-
- public void onClickZeigeFragment1(View view) {
- Button button = (Button) view;
- fragment1_ = zeigeFragment(fragment1.erstellen(messageBuffer.toString()));
- }
-
- public void onClickZeigeFragment2(View view) {
- Button button = (Button) view;
- //zeigeFragment(fragment2.erstellen("Hier stehen dann die Videos"));
- fragment2_ = zeigeFragment(videoListFragment);
- }
- public void onClickZeigeFragment3(View view) {
- Button button = (Button) view;
- fragment3_ = zeigeFragment(fragment3.erstellen(view));
- }
- public void onImageViewReady(ImageView imageView, ImageView imageView2) {
- fragmentImage = imageView;
- fragmentImage2 = imageView2;
- detectorService.videoDetector.debugProcessing(fragmentImage, fragmentImage2); //inputImageView
- }
-
- public void onClickEntferneFragment(View view) {
- entferneFragment();
- }
-
- private Fragment zeigeFragment(Fragment fragment) {
- FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
- ft.replace(R.id.frame, fragment);
- ft.commit();
- aktuellesFragment = fragment;
- return aktuellesFragment;
- }
- private void entferneFragment() {
- if (aktuellesFragment != null) {
- FragmentTransaction ft = getSupportFragmentManager().beginTransaction();
- ft.remove(aktuellesFragment);
- ft.commit();
- aktuellesFragment = null ;
- }
- }
- }
|