Skip to content

Commit fb138d2

Browse files
chore : add files for 12th lecture
1 parent 5826e6b commit fb138d2

File tree

35 files changed

+628
-33
lines changed

35 files changed

+628
-33
lines changed

.DS_Store

2 KB
Binary file not shown.

Lecture10/.DS_Store

6 KB
Binary file not shown.

Lecture11/GithubApi/app/src/main/java/com/codingblocks/githubapi/MainActivity.java

+13-5
Original file line numberDiff line numberDiff line change
@@ -1,8 +1,7 @@
11
package com.codingblocks.githubapi;
22

3-
import android.content.Intent;
4-
import android.support.v7.app.AppCompatActivity;
53
import android.os.Bundle;
4+
import android.support.v7.app.AppCompatActivity;
65
import android.support.v7.widget.LinearLayoutManager;
76
import android.support.v7.widget.RecyclerView;
87
import android.util.Log;
@@ -39,17 +38,26 @@ protected void onCreate(Bundle savedInstanceState) {
3938
recyclerView.setLayoutManager(new LinearLayoutManager(this));
4039

4140
/*
42-
Getting serialized data
41+
Getting data
4342
*/
4443

4544
// Intent i = getIntent();
4645
//
4746
// String receivedUser = i.getStringExtra("USER");
4847
// Gson gson = new Gson();
49-
//
50-
//
5148
// User user = gson.fromJson(receivedUser, User.class);
5249

50+
// Getting the parcelable data back
51+
// ArrayList<User> userArrayList = i.getParcelableArrayListExtra("KEY");
52+
53+
// Can also put parcelable data into your intent
54+
// Intent intent = new Intent(this, MainActivity.class);
55+
// ArrayList<User> arrayList = new ArrayList<>();
56+
// intent.putParcelableArrayListExtra("KEY",arrayList);
57+
//
58+
59+
60+
5361
final RecylerViewAdapter recylerViewAdapter = new RecylerViewAdapter(usersArrayList);
5462
recyclerView.setAdapter(recylerViewAdapter);
5563

Lecture11/GithubApi/app/src/main/java/com/codingblocks/githubapi/User.java

+38-1
Original file line numberDiff line numberDiff line change
@@ -1,10 +1,13 @@
11
package com.codingblocks.githubapi;
22

3+
import android.os.Parcel;
4+
import android.os.Parcelable;
5+
36
/**
47
* Created by the-dagger on 05/07/17.
58
*/
69

7-
public class User {
10+
public class User implements Parcelable{
811

912
String login,id,avatar_url,url,score;
1013

@@ -16,6 +19,26 @@ public User(String login, String id, String avatar_url, String url, String score
1619
this.score = score;
1720
}
1821

22+
protected User(Parcel in) {
23+
login = in.readString();
24+
id = in.readString();
25+
avatar_url = in.readString();
26+
url = in.readString();
27+
score = in.readString();
28+
}
29+
30+
public static final Creator<User> CREATOR = new Creator<User>() {
31+
@Override
32+
public User createFromParcel(Parcel in) {
33+
return new User(in);
34+
}
35+
36+
@Override
37+
public User[] newArray(int size) {
38+
return new User[size];
39+
}
40+
};
41+
1942
public String getLogin() {
2043
return login;
2144
}
@@ -55,4 +78,18 @@ public String getScore() {
5578
public void setScore(String score) {
5679
this.score = score;
5780
}
81+
82+
@Override
83+
public int describeContents() {
84+
return 0;
85+
}
86+
87+
@Override
88+
public void writeToParcel(Parcel dest, int flags) {
89+
dest.writeString(login);
90+
dest.writeString(id);
91+
dest.writeString(avatar_url);
92+
dest.writeString(url);
93+
dest.writeString(score);
94+
}
5895
}

Lecture12/Sensors/.gitignore

+9
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
*.iml
2+
.gradle
3+
/local.properties
4+
/.idea/workspace.xml
5+
/.idea/libraries
6+
.DS_Store
7+
/build
8+
/captures
9+
.externalNativeBuild

Lecture12/Sensors/app/.gitignore

+1
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
/build

Lecture12/Sensors/app/build.gradle

+30
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,30 @@
1+
apply plugin: 'com.android.application'
2+
3+
android {
4+
compileSdkVersion 26
5+
buildToolsVersion "26.0.0"
6+
defaultConfig {
7+
applicationId "com.codingblocks.sensors"
8+
minSdkVersion 15
9+
targetSdkVersion 26
10+
versionCode 1
11+
versionName "1.0"
12+
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
13+
}
14+
buildTypes {
15+
release {
16+
minifyEnabled false
17+
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
18+
}
19+
}
20+
}
21+
22+
dependencies {
23+
compile fileTree(dir: 'libs', include: ['*.jar'])
24+
androidTestCompile('com.android.support.test.espresso:espresso-core:2.2.2', {
25+
exclude group: 'com.android.support', module: 'support-annotations'
26+
})
27+
compile 'com.android.support:appcompat-v7:26.+'
28+
compile 'com.android.support.constraint:constraint-layout:1.0.2'
29+
testCompile 'junit:junit:4.12'
30+
}
+25
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
# Add project specific ProGuard rules here.
2+
# By default, the flags in this file are appended to flags specified
3+
# in /Users/harshit/Library/Android/sdk/tools/proguard/proguard-android.txt
4+
# You can edit the include path and order by changing the proguardFiles
5+
# directive in build.gradle.
6+
#
7+
# For more details, see
8+
# http://developer.android.com/guide/developing/tools/proguard.html
9+
10+
# Add any project specific keep options here:
11+
12+
# If your project uses WebView with JS, uncomment the following
13+
# and specify the fully qualified class name to the JavaScript interface
14+
# class:
15+
#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
16+
# public *;
17+
#}
18+
19+
# Uncomment this to preserve the line number information for
20+
# debugging stack traces.
21+
#-keepattributes SourceFile,LineNumberTable
22+
23+
# If you keep the line number information, uncomment this to
24+
# hide the original source file name.
25+
#-renamesourcefileattribute SourceFile
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,26 @@
1+
package com.codingblocks.sensors;
2+
3+
import android.content.Context;
4+
import android.support.test.InstrumentationRegistry;
5+
import android.support.test.runner.AndroidJUnit4;
6+
7+
import org.junit.Test;
8+
import org.junit.runner.RunWith;
9+
10+
import static org.junit.Assert.*;
11+
12+
/**
13+
* Instrumentation test, which will execute on an Android device.
14+
*
15+
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
16+
*/
17+
@RunWith(AndroidJUnit4.class)
18+
public class ExampleInstrumentedTest {
19+
@Test
20+
public void useAppContext() throws Exception {
21+
// Context of the app under test.
22+
Context appContext = InstrumentationRegistry.getTargetContext();
23+
24+
assertEquals("com.codingblocks.sensors", appContext.getPackageName());
25+
}
26+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,21 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
3+
package="com.codingblocks.sensors">
4+
5+
<application
6+
android:allowBackup="true"
7+
android:icon="@mipmap/ic_launcher"
8+
android:label="@string/app_name"
9+
android:roundIcon="@mipmap/ic_launcher_round"
10+
android:supportsRtl="true"
11+
android:theme="@style/AppTheme">
12+
<activity android:name=".MainActivity">
13+
<intent-filter>
14+
<action android:name="android.intent.action.MAIN" />
15+
16+
<category android:name="android.intent.category.LAUNCHER" />
17+
</intent-filter>
18+
</activity>
19+
</application>
20+
21+
</manifest>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,71 @@
1+
package com.codingblocks.sensors;
2+
3+
import android.hardware.Sensor;
4+
import android.hardware.SensorEvent;
5+
import android.hardware.SensorEventListener;
6+
import android.hardware.SensorManager;
7+
import android.os.Bundle;
8+
import android.support.v7.app.AppCompatActivity;
9+
import android.util.Log;
10+
11+
public class MainActivity extends AppCompatActivity {
12+
13+
public static final String TAG = "MainActivity";
14+
@Override
15+
protected void onCreate(Bundle savedInstanceState) {
16+
super.onCreate(savedInstanceState);
17+
setContentView(R.layout.activity_main);
18+
19+
SensorManager sensorManager = (SensorManager) getSystemService(SENSOR_SERVICE);
20+
21+
Sensor accel = sensorManager.getDefaultSensor(Sensor.TYPE_ACCELEROMETER);
22+
23+
// List<Sensor> sensorList = sensorManager.getSensorList(Sensor.TYPE_ALL);
24+
25+
// for (int i =0; i <sensorList.size(); i++){
26+
//
27+
// Sensor currentSensor = sensorList.get(i);
28+
//
29+
// }
30+
31+
32+
// for (Sensor s : sensorList){
33+
//
34+
// Log.d(TAG, "onCreate: NAME " + s.getName());
35+
// Log.d(TAG, "onCreate: VERSION " + s.getVersion());
36+
// Log.d(TAG, "onCreate: RANGE " + s.getMaximumRange());
37+
// Log.d(TAG, "onCreate: TYPE " + s.getType());
38+
// Log.d(TAG, "onCreate: POWER " + s.getPower());
39+
// Log.d(TAG, "onCreate: VENDOR " + s.getVendor());
40+
// Log.d(TAG, "--------------------------------");
41+
//
42+
// }
43+
44+
45+
sensorManager.registerListener(new SensorEventListener() {
46+
@Override
47+
public void onSensorChanged(SensorEvent sensorEvent) {
48+
Log.d(TAG, "onSensorChanged: accel in x " + sensorEvent.values[0]);
49+
Log.d(TAG, "onSensorChanged: accel in y " + sensorEvent.values[1]);
50+
Log.d(TAG, "onSensorChanged: accel in z " + sensorEvent.values[2]);
51+
}
52+
53+
@Override
54+
public void onAccuracyChanged(Sensor sensor, int i) {
55+
56+
}
57+
},accel,1000000);
58+
59+
//
60+
// Log.d(TAG, "onCreate: NAME" + accel.getName());
61+
// Log.d(TAG, "onCreate: VERSION" + accel.getVersion());
62+
// Log.d(TAG, "onCreate: RANGE" + accel.getMaximumRange());
63+
// Log.d(TAG, "onCreate: TYPE" + accel.getType());
64+
// Log.d(TAG, "onCreate: POWER" + accel.getPower());
65+
// Log.d(TAG, "onCreate: VENDOR" + accel.getVendor());
66+
67+
68+
69+
70+
}
71+
}
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,19 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<android.support.constraint.ConstraintLayout xmlns:android="http://schemas.android.com/apk/res/android"
3+
xmlns:app="http://schemas.android.com/apk/res-auto"
4+
xmlns:tools="http://schemas.android.com/tools"
5+
android:layout_width="match_parent"
6+
android:layout_height="match_parent"
7+
android:id="@+id/layout"
8+
tools:context="com.codingblocks.sensors.MainActivity">
9+
10+
<TextView
11+
android:layout_width="wrap_content"
12+
android:layout_height="wrap_content"
13+
android:text="Hello World!"
14+
app:layout_constraintBottom_toBottomOf="parent"
15+
app:layout_constraintLeft_toLeftOf="parent"
16+
app:layout_constraintRight_toRightOf="parent"
17+
app:layout_constraintTop_toTopOf="parent" />
18+
19+
</android.support.constraint.ConstraintLayout>
Loading
Loading
Loading
Loading
Loading
Loading
Loading
Loading
Loading
Loading
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,6 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<resources>
3+
<color name="colorPrimary">#3F51B5</color>
4+
<color name="colorPrimaryDark">#303F9F</color>
5+
<color name="colorAccent">#FF4081</color>
6+
</resources>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,3 @@
1+
<resources>
2+
<string name="app_name">Sensors</string>
3+
</resources>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,11 @@
1+
<resources>
2+
3+
<!-- Base application theme. -->
4+
<style name="AppTheme" parent="Theme.AppCompat.Light.DarkActionBar">
5+
<!-- Customize your theme here. -->
6+
<item name="colorPrimary">@color/colorPrimary</item>
7+
<item name="colorPrimaryDark">@color/colorPrimaryDark</item>
8+
<item name="colorAccent">@color/colorAccent</item>
9+
</style>
10+
11+
</resources>
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
package com.codingblocks.sensors;
2+
3+
import org.junit.Test;
4+
5+
import static org.junit.Assert.*;
6+
7+
/**
8+
* Example local unit test, which will execute on the development machine (host).
9+
*
10+
* @see <a href="http://d.android.com/tools/testing">Testing documentation</a>
11+
*/
12+
public class ExampleUnitTest {
13+
@Test
14+
public void addition_isCorrect() throws Exception {
15+
assertEquals(4, 2 + 2);
16+
}
17+
}

Lecture12/Sensors/build.gradle

+23
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,23 @@
1+
// Top-level build file where you can add configuration options common to all sub-projects/modules.
2+
3+
buildscript {
4+
repositories {
5+
jcenter()
6+
}
7+
dependencies {
8+
classpath 'com.android.tools.build:gradle:2.3.3'
9+
10+
// NOTE: Do not place your application dependencies here; they belong
11+
// in the individual module build.gradle files
12+
}
13+
}
14+
15+
allprojects {
16+
repositories {
17+
jcenter()
18+
}
19+
}
20+
21+
task clean(type: Delete) {
22+
delete rootProject.buildDir
23+
}

Lecture12/Sensors/gradle.properties

+17
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
# Project-wide Gradle settings.
2+
3+
# IDE (e.g. Android Studio) users:
4+
# Gradle settings configured through the IDE *will override*
5+
# any settings specified in this file.
6+
7+
# For more details on how to configure your build environment visit
8+
# http://www.gradle.org/docs/current/userguide/build_environment.html
9+
10+
# Specifies the JVM arguments used for the daemon process.
11+
# The setting is particularly useful for tweaking memory settings.
12+
org.gradle.jvmargs=-Xmx1536m
13+
14+
# When configured, Gradle will run in incubating parallel mode.
15+
# This option should only be used with decoupled projects. More details, visit
16+
# http://www.gradle.org/docs/current/userguide/multi_project_builds.html#sec:decoupled_projects
17+
# org.gradle.parallel=true

0 commit comments

Comments
 (0)