Skip to content

Commit cc364b7

Browse files
committed
Init project with Kotlin and DrawView library
0 parents  commit cc364b7

File tree

28 files changed

+570
-0
lines changed

28 files changed

+570
-0
lines changed

.gitignore

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

app/.gitignore

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
/build

app/build.gradle

Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
apply plugin: 'com.android.application'
2+
apply plugin: 'kotlin-android'
3+
apply plugin: 'kotlin-android-extensions'
4+
5+
android {
6+
compileSdkVersion 25
7+
buildToolsVersion "25.0.2"
8+
defaultConfig {
9+
minSdkVersion 15
10+
targetSdkVersion 25
11+
12+
applicationId "com.trydroid.coboard"
13+
versionCode 1
14+
versionName "1.0"
15+
}
16+
buildTypes {
17+
release {
18+
minifyEnabled false
19+
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
20+
}
21+
}
22+
23+
sourceSets {
24+
main.java.srcDirs += 'src/main/kotlin'
25+
}
26+
}
27+
28+
dependencies {
29+
compile fileTree(dir: 'libs', include: ['*.jar'])
30+
compile "org.jetbrains.kotlin:kotlin-stdlib:$kotlin_version"
31+
compile "com.android.support:appcompat-v7:$support_libs_version"
32+
compile "com.android.support:design:$support_libs_version"
33+
compile "com.byox.drawview:drawview:$drawview_version"
34+
}
35+
36+
buildscript {
37+
repositories {
38+
jcenter()
39+
}
40+
41+
dependencies {
42+
classpath "org.jetbrains.kotlin:kotlin-gradle-plugin:$kotlin_version"
43+
}
44+
}

app/proguard-rules.pro

Lines changed: 17 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,17 @@
1+
# Add project specific ProGuard rules here.
2+
# By default, the flags in this file are appended to flags specified
3+
# in /Users/teeranai/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+
#}

app/src/main/AndroidManifest.xml

Lines changed: 20 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,20 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
3+
package="com.trydroid.coboard">
4+
5+
<application
6+
android:allowBackup="true"
7+
android:icon="@mipmap/ic_launcher"
8+
android:label="@string/app_name"
9+
android:supportsRtl="true"
10+
android:theme="@style/AppTheme">
11+
<activity android:name=".CoBoardActivity">
12+
<intent-filter>
13+
<action android:name="android.intent.action.MAIN" />
14+
15+
<category android:name="android.intent.category.LAUNCHER" />
16+
</intent-filter>
17+
</activity>
18+
</application>
19+
20+
</manifest>
Lines changed: 66 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,66 @@
1+
package com.trydroid.coboard
2+
3+
import android.os.Bundle
4+
import android.support.v7.app.AppCompatActivity
5+
import android.view.Menu
6+
import android.view.MenuItem
7+
import com.byox.drawview.views.DrawView
8+
import kotlinx.android.synthetic.main.activity_main.*
9+
10+
11+
class CoBoardActivity : AppCompatActivity() {
12+
13+
override fun onCreate(savedInstanceState: Bundle?) {
14+
super.onCreate(savedInstanceState)
15+
setContentView(R.layout.activity_main)
16+
setupDrawView()
17+
}
18+
19+
override fun onCreateOptionsMenu(menu: Menu?): Boolean {
20+
menuInflater.inflate(R.menu.menu_co_board, menu)
21+
return super.onCreateOptionsMenu(menu)
22+
}
23+
24+
override fun onOptionsItemSelected(item: MenuItem?) =
25+
when (item?.itemId) {
26+
R.id.action_clear -> consumeMenuSelected { clearDrawView() }
27+
R.id.action_undo -> consumeMenuSelected { undoDrawView() }
28+
R.id.action_redo -> consumeMenuSelected { redoDrawView() }
29+
else -> super.onOptionsItemSelected(item)
30+
}
31+
32+
private fun setupDrawView() {
33+
drawView.setOnDrawViewListener(mDrawViewListener)
34+
}
35+
36+
private fun redoDrawView() {
37+
if (drawView.canRedo()) drawView.redo()
38+
}
39+
40+
private fun undoDrawView() {
41+
if (drawView.canUndo()) drawView.undo()
42+
}
43+
44+
private fun clearDrawView() {
45+
drawView.restartDrawing()
46+
}
47+
48+
private val mDrawViewListener = object : DrawView.OnDrawViewListener {
49+
override fun onStartDrawing() {
50+
}
51+
52+
override fun onRequestText() {
53+
}
54+
55+
override fun onEndDrawing() {
56+
}
57+
58+
override fun onClearDrawing() {
59+
}
60+
}
61+
62+
inline fun consumeMenuSelected(func: () -> Unit): Boolean {
63+
func()
64+
return true
65+
}
66+
}
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
<vector xmlns:android="http://schemas.android.com/apk/res/android"
2+
android:width="24dp"
3+
android:height="24dp"
4+
android:viewportWidth="24.0"
5+
android:viewportHeight="24.0">
6+
<path
7+
android:fillColor="#FFFFFFFF"
8+
android:pathData="M18.4,10.6C16.55,8.99 14.15,8 11.5,8c-4.65,0 -8.58,3.03 -9.96,7.22L3.9,16c1.05,-3.19 4.05,-5.5 7.6,-5.5 1.95,0 3.73,0.72 5.12,1.88L13,16h9V7l-3.6,3.6z"/>
9+
</vector>
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
<vector xmlns:android="http://schemas.android.com/apk/res/android"
2+
android:width="24dp"
3+
android:height="24dp"
4+
android:viewportWidth="24.0"
5+
android:viewportHeight="24.0">
6+
<path
7+
android:fillColor="#FFFFFFFF"
8+
android:pathData="M12,4L12,1L8,5l4,4L12,6c3.31,0 6,2.69 6,6 0,1.01 -0.25,1.97 -0.7,2.8l1.46,1.46C19.54,15.03 20,13.57 20,12c0,-4.42 -3.58,-8 -8,-8zM12,18c-3.31,0 -6,-2.69 -6,-6 0,-1.01 0.25,-1.97 0.7,-2.8L5.24,7.74C4.46,8.97 4,10.43 4,12c0,4.42 3.58,8 8,8v3l4,-4 -4,-4v3z"/>
9+
</vector>
Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,9 @@
1+
<vector xmlns:android="http://schemas.android.com/apk/res/android"
2+
android:width="24dp"
3+
android:height="24dp"
4+
android:viewportWidth="24.0"
5+
android:viewportHeight="24.0">
6+
<path
7+
android:fillColor="#FFFFFFFF"
8+
android:pathData="M12.5,8c-2.65,0 -5.05,0.99 -6.9,2.6L2,7v9h9l-3.62,-3.62c1.39,-1.16 3.16,-1.88 5.12,-1.88 3.54,0 6.55,2.31 7.6,5.5l2.37,-0.78C21.08,11.03 17.15,8 12.5,8z"/>
9+
</vector>
Lines changed: 18 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,18 @@
1+
<?xml version="1.0" encoding="utf-8"?>
2+
<com.byox.drawview.views.DrawView
3+
xmlns:android="http://schemas.android.com/apk/res/android"
4+
xmlns:app="http://schemas.android.com/apk/res-auto"
5+
android:id="@+id/drawView"
6+
android:layout_width="match_parent"
7+
android:layout_height="match_parent"
8+
app:dv_draw_alpha="255"
9+
app:dv_draw_anti_alias="true"
10+
app:dv_draw_color="@color/colorAccent"
11+
app:dv_draw_corners="round"
12+
app:dv_draw_dither="true"
13+
app:dv_draw_font_family="default_font"
14+
app:dv_draw_font_size="12"
15+
app:dv_draw_mode="draw"
16+
app:dv_draw_style="stroke"
17+
app:dv_draw_tool="pen"
18+
app:dv_draw_width="4" />

0 commit comments

Comments
 (0)