That's because of this line:
eSheet1 = eSheet1.get('Range', 'B1:C1');
which replace the former value of esheet1 which use to be a sheet by a range reference.
Typically with matlab, you don't have to use the get method to access excel objects. I would also recommend that you don't rely on ActiveAnything, there's no point in using ActiveWorkbook when you already have a reference to the workbook so why not use it:
e = actxserver('Excel.Application');
eWorkbook = e.Workbooks.Open(dest);
e.Visible = 1;
eSheet1 = eWorkbook.Sheets.Item(1);
rg = eSheet1.Range('B1:C1');
rg.MergeCells = true;
rg.Value = 'Title1';
rg.Font.ColorIndex = 3;
rg.Font.Bold = 1;
rg.HorizontalAlignment = -4108;
rg = eSheet1.Range('D1:E1');
rg.MergeCells = true;
rg.Value = 'Title2';
rg.Font.ColorIndex = 3;
rg.Font.Bold = 1;
rg.HorizontalAlignment = -4108;
Best Answer