Шпаргалка по работе с SQLLite на Android

1) Типы данных

ТипОписание
NULLпустое значение
INTEGERцелочисленное значение
REALзначение с плавающей точкой
TEXTстроки или символы в кодировке UTF-8, UTF-16BE или UTF-16LE
NUMERICздесь можно хранить булевы значения, а также время и дату
BLOBбинарные данные

boolean — нет. Рекомендуется использовать integer c 0 или 1

date — нет, рекомендуется хранить как текст в формате 2021-06-7T11:12.

2) Создание таблиц:

create table accounts (id integer primary key autoincrement,account text,fio text,address text,sync integer);

3) Добавление данных:

insert into accounts (id,account,address,sync) values (null,'"+account+"','"+address+"',false)

Android STUDIO: чтение JSON из URL

Задача: прочитать и пропарсить c URL ресурса JSON данные.

Как ни удивительно, такие тривиальные вещи в Android требуют кучу телодвижений. Возможно это сделано в угоду универсальности..но мне не понравилось от слова совсем. Плюс пришлось тянуть «стороннюю» библиотеку. Может быть конечно плохо гуглил.

Решение:

1) В build.grade добавим

implementation 'com.android.volley:volley:1.1.0'

2) Добавим класс..ну например ReadJsonAccounts:

package цукаука;

import android.content.Context;
import android.util.Log;
import android.widget.Toast;

import com.android.volley.Request;
import com.android.volley.RequestQueue;
import com.android.volley.Response;
import com.android.volley.VolleyError;
import com.android.volley.toolbox.StringRequest;
import com.android.volley.toolbox.Volley;

import org.json.JSONArray;
import org.json.JSONException;
import org.json.JSONObject;

import java.io.UnsupportedEncodingException;
import java.util.ArrayList;

public class ReadJsonAccounts {
    public ReadJsonAccounts(Context context,String url) {
        StringRequest stringRequest = new StringRequest(Request.Method.GET, url,
                new Response.Listener<String>(){
                    @Override
                    public void onResponse(String response) {
                        try {
                            Log.i("Info", response);
                            JSONObject object = new JSONObject(EncodingToUTF8(response));
                            JSONArray jsonArray = object.getJSONArray("users");
                            ArrayList<JSONObject> listItems = getArrayListFromJSONArray(jsonArray);
                            // чтото делаем с получившимся JSON
                            if(jsonArray!= null){
                                for(int i = 0; i<jsonArray.length();i++){
                                    Log.i("Info", jsonArray.getJSONObject(i).getString("email"));
                                }
                            }
                        }catch (JSONException e){
                            e.printStackTrace();
                        }
                    }
                },
                new Response.ErrorListener(){
                    @Override
                    public void onErrorResponse(VolleyError error) {
                        Toast.makeText(context,error.getMessage(),Toast.LENGTH_SHORT).show();
                    }
                });
        RequestQueue requestQueue = Volley.newRequestQueue(context);
        requestQueue.add(stringRequest);
    }
    public  static  String EncodingToUTF8(String response){
        try {
            byte[] code = response.toString().getBytes("ISO-8859-1");
            response = new String(code, "UTF-8");
        }catch (UnsupportedEncodingException e){
            e.printStackTrace();
            return null;
        }
        return response;
    }
    private ArrayList<JSONObject> getArrayListFromJSONArray(JSONArray jsonArray){
        ArrayList<JSONObject> aList = new ArrayList<JSONObject>();
        try {
            if(jsonArray!= null){
                for(int i = 0; i<jsonArray.length();i++){
                    aList.add(jsonArray.getJSONObject(i));
                }
            }
        }catch (JSONException js){
            js.printStackTrace();
        }
        return aList;
    }
}

3) Пример использования класса:

public class MainActivity extends AppCompatActivity {
    ReadJsonAccounts accounts;
    private static final String JSON_URL = "https://eй.seцйуайцуru/1.json";
    private Context cntcur;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        cntcur=this;
        // нажата кнопка "синхронизировать"
        Button button = (Button) findViewById(R.id.sync_button);
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Log.i("Info", "--нажата кнопка Синхронизация");
                accounts = new ReadJsonAccounts(cntcur,JSON_URL);
            }
        });

Ошибка определения текущих координат пользователя

С выходом новых версий Android (начиная с 11), почему то сломалось определение текущих координат пользователя в webview. Пока сделал следующий костыль:

 function fetchLocation() {
        if (navigator.geolocation) {
            navigator.geolocation.getCurrentPosition(onGeoSuccess, onGeoError)
        } else {            
            console.log("- без передачи геолокации ((")            
        }
     }
    function onGeoSuccess(event){
        latitude=event.coords.latitude;
        longitude=event.coords.longitude;
        accuracy=event.coords.accuracy; //точность
        console.log("- можно снимать координаты в браузере способ №2")
        geosupport=true;
    }
    function onGeoError(event){
            console.log("- без передачи геолокации ((")
    }
    
        console.log("--способ 1");
        navigator.geolocation.getCurrentPosition(
        function(location) {
            latitude=location.coords.latitude;
            longitude=location.coords.longitude;
            accuracy=location.coords.accuracy; //точность
            console.log("- можно снимать координаты в браузере способ №1")
          },
            function(error){
                console.log("-пробую способ 2");
                fetchLocation();
           },{enableHighAccuracy: true,timeout: 2000,
                             maximumAge: 60000}
      );        
    

Загрузка js и css «по требованию»

Задача: по какому то условию (ну в моем случае это загрузка скрипта «Тура по сайту» если вдруг пользователь его не проходил), необходимо до грузить дополнительные JS и CSS файлы, а по завершению их загрузки — запустить.

Решение:

function TourStart(){
    if ((localStorage.getItem(document.location.pathname+"_tour")==null)||(localStorage.getItem(document.location.pathname+"_tour")==false)){
        element = document.createElement("script");
        element.src = "https://shepherdjs.dev/dist/js/shepherd.js";
        element.addEventListener('load', () => {
            console.log("--загружаем тур!");
            element = document.createElement("script");
            element.src = "/js/tour.min.js";
            document.body.appendChild(element);
        });
        document.body.appendChild(element);
        element = document.createElement("link");
        element.href = "https://shepherdjs.dev/dist/css/shepherd.css";
        element.rel="stylesheet"
        document.body.appendChild(element);        
        
    };
};

console.log("-- main.js загружен");
$(document).ready(function() {
   TourStart(); // стартовать тур по странице если нужно..
});

Xcode: показываем экран загрузки во время рендеринга в wkwebview

К сожалению при использовании wkwebview на IOS, инициализация webkit довольно медлительна. И занимает при первом старте порядка 5-10 секунд. Потому для того чтобы «развлечь» пользователя во время ожидания можно показать например какую-то анимацию.

Загрузку можно организовать как-то так:

    override func viewDidLoad() {
        super.viewDidLoad()
        let userContentController = WKUserContentController()
        userContentController.add(self, name: "doMessage")
        let webviewConfiguration = WKWebViewConfiguration()
        webviewConfiguration.userContentController = userContentController
        webview = WKWebView(frame: self.view.frame, configuration: webviewConfiguration)
        view.addSubview(webview!)
        webview?.uiDelegate=self; //разрешаем подмену алертов
        webview?.navigationDelegate = self
        webview?.allowsBackForwardNavigationGestures=false;
        webview?.isOpaque=false;
        webview?.backgroundColor=UIColor.clear;
        webview?.scrollView.backgroundColor=UIColor.clear;
        webview?.load(URLRequest(url: URL(string:"https://увувцувцу")!));
        let jeremyGif = UIImage.gifImageWithName("images/anim")
                let imageView = UIImageView(image: jeremyGif)
                imageView.frame =
                    CGRect(x: (self.view.frame.size.width-267)/2, y: (self.view.frame.size.height-300)/2,
                           width: 267,
                           height: 300)
        imageView.tag=100;
        view.addSubview(imageView);

Результатом будет показ «фона» и анимации до показа страницы. Далее нам нужно отловить что рендеринг состоялся и убрать анимацию:

    func webView(_ webView: WKWebView,
       didFinish navigation: WKNavigation!) {
       print("loaded")
        let ivt=self.view.viewWithTag(100);
        ivt?.removeFromSuperview();
        webview?.isOpaque=true;
     }
1 88 89 90 91 92 301