Задать вопрос
  • MVC как вывести модифицированный текст в код HTML из input при перезагрузке страницы?

    @defond Автор вопроса
    Модель:
    public class UserContainer
        {
            public string Fam { get; set; }
            public string Name { get; set; }
            public string Name2 { get; set; }
     
            public UserContainer(string F, string N, string N2)
            {
                Fam = F; Name = N; Name2 = N2;
            }
        }


    Контроллер:

    using System;
    using System.Collections.Generic;
    using System.Linq;
    using System.Web;
    using System.Web.Mvc;
    using Vasya.Models;
     
    namespace Vasya.Controllers
    {
        public class HomeController : Controller
        {
            [HttpGet]
            public ActionResult Index()
            {
                UserContainer UCon = new UserContainer("","","");
                return View(UCon);
            }
     
            [HttpPost]
            public ActionResult Index(string Fam, string Name, string Name2)
            {
                UserContainer UCon = new UserContainer(Fam, Name, Name2);
                return View(UCon);
            }
     
        }
    }


    HTML5
    @model System.Data.DataTable
    
    <div>
            Привет, @Model.Fam &nbsp @Model.Name &nbsp @Model.Name2
           <form action="/Home/Index" method="post"> 
              <p><input class="text-box single-line" size = 20 id ="N1" name ="Fam" type ="text" value = "@Model.Fam" /> </p>
              <p><input class="text-box single-line" size = 20 id ="N2" name ="Name" type ="text" value = "@Model.Name" /> </p>
              <p><input class="text-box single-line" size = 20 id ="N3" name ="Name2" type ="text" value = "@Model.Name2" /> </p>
              <input type="submit" id="SendButton" value="Ok" />
           </form>
     
        </div>


    Нашел решение, может кому то пригодиться. Решение рабочее, всё работает отлично!
    П.С,: Самому себе отвечать на вопрос на Тостере - это конечно сильно. )
    Ответ написан
    Комментировать
  • РЕШЕНО [SQLite] INSERT блокирует базу данных, каким образом можно решить данный вопрос?

    @defond Автор вопроса
    Мне помогли решить вопрос на Кибер форуме.

    Я не понимаю как, т.к. у меня был по логике такой же класс. Назывался по другому, и построение запросов было ближе к рекомендациям MSDN, но факт остается фактом - код в ответе работает, мой нет.

    И дополнение к ответу, вместо:
    public static Close()
            {
                connection.Close();
            }

    нужно читать:
    public static void Close()
            {
                connection.Close();
            }

    Очевидная опечатка, но вдруг кто-то скопирует. )

    На всякий случай, размещаю верный пример кода:
    class Database
        {
            const string dbFileName = @"res\db\def.db";
            private static SQLiteConnection connection;
     
            static Database()
            {
                connection = new SQLiteConnection("Data Source=" + dbFileName + ";mode=Exclusive;datetimeformat=CurrentCulture");
                connection.Open();
            }
     
            public static void Close()
            {
                connection.Close();
            }
     
            // можно также добавить методы для получения данных при необходимости...
     
            public static void ExecuteSqlTransaction(string query)
            {
                using (SQLiteTransaction dbTrans = connection.BeginTransaction())
                {
                    using (SQLiteCommand cmd = connection.CreateCommand())
                    {
                        cmd.CommandText = query;
                        cmd.ExecuteNonQuery();
                    }
                    try
                    {
                        dbTrans.Commit();
                    }
                    catch
                    {
                        MessageBox.Show("Незадача какая то!");
                    }
                }
            }
        }
    Ответ написан
    Комментировать
  • Проект для команды начинающих разработчиков?

    Есть реальный проект. Связан с авиационной безопасностью. Вот ссылка на статью, в которой я немного описываю проект.

    Под диплом - отличная вещь. Т.к. технически не сложный, но интересный и необычный.

    Над проектом уже работаем. Есть структура. Есть специалисты-консультанты. Проект будет использоваться в реальной жизни.
    Ответ написан
    Комментировать
  • Как получить и отправить GPS координаты на Андроид?

    Вот код рабочего класса для получения координат GPS или NET.
    package ru.defond.fly;
    
    import android.app.AlertDialog;
    import android.app.Service;
    import android.content.Context;
    import android.content.DialogInterface;
    import android.content.Intent;
    import android.location.Location;
    import android.location.LocationListener;
    import android.location.LocationManager;
    import android.os.Bundle;
    import android.os.IBinder;
    import android.provider.Settings;
    import android.util.Log;
    
    public class GPSTracker extends Service implements LocationListener {
    
        private final Context mContext;
    
        // flag for GPS status
        boolean isGPSEnabled = false;
    
        // flag for network status
        boolean isNetworkEnabled = false;
    
        // flag for GPS status
        boolean canGetLocation = false;
    
        Location location; // location
        double latitude; // latitude
        double longitude; // longitude
        double altitude;
        double speed;
        double bearing;
    
        // The minimum distance to change Updates in meters
        private static final long MIN_DISTANCE_CHANGE_FOR_UPDATES = 10; // 10 meters
    
        // The minimum time between updates in milliseconds
        private static final long MIN_TIME_BW_UPDATES = 1000 * 60 * 1; // 1 minute
    
        // Declaring a Location Manager
        protected LocationManager locationManager;
    
        public GPSTracker(Context context) {
            this.mContext = context;
            getLocation();
        }
    
        public Location getLocation() {
            try {
                locationManager = (LocationManager) mContext
                        .getSystemService(LOCATION_SERVICE);
    
                // getting GPS status
                isGPSEnabled = locationManager
                        .isProviderEnabled(LocationManager.GPS_PROVIDER);
    
                // getting network status
                isNetworkEnabled = locationManager
                        .isProviderEnabled(LocationManager.NETWORK_PROVIDER);
    
                if (!isGPSEnabled && !isNetworkEnabled) {
                    // no network provider is enabled
                } else {
                    this.canGetLocation = true;
                    // First get location from Network Provider
                    if (isNetworkEnabled) {
                        locationManager.requestLocationUpdates(
                                LocationManager.NETWORK_PROVIDER,
                                MIN_TIME_BW_UPDATES,
                                MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
                        Log.d("Network", "Network");
                        if (locationManager != null) {
                            location = locationManager
                                    .getLastKnownLocation(LocationManager.NETWORK_PROVIDER);
                            if (location != null) {
                                latitude = location.getLatitude();
                                longitude = location.getLongitude();
                                altitude = location.getAltitude();
                                speed = location.getSpeed();
                                bearing = location.getBearing();
                            }
                        }
                    }
                    // if GPS Enabled get lat/long using GPS Services
                    if (isGPSEnabled) {
                        if (location == null) {
                            locationManager.requestLocationUpdates(
                                    LocationManager.GPS_PROVIDER,
                                    MIN_TIME_BW_UPDATES,
                                    MIN_DISTANCE_CHANGE_FOR_UPDATES, this);
                            Log.d("GPS Enabled", "GPS Enabled");
                            if (locationManager != null) {
                                location = locationManager
                                        .getLastKnownLocation(LocationManager.GPS_PROVIDER);
                                if (location != null) {
                                    latitude = location.getLatitude();
                                    longitude = location.getLongitude();
                                    altitude = location.getAltitude();
                                    speed = location.getSpeed();
                                    bearing = location.getBearing();
                                }
                            }
                        }
                    }
                }
    
            } catch (Exception e) {
                e.printStackTrace();
            }
    
            return location;
        }
    
        /**
         * Stop using GPS listener
         * Calling this function will stop using GPS in your app
         * */
        public void stopUsingGPS(){
            if(locationManager != null){
                locationManager.removeUpdates(GPSTracker.this);
            }
        }
    
        /**
         * Function to get latitude
         * */
        public double getLatitude(){
            if(location != null){
                latitude = location.getLatitude();
            }
    
            // return latitude
            return latitude;
        }
    
        /**
         * Function to get longitude
         * */
        public double getLongitude(){
            if(location != null){
                longitude = location.getLongitude();
            }
    
            // return longitude
            return longitude;
        }
    
        public double getAltitude(){
            if(location != null){
                altitude = location.getAltitude();
            }
    
            // return
            return altitude;
        }
    
        public double getSpeed() {
            if(location != null){
                speed = location.getSpeed();
            }
            return speed;
        }
    
        public double getBearing(){
            if(location != null){
                bearing = location.getBearing();
            }
            return bearing;
        }
    
        /**
         * Function to check GPS/wifi enabled
         * @return boolean
         * */
        public boolean canGetLocation() {
            return this.canGetLocation;
        }
    
        /**
         * Function to show settings alert dialog
         * On pressing Settings button will lauch Settings Options
         * */
        public void showSettingsAlert(){
            AlertDialog.Builder alertDialog = new AlertDialog.Builder(mContext);
    
            // Setting Dialog Title
            alertDialog.setTitle("GPS is settings");
    
            // Setting Dialog Message
            alertDialog.setMessage("GPS is not enabled. Do you want to go to settings menu?");
    
            // On pressing Settings button
            alertDialog.setPositiveButton("Settings", new DialogInterface.OnClickListener() {
                public void onClick(DialogInterface dialog,int which) {
                    Intent intent = new Intent(Settings.ACTION_LOCATION_SOURCE_SETTINGS);
                    mContext.startActivity(intent);
                }
            });
    
            // on pressing cancel button
            alertDialog.setNegativeButton("Cancel", new DialogInterface.OnClickListener() {
                public void onClick(DialogInterface dialog, int which) {
                    dialog.cancel();
                }
            });
    
            // Showing Alert Message
            alertDialog.show();
        }
    
        @Override
        public void onLocationChanged(Location location) {
        }
    
        @Override
        public void onProviderDisabled(String provider) {
        }
    
        @Override
        public void onProviderEnabled(String provider) {
        }
    
        @Override
        public void onStatusChanged(String provider, int status, Bundle extras) {
        }
    
        @Override
        public IBinder onBind(Intent arg0) {
            return null;
        }
    
    }


    В активити я использую вот такую конструкцию:

    gps = new GPSTracker(StartActivity.this);
    
            // check if GPS enabled
            if(gps.canGetLocation()){
    
                double latitude = gps.getLatitude();
                double longitude = gps.getLongitude();
                double altitude = gps.getAltitude();
                double speed = gps.getSpeed();
                double bearing = gps.getBearing();
                double speedLimitA = ((10*1000)/(60*60));
    
                // \n is for new line
                Toast.makeText(getApplicationContext(), "Your Location is - \nLat: " + latitude
                        + "\nLong: " + longitude
                        + "\nAlt:" + altitude, Toast.LENGTH_LONG).show();
                Intent intent = new Intent(this, Logik_Activity.class);
                intent.putExtra("alt",altitude);
                intent.putExtra("speed",speed);
                intent.putExtra("bearing",bearing);
                if (speed < speedLimitA){
                    startActivity(intent);
                }
                // if speed > 0 then AAA else BBB
    
            }else{
                // can't get location
                // GPS or Network is not enabled
                // Ask user to enable GPS/network in settings
                gps.showSettingsAlert();
            }


    Вам нужно соответственно вставить код не для перехода, а для отправки данных. Я к сожалению отправкой POST-запросов под Андроид не занимался - помочь пока не могу.

    Сам неделю назад за Андроид сел. :) Чем богат...
    Ответ написан
    Комментировать
  • Какой алгоритм сортировки слов по смыслу или библиотеку использовать?

    Необходимо найти сходства у этих строк по смыслу и рассортировать


    Уважаемый автор вопроса, victorvsk Вам ответил правильно - Вы задали некорректный вопрос.

    Как я понял, из тех данных, что Вы предоставили, сортировка будет осуществляться именно по смыслу. Тогда что такое смысл? На мой взгляд, в представленном случае, вариантов может быть несколько - смыслом будет сортировка по слову "проблема" или по слову "задача" или по слову "есть/нет решения". Что для Вас будет смыслом - непонятно из вопроса.

    Так же victorvsk Вам ответил правильно - самым простым вариантом будет поиск по расстоянию. Я делал по связке двух подходов Левенштейна и Оливера.

    Реализация расстояния по Левенштейну. Посмотрите, попробуйте, там все очень просто, а на словах более 3-х символов, дает очень неплохие результаты.

    Либо, как уже советовали, пользуйте готовые решения, в Гугле их очень много.

    Дополнение

    Вот реализация алгоритмов на PHP и еще.

    Где то была реализация на Питоне, но пока не могу найти. Посмотрите еще вот эту статью.

    Удачи. :)
    Ответ написан
    1 комментарий