Архив рубрики: Из жизни

Сюда тащатся заметки из ЖЖшки

О понятности кода..

Вот если выбирать как писать код, вот так:

 $url = ($path == '') ? 'javascript:void(0)' : "index.php?content_page=$path";

Или вот так:

if ($path==""){
   $url='javascript:void(0)';
} else {
   $url="index.php?content_page=$path";
};

То я выберу последнее. И меня коробит немножко когда читаю код, написаный в «коротком» стиле. Не роботы же. Может конечно это сила привычки, и со временем, если постоянно писать «сокращенный» код то он становится читаемым «на лету». Но я всё-же за более «человечный» код, чтоб было понятно сразу, без разбора конструкции.

Вывод телефона и сервиса из спящего режима. Разработка под Android

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

Решение:

Создадим стартующий при загрузке сервис при помощи класса WakefulBroadcastReceiver.

Android Manifest:

— назначаем права на вывод из спящего режима, загрузку при перезагрузке, полный доступ в интернет и сеть

— обьявляем ресивер BootBroadcast как выполняемый при перезагрузке телефона

Читать далее Вывод телефона и сервиса из спящего режима. Разработка под Android

Получение страницы по http протоколу на Android

Задача: получить «сырой» json  по протоколу http в приложении под андроид.

Решение:

1)  Разрешим доступ в интернет в AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="ru.erver.noc.nocmessages">
    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.RECEIVE_BOOT_COMPLETED" />
    <application
        android:resource="@xml/netsec"
        android:allowBackup="true"
        android:icon="@mipmap/ic_launcher"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/Theme.AppCompat.NoActionBar" >
        <activity android:name=".Form1">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

2) Код:

package ru.yarteleservice.noc.nocmessages;

import android.content.SharedPreferences;
import android.os.AsyncTask;
import android.preference.PreferenceManager;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.util.Log;
import android.view.View;
import android.widget.EditText;

import java.io.BufferedReader;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.HttpURLConnection;
import java.net.URL;

public class Form1 extends AppCompatActivity {
    EditText logv;
    jsonnoc jsn;

    public void AddToLog(String txt) {
        logv = (EditText) findViewById(R.id.editText3);
        if (txt == "clear") {
            logv.setText("");
        } else {
            logv.append(txt);
            logv.append("\n");
        }
        ;
    }

    ;

    public void ClickEnterNocButton(View view) {

        Log.d("неашипка", "--click!");
        AddToLog("clear");

        EditText elogin = (EditText) findViewById(R.id.editText);
        EditText epass = (EditText) findViewById(R.id.editText2);

        AddToLog("-пробуем залогиниться");
        // jsonnoc jsn=new jsonnoc();
        //jsn.GetJsonMet("{'userlogin':'login'}");
        new GetMyDataFromUrl().execute("!!!!!!!!!");

        AddToLog("-сохраняем настройки");

        SharedPreferences mSettings = PreferenceManager.getDefaultSharedPreferences(getApplicationContext());
        SharedPreferences.Editor mEdit = mSettings.edit();
        mEdit.putString("userlogin", elogin.getText().toString());
        mEdit.commit();
        mEdit.apply();
        mEdit.putString("userpass", epass.getText().toString());
        mEdit.commit();
        mEdit.apply();

    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_form1);
        AddToLog("-читаем настройки");

        EditText elogin = (EditText) findViewById(R.id.editText);
        EditText epass = (EditText) findViewById(R.id.editText2);

        SharedPreferences mSettings = PreferenceManager.getDefaultSharedPreferences(getApplicationContext());

        elogin.setText(mSettings.getString("userlogin", ""));
        epass.setText(mSettings.getString("userpass", ""));

        AddToLog(elogin.getText().toString());
        AddToLog(epass.getText().toString());

    }

    class GetMyDataFromUrl extends AsyncTask<String, Integer, String>{

        @Override
        protected String doInBackground(String... arg) {
            String res;
            BufferedReader reader = null;
            String resultJson = "";

            res=null;
            HttpURLConnection urlConnection = null;
            Log.d("неашипка", "--пробую почитать json");
            try {
                URL url = new URL("http://noc.dfvdfv.ru/getjsonmess.php");
                urlConnection = (HttpURLConnection) url.openConnection();
                urlConnection.setRequestMethod("GET");
                urlConnection.connect();

                InputStream inputStream = urlConnection.getInputStream();
                StringBuffer buffer = new StringBuffer();

                reader = new BufferedReader(new InputStreamReader(inputStream));

                String line;
                while ((line = reader.readLine()) != null) {
                    buffer.append(line);
                }
                resultJson = buffer.toString();
                Log.d("неашипка", resultJson);
            }
            catch (Exception e) {
                e.printStackTrace();
                Log.d("ашипка", "--не смогли прочитать JSON");
            }
            return res;
        }

        @Override
        protected void onPostExecute(String s) {
            super.onPostExecute(s);
        }
    }
}

Результат:

Чтиво за последнее время

1.Взрослое

  • Вычислитель. Дилогия. Александр Николаевич Громов. Сюжет: часть планеты покрытая болотом становится местом для изгнания преступников, среди которых — гениальный математик. (+)
  • Турист. Мак Симов. Сюжет: бухгалтер совершающий туристическую прогулку по горам попадает на космический корабль. Туто то скрытые таланты и просыпаются 😉 (+)
  • По дороге памяти. Майк Резник. Сюжет: Пол прожил всю жизнь с любимой женой, но у неёё нашли болезнь Альцгеймера. В конце кнцов она перестала его узнавать, но Пол нашел выход. (+)
  • Сын галактики 1-2. Дмитрий Викторович Распопов. Сюжет: обыкновенный земной задрот становится спасителем галактики.

2.Детское

  • Разноцветное крылышко. Галина Грановская.Сюжет:  Жизнь бабочки (+)
  • Утренняя заря. Александр Павлович  Бердник.  Детская фантастика 60-х годов. Читается наивно, но ребенок слушал. (+)
  • Космические Бродяги. Загадочный груз. Саша Сильвер. Сюжет: приключения кадетов межзвездного флота. Немного нудновато. Ребенок не оценил.(-)
  • Маленькие Дикари. Эрнест Сетон-Томпсон. Сюжет: приключения мальчишек решивших стать индейцами. Я вспомнил как её зачитывал в детстве. Но Мой ребенок не оценил. (+/-)

Не понимаю разработчиков в 1С

С какого то перепуга убрали возможность увидеть код элемента некоторых справочников. Например в Рознице 2.2. — никакими средствами не увидеть код склада. На форумах народ пишет что «ищите по реквизитам или наименованию». Но! У склада нет того реквизита который бы мог быть уникальным. Например у меня следующая структура складов (с группами):

-Вологда
—Ремонты
—Готовые-Москва
—Ремонты
—Готовые

И всё.. Приплыли. По реквизиту не найдешь, по названию то-же — есть одинаковые. Плюс где гарантия что кому-то не захочется справочник переименовать?? Выход искать — только по коду.

Пришлось написать обработку которая выводит кода всех складов. Бред!