В настоящее время я занимаюсь разработкой приложения для физики, которое должно показать список формул и даже решить некоторые из них (единственная проблема - это ListView
)
Это мой основной макет
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:measureWithLargestChild="false"
android:orientation="vertical"
tools:context=".CatList" >
<RelativeLayout
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/titlebar" >
<TextView
android:id="@+id/Title1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_centerHorizontal="true"
android:layout_centerVertical="true"
android:text="@string/app_name"
android:textAppearance="?android:attr/textAppearanceLarge"
android:textColor="#ff1c00"
android:textIsSelectable="false" />
</RelativeLayout>
<ListView
android:id="@+id/listFormulas"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
</ListView>
</LinearLayout>
И это моя основная деятельность
package com.wildsushii.quickphysics;
import java.io.IOException;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import org.json.JSONException;
import org.json.JSONObject;
import android.os.Bundle;
import android.app.Activity;
import android.content.Context;
import android.content.res.AssetManager;
import android.view.Menu;
import android.widget.ListView;
public class CatList extends Activity {
public static String AssetJSONFile (String filename, Context context) throws IOException {
AssetManager manager = context.getAssets();
InputStream file = manager.open(filename);
byte[] formArray = new byte[file.available()];
file.read(formArray);
file.close();
return new String(formArray);
}
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_cat_list);
ListView categoriesL = (ListView)findViewById(R.id.listFormulas);
ArrayList<HashMap<String, String>> formList = new ArrayList<HashMap<String, String>>();
Context context = null;
try {
String jsonLocation = AssetJSONFile("formules.json", context);
JSONObject formArray = (new JSONObject()).getJSONObject("formules");
String formule = formArray.getString("formule");
String url = formArray.getString("url");
} catch (IOException e) {
e.printStackTrace();
} catch (JSONException e) {
e.printStackTrace();
}
//My problem is here!!
}
@Override
public boolean onCreateOptionsMenu(Menu menu) {
// Inflate the menu; this adds items to the action bar if it is present.
getMenuInflater().inflate(R.menu.cat_list, menu);
return true;
}
}
Я действительно знаю, что могу сделать это без использования JSON, но мне нужно больше практиковаться в разборе JSON. Кстати, это JSON
{
"formules": [
{
"formule": "Linear Motion",
"url": "qp1"
},
{
"formule": "Constant Acceleration Motion",
"url": "qp2"
},
{
"formule": "Projectile Motion",
"url": "qp3"
},
{
"formule": "Force",
"url": "qp4"
},
{
"formule": "Work, Power, Energy",
"url": "qp5"
},
{
"formule": "Rotary Motion",
"url": "qp6"
},
{
"formule": "Harmonic Motion",
"url": "qp7"
},
{
"formule": "Gravity",
"url": "qp8"
},
{
"formule": "Lateral and Longitudinal Waves",
"url": "qp9"
},
{
"formule": "Sound Waves",
"url": "qp10"
},
{
"formule": "Electrostatics",
"url": "qp11"
},
{
"formule": "Direct Current",
"url": "qp12"
},
{
"formule": "Magnetic Field",
"url": "qp13"
},
{
"formule": "Alternating Current",
"url": "qp14"
},
{
"formule": "Thermodynamics",
"url": "qp15"
},
{
"formule": "Hydrogen Atom",
"url": "qp16"
},
{
"formule": "Optics",
"url": "qp17"
},
{
"formule": "Modern Physics",
"url": "qp18"
},
{
"formule": "Hydrostatics",
"url": "qp19"
},
{
"formule": "Astronomy",
"url": "qp20"
}
]
}
Я много чего перепробовал и даже удалил весь проект, чтобы сделать новый :(
Ответы:
Как описывает Файзан в своем ответе здесь :
Прежде всего, прочитайте файл Json из вашего файла с использованием приведенного ниже кода.
а затем вы можете просто прочитать эту строку, возвращаемую этой функцией как
и использовать этот метод, как это
Более подробную информацию о JSON читайте ЗДЕСЬ
источник
m_li.put("formula", formula);
следуетm_li.put("formula", formula_value);
и следует использоватьLog
вместо System.out.printlnЧто ты делаешь
Так что поменяйте на
Разобрать
Я считаю, что вы получили строку из папки Assests.
источник
У Kotlin есть эта функция расширения для чтения файла, возвращаемого в виде строки.
fun AssetManager.readAssetsFile(fileName : String): String = open(fileName).bufferedReader().use{it.readText()}
Разбор выходной строки с использованием любого анализатора JSON.
источник
Метод для чтения файла JSON из папки Assets и возврата в виде строкового объекта.
Теперь для анализа данных в вашей деятельности: -
источник
Исходный код Как извлечь Local Json из папки Assets
https://drive.google.com/open?id=1NG1amTVWPNViim_caBr8eeB4zczTDK2p
источник
Использование OKIO
а потом...
источник
Просто суммирую ответ @ libing с примером, который работал для меня.
private fun AssetManager.readAssetsFile(fileName : String): String = open(fileName).bufferedReader().use{it.readText()}
Без этой функции расширения то же самое может быть достигнуто с помощью
BufferedReader
иInputStreamReader
таким образом:источник
Если вы используете Kotlin в Android, то вы можете создать функцию расширения .
Функции расширения определены вне любого класса - но они ссылаются на имя класса и могут использовать
this
. В нашем случае мы используемapplicationContext
.Таким образом, в классе Utility вы можете определить все функции расширения.
Utility.kt
MainActivity.kt
Вы можете определить приватную функцию для загрузки данных JSON из assert следующим образом:
Вы должны пройти
facilityModelList
в своемListView
FacilityModel.kt
В моем случае ответ JSON начинается с JSONArray
источник