Форум программистов, компьютерный форум, киберфорум
Наши страницы
Программирование Android
Войти
Регистрация
Восстановить пароль
 
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
#1

Как запустить метод в заданное время

19.11.2016, 19:15. Просмотров 753. Ответов 22
Метки нет (Все метки)

Доброго времени суток) Борюсь над задачей, в которой нужно, чтобы в указанное время запускался метод, даже если приложение было закрыто/свёрнуто. Гугл говорит, что нужно использовать AlarmManager. Окей, использую, но в качестве параметра нужно прописать pendingIntent. И вот тут начинаются проблемы. Чтобы создать PendingIntent, нужен Intent, где в одном из параметров нужен ещё и .class отдельный. Неужели нет других вариантов??? Вообщем, мне нужно, как-то реализовать метод volume_method() в указанное время. Помогите!!!
Java
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public void volume_method() {
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_NOTIFICATION);
        volumesetter.setStreamVolume(AudioManager.STREAM_NOTIFICATION, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_SYSTEM);
        volumesetter.setStreamVolume(AudioManager.STREAM_SYSTEM, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_RING);
        volumesetter.setStreamVolume(AudioManager.STREAM_RING, volume_set, volume_set);
    }
 
public void AM() {
        am = (AlarmManager)getSystemService(ALARM_SERVICE);
        time = System.currentTimeMillis() - c_time.getTimeInMillis() + time_set_h*60*60*1000 + time_set_m*60*1000;
        am.setRepeating(AlarmManager.RTC, System.currentTimeMillis() - c_time.getTimeInMillis() + time, AlarmManager.INTERVAL_DAY, volume_method());
    }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.11.2016, 19:15
Ответы с готовыми решениями:

Как запустить метод в сервисе, в определённое время?
Как запускать метод в сервисе, с понедельника по пятницу в определённое время?...

Переход между Activity через заданное время. Как лучше?
Добрый день. Вопрос от новичка. Какую задачу хотел решить: появляется...

Как запустить метод из Service?
При запуске сервиса в onCreate запускается метод, когда он отрабатывает...

Как запустить метод в Activity из BroadcastReceiver
Здравствуйте!!! Все до банальности просто и повторяется, по кругу :) Новичок,...

Как запустить метод из другого класса?
есть класс: public class Class1 extends DialogFragment implements...

22
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
19.11.2016, 19:39 #2
То что ты написал должно быть внутри сервиса, который ты и прописываешь в Intent.
0
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
19.11.2016, 19:46  [ТС] #3
Цитата Сообщение от ExFau$t Посмотреть сообщение
То что ты написал должно быть внутри сервиса, который ты и прописываешь в Intent.
То есть, мне создать интент, где указать класс, в который я вставлю
Этот код
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
public void volume_method() {
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_NOTIFICATION);
        volumesetter.setStreamVolume(AudioManager.STREAM_NOTIFICATION, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_SYSTEM);
        volumesetter.setStreamVolume(AudioManager.STREAM_SYSTEM, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_RING);
        volumesetter.setStreamVolume(AudioManager.STREAM_RING, volume_set, volume_set);
    }
 
    public void AM() {
        am = (AlarmManager)getSystemService(ALARM_SERVICE);
        time = System.currentTimeMillis() - c_time.getTimeInMillis() + time_set_h*60*60*1000 + time_set_m*60*1000;
        //am.setRepeating(AlarmManager.RTC, System.currentTimeMillis() - c_time.getTimeInMillis() + time, AlarmManager.INTERVAL_DAY, volume_method());
    }
Правильно понял? А что делать с PendingIntent, который запрашивает AlarmManager?
0
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
19.11.2016, 22:07 #4
Делаешь аля такое что-нибудь:
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
public class MyBroadcast extends BroadcastReceiver {
 
    public void SetAlarm(Context context, PendingIntent pendingIntent) {
        Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR_OF_DAY,15);
        calendar.set(Calendar.MINUTE,0);
        AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
        alarmManager.setRepeating(AlarmManager.RTC_WAKEUP,calendar.getTimeInMillis(),60000*60*24,pendingIntent);
    }
 
    @Override
    public void onReceive(Context context, Intent intent) {
        Log.e("11111111111111111111111", "log receive");
    }
}
и инициализируешь, например, так:
Java
1
2
3
4
MyBroadcast al = new MyBroadcast();
            Intent intent = new Intent(this, MyBroadcast.class);
            PendingIntent pi = PendingIntent.getBroadcast(this, 0, intent, 0);
            al.SetAlarm(this, pi);
Писал по памяти...

Добавлено через 42 секунды
Само собой класс этот объявляешь в манифесте:
XML
1
2
3
<receiver android:name="com.blabla.app.MyBroadcast">
 
        </receiver>
1
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
19.11.2016, 23:18  [ТС] #5
Цитата Сообщение от ExFau$t Посмотреть сообщение
Делаешь аля такое что-нибудь:
Сделал! подскажите чайнику, как мне мои переменные time_set_h и time_set_m передать в MyBroadcast.class? И как всю эту тему вызвать сдесь
Java
1
2
3
4
5
6
7
button_alert.setPositiveButton(R.string.OkeyButton, new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            //Чо писать? :)
                            dialog.cancel();
                        }
                    });
0
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
19.11.2016, 23:45 #6
Цитата Сообщение от ExFau$t Посмотреть сообщение
и инициализируешь, например, так:
Java
1
2
3
4
MyBroadcast al = new MyBroadcast();
            Intent intent = new Intent(this, MyBroadcast.class);
            PendingIntent pi = PendingIntent.getBroadcast(this, 0, intent, 0);
            al.SetAlarm(this, pi);
это и пиши, только вместо this ставишь контекст. Если нужно переменные передать, то расширь метод SetAlarm в бродкасте, а потом допишешь сюда:
Java
1
al.SetAlarm(this, pi,time_set_h ,time_set_m);
1
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
20.11.2016, 12:02  [ТС] #7
Цитата Сообщение от ExFau$t Посмотреть сообщение
это и пиши
Java
1
2
3
4
5
button_alert.setPositiveButton(R.string.OkeyButton, new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            AM();
                            dialog.cancel();
Java
1
2
3
4
5
6
public void AM() {
        MyBroadcast al = new MyBroadcast();
        Intent intent = new Intent(this, MyBroadcast.class);
        PendingIntent pi = PendingIntent.getBroadcast(this, 0, intent, 0);
        al.SetAlarm(this, pi,time_set_h ,time_set_m);
    }
Java
1
2
3
4
5
public void SetAlarm(Context context, PendingIntent pendingIntent, int time_set_h, int time_set_m) {
        time = System.currentTimeMillis() - c_time.getTimeInMillis() + time_set_h*60*60*1000 + time_set_m*60*1000;
        AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
        alarmManager.setRepeating(AlarmManager.RTC,System.currentTimeMillis() - c_time.getTimeInMillis() + time, AlarmManager.INTERVAL_DAY,pendingIntent);
    }
IDEA ошибок не видит. Только вот я так и не понял, куда мне сунуть этот метод, который должен выполняться в заданное время?
Java
1
2
3
4
5
6
7
8
public void volume_method() {
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_NOTIFICATION);
        volumesetter.setStreamVolume(AudioManager.STREAM_NOTIFICATION, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_SYSTEM);
        volumesetter.setStreamVolume(AudioManager.STREAM_SYSTEM, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_RING);
        volumesetter.setStreamVolume(AudioManager.STREAM_RING, volume_set, volume_set);
    }
0
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
20.11.2016, 15:06 #8
сюда:
Java
1
2
3
public void onReceive(Context context, Intent intent) {
        Log.e("11111111111111111111111", "log receive");
    }
0
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
20.11.2016, 17:10  [ТС] #9
ExFau$t, Спасибо, передал, но почему-то по тому же принципу не получатся передать int volume_set, который также нужен. Ибо теперь context and intent are never used Что делать??
0
Миниатюры
Как запустить метод в заданное время   Как запустить метод в заданное время  
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
20.11.2016, 17:51 #10
Наверное потому, что они не используются, а то что у тебя красным бродкаст подчёркнут тебя не смущает?

Добавлено через 2 минуты
Убери volume_set из OnREcieve, переменную свою можно через конструктор передать.
0
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
20.11.2016, 17:54  [ТС] #11
Цитата Сообщение от ExFau$t Посмотреть сообщение
Наверное потому, что они не используются,
Они не используются после строчки al.onReceive(this, intent, volume_set);
Цитата Сообщение от ExFau$t Посмотреть сообщение
а то что у тебя красным бродкаст подчёркнут тебя не смущает?
Смущает, а чо делать??
0
Миниатюры
Как запустить метод в заданное время  
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
20.11.2016, 22:09 #12
Цитата Сообщение от ExFau$t Посмотреть сообщение
Убери volume_set из OnREcieve, переменную свою можно через конструктор передать.
Я уже написал
0
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
21.11.2016, 21:14  [ТС] #13
Цитата Сообщение от ExFau$t Посмотреть сообщение
Я уже написал
Ой, извини, не заметил

Добавлено через 22 часа 58 минут
Цитата Сообщение от ExFau$t Посмотреть сообщение
переменную свою можно через конструктор передать.
Уже смешно стало, я второй вечер над этим долблюсь и ничего не получается... Конструктор сделал, параметры вроде передал, а не работает! Или ошибка или ничего не происходит! Помоги правильно его сделать, кодом... Я - чайник, и уже кипю
0
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
21.11.2016, 22:45 #14
Показывай, что сделал и какая ошибка...
0
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
22.11.2016, 18:50  [ТС] #15
Цитата Сообщение от ExFau$t Посмотреть сообщение
Показывай, что сделал и какая ошибка...
попробовал два разных варианта: в первом - вроде всё ок, однако не работает. А во втором ошибка.
0
Миниатюры
Как запустить метод в заданное время   Как запустить метод в заданное время   Как запустить метод в заданное время  

Как запустить метод в заданное время  
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
22.11.2016, 19:42 #16
А скопировать нельзя было? В строчке time=... какая-то ерунда написана. System.currentTimeMillis()-c_time.getTime.. по всей видимости равно 0. Задай для начала в будильник текущее время.
0
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
22.11.2016, 19:53  [ТС] #17
Цитата Сообщение от ExFau$t Посмотреть сообщение
какая-то ерунда написана
Согласен... Просто не совсем разобрался в этом AlarmManager. getTimeInMillis - даёт время календаря, currentTimeInMillis - даёт время с начала 1970-го вроде. Я как подумал... Мне нужно взять текущее время и к нему прибавить разницу Заданного и текущего... Эм... или просто нужно указать заданное время... Эм.. а как?? Я пытался взять текущее время, отнять от него время прошедшее от 0:00 и прибавить заданное. Но как взять время от 0:00??
0
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
22.11.2016, 20:17 #18
Я уже писал как надо. Задать будильник на 15 часов 0 минут:
Java
1
2
3
4
5
Calendar calendar = Calendar.getInstance();
        calendar.set(Calendar.HOUR_OF_DAY,15);
        calendar.set(Calendar.MINUTE,0);
        AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
        alarmManager.setRepeating(AlarmManager.RTC_WAKEUP,calendar.getTimeInMillis(),60000*60*24,pendingIntent);
Задать будильник сейчас - currentTimeInMillis

Добавлено через 1 минуту
setRepeating - будет повторяться раз в 60000*60*24 секунд.
1
JerryLetehen
14 / 14 / 2
Регистрация: 07.11.2015
Сообщений: 234
22.11.2016, 20:41  [ТС] #19
Цитата Сообщение от ExFau$t Посмотреть сообщение
Я уже писал как надо. Задать будильник на 15 часов 0 минут:
А вот оно как.... а ёклмн... крч написал вот так
MainActivity
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
package com.example.jerryletehen.setyourvolume;
 
 
import android.app.PendingIntent;
import android.app.TimePickerDialog;
import android.content.DialogInterface;
import android.content.Intent;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.widget.Button;
import android.widget.SeekBar;
import android.widget.TextView;
import android.widget.TimePicker;
import android.media.AudioManager;
 
import java.util.Calendar;
 
 
public class MainActivity extends AppCompatActivity {
    TimePickerDialog timepickerdialog;
    AudioManager volumesetter;
    SeekBar volumeBar;
    int volume = 0;
    public int volume_set;
    int time_set_h;
    int time_set_m;
    boolean checktime = false;
    boolean checkvolume = false;
    public static long time = 0;
 
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        // finals
        final TextView editTime = (TextView) findViewById(R.id.editTime);
        final TextView editVolume = (TextView) findViewById(R.id.editVolume);
        final Button button = (Button) findViewById(R.id.button);
        final TextView test = (TextView) findViewById(R.id.test);
        // Users clicks
        // set Time
        editTime.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                Calendar mcurrentTime = Calendar.getInstance();
                int hour = mcurrentTime.get(Calendar.HOUR_OF_DAY);
                int minute = mcurrentTime.get(Calendar.MINUTE);
 
                timepickerdialog = new TimePickerDialog(MainActivity.this, new TimePickerDialog.OnTimeSetListener() {
                    @Override
                    public void onTimeSet(TimePicker timePicker, int selectedHour, int selectedMinute) {
                        String selectedMinute0;
                        if (selectedMinute == 0 || selectedMinute == 1 || selectedMinute == 2 || selectedMinute == 3 || selectedMinute == 4 || selectedMinute == 5 || selectedMinute == 6 || selectedMinute == 7 || selectedMinute == 8 || selectedMinute == 9) {
                            selectedMinute0 = "0";
                            editTime.setText(selectedHour + ":" + selectedMinute0 + selectedMinute);
                            checktime = true;
                        } else {
                            editTime.setText(selectedHour + ":" + selectedMinute);
                            time_set_h = selectedHour;
                            time_set_m = selectedMinute;
                            checktime = true;
                        }
                    }
                }, hour, minute, true);//Yes 24 hour time
                timepickerdialog.show();
            }
        });
        // set Volume level
        editVolume.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                final AlertDialog.Builder volumeSetter = new AlertDialog.Builder(MainActivity.this);
                volumeSetter.setTitle(R.string.ChangeVolume);
                volumeBar = new SeekBar(MainActivity.this);
                volumesetter = (AudioManager) getSystemService(AUDIO_SERVICE);
                volumeBar.setMax(volumesetter.getStreamMaxVolume(AudioManager.STREAM_RING));
                volumeBar.setProgress(volumesetter.getStreamVolume(AudioManager.STREAM_RING));
                volumeBar.setOnSeekBarChangeListener(new SeekBar.OnSeekBarChangeListener() {
                    @Override
                    public void onProgressChanged(SeekBar seekBar, int progress, boolean fromUser) {
                        volume = progress;
                    }
 
                    @Override
                    public void onStartTrackingTouch(SeekBar seekBar) {
                    }
 
                    @Override
                    public void onStopTrackingTouch(SeekBar seekBar) {
                    }
                });
                volumeSetter.setView(volumeBar);
                volumeSetter.setNeutralButton(R.string.OkeyButton, new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        editVolume.setText(getString(R.string.Set) + volume);
                        volume_set = volume;
                        checkvolume = true;
                        dialog.cancel();
                    }
                });
                volumeSetter.setNegativeButton(R.string.Back_Button, new DialogInterface.OnClickListener() {
                    @Override
                    public void onClick(DialogInterface dialog, int which) {
                        dialog.cancel();
                    }
                });
                volumeSetter.show();
            }
        });
        // main button
        button.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                AlertDialog.Builder button_alert = new AlertDialog.Builder(MainActivity.this);
                if (!checktime) {
                    button_alert.setMessage(R.string.DidnotSetTime);
                    button_alert.setNegativeButton(R.string.Back_Button, new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            dialog.cancel();
                        }
                    });
                } else if (!checkvolume) {
                    button_alert.setMessage(R.string.DidnotSetVolumeLevel);
                    button_alert.setNegativeButton(R.string.Back_Button, new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            dialog.cancel();
                        }
                    });
                } else {
                    button_alert.setMessage(R.string.CompleteText);
                    button_alert.setPositiveButton(R.string.OkeyButton, new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            AM();
                            dialog.cancel();
                        }
                    });
                    button_alert.setNegativeButton(R.string.Back_Button, new DialogInterface.OnClickListener() {
                        @Override
                        public void onClick(DialogInterface dialog, int which) {
                            dialog.cancel();
                        }
                    });
                }
                button_alert.show();
            }
        });
    }
 
    public void AM() {
        MyBroadcast al = new MyBroadcast(volume_set);
        Intent intent = new Intent(this, MyBroadcast.class);
        PendingIntent pi = PendingIntent.getBroadcast(this, 0, intent, 0);
        al.SetAlarm(this, pi,time_set_h ,time_set_m);
    }
 
}
MyBroadCast
Java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
package com.example.jerryletehen.setyourvolume;
 
import android.app.AlarmManager;
import android.app.PendingIntent;
import android.content.BroadcastReceiver;
import android.content.Context;
import android.content.Intent;
import android.media.AudioManager;
 
import java.util.Calendar;
 
 
public class MyBroadcast extends BroadcastReceiver {
 
 
    AudioManager volumesetter;
 
    int volume_set;
 
    MyBroadcast(int volume_set) {
        this.volume_set = volume_set;
    }
 
 
    public void SetAlarm(Context context, PendingIntent pendingIntent, int time_set_h, int time_set_m) {
        Calendar c_time = Calendar.getInstance();
        c_time.set(Calendar.HOUR_OF_DAY,time_set_h);
        c_time.set(Calendar.MINUTE,time_set_m);
        AlarmManager alarmManager = (AlarmManager) context.getSystemService(Context.ALARM_SERVICE);
        alarmManager.setRepeating(AlarmManager.RTC, c_time.getTimeInMillis(), AlarmManager.INTERVAL_DAY,pendingIntent);
    }
 
    @Override
    public void onReceive(Context context, Intent intent) {
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_NOTIFICATION);
        volumesetter.setStreamVolume(AudioManager.STREAM_NOTIFICATION, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_SYSTEM);
        volumesetter.setStreamVolume(AudioManager.STREAM_SYSTEM, volume_set, volume_set);
        volumesetter.getStreamMaxVolume(AudioManager.STREAM_RING);
        volumesetter.setStreamVolume(AudioManager.STREAM_RING, volume_set, volume_set);
    }
}

И всё равно чо-то не робит
0
ExFau$t
542 / 493 / 107
Регистрация: 08.05.2012
Сообщений: 2,468
22.11.2016, 21:09 #20
Цитата Сообщение от ExFau$t Посмотреть сообщение
<receiver android:name="com.blabla.app.MyBroadcast">
</receiver>
Должно быть это в манифесте.
А это:
Java
1
2
time_set_h = selectedHour;
time_set_m = selectedMinute;
наверное надо вынести из if.
0
22.11.2016, 21:09
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
22.11.2016, 21:09

Как запустить метод Fragment из MainActivity?
есть фрагмент с картой, в нем метод: public void Sputnik(GoogleMap map) { ...

Ждать ответ заданное время
Как реализовать такое: Я отправляю на сервер TCP данные и затем в течение...

Выводить оповещения в заданное время
Здравствуйте. Нужно выводить оповещения в заданное время, создаю сервис через...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
20
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2018, vBulletin Solutions, Inc.
Рейтинг@Mail.ru