こんな便利でかわいいアプリが無料です。
さらに、アプリ内課金で購入すれば、いろいろなキャラが走ってくれます。
画像を用意すれば自分でキャラも作成できるようです。
ぜひ、お試しあれ!!
こんな便利でかわいいアプリが無料です。
さらに、アプリ内課金で購入すれば、いろいろなキャラが走ってくれます。
画像を用意すれば自分でキャラも作成できるようです。
ぜひ、お試しあれ!!
以下、デフォルト状態での、それぞれの入力候補。
「すいーつ」
「はーと」
「どうぶつ」
Android端末が元々備えている「ユーザー辞書」に、絵文字を登録していきます。
絵文字パックから、やっていきます。
「すいーつ」
「はーと」
「どうぶつ」
検索して、「辞書に追加」ボタンで連続追加していくだけです。
「すいーつ」
「はーと」
「どうぶつ」
それでも、反映されない場合は、過去の入力から学習したGboard内の辞書が優先的に表示されてしまう場合があるようです。
以下の手順で学習内容は削除できるようです。
今回、利用したアプリは以下。
まずは、開発環境にいれておきます。
グラフの書き出しに必要です。
$ brew install graphviz
Graphviz - Graph Visualization Software
つづいて、確認するマルチモジュールプロジェクト の build.gradle に追記。
apply from: file('gradle/dependencyGraph.gradle')
該当位置に、gradleタスクを記述したファイルを置きます。
学習コストがかかるので、安定のJakeコードをそのままコピペで
まずは稼動させて、モチベーションを上げて進みましょう。
# gradle/dependencyGraph.gradle
task projectDependencyGraph {
doLast {
def dot = new File(rootProject.buildDir, 'reports/dependency-graph/project.dot')
dot.parentFile.mkdirs()
dot.delete()
dot << 'digraph {\n'
dot << " graph [label=\"${rootProject.name}\n \",labelloc=t,fontsize=30,ranksep=1.4];\n"
dot << ' node [style=filled, fillcolor="#bbbbbb"];\n'
dot << ' rankdir=TB;\n'
def rootProjects = []
def queue = [rootProject]
while (!queue.isEmpty()) {
def project = queue.remove(0)
rootProjects.add(project)
queue.addAll(project.childProjects.values())
}
def projects = new LinkedHashSet<Project>()
def dependencies = new LinkedHashMap<Tuple2<Project, Project>, List<String>>()
def multiplatformProjects = []
def jsProjects = []
def androidProjects = []
def javaProjects = []
queue = [rootProject]
while (!queue.isEmpty()) {
def project = queue.remove(0)
queue.addAll(project.childProjects.values())
if (project.plugins.hasPlugin('org.jetbrains.kotlin.multiplatform')) {
multiplatformProjects.add(project)
}
if (project.plugins.hasPlugin('kotlin2js')) {
jsProjects.add(project)
}
if (project.plugins.hasPlugin('com.android.library') || project.plugins.hasPlugin('com.android.application')) {
androidProjects.add(project)
}
if (project.plugins.hasPlugin('java-library') || project.plugins.hasPlugin('java')) {
javaProjects.add(project)
}
project.configurations.all { config ->
config.dependencies
.withType(ProjectDependency)
.collect { it.dependencyProject }
.each { dependency ->
projects.add(project)
projects.add(dependency)
rootProjects.remove(dependency)
def graphKey = new Tuple2<Project, Project>(project, dependency)
def traits = dependencies.computeIfAbsent(graphKey) { new ArrayList<String>() }
if (config.name.toLowerCase().endsWith('implementation')) {
traits.add('style=dotted')
}
}
}
}
projects = projects.sort { it.path }
dot << '\n # Projects\n\n'
for (project in projects) {
def traits = []
if (rootProjects.contains(project)) {
traits.add('shape=box')
}
if (multiplatformProjects.contains(project)) {
traits.add('fillcolor="#ffd2b3"')
} else if (jsProjects.contains(project)) {
traits.add('fillcolor="#ffffba"')
} else if (androidProjects.contains(project)) {
traits.add('fillcolor="#baffc9"')
} else if (javaProjects.contains(project)) {
traits.add('fillcolor="#ffb3ba"')
} else {
traits.add('fillcolor="#eeeeee"')
}
dot << " \"${project.path}\" [${traits.join(", ")}];\n"
}
dot << '\n {rank = same;'
for (project in projects) {
if (rootProjects.contains(project)) {
dot << " \"${project.path}\";"
}
}
dot << '}\n'
dot << '\n # Dependencies\n\n'
dependencies.forEach { key, traits ->
dot << " \"${key.first.path}\" -> \"${key.second.path}\""
if (!traits.isEmpty()) {
dot << " [${traits.join(", ")}]"
}
dot << '\n'
}
dot << '}\n'
def p = 'dot -Tpng -O project.dot'.execute([], dot.parentFile)
p.waitFor()
if (p.exitValue() != 0) {
throw new RuntimeException(p.errorStream.text)
}
println("Project module dependency graph created at ${dot.absolutePath}.png")
}
}
projectDependencyGraph.gradle · JakeWharton/SdkSearch
以上の2ファイルに対する作業を、
シンプルなマルチモジュール構成のコードをお借りしてやってみます。
あとは、タスク実行するだけ。
以下動画のようにPNG画像としてグラフが書き出されます。
DoroidKaigi2019 コードでも利用されていますね。
conference-app-2019/dependencyGraph.gradle at master · DroidKaigi/conference-app-2019
便利です。