|
I have this code
public partial class TrimOptions : Form
{
public bool trimFirst { get; set; } = false;
public bool trimLast { get; set; } = false;
public bool ifBlank { get; set; } = true;
public TrimOptions()
{
InitializeComponent();
chkTrimFirst.DataBindings.Add(new Binding("Checked", trimFirst, null, false, DataSourceUpdateMode.OnPropertyChanged));
chkTrimLast.DataBindings.Add(new Binding("Checked", trimLast, null, false, DataSourceUpdateMode.OnPropertyChanged));
chkIfBlank.DataBindings.Add(new Binding("Checked", ifBlank, null, false, DataSourceUpdateMode.OnPropertyChanged));
} Whatever I set the properties to in code is reflected in the UI when the form is displayed. So far, so good. However, the user clicking the checkboxes does not set the properties, and setting the properties programmatically does not change the UI (nor the Checked property of the control).
I would like programmatic changes to the properties to update the UI, and I would like the user changing the UI to update the properties. How to do that?
modified 14-Feb-21 13:43pm.
|
|
|
|
|
|
Thank you!
chkTrimFirst.DataBindings.Add(new Binding("Checked", this, "trimFirst", false, DataSourceUpdateMode.OnPropertyChanged));
chkTrimLast.DataBindings.Add(new Binding("Checked", this, "trimLast", false, DataSourceUpdateMode.OnPropertyChanged));
chkIfBlank.DataBindings.Add(new Binding("Checked", this, "ifBlank", false, DataSourceUpdateMode.OnPropertyChanged)); This is working just fine now.
|
|
|
|
|
Excellent! I see you recognized "this" (the data source) as the form.
It was only in wine that he laid down no limit for himself, but he did not allow himself to be confused by it.
― Confucian Analects: Rules of Confucius about his food
|
|
|
|
|
I am using following code to download file from FTP. I want to enhance this code with Auto Resume functionality in case of Internet disconnection. This code works perfect to download a file but doesn't auto resume. Please provide me C# source code to apply auto resume. My code supports bigger file also that is multiple GB download. Please review my code and please suggest how in my code I can integrate Resume.
\\\\\\\\\\\\\\\\\\\\ code
try
{
//Create FTP Request.
FtpWebRequest request = (FtpWebRequest)WebRequest.Create(FTPPath);
request.Method = WebRequestMethods.Ftp.DownloadFile;
//Enter FTP Server credentials.
request.Credentials = new NetworkCredential(FTPUser, FTPPassword);
request.UsePassive = true;
request.UseBinary = true;
request.EnableSsl = false;
FtpWebResponse response = (FtpWebResponse)request.GetResponse();
using (Stream stream = response.GetResponseStream())
{
int length = 0;
int bytesToRead = 26214400;
byte[] buffer = new Byte[bytesToRead]; // Buffer to read bytes in chunk size specified above
long responseFileLength = this.FtpGetFileSize(FTPPath, FTPUser, FTPPassword); // Get the file size on the ftp
HttpContext.Current.Response.Buffer = false;
HttpContext.Current.Response.Clear();
HttpContext.Current.Response.ClearContent();
HttpContext.Current.Response.ClearHeaders();
HttpContext.Current.Response.Expires = -1;
HttpContext.Current.Response.ContentType = "application/octet-stream";
HttpContext.Current.Response.AddHeader("Content-Disposition", "attachment; filename=\"" + origionalFileName + "\"");
HttpContext.Current.Response.AddHeader("Content-Length", responseFileLength.ToString());
do
{
if (HttpContext.Current.Response.IsClientConnected)
{
length = stream.Read(buffer, 0, bytesToRead);
HttpContext.Current.Response.OutputStream.Write(buffer, 0, length);
HttpContext.Current.Response.Flush();
buffer = new Byte[bytesToRead];
}
else
{
length = -1;
}
} while (length > 0); //Repeat until no data is read
IsDownloaded = true;
HttpContext.Current.Response.Clear();
}
}
catch (WebException ex)
{
}
|
|
|
|
|
|
You seem to have the wrong idea about this site, you may request help with a problem but supplying code is not what CP is about.
Never underestimate the power of human stupidity -
RAH
I'm old. I know stuff - JSOP
|
|
|
|
|
|
Kindly understand that I really can't figure out how to get this neural network concept to work as code. Anyway, has anyone figured out how to create the C# source code implementation for this?
https://imgur.com/qN1QLHe
|
|
|
|
|
|
Probably yes.
But ... while we are more than willing to help those that are stuck: that doesn't mean that we are here to do it all for you! We can't do all the work, you are either getting paid for this, or it's part of your grades and it wouldn't be at all fair for us to do it all for you.
So we need you to do the work, and we will help you when you get stuck. That doesn't mean we will give you a step by step solution you can hand in!
Start by explaining where you are at the moment, and what the next step in the process is. Then tell us what you have tried to get that next step working, and what happened when you did.
If you are having problems getting started at all, then this may help: How to Write Code to Solve a Problem, A Beginner's Guide[^]
"I have no idea what I did, but I'm taking full credit for it." - ThisOldTony
"Common sense is so rare these days, it should be classified as a super power" - Random T-shirt
AntiTwitter: @DalekDave is now a follower!
|
|
|
|
|
|
|
I tried to simulate a process in which by pressing a button, some calculations take place (I used a tutorial). Now, I want to test and learn how I can manipulate GUI from an another thread. I decided to change button1 text. I added its code to DoWork section. As I expected, it throws cross-thread exception. Please write me a code and use Invoke and Delegate to see how I can access GUI. I want to learn from your code. Thanks.
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
button1.Text = "processing";
int sum = 0;
for (int i = 0; i <= 100; i++)
{
Thread.Sleep(100);
sum = sum + i;
backgroundWorker1.ReportProgress(i);
if (backgroundWorker1.CancellationPending)
{
e.Cancel = true;
backgroundWorker1.ReportProgress(0);
return;
}
}
e.Result = sum;
}
private void backgroundWorker1_ProgressChanged(object sender, ProgressChangedEventArgs e)
{
progressBar1.Value = e.ProgressPercentage;
label1.Text = e.ProgressPercentage + "%";
}
private void backgroundWorker1_RunWorkerCompleted(object sender, RunWorkerCompletedEventArgs e)
{
if (e.Cancelled)
{
label1.Text = "Process canceled";
}
else if (e.Error != null)
{
label1.Text = e.Error.Message;
}
else
{
label1.Text = "Result: " + e.Result.ToString();
}
}
private void button1_Click(object sender, EventArgs e)
{
if (!backgroundWorker1.IsBusy)
{
backgroundWorker1.RunWorkerAsync();
}
else
{
MessageBox.Show("Busy processing!. Please wait...");
}
}
private void button2_Click(object sender, EventArgs e)
{
if (backgroundWorker1.IsBusy)
{
backgroundWorker1.CancelAsync();
}
else
{
label1.Text = "No operation is running to cancel.";
}
}
}
modified 11-Feb-21 14:05pm.
|
|
|
|
|
UWP, WPF or Windows Forms?
Seems optimistic to "report progress" when "cancelling" ... that's RunWorkerCompleted territory.
It was only in wine that he laid down no limit for himself, but he did not allow himself to be confused by it.
― Confucian Analects: Rules of Confucius about his food
|
|
|
|
|
|
Consider that I have to keep order of my operations, so
button1.Text = "processing" needs to be in DoWork section.
|
|
|
|
|
No, you don't.
UI stuff like that should happen outside the BackgroundWorker, like right before you start it on its way.
|
|
|
|
|
1) Add reference to WindowsBase.dll
2) Add: using System.Windows.Threading;
3) Add delegate declaration OUTSIDE of method:
delegate void ProgressDelegate( int pct );
4) Replace (in this case):
backgroundWorker1.ReportProgress(i);
with:
ProgressDelegate progressDelegate = delegate ( int pct ) { this.progressBar1.Value = pct; };
System.Windows.Threading.Dispatcher.CurrentDispatcher.BeginInvoke(
DispatcherPriority.Normal, progressDelegate, percentComplete );
Then it's just a matter of tailoring for various UI controls.
It was only in wine that he laid down no limit for himself, but he did not allow himself to be confused by it.
― Confucian Analects: Rules of Confucius about his food
|
|
|
|
|
Isn't that the same question that you ask here :
Re: BackGroundWorker gives runtime error - C# Discussion Boards[^]
Did you give those links, I gave to you at that question, a try ?
If not - why not ?
If yes - where do you stuck ?
To Clarify :
Invoke means that you give an order to do something outside your Thread or Worker which originally happen inside the UI-Thread.
|
|
|
|
|
That basically is the same question once more. The answer hasn't changed.
You are wasting your and our time by repeating your question and ignoring the answers you've got.
Luc Pattyn [My Articles]
If you can't find it on YouTube try TikTok...
|
|
|
|
|
Luc Pattyn wrote: No, Master Luke.
(Ghhh.. I am your father, ghhhh)
Luc Pattyn wrote: You are wasting your and our time He has the right to do so; to be ignorant. There's always those looking for easy answers, unwilling to learn. This site is easy money for some. I learned a lot from you, mostly that I should be patient.
Want to tell him he's wasting money? This is voluntary, remember? If he insist on failing, I'd for one gladly help.
Bastard Programmer from Hell
"If you just follow the bacon Eddy, wherever it leads you, then you won't have to think about politics." -- Some Bell.
|
|
|
|
|
I'm not wasting your time. I couldn't find out how to use the procedure in my own situation.
For example, based on the explanations in Towards Cleaner Code II, a C# GUI Invoke/Async Helper [^] I wrote the following code:
private void backgroundWorker1_DoWork(object sender, DoWorkEventArgs e)
{
if (button1.InvokeRequired)
{
button1.Invoke(delegate { updatetext("Processing"); });
}
else
{
updatetext("Processing");
}
int sum = 0;
for (int i = 0; i <= 100; i++)
{
Thread.Sleep(100);
sum = sum + i;
backgroundWorker1.ReportProgress(i);
if (backgroundWorker1.CancellationPending)
{
e.Cancel = true;
backgroundWorker1.ReportProgress(0);
return;
}
}
e.Result = sum;
}
private void updatetext(string txt)
{
button1.Text = txt;
}
But,
button1.Invoke(delegate { updatetext("Processing"); }); says the method is not a delegate type and cannot be compiled.
modified 12-Feb-21 0:54am.
|
|
|
|
|
I found my own solution:
button1.Invoke((Action)delegate { updatetext("Processing"); });
or
button1.Invoke((MethodInvoker)delegate { updatetext("Processing"); });
|
|
|
|
|
Message Closed
modified 13-Feb-21 8:00am.
|
|
|
|