Oreo
This commit is contained in:
parent
f111bd45b4
commit
3a3ec64eba
@ -34,18 +34,21 @@
|
||||
</service>
|
||||
|
||||
|
||||
|
||||
<service
|
||||
android:name=".RestartService"
|
||||
android:enabled="true"
|
||||
android:exported="true" />
|
||||
<receiver android:name=".AlarmReceiver"/>
|
||||
<receiver android:name=".RebootReceiver">
|
||||
<intent-filter>
|
||||
<action android:name="android.intent.action.BOOT_COMPLETED"/>
|
||||
<action android:name="android.intent.action.QUICKBOOT_POWERON" />
|
||||
<action android:name="android.intent.action.SCREEN_ON" />
|
||||
</intent-filter>
|
||||
</receiver>
|
||||
|
||||
<service
|
||||
android:name=".NotificationListenerMusic"
|
||||
android:permission="android.permission.BIND_NOTIFICATION_LISTENER_SERVICE">
|
||||
<intent-filter>
|
||||
<action android:name="android.service.notification.NotificationListenerService" />
|
||||
</intent-filter>
|
||||
</service>
|
||||
|
||||
|
||||
</application>
|
||||
|
@ -1,21 +0,0 @@
|
||||
package com.flywithu.carnav;
|
||||
|
||||
import android.content.BroadcastReceiver;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.os.Build;
|
||||
|
||||
public class AlarmReceiver extends BroadcastReceiver{
|
||||
|
||||
@Override
|
||||
public void onReceive(Context context, Intent intent) {
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
|
||||
Intent in = new Intent(context, RestartService.class);
|
||||
context.startForegroundService(in);
|
||||
} else {
|
||||
Intent in = new Intent(context, RealService.class);
|
||||
context.startService(in);
|
||||
}
|
||||
}
|
||||
|
||||
}
|
@ -8,15 +8,18 @@ import android.content.IntentFilter;
|
||||
import android.hardware.usb.UsbDeviceConnection;
|
||||
import android.hardware.usb.UsbManager;
|
||||
import android.os.Bundle;
|
||||
import android.widget.TextView;
|
||||
import android.widget.Toast;
|
||||
|
||||
import androidx.appcompat.app.AppCompatActivity;
|
||||
import androidx.core.app.NotificationManagerCompat;
|
||||
|
||||
import com.hoho.android.usbserial.driver.UsbSerialDriver;
|
||||
import com.hoho.android.usbserial.driver.UsbSerialPort;
|
||||
import com.hoho.android.usbserial.driver.UsbSerialProber;
|
||||
|
||||
import java.util.List;
|
||||
import java.util.Set;
|
||||
|
||||
public class MainActivity extends AppCompatActivity {
|
||||
|
||||
@ -41,12 +44,41 @@ public class MainActivity extends AppCompatActivity {
|
||||
|
||||
}
|
||||
|
||||
|
||||
private boolean isNotiPermissionAllowed() {
|
||||
Set<String> notiListenerSet = NotificationManagerCompat.getEnabledListenerPackages(this);
|
||||
String myPackageName = getPackageName();
|
||||
|
||||
for (String packageName : notiListenerSet) {
|
||||
if (packageName == null) {
|
||||
continue;
|
||||
}
|
||||
if (packageName.equals(myPackageName)) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
protected void onCreate(Bundle savedInstanceState) {
|
||||
super.onCreate(savedInstanceState);
|
||||
setContentView(R.layout.activity_main);
|
||||
|
||||
|
||||
boolean isPermissionAllowed = isNotiPermissionAllowed();
|
||||
|
||||
if (!isPermissionAllowed) {
|
||||
Intent intent = new Intent("android.settings.ACTION_NOTIFICATION_LISTENER_SETTINGS");
|
||||
startActivity(intent);
|
||||
} else {
|
||||
((TextView) findViewById(R.id.textViewNotificationStatus)).setText((isNotiPermissionAllowed()) ? "OK" : "NO");
|
||||
}
|
||||
|
||||
|
||||
|
||||
UsbManager manager = (UsbManager) getSystemService(Context.USB_SERVICE);
|
||||
List<UsbSerialDriver> availableDrivers = UsbSerialProber.getDefaultProber().findAllDrivers(manager);
|
||||
if (!availableDrivers.isEmpty()) {
|
||||
@ -99,11 +131,9 @@ public class MainActivity extends AppCompatActivity {
|
||||
UsbSerialPort sPort = null;
|
||||
sPort = driver.getPorts().get(0);
|
||||
sPort.open(connection);
|
||||
Toast.makeText(getApplicationContext(), "Serial Count:" + String.valueOf(driver.getPorts().size()), Toast.LENGTH_LONG).show();
|
||||
Toast.makeText(getApplicationContext(), "Serial Count:" + driver.getPorts().size(), Toast.LENGTH_LONG).show();
|
||||
|
||||
sPort.close();
|
||||
sPort = null;
|
||||
|
||||
|
||||
goService();
|
||||
}
|
||||
|
@ -43,7 +43,7 @@ public class MusicTitle {
|
||||
}
|
||||
|
||||
public int getTotal() {
|
||||
return 100;
|
||||
return (total > 0) ? this.total : 100;
|
||||
}
|
||||
|
||||
//public void setTotal(int total) {
|
||||
@ -54,11 +54,13 @@ public class MusicTitle {
|
||||
return position;
|
||||
}
|
||||
|
||||
public void setPosition(int position) {
|
||||
this.position = position;
|
||||
public void setTotal(int total) {
|
||||
this.total = total;
|
||||
}
|
||||
|
||||
|
||||
public void setPosition(long position) {
|
||||
this.position = (int) position;
|
||||
}
|
||||
|
||||
public String getArtist() {
|
||||
if(artist == null)
|
||||
|
@ -0,0 +1,143 @@
|
||||
package com.flywithu.carnav;
|
||||
|
||||
import android.annotation.TargetApi;
|
||||
import android.app.Notification;
|
||||
import android.content.ComponentName;
|
||||
import android.content.Context;
|
||||
import android.content.Intent;
|
||||
import android.media.MediaMetadata;
|
||||
import android.media.session.MediaController;
|
||||
import android.media.session.MediaSession;
|
||||
import android.media.session.MediaSessionManager;
|
||||
import android.media.session.PlaybackState;
|
||||
import android.os.Bundle;
|
||||
import android.os.IBinder;
|
||||
import android.service.notification.NotificationListenerService;
|
||||
import android.service.notification.StatusBarNotification;
|
||||
import android.util.Log;
|
||||
|
||||
import androidx.annotation.Nullable;
|
||||
|
||||
import java.util.Arrays;
|
||||
import java.util.List;
|
||||
|
||||
@TargetApi(21)
|
||||
public class NotificationListenerMusic extends NotificationListenerService {
|
||||
String[] musicAppFilter = {"com.iloen.melon", "skplanet.musicmate"};
|
||||
|
||||
@Override
|
||||
public IBinder onBind(Intent intent) {
|
||||
ComponentName componentName = new ComponentName(this, getClass());
|
||||
MediaSessionManager manager = (MediaSessionManager) this.getSystemService(Context.MEDIA_SESSION_SERVICE);
|
||||
|
||||
manager.addOnActiveSessionsChangedListener(new MediaSessionManager.OnActiveSessionsChangedListener() {
|
||||
@Override
|
||||
public void onActiveSessionsChanged(@Nullable List<MediaController> controllers) {
|
||||
for (MediaController controller : controllers) {
|
||||
if (controllers != null) {
|
||||
try {
|
||||
|
||||
controller.registerCallback(new MediaController.Callback() {
|
||||
MusicTitle currentSong = new MusicTitle();
|
||||
|
||||
private Intent getMusicIntent() {
|
||||
Intent music = new Intent("com.flywithu.carnav.metachanged");
|
||||
music.putExtra("artist", currentSong.getArtist());
|
||||
music.putExtra("album", currentSong.getAlbum());
|
||||
music.putExtra("track", currentSong.getTrack());
|
||||
music.putExtra("playstate", currentSong.isRunning());
|
||||
music.putExtra("position", currentSong.getPosition());
|
||||
music.putExtra("total", currentSong.getTotal());
|
||||
|
||||
return music;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onQueueChanged(List<MediaSession.QueueItem> queue) {
|
||||
currentSong.setTotal(queue.size());
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPlaybackStateChanged(@Nullable PlaybackState state) {
|
||||
super.onPlaybackStateChanged(state);
|
||||
currentSong.setRunning(state.getState() == PlaybackState.STATE_PLAYING);
|
||||
currentSong.setPosition(state.getActiveQueueItemId());
|
||||
Log.d("NotificationMusic", "Playback");
|
||||
if (currentSong.getAlbum() != null) {
|
||||
sendBroadcast(getMusicIntent());
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onMetadataChanged(MediaMetadata metadata) {
|
||||
super.onMetadataChanged(metadata);
|
||||
currentSong.setArtist(metadata.getString(MediaMetadata.METADATA_KEY_ARTIST));
|
||||
currentSong.setTrack(metadata.getString(MediaMetadata.METADATA_KEY_TITLE));
|
||||
currentSong.setAlbum(metadata.getString(MediaMetadata.METADATA_KEY_ALBUM));
|
||||
|
||||
|
||||
sendBroadcast(getMusicIntent());
|
||||
}
|
||||
});
|
||||
|
||||
} catch (Exception e) {
|
||||
e.printStackTrace();
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}, componentName);
|
||||
|
||||
return super.onBind(intent);
|
||||
}
|
||||
|
||||
|
||||
private void checkMusicStatus() {
|
||||
StatusBarNotification[] activeNotifications = getActiveNotifications();
|
||||
for (StatusBarNotification noti : activeNotifications) {
|
||||
if (Arrays.asList(musicAppFilter).contains(noti.getPackageName())) {
|
||||
Notification mytest = noti.getNotification();
|
||||
|
||||
Bundle extras = noti.getNotification().extras;
|
||||
|
||||
|
||||
for (String a : extras.keySet()) {
|
||||
Object value = extras.get(a);
|
||||
if (value instanceof Boolean) {
|
||||
Log.d("NotificationListener", "KEY:" + extras.getBoolean(a));
|
||||
} else if (value instanceof Integer) {
|
||||
Log.d("NotificationListener", "KEY:" + extras.getInt(a));
|
||||
} else {
|
||||
Log.d("NotificationListener", "KEY:" + a + "/" + extras.getString(a));
|
||||
}
|
||||
|
||||
}
|
||||
// CharSequence title = extras.getString(Notification.EXTRA_TITLE);
|
||||
// CharSequence artist = extras.getCharSequence(Notification.EXTRA_TEXT);
|
||||
// Log.d("NotificationListener","NAME:"+noti.getPackageName());
|
||||
// Log.i("NotificationListener", "[snowdeer] title:" + title);
|
||||
// Log.i("NotificationListener", "[snowdeer] artist:" + artist);
|
||||
|
||||
}
|
||||
|
||||
|
||||
// Log.d("TAG",noti.getNotification().getGroup());
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onNotificationPosted(StatusBarNotification sbn) {
|
||||
checkMusicStatus();
|
||||
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onNotificationRemoved(StatusBarNotification sbn) {
|
||||
checkMusicStatus();
|
||||
}
|
||||
|
||||
|
||||
}
|
@ -1,7 +1,9 @@
|
||||
package com.flywithu.carnav;
|
||||
|
||||
import android.app.AlarmManager;
|
||||
import android.app.Application;
|
||||
import android.app.Notification;
|
||||
import android.app.NotificationChannel;
|
||||
import android.app.NotificationManager;
|
||||
import android.app.PendingIntent;
|
||||
import android.app.Service;
|
||||
import android.content.BroadcastReceiver;
|
||||
@ -10,12 +12,15 @@ import android.content.Intent;
|
||||
import android.content.IntentFilter;
|
||||
import android.hardware.usb.UsbDeviceConnection;
|
||||
import android.hardware.usb.UsbManager;
|
||||
import android.os.Build;
|
||||
import android.os.Bundle;
|
||||
import android.os.Handler;
|
||||
import android.os.IBinder;
|
||||
import android.util.Log;
|
||||
import android.widget.Toast;
|
||||
|
||||
import androidx.core.app.NotificationCompat;
|
||||
|
||||
import com.hoho.android.usbserial.driver.UsbSerialDriver;
|
||||
import com.hoho.android.usbserial.driver.UsbSerialPort;
|
||||
import com.hoho.android.usbserial.driver.UsbSerialProber;
|
||||
@ -24,7 +29,6 @@ import java.io.IOException;
|
||||
import java.nio.ByteBuffer;
|
||||
import java.nio.charset.Charset;
|
||||
import java.text.SimpleDateFormat;
|
||||
import java.util.Calendar;
|
||||
import java.util.Date;
|
||||
import java.util.List;
|
||||
|
||||
@ -34,6 +38,7 @@ public class RealService extends Service {
|
||||
|
||||
private static UsbSerialPort sPort = null;
|
||||
private MusicTitle currentSong = new MusicTitle();
|
||||
Boolean oldmethod = true;
|
||||
private BroadcastReceiver mReceiver = new BroadcastReceiver() {
|
||||
|
||||
@Override
|
||||
@ -50,27 +55,60 @@ public class RealService extends Service {
|
||||
}
|
||||
|
||||
String action = intent.getAction();
|
||||
String cmd = intent.getStringExtra("command");
|
||||
Log.v("MUSIC ", action + " / " + cmd);
|
||||
String artist = intent.getStringExtra("artist");
|
||||
String album = intent.getStringExtra("album");
|
||||
String track = intent.getStringExtra("track");
|
||||
Long myPosition = intent.getLongExtra("id", 1);
|
||||
Log.v("MUSIC", artist + ":" + album + ":" + track);
|
||||
boolean isRunning = intent.getBooleanExtra("playstate", false) | intent.getBooleanExtra("playing", false);
|
||||
|
||||
currentSong.setRunning(isRunning);
|
||||
|
||||
if (isRunning == true) {
|
||||
currentSong.setAlbum(album);
|
||||
currentSong.setArtist(artist);
|
||||
currentSong.setTrack(track);
|
||||
currentSong.setPosition(myPosition.intValue());
|
||||
if (action.startsWith("com.flywithu")) {
|
||||
oldmethod = false;
|
||||
}
|
||||
|
||||
if (oldmethod == true) {
|
||||
String cmd = intent.getStringExtra("command");
|
||||
Log.v("MUSIC ", action + " / " + cmd);
|
||||
String artist = intent.getStringExtra("artist");
|
||||
String album = intent.getStringExtra("album");
|
||||
String track = intent.getStringExtra("track");
|
||||
Long myPosition = intent.getLongExtra("id", 1);
|
||||
Log.v("MUSIC", artist + ":" + album + ":" + track);
|
||||
boolean isRunning = intent.getBooleanExtra("playstate", false) | intent.getBooleanExtra("playing", false);
|
||||
currentSong.setRunning(isRunning);
|
||||
|
||||
if (isRunning == true) {
|
||||
currentSong.setAlbum(album);
|
||||
currentSong.setArtist(artist);
|
||||
currentSong.setTrack(track);
|
||||
currentSong.setPosition(myPosition.intValue());
|
||||
}
|
||||
} else {
|
||||
currentSong.setAlbum(intent.getStringExtra("album"));
|
||||
currentSong.setArtist(intent.getStringExtra("artist"));
|
||||
currentSong.setTrack(intent.getStringExtra("track"));
|
||||
currentSong.setPosition(0);
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
};
|
||||
|
||||
private void setNotification() {
|
||||
NotificationCompat.Builder builder = new NotificationCompat.Builder(this, "default");
|
||||
builder.setSmallIcon(R.mipmap.ic_launcher);
|
||||
builder.setContentTitle(null);
|
||||
builder.setContentText(null);
|
||||
Intent notificationIntent = new Intent(this, MainActivity.class);
|
||||
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, notificationIntent, 0);
|
||||
builder.setContentIntent(pendingIntent);
|
||||
|
||||
NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
|
||||
manager.createNotificationChannel(new NotificationChannel("default", "기본 채널", NotificationManager.IMPORTANCE_NONE));
|
||||
}
|
||||
|
||||
Notification notification = builder.build();
|
||||
startForeground(9, notification);
|
||||
|
||||
|
||||
}
|
||||
|
||||
public RealService() {
|
||||
}
|
||||
|
||||
@ -195,6 +233,9 @@ public class RealService extends Service {
|
||||
iF.addAction("com.android.music.playstatechanged");
|
||||
iF.addAction("com.android.music.playbackcomplete");
|
||||
iF.addAction("com.android.music.queuechanged");
|
||||
iF.addAction("com.flywithu.carnav.metachanged");
|
||||
|
||||
|
||||
|
||||
|
||||
registerReceiver(mReceiver, iF);
|
||||
@ -243,7 +284,7 @@ public class RealService extends Service {
|
||||
}).start();
|
||||
|
||||
|
||||
return START_NOT_STICKY;
|
||||
return START_STICKY;
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -256,7 +297,6 @@ public class RealService extends Service {
|
||||
showToast(getApplication(), "stop Error");
|
||||
}
|
||||
serviceIntent = null;
|
||||
setAlarmTimer();
|
||||
Thread.currentThread().interrupt();
|
||||
unregisterReceiver(mReceiver);
|
||||
showToast(getApplication(), "stop Service");
|
||||
@ -266,6 +306,10 @@ public class RealService extends Service {
|
||||
@Override
|
||||
public void onCreate() {
|
||||
super.onCreate();
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
|
||||
setNotification();
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
@ -288,16 +332,7 @@ public class RealService extends Service {
|
||||
});
|
||||
}
|
||||
|
||||
protected void setAlarmTimer() {
|
||||
final Calendar c = Calendar.getInstance();
|
||||
c.setTimeInMillis(System.currentTimeMillis());
|
||||
c.add(Calendar.SECOND, 1);
|
||||
Intent intent = new Intent(this, AlarmReceiver.class);
|
||||
PendingIntent sender = PendingIntent.getBroadcast(this, 0, intent, 0);
|
||||
|
||||
AlarmManager mAlarmManager = (AlarmManager) getSystemService(Context.ALARM_SERVICE);
|
||||
mAlarmManager.set(AlarmManager.RTC_WAKEUP, c.getTimeInMillis(), sender);
|
||||
}
|
||||
|
||||
|
||||
}
|
@ -10,7 +10,7 @@ public class RebootReceiver extends BroadcastReceiver {
|
||||
public void onReceive(Context context, Intent intent) {
|
||||
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
|
||||
Intent in = new Intent(context, RestartService.class);
|
||||
Intent in = new Intent(context, RealService.class);
|
||||
context.startForegroundService(in);
|
||||
} else {
|
||||
Intent in = new Intent(context, RealService.class);
|
||||
|
@ -1,67 +0,0 @@
|
||||
package com.flywithu.carnav;
|
||||
|
||||
import android.app.Notification;
|
||||
import android.app.NotificationChannel;
|
||||
import android.app.NotificationManager;
|
||||
import android.app.PendingIntent;
|
||||
import android.app.Service;
|
||||
import android.content.Intent;
|
||||
import android.os.Build;
|
||||
import android.os.IBinder;
|
||||
|
||||
import androidx.core.app.NotificationCompat;
|
||||
|
||||
public class RestartService extends Service {
|
||||
public RestartService() {
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onCreate() {
|
||||
super.onCreate();
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onDestroy() {
|
||||
super.onDestroy();
|
||||
}
|
||||
|
||||
@Override
|
||||
public int onStartCommand(Intent intent, int flags, int startId) {
|
||||
NotificationCompat.Builder builder = new NotificationCompat.Builder(this, "default");
|
||||
builder.setSmallIcon(R.mipmap.ic_launcher);
|
||||
builder.setContentTitle(null);
|
||||
builder.setContentText(null);
|
||||
Intent notificationIntent = new Intent(this, MainActivity.class);
|
||||
PendingIntent pendingIntent = PendingIntent.getActivity(this, 0, notificationIntent, 0);
|
||||
builder.setContentIntent(pendingIntent);
|
||||
|
||||
NotificationManager manager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
|
||||
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
|
||||
manager.createNotificationChannel(new NotificationChannel("default", "기본 채널", NotificationManager.IMPORTANCE_NONE));
|
||||
}
|
||||
|
||||
Notification notification = builder.build();
|
||||
startForeground(9, notification);
|
||||
|
||||
/////////////////////////////////////////////////////////////////////
|
||||
Intent in = new Intent(this, RealService.class);
|
||||
startService(in);
|
||||
|
||||
stopForeground(true);
|
||||
stopSelf();
|
||||
|
||||
return START_NOT_STICKY;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public IBinder onBind(Intent intent) {
|
||||
return null;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onUnbind(Intent intent) {
|
||||
return super.onUnbind(intent);
|
||||
}
|
||||
|
||||
}
|
@ -1,18 +1,40 @@
|
||||
<?xml version="1.0" encoding="utf-8"?>
|
||||
<androidx.constraintlayout.widget.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
|
||||
xmlns:app="http://schemas.android.com/apk/res-auto"
|
||||
xmlns:tools="http://schemas.android.com/tools"
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
tools:context=".MainActivity">
|
||||
|
||||
<TextView
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="Hello World!"
|
||||
app:layout_constraintBottom_toBottomOf="parent"
|
||||
app:layout_constraintLeft_toLeftOf="parent"
|
||||
app:layout_constraintRight_toRightOf="parent"
|
||||
app:layout_constraintTop_toTopOf="parent" />
|
||||
<LinearLayout
|
||||
android:layout_width="match_parent"
|
||||
android:layout_height="match_parent"
|
||||
android:orientation="vertical">
|
||||
|
||||
<TextView
|
||||
android:id="@+id/textViewNotification"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="Permission Notification" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/textViewNotificationStatus"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="Permission Notification" />
|
||||
|
||||
|
||||
<TextView
|
||||
android:id="@+id/textViewUSB"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="Permission USB" />
|
||||
|
||||
<TextView
|
||||
android:id="@+id/textViewUSBStatus"
|
||||
android:layout_width="wrap_content"
|
||||
android:layout_height="wrap_content"
|
||||
android:text="Permission USB" />
|
||||
|
||||
</LinearLayout>
|
||||
|
||||
</androidx.constraintlayout.widget.ConstraintLayout>
|
@ -7,7 +7,7 @@ buildscript {
|
||||
|
||||
}
|
||||
dependencies {
|
||||
classpath 'com.android.tools.build:gradle:3.5.0'
|
||||
classpath 'com.android.tools.build:gradle:3.5.2'
|
||||
|
||||
// NOTE: Do not place your application dependencies here; they belong
|
||||
// in the individual module build.gradle files
|
||||
|
Loading…
x
Reference in New Issue
Block a user