Asignar código de macro al control de formulario

Asignación de código de macro a control de formulario usando Aspose.Cells

El siguiente código de ejemplo crea un nuevo libro de trabajo, asigna un código de macro a un botón de formulario y guarda el resultado en el formato XLSM. Una vez, abrirá el archivo de salida XLSM en Microsoft Excel y verá el siguiente código de macro.

 Sub ShowMessage()

    MsgBox "Welcome to Aspose!"

End Sub

Aquí hay un código de muestra para generar el archivo de salida XLSM con código de macro.

// For complete examples and data files, please go to https://github.com/aspose-cells/Aspose.Cells-for-Java
// The path to the documents directory.
String dataDir = Utils.getDataDir(AssignMacroToFormControl.class);
Workbook workbook = new Workbook();
Worksheet sheet = workbook.getWorksheets().get(0);
int moduleIdx = workbook.getVbaProject().getModules().add(sheet);
VbaModule module = workbook.getVbaProject().getModules().get(moduleIdx);
module.setCodes("Sub ShowMessage()" + "\r\n" +
" MsgBox \"Welcome to Aspose!\"" + "\r\n" +
"End Sub");
Button button = (Button) sheet.getShapes().addShape(MsoDrawingType.BUTTON, 2, 0, 2, 0, 28, 80);
button.setPlacement(PlacementType.FREE_FLOATING);
button.getFont().setName("Tahoma");
button.getFont().setBold(true);
button.getFont().setColor(Color.getBlue());
button.setText("Aspose");
button.setMacroName(sheet.getName() + ".ShowMessage");
workbook.save(dataDir + "Output.xlsm");
System.out.println("File saved");